| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package e2e |
| |
| import ( |
| "net/http" |
| "testing" |
| "time" |
| |
| "github.com/stretchr/testify/assert" |
| ) |
| |
| func TestRoute_With_Log_Plugin(t *testing.T) { |
| // clean log |
| CleanAPISIXErrorLog(t) |
| |
| tests := []HttpTestCase{ |
| { |
| Desc: "make sure the route is not created ", |
| Object: APISIXExpect(t), |
| Method: http.MethodGet, |
| Path: "/hello_", |
| ExpectStatus: http.StatusNotFound, |
| ExpectBody: `{"error_msg":"404 Route Not Found"}`, |
| }, |
| { |
| Desc: "create route", |
| Object: ManagerApiExpect(t), |
| Method: http.MethodPut, |
| Path: "/apisix/admin/routes/r1", |
| Body: `{ |
| "name": "route1", |
| "uri": "/hello_", |
| "plugins": { |
| "http-logger": { |
| "uri": "http://172.16.238.20:1982/hello", |
| "batch_max_size": 1, |
| "max_retry_count": 1, |
| "retry_delay": 2, |
| "buffer_duration": 2, |
| "inactive_timeout": 2, |
| "name": "http logger", |
| "timeout": 3, |
| "concat_method": "json" |
| } |
| }, |
| "upstream": { |
| "type": "roundrobin", |
| "nodes": [{ |
| "host": "172.16.238.20", |
| "port": 1981, |
| "weight": 1 |
| }] |
| } |
| }`, |
| Headers: map[string]string{"Authorization": token}, |
| ExpectStatus: http.StatusOK, |
| }, |
| { |
| Desc: "access route to trigger log", |
| Object: APISIXExpect(t), |
| Method: http.MethodGet, |
| Path: "/hello_", |
| ExpectStatus: http.StatusOK, |
| ExpectBody: "hello world", |
| Sleep: sleepTime, |
| }, |
| } |
| |
| for _, tc := range tests { |
| testCaseCheck(tc, t) |
| } |
| |
| // sleep for process log |
| time.Sleep(1500 * time.Millisecond) |
| |
| // verify http logger by checking log |
| //todo: should use a fake upstream for confirming whether we got the log data. |
| logContent := ReadAPISIXErrorLog(t) |
| assert.Contains(t, logContent, "Batch Processor[http logger] successfully processed the entries") |
| |
| // clean log |
| CleanAPISIXErrorLog(t) |
| |
| tests = []HttpTestCase{ |
| { |
| Desc: "create route with wrong https endpoint", |
| Object: ManagerApiExpect(t), |
| Method: http.MethodPut, |
| Path: "/apisix/admin/routes/r2", |
| Body: `{ |
| "name": "route2", |
| "uri": "/hello", |
| "plugins": { |
| "http-logger": { |
| "uri": "https://127.0.0.1:8888/hello-world-http", |
| "batch_max_size": 1, |
| "max_retry_count": 1, |
| "retry_delay": 2, |
| "buffer_duration": 2, |
| "inactive_timeout": 2, |
| "name": "http logger", |
| "timeout": 3, |
| "concat_method": "json" |
| } |
| }, |
| "upstream": { |
| "type": "roundrobin", |
| "nodes": [{ |
| "host": "172.16.238.20", |
| "port": 1982, |
| "weight": 1 |
| }] |
| } |
| }`, |
| Headers: map[string]string{"Authorization": token}, |
| ExpectStatus: http.StatusOK, |
| }, |
| { |
| Desc: "access route to trigger log", |
| Object: APISIXExpect(t), |
| Method: http.MethodGet, |
| Path: "/hello", |
| ExpectStatus: http.StatusOK, |
| ExpectBody: "hello world", |
| Sleep: sleepTime, |
| }, |
| } |
| |
| for _, tc := range tests { |
| testCaseCheck(tc, t) |
| } |
| |
| // sleep for process log |
| time.Sleep(1500 * time.Millisecond) |
| |
| // verify http logger by checking log |
| //todo: should use a fake upstream for confirming whether we got the log data. |
| logContent = ReadAPISIXErrorLog(t) |
| assert.Contains(t, logContent, "Batch Processor[http logger] failed to process entries: failed to connect to host[127.0.0.1] port[8888] connection refused") |
| |
| // clean log |
| CleanAPISIXErrorLog(t) |
| |
| // todo: check disable http logger |
| |
| tests = []HttpTestCase{ |
| { |
| Desc: "delete route", |
| Object: ManagerApiExpect(t), |
| Method: http.MethodDelete, |
| Path: "/apisix/admin/routes/r1", |
| Headers: map[string]string{"Authorization": token}, |
| ExpectStatus: http.StatusOK, |
| }, |
| { |
| Desc: "make sure the route has been deleted", |
| Object: APISIXExpect(t), |
| Method: http.MethodGet, |
| Path: "/hello_", |
| ExpectStatus: http.StatusNotFound, |
| ExpectBody: `{"error_msg":"404 Route Not Found"}`, |
| Sleep: sleepTime, |
| }, |
| { |
| Desc: "delete route 2", |
| Object: ManagerApiExpect(t), |
| Method: http.MethodDelete, |
| Path: "/apisix/admin/routes/r2", |
| Headers: map[string]string{"Authorization": token}, |
| ExpectStatus: http.StatusOK, |
| }, |
| { |
| Desc: "make sure the route 2 has been deleted", |
| Object: APISIXExpect(t), |
| Method: http.MethodGet, |
| Path: "/hello", |
| ExpectStatus: http.StatusNotFound, |
| ExpectBody: `{"error_msg":"404 Route Not Found"}`, |
| Sleep: sleepTime, |
| }, |
| } |
| |
| for _, tc := range tests { |
| testCaseCheck(tc, t) |
| } |
| } |