github.com/akamai/AkamaiOPEN-edgegrid-golang/v8@v8.1.0/pkg/appsec/eval_rule_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_ListEvalRule(t *testing.T) { 17 18 result := GetEvalRulesResponse{} 19 20 respData := compactJSON(loadFixtureBytes("testdata/TestEvalRule/EvalRules.json")) 21 err := json.Unmarshal([]byte(respData), &result) 22 require.NoError(t, err) 23 24 tests := map[string]struct { 25 params GetEvalRulesRequest 26 responseStatus int 27 responseBody string 28 expectedPath string 29 expectedResponse *GetEvalRulesResponse 30 withError error 31 headers http.Header 32 }{ 33 "200 OK": { 34 params: GetEvalRulesRequest{ 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-rules?includeConditionException=true", 45 expectedResponse: &result, 46 }, 47 "500 internal server error": { 48 params: GetEvalRulesRequest{ 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-rules?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.GetEvalRules( 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 EvalRule 99 func TestAppSec_GetEvalRule(t *testing.T) { 100 101 result := GetEvalRuleResponse{} 102 103 respData := compactJSON(loadFixtureBytes("testdata/TestEvalRule/EvalRule.json")) 104 err := json.Unmarshal([]byte(respData), &result) 105 require.NoError(t, err) 106 107 tests := map[string]struct { 108 params GetEvalRuleRequest 109 responseStatus int 110 responseBody string 111 expectedPath string 112 expectedResponse *GetEvalRuleResponse 113 withError error 114 }{ 115 "200 OK": { 116 params: GetEvalRuleRequest{ 117 ConfigID: 43253, 118 Version: 15, 119 PolicyID: "AAAA_81230", 120 RuleID: 12345, 121 }, 122 responseStatus: http.StatusOK, 123 responseBody: respData, 124 expectedPath: "/appsec/v1/configs/43253/versions/15/security-policies/AAAA_81230/eval-rules/12345?includeConditionException=true", 125 expectedResponse: &result, 126 }, 127 "500 internal server error": { 128 params: GetEvalRuleRequest{ 129 ConfigID: 43253, 130 Version: 15, 131 PolicyID: "AAAA_81230", 132 RuleID: 12345, 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-rules/12345?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.GetEvalRule(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 EvalRule. 173 func TestAppSec_UpdateEvalRule(t *testing.T) { 174 result := UpdateEvalRuleResponse{} 175 176 respData := compactJSON(loadFixtureBytes("testdata/TestEvalRule/EvalRule.json")) 177 err := json.Unmarshal([]byte(respData), &result) 178 require.NoError(t, err) 179 180 req := UpdateEvalRuleRequest{} 181 182 reqData := compactJSON(loadFixtureBytes("testdata/TestEvalRule/EvalRule.json")) 183 err = json.Unmarshal([]byte(reqData), &req) 184 require.NoError(t, err) 185 186 tests := map[string]struct { 187 params UpdateEvalRuleRequest 188 responseStatus int 189 responseBody string 190 expectedPath string 191 expectedResponse *UpdateEvalRuleResponse 192 withError error 193 headers http.Header 194 }{ 195 "200 Success": { 196 params: UpdateEvalRuleRequest{ 197 ConfigID: 43253, 198 Version: 15, 199 PolicyID: "AAAA_81230", 200 RuleID: 12345, 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-rules/12345/action-condition-exceptions", 209 }, 210 "500 internal server error": { 211 params: UpdateEvalRuleRequest{ 212 ConfigID: 43253, 213 Version: 15, 214 PolicyID: "AAAA_81230", 215 RuleID: 12345, 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-rules/12345/action-condition-exceptions", 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.UpdateEvalRule( 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 }