From 96e68c576127165a4181d283611d102175c73377 Mon Sep 17 00:00:00 2001 From: wklken Date: Fri, 1 Nov 2024 09:55:25 +0800 Subject: [PATCH] fix(plugins/bk-mock): set_header should override same key (#83) --- src/apisix/ci/Dockerfile.apisix-test-nginx | 2 +- src/apisix/plugins/bk-mock.lua | 9 +- src/apisix/t/bk-mock.t | 107 +++++++++++++++++++++ src/apisix/tests/test-bk-mock.lua | 13 +-- 4 files changed, 113 insertions(+), 18 deletions(-) create mode 100644 src/apisix/t/bk-mock.t diff --git a/src/apisix/ci/Dockerfile.apisix-test-nginx b/src/apisix/ci/Dockerfile.apisix-test-nginx index da08a5c..4dffe09 100644 --- a/src/apisix/ci/Dockerfile.apisix-test-nginx +++ b/src/apisix/ci/Dockerfile.apisix-test-nginx @@ -20,7 +20,7 @@ RUN wget https://github.com/apache/apisix/archive/refs/tags/${APISIX_VERSION}.ta # install dependencies ARG CODE_DIR=/codes/apisix-${APISIX_VERSION} -RUN sed -i 's#yum install -y openresty openresty-debug openresty-openssl111-debug-devel pcre pcre-devel#yum install -y openresty openresty-debug openresty-openssl111-debug-devel pcre pcre-devel --skip-broken#g' ${CODE_DIR}/ci/centos7-ci.sh +RUN sed -i 's#yum install -y openresty openresty-debug openresty-openssl111-debug-devel pcre pcre-devel#yum install -y openresty openresty-debug-1.25.3.2-1.el7.x86_64 openresty-openssl111-debug-devel pcre pcre-devel --skip-broken#g' ${CODE_DIR}/ci/centos7-ci.sh RUN sed -i 's|https://registry.npm.taobao.org|https://registry.npmmirror.com|g' ${CODE_DIR}/t/plugin/grpc-web/package-lock.json RUN cd ${CODE_DIR} && bash ./ci/centos7-ci.sh install_dependencies RUN cp -r ${CODE_DIR}/t /usr/local/apisix/ diff --git a/src/apisix/plugins/bk-mock.lua b/src/apisix/plugins/bk-mock.lua index 3e7f137..d155fc7 100644 --- a/src/apisix/plugins/bk-mock.lua +++ b/src/apisix/plugins/bk-mock.lua @@ -27,7 +27,6 @@ local pl_types = require("pl.types") local core = require("apisix.core") -local ngx = ngx local pairs = pairs local plugin_name = "bk-mock" @@ -75,11 +74,11 @@ function _M.header_filter(conf) end for key, value in pairs(conf.response_headers) do - -- set the header if it is not set by other plugins(they have higher priority) - if not ngx.header[key] then - core.response.set_header(key, value) - end + core.response.set_header(key, value) end + + -- fixme: add a config with_mock_header to control whether to add the header + core.response.set_header("x-mock-by", "bk-apigateway") end return _M diff --git a/src/apisix/t/bk-mock.t b/src/apisix/t/bk-mock.t new file mode 100644 index 0000000..5378219 --- /dev/null +++ b/src/apisix/t/bk-mock.t @@ -0,0 +1,107 @@ +# +# TencentBlueKing is pleased to support the open source community by making +# 蓝鲸智云 - API 网关(BlueKing - APIGateway) available. +# Copyright (C) 2017 THL A29 Limited, a Tencent company. All rights reserved. +# Licensed under the MIT License (the "License"); you may not use this file except +# in compliance with the License. You may obtain a copy of the License at +# +# http://opensource.org/licenses/MIT +# +# 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. +# +# We undertake not to change the open source license (MIT license) applicable +# to the current version of the project delivered to anyone in the future. +# + +use t::APISIX 'no_plan'; + +repeat_each(1); +no_long_string(); +no_shuffle(); +no_root_location(); + +add_block_preprocessor(sub { + my ($block) = @_; + + if (!defined $block->request) { + $block->set_value("request", "GET /t"); + } +}); + +run_tests; + +__DATA__ + +=== TEST 1: sanity +--- config + location /t { + content_by_lua_block { + local plugin = require("apisix.plugins.bk-mock") + local ok, err = plugin.check_schema({ + response_status = 200, + response_example = 'Hello world', + response_headers = { + ["Content-Type"] = "application/json" + } + }) + if not ok then + ngx.say(err) + end + + ngx.say("done") + } + } +--- response_body +done + +=== TEST 2: add route +--- config + location /t { + content_by_lua_block { + local t = require("lib.test_admin").test + local code, body = t('/apisix/admin/routes/1', + ngx.HTTP_PUT, + [[{ + "plugins": { + "bk-mock": { + "response_status": 400, + "response_example": "abc\n", + "response_headers" : { + "foo": "bar", + "Content-Type": "application/json2" + } + } + }, + "upstream": { + "nodes": { + "127.0.0.1:1980": 1 + }, + "type": "roundrobin" + }, + "uri": "/hello" + }]] + ) + if code >= 300 then + ngx.status = code + end + ngx.say(body) + } + } +--- request +GET /t +--- response_body +passed + +=== TEST 3: check +--- request +GET /hello HTTP/1.1 +--- error_code: 400 +--- response_body +abc +--- response_headers +Content-Type: application/json2 +foo: bar +x-mock-by: bk-apigateway diff --git a/src/apisix/tests/test-bk-mock.lua b/src/apisix/tests/test-bk-mock.lua index 0a3e6a2..2a3a7e5 100644 --- a/src/apisix/tests/test-bk-mock.lua +++ b/src/apisix/tests/test-bk-mock.lua @@ -123,6 +123,7 @@ describe( plugin.header_filter(conf) assert.stub(core.response.set_header).was_called_with("X-Token", "foo") + assert.stub(core.response.set_header).was_called_with("x-mock-by", "bk-apigateway") end ) @@ -134,18 +135,6 @@ describe( assert.stub(core.response.set_header).was_not_called() end ) - - it( - "header cannot be overwriten", function() - ngx.header["X-Token"] = "bar" - conf.response_headers = { - ["X-Token"] = "foo", - } - - plugin.header_filter(conf) - assert.is_equal(ngx.header["X-Token"], "bar") - end - ) end ) end