github.com/akamai/AkamaiOPEN-edgegrid-golang/v8@v8.1.0/pkg/appsec/eval_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  // Test get EvalPenaltyBox
    17  func TestAppSec_GetEvalPenaltyBox(t *testing.T) {
    18  
    19  	result := GetPenaltyBoxResponse{}
    20  
    21  	respData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
    22  	err := json.Unmarshal([]byte(respData), &result)
    23  	require.NoError(t, err)
    24  
    25  	tests := map[string]struct {
    26  		params           GetPenaltyBoxRequest
    27  		responseStatus   int
    28  		responseBody     string
    29  		expectedPath     string
    30  		expectedResponse *GetPenaltyBoxResponse
    31  		withError        error
    32  	}{
    33  		"200 OK": {
    34  			params: GetPenaltyBoxRequest{
    35  				ConfigID: 43253,
    36  				Version:  15,
    37  				PolicyID: "AAAA_81230",
    38  			},
    39  			responseStatus:   http.StatusOK,
    40  			responseBody:     respData,
    41  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-penalty-box",
    42  			expectedResponse: &result,
    43  		},
    44  		"500 internal server error": {
    45  			params: GetPenaltyBoxRequest{
    46  				ConfigID: 43253,
    47  				Version:  15,
    48  				PolicyID: "AAAA_81230",
    49  			},
    50  			responseStatus: http.StatusInternalServerError,
    51  			responseBody: `
    52  			{
    53  				"type": "internal_error",
    54  				"title": "Internal Server Error",
    55  				"detail": "Error fetching match target"
    56  			}`,
    57  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-penalty-box",
    58  			withError: &Error{
    59  				Type:       "internal_error",
    60  				Title:      "Internal Server Error",
    61  				Detail:     "Error fetching match target",
    62  				StatusCode: http.StatusInternalServerError,
    63  			},
    64  		},
    65  	}
    66  
    67  	for name, test := range tests {
    68  		t.Run(name, func(t *testing.T) {
    69  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
    70  				assert.Equal(t, test.expectedPath, r.URL.String())
    71  				assert.Equal(t, http.MethodGet, r.Method)
    72  				w.WriteHeader(test.responseStatus)
    73  				_, err := w.Write([]byte(test.responseBody))
    74  				assert.NoError(t, err)
    75  			}))
    76  			client := mockAPIClient(t, mockServer)
    77  			result, err := client.GetEvalPenaltyBox(context.Background(), test.params)
    78  			if test.withError != nil {
    79  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
    80  				return
    81  			}
    82  			require.NoError(t, err)
    83  			assert.Equal(t, test.expectedResponse, result)
    84  		})
    85  	}
    86  }
    87  
    88  // Test Update EvalPenaltyBox.
    89  func TestAppSec_UpdateEvalPenaltyBox(t *testing.T) {
    90  	result := UpdatePenaltyBoxResponse{}
    91  
    92  	respData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
    93  	err := json.Unmarshal([]byte(respData), &result)
    94  	require.NoError(t, err)
    95  
    96  	req := UpdatePenaltyBoxRequest{}
    97  
    98  	reqData := compactJSON(loadFixtureBytes("testdata/TestPenaltyBoxes/PenaltyBox.json"))
    99  	err = json.Unmarshal([]byte(reqData), &req)
   100  	require.NoError(t, err)
   101  
   102  	tests := map[string]struct {
   103  		params           UpdatePenaltyBoxRequest
   104  		responseStatus   int
   105  		responseBody     string
   106  		expectedPath     string
   107  		expectedResponse *UpdatePenaltyBoxResponse
   108  		withError        error
   109  		headers          http.Header
   110  	}{
   111  		"200 Success": {
   112  			params: UpdatePenaltyBoxRequest{
   113  				ConfigID:             43253,
   114  				Version:              15,
   115  				PolicyID:             "AAAA_81230",
   116  				PenaltyBoxProtection: false,
   117  				Action:               string(ActionTypeDeny),
   118  			},
   119  			headers: http.Header{
   120  				"Content-Type": []string{"application/json;charset=UTF-8"},
   121  			},
   122  			responseStatus:   http.StatusCreated,
   123  			responseBody:     respData,
   124  			expectedResponse: &result,
   125  			expectedPath:     "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-penalty-box",
   126  		},
   127  		"500 internal server error": {
   128  			params: UpdatePenaltyBoxRequest{
   129  				ConfigID:             43253,
   130  				Version:              15,
   131  				PolicyID:             "AAAA_81230",
   132  				PenaltyBoxProtection: true,
   133  				Action:               string(ActionTypeDeny),
   134  			},
   135  			responseStatus: http.StatusInternalServerError,
   136  			responseBody: `
   137  			{
   138  				"type": "internal_error",
   139  				"title": "Internal Server Error",
   140  				"detail": "Error creating zone"
   141  			}`,
   142  			expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-penalty-box",
   143  			withError: &Error{
   144  				Type:       "internal_error",
   145  				Title:      "Internal Server Error",
   146  				Detail:     "Error creating zone",
   147  				StatusCode: http.StatusInternalServerError,
   148  			},
   149  		},
   150  	}
   151  
   152  	for name, test := range tests {
   153  		t.Run(name, func(t *testing.T) {
   154  			mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
   155  				assert.Equal(t, http.MethodPut, r.Method)
   156  				w.WriteHeader(test.responseStatus)
   157  				if len(test.responseBody) > 0 {
   158  					_, err := w.Write([]byte(test.responseBody))
   159  					assert.NoError(t, err)
   160  				}
   161  			}))
   162  			client := mockAPIClient(t, mockServer)
   163  			result, err := client.UpdateEvalPenaltyBox(
   164  				session.ContextWithOptions(
   165  					context.Background(),
   166  					session.WithContextHeaders(test.headers)), test.params)
   167  			if test.withError != nil {
   168  				assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err)
   169  				return
   170  			}
   171  			require.NoError(t, err)
   172  			assert.Equal(t, test.expectedResponse, result)
   173  		})
   174  	}
   175  }