github.com/akamai/AkamaiOPEN-edgegrid-golang/v8@v8.1.0/pkg/appsec/eval_group_test.go (about)

     1  package appsec
     2  
     3  import (
     4  	"context"
     5  	"encoding/json"
     6  	"errors"
     7  	"net/http"
     8  	"net/http/httptest"
     9  	"testing"
    10  
    11  	"github.com/akamai/AkamaiOPEN-edgegrid-golang/v8/pkg/session"
    12  	"github.com/stretchr/testify/assert"
    13  	"github.com/stretchr/testify/require"
    14  )
    15  
    16  func TestAppSec_ListEvalGroup(t *testing.T) {
    17  
    18  	result := GetAttackGroupsResponse{}
    19  
    20  	respData := compactJSON(loadFixtureBytes("testdata/TestAttackGroup/AttackGroups.json"))
    21  	err := json.Unmarshal([]byte(respData), &result)
    22  	require.NoError(t, err)
    23  
    24  	tests := map[string]struct {
    25  		params           GetAttackGroupsRequest
    26  		responseStatus   int
    27  		responseBody     string
    28  		expectedPath     string
    29  		expectedResponse *GetAttackGroupsResponse
    30  		withError        error
    31  		headers          http.Header
    32  	}{
    33  		"200 OK": {
    34  			params: GetAttackGroupsRequest{
    35  				ConfigID: 43253,
    36  				Version:  15,
    37  				PolicyID: "AAAA_81230",
    38  			},
    39  			headers: http.Header{
    40  				"Content-Type": []string{"application/json"},
    41  			},
    42  			responseStatus:   http.StatusOK,
    43  			responseBody:     string(respData),
    44  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups?includeConditionException=true",
    45  			expectedResponse: &result,
    46  		},
    47  		"500 internal server error": {
    48  			params: GetAttackGroupsRequest{
    49  				ConfigID: 43253,
    50  				Version:  15,
    51  				PolicyID: "AAAA_81230",
    52  			},
    53  			headers:        http.Header{},
    54  			responseStatus: http.StatusInternalServerError,
    55  			responseBody: `
    56  {
    57      "type": "internal_error",
    58      "title": "Internal Server Error",
    59      "detail": "Error fetching propertys",
    60      "status": 500
    61  }`,
    62  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups?includeConditionException=true",
    63  			withError: &Error{
    64  				Type:       "internal_error",
    65  				Title:      "Internal Server Error",
    66  				Detail:     "Error fetching propertys",
    67  				StatusCode: http.StatusInternalServerError,
    68  			},
    69  		},
    70  	}
    71  
    72  	for name, test := range tests {
    73  		t.Run(name, func(t *testing.T) {
    74  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
    75  				assert.Equal(t, test.expectedPath, r.URL.String())
    76  				assert.Equal(t, http.MethodGet, r.Method)
    77  				w.WriteHeader(test.responseStatus)
    78  				_, err := w.Write([]byte(test.responseBody))
    79  				assert.NoError(t, err)
    80  			}))
    81  			client := mockAPIClient(t, mockServer)
    82  			result, err := client.GetEvalGroups(
    83  				session.ContextWithOptions(
    84  					context.Background(),
    85  					session.WithContextHeaders(test.headers),
    86  				),
    87  				test.params)
    88  			if test.withError != nil {
    89  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
    90  				return
    91  			}
    92  			require.NoError(t, err)
    93  			assert.Equal(t, test.expectedResponse, result)
    94  		})
    95  	}
    96  }
    97  
    98  // Test AttackGroupConditionException
    99  func TestAppSec_GetEvalGroup(t *testing.T) {
   100  
   101  	result := GetAttackGroupResponse{}
   102  
   103  	respData := compactJSON(loadFixtureBytes("testdata/TestAttackGroup/AttackGroup.json"))
   104  	err := json.Unmarshal([]byte(respData), &result)
   105  	require.NoError(t, err)
   106  
   107  	tests := map[string]struct {
   108  		params           GetAttackGroupRequest
   109  		responseStatus   int
   110  		responseBody     string
   111  		expectedPath     string
   112  		expectedResponse *GetAttackGroupResponse
   113  		withError        error
   114  	}{
   115  		"200 OK": {
   116  			params: GetAttackGroupRequest{
   117  				ConfigID: 43253,
   118  				Version:  15,
   119  				PolicyID: "AAAA_81230",
   120  				Group:    "SQL",
   121  			},
   122  			responseStatus:   http.StatusOK,
   123  			responseBody:     respData,
   124  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups/SQL?includeConditionException=true",
   125  			expectedResponse: &result,
   126  		},
   127  		"500 internal server error": {
   128  			params: GetAttackGroupRequest{
   129  				ConfigID: 43253,
   130  				Version:  15,
   131  				PolicyID: "AAAA_81230",
   132  				Group:    "SQL",
   133  			},
   134  			responseStatus: http.StatusInternalServerError,
   135  			responseBody: `
   136  			{
   137  				"type": "internal_error",
   138  				"title": "Internal Server Error",
   139  				"detail": "Error fetching match target"
   140  			}`,
   141  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups/SQL?includeConditionException=true",
   142  			withError: &Error{
   143  				Type:       "internal_error",
   144  				Title:      "Internal Server Error",
   145  				Detail:     "Error fetching match target",
   146  				StatusCode: http.StatusInternalServerError,
   147  			},
   148  		},
   149  	}
   150  
   151  	for name, test := range tests {
   152  		t.Run(name, func(t *testing.T) {
   153  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
   154  				assert.Equal(t, test.expectedPath, r.URL.String())
   155  				assert.Equal(t, http.MethodGet, r.Method)
   156  				w.WriteHeader(test.responseStatus)
   157  				_, err := w.Write([]byte(test.responseBody))
   158  				assert.NoError(t, err)
   159  			}))
   160  			client := mockAPIClient(t, mockServer)
   161  			result, err := client.GetEvalGroup(context.Background(), test.params)
   162  			if test.withError != nil {
   163  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
   164  				return
   165  			}
   166  			require.NoError(t, err)
   167  			assert.Equal(t, test.expectedResponse, result)
   168  		})
   169  	}
   170  }
   171  
   172  // Test Update AttackGroupConditionException.
   173  func TestAppSec_UpdateEvalGroup(t *testing.T) {
   174  	result := UpdateAttackGroupResponse{}
   175  
   176  	respData := compactJSON(loadFixtureBytes("testdata/TestAttackGroup/AttackGroup.json"))
   177  	err := json.Unmarshal([]byte(respData), &result)
   178  	require.NoError(t, err)
   179  
   180  	req := UpdateAttackGroupRequest{}
   181  
   182  	reqData := compactJSON(loadFixtureBytes("testdata/TestAttackGroup/AttackGroup.json"))
   183  	err = json.Unmarshal([]byte(reqData), &req)
   184  	require.NoError(t, err)
   185  
   186  	tests := map[string]struct {
   187  		params           UpdateAttackGroupRequest
   188  		responseStatus   int
   189  		responseBody     string
   190  		expectedPath     string
   191  		expectedResponse *UpdateAttackGroupResponse
   192  		withError        error
   193  		headers          http.Header
   194  	}{
   195  		"200 Success": {
   196  			params: UpdateAttackGroupRequest{
   197  				ConfigID: 43253,
   198  				Version:  15,
   199  				PolicyID: "AAAA_81230",
   200  				Group:    "SQL",
   201  			},
   202  			headers: http.Header{
   203  				"Content-Type": []string{"application/json;charset=UTF-8"},
   204  			},
   205  			responseStatus:   http.StatusCreated,
   206  			responseBody:     respData,
   207  			expectedResponse: &result,
   208  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups/SQL/action-condition-exception",
   209  		},
   210  		"500 internal server error": {
   211  			params: UpdateAttackGroupRequest{
   212  				ConfigID: 43253,
   213  				Version:  15,
   214  				PolicyID: "AAAA_81230",
   215  				Group:    "SQL",
   216  			},
   217  			responseStatus: http.StatusInternalServerError,
   218  			responseBody: `
   219  			{
   220  				"type": "internal_error",
   221  				"title": "Internal Server Error",
   222  				"detail": "Error creating zone"
   223  			}`,
   224  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-groups/SQL/action-condition-exception",
   225  			withError: &Error{
   226  				Type:       "internal_error",
   227  				Title:      "Internal Server Error",
   228  				Detail:     "Error creating zone",
   229  				StatusCode: http.StatusInternalServerError,
   230  			},
   231  		},
   232  	}
   233  
   234  	for name, test := range tests {
   235  		t.Run(name, func(t *testing.T) {
   236  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
   237  				assert.Equal(t, http.MethodPut, r.Method)
   238  				w.WriteHeader(test.responseStatus)
   239  				if len(test.responseBody) > 0 {
   240  					_, err := w.Write([]byte(test.responseBody))
   241  					assert.NoError(t, err)
   242  				}
   243  			}))
   244  			client := mockAPIClient(t, mockServer)
   245  			result, err := client.UpdateEvalGroup(
   246  				session.ContextWithOptions(
   247  					context.Background(),
   248  					session.WithContextHeaders(test.headers)), test.params)
   249  			if test.withError != nil {
   250  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
   251  				return
   252  			}
   253  			require.NoError(t, err)
   254  			assert.Equal(t, test.expectedResponse, result)
   255  		})
   256  	}
   257  }