2020-06-26 17:25:58 +08:00
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
BEGIN {
|
2021-02-05 09:00:20 +08:00
|
|
|
$ENV{"ETCD_ENABLE_AUTH"} = "false";
|
|
|
|
delete $ENV{"FLUSH_ETCD"};
|
2020-06-26 17:25:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
use t::APISIX 'no_plan';
|
|
|
|
|
|
|
|
repeat_each(1);
|
|
|
|
no_long_string();
|
|
|
|
no_root_location();
|
|
|
|
log_level("info");
|
|
|
|
|
|
|
|
# Authentication is enabled at etcd and credentials are set
|
2020-09-16 10:19:04 +08:00
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" user add root:5tHkHhYkjr6cQY');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" role add root');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" user grant-role root root');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" role list');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" user user list');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" auth enable');
|
2020-06-26 17:25:58 +08:00
|
|
|
|
|
|
|
run_tests;
|
|
|
|
|
2020-09-16 10:19:04 +08:00
|
|
|
# Authentication is disabled at etcd
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" --user root:5tHkHhYkjr6cQY auth disable');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" user delete root');
|
|
|
|
system('etcdctl --endpoints="http://127.0.0.1:2379" role delete root');
|
2020-06-26 17:25:58 +08:00
|
|
|
|
|
|
|
__DATA__
|
|
|
|
|
|
|
|
=== TEST 1: Set and Get a value pass
|
|
|
|
--- config
|
|
|
|
location /t {
|
|
|
|
content_by_lua_block {
|
|
|
|
local core = require("apisix.core")
|
|
|
|
local key = "/test_key"
|
|
|
|
local val = "test_value"
|
|
|
|
local res, err = core.etcd.set(key, val)
|
|
|
|
ngx.say(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
--- request
|
|
|
|
GET /t
|
2020-09-16 10:19:04 +08:00
|
|
|
--- error_code: 500
|
|
|
|
--- error_log eval
|
|
|
|
qr /insufficient credentials code: 401/
|