github.com/akamai/AkamaiOPEN-edgegrid-golang/v8@v8.1.0/pkg/appsec/penalty_box_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_ListPenaltyBoxes(t *testing.T) {
    17  
    18  	result := GetPenaltyBoxesResponse{}
    19  
    20  	respData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
    21  	err := json.Unmarshal([]byte(respData), &result)
    22  	require.NoError(t, err)
    23  
    24  	tests := map[string]struct {
    25  		params           GetPenaltyBoxesRequest
    26  		responseStatus   int
    27  		responseBody     string
    28  		expectedPath     string
    29  		expectedResponse *GetPenaltyBoxesResponse
    30  		withError        error
    31  		headers          http.Header
    32  	}{
    33  		"200 OK": {
    34  			params: GetPenaltyBoxesRequest{
    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/penalty-box",
    45  			expectedResponse: &result,
    46  		},
    47  		"500 internal server error": {
    48  			params: GetPenaltyBoxesRequest{
    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/penalty-box",
    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.GetPenaltyBoxes(
    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 PenaltyBox
    99  func TestAppSec_GetPenaltyBox(t *testing.T) {
   100  
   101  	result := GetPenaltyBoxResponse{}
   102  
   103  	respData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
   104  	err := json.Unmarshal([]byte(respData), &result)
   105  	require.NoError(t, err)
   106  
   107  	tests := map[string]struct {
   108  		params           GetPenaltyBoxRequest
   109  		responseStatus   int
   110  		responseBody     string
   111  		expectedPath     string
   112  		expectedResponse *GetPenaltyBoxResponse
   113  		withError        error
   114  	}{
   115  		"200 OK": {
   116  			params: GetPenaltyBoxRequest{
   117  				ConfigID: 43253,
   118  				Version:  15,
   119  				PolicyID: "AAAA_81230",
   120  			},
   121  			responseStatus:   http.StatusOK,
   122  			responseBody:     respData,
   123  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/penalty-box",
   124  			expectedResponse: &result,
   125  		},
   126  		"500 internal server error": {
   127  			params: GetPenaltyBoxRequest{
   128  				ConfigID: 43253,
   129  				Version:  15,
   130  				PolicyID: "AAAA_81230",
   131  			},
   132  			responseStatus: http.StatusInternalServerError,
   133  			responseBody: `
   134  			{
   135  				"type": "internal_error",
   136  				"title": "Internal Server Error",
   137  				"detail": "Error fetching match target"
   138  			}`,
   139  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/penalty-box",
   140  			withError: &Error{
   141  				Type:       "internal_error",
   142  				Title:      "Internal Server Error",
   143  				Detail:     "Error fetching match target",
   144  				StatusCode: http.StatusInternalServerError,
   145  			},
   146  		},
   147  	}
   148  
   149  	for name, test := range tests {
   150  		t.Run(name, func(t *testing.T) {
   151  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
   152  				assert.Equal(t, test.expectedPath, r.URL.String())
   153  				assert.Equal(t, http.MethodGet, r.Method)
   154  				w.WriteHeader(test.responseStatus)
   155  				_, err := w.Write([]byte(test.responseBody))
   156  				assert.NoError(t, err)
   157  			}))
   158  			client := mockAPIClient(t, mockServer)
   159  			result, err := client.GetPenaltyBox(context.Background(), test.params)
   160  			if test.withError != nil {
   161  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
   162  				return
   163  			}
   164  			require.NoError(t, err)
   165  			assert.Equal(t, test.expectedResponse, result)
   166  		})
   167  	}
   168  }
   169  
   170  // Test Update PenaltyBox.
   171  func TestAppSec_UpdatePenaltyBox(t *testing.T) {
   172  	result := UpdatePenaltyBoxResponse{}
   173  
   174  	respData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
   175  	err := json.Unmarshal([]byte(respData), &result)
   176  	require.NoError(t, err)
   177  
   178  	req := UpdatePenaltyBoxRequest{}
   179  
   180  	reqData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
   181  	err = json.Unmarshal([]byte(reqData), &req)
   182  	require.NoError(t, err)
   183  
   184  	tests := map[string]struct {
   185  		params           UpdatePenaltyBoxRequest
   186  		responseStatus   int
   187  		responseBody     string
   188  		expectedPath     string
   189  		expectedResponse *UpdatePenaltyBoxResponse
   190  		withError        error
   191  		headers          http.Header
   192  	}{
   193  		"200 Success": {
   194  			params: UpdatePenaltyBoxRequest{
   195  				ConfigID:             43253,
   196  				Version:              15,
   197  				PolicyID:             "AAAA_81230",
   198  				PenaltyBoxProtection: true,
   199  				Action:               string(ActionTypeDeny),
   200  			},
   201  			headers: http.Header{
   202  				"Content-Type": []string{"application/json;charset=UTF-8"},
   203  			},
   204  			responseStatus:   http.StatusCreated,
   205  			responseBody:     respData,
   206  			expectedResponse: &result,
   207  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/penalty-box",
   208  		},
   209  		"500 internal server error": {
   210  			params: UpdatePenaltyBoxRequest{
   211  				ConfigID:             43253,
   212  				Version:              15,
   213  				PolicyID:             "AAAA_81230",
   214  				PenaltyBoxProtection: true,
   215  				Action:               string(ActionTypeDeny),
   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/penalty-box",
   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.UpdatePenaltyBox(
   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  }