github.com/akamai/AkamaiOPEN-edgegrid-golang/v8@v8.1.0/pkg/appsec/malware_policy_action_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_ListMalwarePolicyActions(t *testing.T) { 17 18 result := GetMalwarePolicyActionsResponse{} 19 20 respData := compactJSON(loadFixtureBytes("testdata/TestMalwarePolicyAction/MalwarePolicyActions.json")) 21 err := json.Unmarshal([]byte(respData), &result) 22 require.NoError(t, err) 23 24 tests := map[string]struct { 25 params GetMalwarePolicyActionsRequest 26 responseStatus int 27 responseBody string 28 expectedPath string 29 expectedResponse *GetMalwarePolicyActionsResponse 30 withError error 31 headers http.Header 32 }{ 33 "200 OK": { 34 params: GetMalwarePolicyActionsRequest{ 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/malware-policies", 45 expectedResponse: &result, 46 }, 47 "500 internal server error": { 48 params: GetMalwarePolicyActionsRequest{ 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/malware-policies", 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.GetMalwarePolicyActions( 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 Update MalwarePolicyAction. 99 func TestAppSec_UpdateMalwarePolicyAction(t *testing.T) { 100 reqData := compactJSON(loadFixtureBytes("testdata/TestMalwarePolicyAction/MalwarePolicyAction.json")) 101 request := UpdateMalwarePolicyActionRequest{} 102 err := json.Unmarshal([]byte(reqData), &request) 103 require.NoError(t, err) 104 105 respData := compactJSON(loadFixtureBytes("testdata/TestMalwarePolicyAction/MalwarePolicyAction.json")) 106 result := UpdateMalwarePolicyActionResponse{} 107 err = json.Unmarshal([]byte(respData), &result) 108 require.NoError(t, err) 109 110 tests := map[string]struct { 111 params UpdateMalwarePolicyActionRequest 112 responseStatus int 113 responseBody string 114 expectedPath string 115 expectedResponse *UpdateMalwarePolicyActionResponse 116 withError error 117 headers http.Header 118 }{ 119 "200 Success": { 120 params: UpdateMalwarePolicyActionRequest{ 121 ConfigID: 43253, 122 Version: 15, 123 PolicyID: "AAAA_81230", 124 MalwarePolicyID: 134644, 125 Action: "none", 126 UnscannedAction: "none", 127 }, 128 headers: http.Header{ 129 "Content-Type": []string{"application/json;charset=UTF-8"}, 130 }, 131 responseStatus: http.StatusOK, 132 responseBody: respData, 133 expectedResponse: &result, 134 expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/malware-policies/134644", 135 }, 136 "500 internal server error": { 137 params: UpdateMalwarePolicyActionRequest{ 138 ConfigID: 43253, 139 Version: 15, 140 PolicyID: "AAAA_81230", 141 MalwarePolicyID: 134644, 142 Action: "alert", 143 UnscannedAction: "deny", 144 }, 145 responseStatus: http.StatusInternalServerError, 146 responseBody: ` 147 { 148 "type": "internal_error", 149 "title": "Internal Server Error", 150 "detail": "Error creating zone" 151 }`, 152 expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/malware-policies/134644", 153 withError: &Error{ 154 Type: "internal_error", 155 Title: "Internal Server Error", 156 Detail: "Error creating zone", 157 StatusCode: http.StatusInternalServerError, 158 }, 159 }, 160 } 161 162 for name, test := range tests { 163 t.Run(name, func(t *testing.T) { 164 mockServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { 165 assert.Equal(t, http.MethodPut, r.Method) 166 w.WriteHeader(test.responseStatus) 167 if len(test.responseBody) > 0 { 168 _, err := w.Write([]byte(test.responseBody)) 169 assert.NoError(t, err) 170 } 171 })) 172 client := mockAPIClient(t, mockServer) 173 result, err := client.UpdateMalwarePolicyAction( 174 session.ContextWithOptions( 175 context.Background(), 176 session.WithContextHeaders(test.headers)), test.params) 177 if test.withError != nil { 178 assert.True(t, errors.Is(err, test.withError), "want: %s; got: %s", test.withError, err) 179 return 180 } 181 require.NoError(t, err) 182 assert.Equal(t, test.expectedResponse, result) 183 }) 184 } 185 }