emqx/apps/emqx_machine/test/emqx_restricted_shell_SUITE...

91 lines
3.2 KiB
Erlang

%%--------------------------------------------------------------------
%% Copyright (c) 2020-2023 EMQ Technologies Co., Ltd. All Rights Reserved.
%%
%% Licensed 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.
%%--------------------------------------------------------------------
-module(emqx_restricted_shell_SUITE).
-compile(export_all).
-compile(nowarn_export_all).
-include_lib("emqx/include/emqx.hrl").
-include_lib("eunit/include/eunit.hrl").
-include_lib("common_test/include/ct.hrl").
all() -> emqx_common_test_helpers:all(?MODULE).
init_per_suite(Config) ->
emqx_common_test_helpers:start_apps([]),
Config.
end_per_suite(_Config) ->
emqx_common_test_helpers:stop_apps([]).
t_local_allowed(_Config) ->
LocalProhibited = [halt, q],
State = undefined,
lists:foreach(
fun(LocalFunc) ->
?assertEqual({false, State}, emqx_restricted_shell:local_allowed(LocalFunc, [], State))
end,
LocalProhibited
),
LocalAllowed = [ls, pwd],
lists:foreach(
fun(LocalFunc) ->
?assertEqual({true, State}, emqx_restricted_shell:local_allowed(LocalFunc, [], State))
end,
LocalAllowed
),
ok.
t_non_local_allowed(_Config) ->
RemoteProhibited = [{erlang, halt}, {c, q}, {init, stop}, {init, restart}, {init, reboot}],
State = undefined,
lists:foreach(
fun(RemoteFunc) ->
?assertEqual(
{false, State}, emqx_restricted_shell:non_local_allowed(RemoteFunc, [], State)
)
end,
RemoteProhibited
),
RemoteAllowed = [{erlang, date}, {erlang, system_time}],
lists:foreach(
fun(RemoteFunc) ->
?assertEqual({true, State}, emqx_restricted_shell:local_allowed(RemoteFunc, [], State))
end,
RemoteAllowed
),
ok.
t_lock(_Config) ->
State = undefined,
emqx_restricted_shell:lock(),
?assertEqual({false, State}, emqx_restricted_shell:local_allowed(q, [], State)),
?assertEqual({true, State}, emqx_restricted_shell:local_allowed(ls, [], State)),
?assertEqual({false, State}, emqx_restricted_shell:non_local_allowed({init, stop}, [], State)),
?assertEqual(
{true, State}, emqx_restricted_shell:non_local_allowed({inet, getifaddrs}, [], State)
),
emqx_restricted_shell:unlock(),
?assertEqual({true, State}, emqx_restricted_shell:local_allowed(q, [], State)),
?assertEqual({true, State}, emqx_restricted_shell:local_allowed(ls, [], State)),
?assertEqual({true, State}, emqx_restricted_shell:non_local_allowed({init, stop}, [], State)),
?assertEqual(
{true, State}, emqx_restricted_shell:non_local_allowed({inet, getifaddrs}, [], State)
),
emqx_restricted_shell:lock(),
ok.