summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorArnaud Cogoluègnes <acogoluegnes@gmail.com>2016-12-12 17:22:09 +0100
committerArnaud Cogoluègnes <acogoluegnes@gmail.com>2016-12-12 17:22:09 +0100
commit9966bf207df0dd6999ff237f92de1c3731f6fc84 (patch)
tree4b8afd4f88b902f3bdd2c4dcd8f43e1ac6096a0a /test
parent4d3d1705e835e2bad9b82ff10bbaee6f8130a2a9 (diff)
downloadrabbitmq-server-git-9966bf207df0dd6999ff237f92de1c3731f6fc84.tar.gz
Improve global runtime parameters support
References rabbitmq/rabbitmq-mqtt#73
Diffstat (limited to 'test')
-rw-r--r--test/rabbitmqctl_integration_SUITE.erl103
1 files changed, 97 insertions, 6 deletions
diff --git a/test/rabbitmqctl_integration_SUITE.erl b/test/rabbitmqctl_integration_SUITE.erl
index 9305781bda..ba72578775 100644
--- a/test/rabbitmqctl_integration_SUITE.erl
+++ b/test/rabbitmqctl_integration_SUITE.erl
@@ -31,17 +31,24 @@
-export([list_queues_local/1
,list_queues_offline/1
,list_queues_online/1
+ ,manage_global_parameters/1
]).
all() ->
- [{group, list_queues}].
+ [
+ {group, list_queues},
+ {group, global_parameters}
+ ].
groups() ->
- [{list_queues, [],
- [list_queues_local
- ,list_queues_online
- ,list_queues_offline
- ]}].
+ [
+ {list_queues, [],
+ [list_queues_local
+ ,list_queues_online
+ ,list_queues_offline
+ ]},
+ {global_parameters, [], [manage_global_parameters]}
+ ].
init_per_suite(Config) ->
rabbit_ct_helpers:log_environment(),
@@ -56,6 +63,13 @@ init_per_group(list_queues, Config0) ->
Config1 = declare_some_queues(Config),
rabbit_ct_broker_helpers:stop_node(Config1, NumNodes - 1),
Config1;
+init_per_group(global_parameters,Config) ->
+ Config1 = rabbit_ct_helpers:set_config(Config, [
+ {rmq_nodename_suffix, ?MODULE}
+ ]),
+ rabbit_ct_helpers:run_setup_steps(Config1,
+ rabbit_ct_broker_helpers:setup_steps() ++
+ rabbit_ct_client_helpers:setup_steps());
init_per_group(_, Config) ->
Config.
@@ -92,6 +106,10 @@ end_per_group(list_queues, Config0) ->
rabbit_ct_helpers:run_steps(Config1,
rabbit_ct_client_helpers:teardown_steps() ++
rabbit_ct_broker_helpers:teardown_steps());
+end_per_group(global_parameters, Config) ->
+ rabbit_ct_helpers:run_teardown_steps(Config,
+ rabbit_ct_client_helpers:teardown_steps() ++
+ rabbit_ct_broker_helpers:teardown_steps());
end_per_group(_, Config) ->
Config.
@@ -126,6 +144,65 @@ list_queues_offline(Config) ->
assert_ctl_queues(Config, 1, ["--offline"], OfflineQueues),
ok.
+manage_global_parameters(Config) ->
+ 0 = length(global_parameters(Config)),
+ GlobalParameterValue1 = <<"vhost1">>,
+ control_action(Config, set_global_parameter,
+ ["{mqtt_cert_user_vhost, <<\"O=client,CN=dummy1\">>}",
+ GlobalParameterValue1
+ ]),
+
+ 1 = length(global_parameters(Config)),
+
+ GlobalParameterValue1 = rabbit_ct_broker_helpers:rpc(
+ Config, 0,
+ rabbit_runtime_parameters, value_global,
+ [
+ {mqtt_cert_user_vhost, <<"O=client,CN=dummy1">>}
+ ]
+ ),
+
+ GlobalParameterValue2 = <<"vhost2">>,
+ control_action(Config, set_global_parameter,
+ ["{mqtt_cert_user_vhost, <<\"O=client,CN=dummy2\">>}",
+ GlobalParameterValue2
+ ]),
+
+ 2 = length(global_parameters(Config)),
+
+ GlobalParameterValue2 = rabbit_ct_broker_helpers:rpc(
+ Config, 0,
+ rabbit_runtime_parameters, value_global,
+ [
+ {mqtt_cert_user_vhost, <<"O=client,CN=dummy2">>}
+ ]
+ ),
+
+ NewGlobalParameterValue = <<"vhost3">>,
+
+ control_action(Config, set_global_parameter,
+ ["{mqtt_cert_user_vhost, <<\"O=client,CN=dummy1\">>}",
+ NewGlobalParameterValue
+ ]),
+
+ 2 = length(global_parameters(Config)),
+
+ NewGlobalParameterValue = rabbit_ct_broker_helpers:rpc(
+ Config, 0,
+ rabbit_runtime_parameters, value_global,
+ [
+ {mqtt_cert_user_vhost, <<"O=client,CN=dummy1">>}
+ ]
+ ),
+
+ control_action(Config, clear_global_parameter,
+ ["{mqtt_cert_user_vhost, <<\"O=client,CN=dummy1\">>}"]
+ ),
+
+ 1 = length(global_parameters(Config)),
+
+ ok.
+
%%----------------------------------------------------------------------------
%% Helpers
%%----------------------------------------------------------------------------
@@ -144,3 +221,17 @@ assert_ctl_queues(Config, Node, Args, Expected0) ->
run_list_queues(Config, Node, Args) ->
rabbit_ct_broker_helpers:rabbitmqctl_list(Config, Node, ["list_queues"] ++ Args ++ ["name"]).
+
+control_action(Config, Command, Args) ->
+ Node = rabbit_ct_broker_helpers:get_node_config(Config, 0, nodename),
+ rabbit_control_main:action(
+ Command, Node, Args, [],
+ fun (Format, Args1) ->
+ io:format(Format ++ " ...~n", Args1)
+ end).
+
+global_parameters(Config) ->
+ rabbit_ct_broker_helpers:rpc(
+ Config, 0,
+ rabbit_runtime_parameters, list_global, []
+ ). \ No newline at end of file