# # 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. # use t::APISIX 'no_plan'; repeat_each(1); no_long_string(); no_root_location(); no_shuffle(); log_level("info"); run_tests; __DATA__ === TEST 1: add consumer with username --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "username":"jack", "desc": "new consumer" }]], [[{ "node": { "value": { "username": "jack", "desc": "new consumer" } }, "action": "set" }]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 2: update consumer with username and plugins --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local etcd = require("apisix.core.etcd") local res = assert(etcd.get('/consumers/jack')) local prev_create_time = res.body.node.value.create_time assert(prev_create_time ~= nil, "create_time is nil") local update_time = res.body.node.value.update_time assert(update_time ~= nil, "update_time is nil") ngx.sleep(1) local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "username": "jack", "desc": "new consumer", "plugins": { "key-auth": { "key": "auth-one" } } }]], [[{ "node": { "value": { "username": "jack", "desc": "new consumer", "plugins": { "key-auth": { "key": "auth-one" } } } }, "action": "set" }]] ) ngx.status = code ngx.say(body) local res = assert(etcd.get('/consumers/jack')) local create_time = res.body.node.value.create_time assert(prev_create_time == create_time, "create_time mismatched") local update_time = res.body.node.value.update_time assert(update_time ~= nil, "update_time is nil") } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 3: get consumer --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers/jack', ngx.HTTP_GET, nil, [[{ "node": { "value": { "username": "jack", "desc": "new consumer", "plugins": { "key-auth": { "key": "auth-one" } } } }, "action": "get" }]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 4: delete consumer --- config location /t { content_by_lua_block { ngx.sleep(0.3) local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers/jack', ngx.HTTP_DELETE, nil, [[{"action": "delete"}]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 5: delete consumer(id: not_found) --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code = t('/apisix/admin/consumers/not_found', ngx.HTTP_DELETE, nil, [[{ "action": "delete" }]] ) ngx.say("[delete] code: ", code) } } --- request GET /t --- response_body [delete] code: 404 --- no_error_log [error] === TEST 6: missing username --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "id":"jack" }]], [[{ "node": { "value": { "id": "jack" } }, "action": "set" }]] ) ngx.status = code ngx.print(body) } } --- request GET /t --- error_code: 400 --- response_body {"error_msg":"invalid configuration: property \"username\" is required"} --- no_error_log [error] === TEST 7: add consumer with labels --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "username":"jack", "desc": "new consumer", "labels": { "build":"16", "env":"production", "version":"v2" } }]], [[{ "node": { "value": { "username": "jack", "desc": "new consumer", "labels": { "build":"16", "env":"production", "version":"v2" } } }, "action": "set" }]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 8: invalid format of label value: set consumer --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "username":"jack", "desc": "new consumer", "labels": { "env": ["production", "release"] } }]] ) ngx.status = code ngx.print(body) } } --- request GET /t --- error_code: 400 --- response_body {"error_msg":"invalid configuration: property \"labels\" validation failed: failed to validate env (matching \".*\"): wrong type: expected string, got table"} --- no_error_log [error] === TEST 9: post consumers --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_POST, "" ) ngx.status = code ngx.print(body) } } --- request GET /t --- error_code: 405 --- response_body {"error_msg":"not supported `POST` method for consumer"} --- no_error_log [error] === TEST 10: add consumer with create_time and update_time(pony) --- config location /t { content_by_lua_block { local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers', ngx.HTTP_PUT, [[{ "username":"pony", "desc": "new consumer", "create_time": 1602883670, "update_time": 1602893670 }]], [[{ "node": { "value": { "username": "pony", "desc": "new consumer", "create_time": 1602883670, "update_time": 1602893670 } }, "action": "set" }]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error] === TEST 11: delete test consumer(pony) --- config location /t { content_by_lua_block { ngx.sleep(0.3) local t = require("lib.test_admin").test local code, body = t('/apisix/admin/consumers/pony', ngx.HTTP_DELETE, nil, [[{"action": "delete"}]] ) ngx.status = code ngx.say(body) } } --- request GET /t --- response_body passed --- no_error_log [error]