#!/usr/bin/env bash # # 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. # . ./t/cli/common.sh # log format git checkout conf/config.yaml echo ' nginx_config: http: access_log_format: "$remote_addr - $remote_user [$time_local] $http_host test_access_log_format" ' > conf/config.yaml make init grep "test_access_log_format" conf/nginx.conf > /dev/null if [ ! $? -eq 0 ]; then echo "failed: access_log_format in nginx.conf doesn't change" exit 1 fi echo "passed: access_log_format in nginx.conf is ok" # check enable access log echo ' nginx_config: http: enable_access_log: true access_log_format: "$remote_addr - $remote_user [$time_local] $http_host test_enable_access_log_true" ' > conf/config.yaml make init count_test_access_log=`grep -c "test_enable_access_log_true" conf/nginx.conf || true` if [ $count_test_access_log -eq 0 ]; then echo "failed: nginx.conf file doesn't find access_log_format when enable access log" exit 1 fi count_access_log_off=`grep -c "access_log off;" conf/nginx.conf || true` if [ $count_access_log_off -eq 3 ]; then echo "failed: nginx.conf file find access_log off; when enable access log" exit 1 fi make run sleep 0.1 curl http://127.0.0.1:9080/hi sleep 4 tail -n 1 logs/access.log > output.log count_grep=`grep -c "test_enable_access_log_true" output.log || true` if [ $count_grep -eq 0 ]; then echo "failed: not found test_enable_access_log in access.log " exit 1 fi make stop echo ' nginx_config: http: enable_access_log: false access_log_format: "$remote_addr - $remote_user [$time_local] $http_host test_enable_access_log_false" ' > conf/config.yaml make init count_test_access_log=`grep -c "test_enable_access_log_false" conf/nginx.conf || true` if [ $count_test_access_log -eq 1 ]; then echo "failed: nginx.conf file find access_log_format when disable access log" exit 1 fi count_access_log_off=`grep -c "access_log off;" conf/nginx.conf || true` if [ $count_access_log_off -ne 3 ]; then echo "failed: nginx.conf file doesn't find access_log off; when disable access log" exit 1 fi make run sleep 0.1 curl http://127.0.0.1:9080/hi sleep 4 tail -n 1 logs/access.log > output.log count_grep=`grep -c "test_enable_access_log_false" output.log || true` if [ $count_grep -eq 1 ]; then echo "failed: found test_enable_access_log in access.log " exit 1 fi make stop echo "passed: enable_access_log is ok" # access log with JSON format echo ' nginx_config: http: access_log_format: |- {"@timestamp": "$time_iso8601", "client_ip": "$remote_addr", "status": "$status"} access_log_format_escape: json ' > conf/config.yaml make init make run sleep 0.1 curl http://127.0.0.1:9080/hello2 sleep 4 tail -n 1 logs/access.log > output.log if [ `grep -c '"client_ip": "127.0.0.1"' output.log` -eq '0' ]; then echo "failed: invalid JSON log in access log" exit 1 fi if [ `grep -c 'main escape=json' conf/nginx.conf` -eq '0' ]; then echo "failed: not found \"escape=json\" in conf/nginx.conf" exit 1 fi make stop echo "passed: access log with JSON format" # check uninitialized variable in access log when access admin git checkout conf/config.yaml rm logs/error.log make init make run code=$(curl -v -k -i -m 20 -o /dev/null -s -w %{http_code} http://127.0.0.1:9080/apisix/admin/routes -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1') make stop if [ ! $code -eq 200 ]; then echo "failed: failed to access admin" exit 1 fi if grep -E 'using uninitialized ".+" variable while logging request' logs/error.log; then echo "failed: uninitialized variable found during writing access log" exit 1 fi echo "pass: uninitialized variable not found during writing access log" # don't log uninitialized access log variable when the HTTP request is malformed git checkout conf/config.yaml rm logs/error.log ./bin/apisix start sleep 1 # wait for apisix starts curl -v -k -i -m 20 -o /dev/null -s https://127.0.0.1:9080 || true if grep -E 'using uninitialized ".+" variable while logging request' logs/error.log; then echo "failed: log uninitialized access log variable when the HTTP request is malformed" exit 1 fi make stop echo "don't log uninitialized access log variable when the HTTP request is malformed"