mirror of
https://gitee.com/iresty/apisix.git
synced 2024-12-14 08:51:29 +08:00
187 lines
3.8 KiB
Perl
187 lines
3.8 KiB
Perl
|
use t::APISix 'no_plan';
|
||
|
|
||
|
repeat_each(1);
|
||
|
log_level('info');
|
||
|
worker_connections(1024);
|
||
|
no_root_location();
|
||
|
no_shuffle();
|
||
|
|
||
|
run_tests();
|
||
|
|
||
|
__DATA__
|
||
|
|
||
|
=== TEST 1: set upstream(id: 1)
|
||
|
--- config
|
||
|
location /t {
|
||
|
content_by_lua_block {
|
||
|
local t = require("lib.test_admin").test
|
||
|
local code, body = t('/apisix/admin/upstreams/1',
|
||
|
ngx.HTTP_PUT,
|
||
|
[[{
|
||
|
"nodes": {
|
||
|
"127.0.0.1:1980": 1
|
||
|
},
|
||
|
"type": "roundrobin",
|
||
|
"desc": "new upstream"
|
||
|
}]]
|
||
|
)
|
||
|
|
||
|
if code >= 300 then
|
||
|
ngx.status = code
|
||
|
end
|
||
|
ngx.say(body)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
passed
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 2: set route(id: 1)
|
||
|
--- 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,
|
||
|
[[{
|
||
|
"uri": "/hello",
|
||
|
"upstream_id": "1"
|
||
|
}]]
|
||
|
)
|
||
|
|
||
|
if code >= 300 then
|
||
|
ngx.status = code
|
||
|
end
|
||
|
ngx.say(body)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
passed
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 3: /not_found
|
||
|
--- request
|
||
|
GET /not_found
|
||
|
--- error_code: 404
|
||
|
--- response_body eval
|
||
|
qr/404 Not Found/
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 4: hit routes
|
||
|
--- request
|
||
|
GET /hello
|
||
|
--- response_body
|
||
|
hello world
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 5: delete upstream(id: 1)
|
||
|
--- config
|
||
|
location /t {
|
||
|
content_by_lua_block {
|
||
|
ngx.sleep(0.5)
|
||
|
local t = require("lib.test_admin").test
|
||
|
local code, message = t('/apisix/admin/upstreams/1',
|
||
|
ngx.HTTP_DELETE,
|
||
|
nil,
|
||
|
[[{
|
||
|
"action": "delete"
|
||
|
}]]
|
||
|
)
|
||
|
ngx.print("[delete] code: ", code, " message: ", message)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
[delete] code: 400 message: {"error_msg":"can not delete this upstream, route [1] is still using it now"}
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 6: delete route(id: 1)
|
||
|
--- config
|
||
|
location /t {
|
||
|
content_by_lua_block {
|
||
|
local t = require("lib.test_admin").test
|
||
|
local code, message = t('/apisix/admin/routes/1',
|
||
|
ngx.HTTP_DELETE,
|
||
|
nil,
|
||
|
[[{
|
||
|
"action": "delete"
|
||
|
}]]
|
||
|
)
|
||
|
ngx.say("[delete] code: ", code, " message: ", message)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
[delete] code: 200 message: passed
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 7: delete upstream(id: 1)
|
||
|
--- config
|
||
|
location /t {
|
||
|
content_by_lua_block {
|
||
|
local t = require("lib.test_admin").test
|
||
|
local code, message = t('/apisix/admin/upstreams/1',
|
||
|
ngx.HTTP_DELETE,
|
||
|
nil,
|
||
|
[[{
|
||
|
"action": "delete"
|
||
|
}]]
|
||
|
)
|
||
|
ngx.say("[delete] code: ", code, " message: ", message)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
[delete] code: 200 message: passed
|
||
|
--- no_error_log
|
||
|
[error]
|
||
|
|
||
|
|
||
|
|
||
|
=== TEST 8: delete upstream again(id: 1)
|
||
|
--- config
|
||
|
location /t {
|
||
|
content_by_lua_block {
|
||
|
local t = require("lib.test_admin").test
|
||
|
local code, message = t('/apisix/admin/upstreams/1',
|
||
|
ngx.HTTP_DELETE,
|
||
|
nil,
|
||
|
[[{
|
||
|
"action": "delete"
|
||
|
}]]
|
||
|
)
|
||
|
ngx.say("[delete] code: ", code)
|
||
|
}
|
||
|
}
|
||
|
--- request
|
||
|
GET /t
|
||
|
--- response_body
|
||
|
[delete] code: 404
|
||
|
--- no_error_log
|
||
|
[error]
|