summaryrefslogtreecommitdiff
path: root/test/webadmin_tests.erl
diff options
context:
space:
mode:
Diffstat (limited to 'test/webadmin_tests.erl')
-rw-r--r--test/webadmin_tests.erl73
1 files changed, 73 insertions, 0 deletions
diff --git a/test/webadmin_tests.erl b/test/webadmin_tests.erl
new file mode 100644
index 00000000..6ed1d11f
--- /dev/null
+++ b/test/webadmin_tests.erl
@@ -0,0 +1,73 @@
+%%%-------------------------------------------------------------------
+%%% Author : Pawel Chmielowski <pawel@process-one.net>
+%%% Created : 23 Mar 2020 by Pawel Chmielowski <pawel@process-one.net>
+%%%
+%%%
+%%% ejabberd, Copyright (C) 2002-2020 ProcessOne
+%%%
+%%% This program is free software; you can redistribute it and/or
+%%% modify it under the terms of the GNU General Public License as
+%%% published by the Free Software Foundation; either version 2 of the
+%%% License, or (at your option) any later version.
+%%%
+%%% This program is distributed in the hope that it will be useful,
+%%% but WITHOUT ANY WARRANTY; without even the implied warranty of
+%%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+%%% General Public License for more details.
+%%%
+%%% You should have received a copy of the GNU General Public License along
+%%% with this program; if not, write to the Free Software Foundation, Inc.,
+%%% 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+%%%
+%%%-------------------------------------------------------------------
+-module(webadmin_tests).
+
+%% API
+-compile(export_all).
+-import(suite, [disconnect/1, is_feature_advertised/3, upload_jid/1,
+my_jid/1, wait_for_slave/1, wait_for_master/1,
+send_recv/2, put_event/2, get_event/1]).
+
+-include("suite.hrl").
+-include_lib("stdlib/include/assert.hrl").
+
+%%%===================================================================
+%%% API
+%%%===================================================================
+%%%===================================================================
+%%% Single user tests
+%%%===================================================================
+single_cases() ->
+ {webadmin_single, [sequence],
+ [single_test(login_page),
+ single_test(welcome_page)]}.
+
+login_page(Config) ->
+ Headers = ?match({ok, {{"HTTP/1.1", 401, _}, Headers, _}},
+ httpc:request(get, {page(Config, ""), []}, [],
+ [{body_format, binary}]),
+ Headers),
+ ?match("basic realm=\"ejabberd\"", proplists:get_value("www-authenticate", Headers, none)).
+
+welcome_page(Config) ->
+ Body = ?match({ok, {{"HTTP/1.1", 200, _}, _, Body}},
+ httpc:request(get, {page(Config, ""), [basic_auth_header(Config)]}, [],
+ [{body_format, binary}]),
+ Body),
+ ?match({_, _}, binary:match(Body, <<"ejabberd Web Admin">>)).
+
+%%%===================================================================
+%%% Internal functions
+%%%===================================================================
+single_test(T) ->
+ list_to_atom("webadmin_" ++ atom_to_list(T)).
+
+basic_auth_header(Config) ->
+ Server = ?config(server, Config),
+ ejabberd_auth:try_register(<<"admin">>, Server, <<"pass">>),
+ {"authorization", "Basic "++base64:encode_to_string(<<"admin@", Server/binary, ":pass">>)}.
+
+page(Config, Tail) ->
+ Server = ?config(server_host, Config),
+ Port = ct:get_config(web_port, 5280),
+ "http://" ++ Server ++ ":" ++ integer_to_list(Port) ++ "/admin/" ++ Tail.