summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorPaweł Chmielowski <pchmielowski@process-one.net>2020-03-23 10:52:07 +0100
committerPaweł Chmielowski <pchmielowski@process-one.net>2020-03-23 10:52:07 +0100
commita2d1ffffe6f1068c6417006dfe7be3fab7d003e6 (patch)
treebc0af916a58402d9bdb104168f71de2bd5c26a0c /test
parentUpdate deps (diff)
Add baisc tests for webadmin
Diffstat (limited to 'test')
-rw-r--r--test/ejabberd_SUITE.erl4
-rw-r--r--test/ejabberd_SUITE_data/ejabberd.yml3
-rw-r--r--test/webadmin_tests.erl73
3 files changed, 80 insertions, 0 deletions
diff --git a/test/ejabberd_SUITE.erl b/test/ejabberd_SUITE.erl
index 25e42a9d..ee19dd4b 100644
--- a/test/ejabberd_SUITE.erl
+++ b/test/ejabberd_SUITE.erl
@@ -259,6 +259,8 @@ init_per_testcase(TestCase, OrigConfig) ->
case Test of
"test_connect" ++ _ ->
Config;
+ "webadmin_" ++ _ ->
+ Config;
"test_legacy_auth_feature" ->
connect(Config);
"test_legacy_auth" ++ _ ->
@@ -372,6 +374,7 @@ db_tests(DB) when DB == mnesia; DB == redis ->
auth_md5,
presence_broadcast,
last,
+ webadmin_tests:single_cases(),
roster_tests:single_cases(),
private_tests:single_cases(),
privacy_tests:single_cases(),
@@ -401,6 +404,7 @@ db_tests(DB) ->
auth_md5,
presence_broadcast,
last,
+ webadmin_tests:single_cases(),
roster_tests:single_cases(),
private_tests:single_cases(),
privacy_tests:single_cases(),
diff --git a/test/ejabberd_SUITE_data/ejabberd.yml b/test/ejabberd_SUITE_data/ejabberd.yml
index cea93fe9..92232560 100644
--- a/test/ejabberd_SUITE_data/ejabberd.yml
+++ b/test/ejabberd_SUITE_data/ejabberd.yml
@@ -66,6 +66,8 @@ access_rules:
acl:
local:
user_regexp: ""
+ admin:
+ user: "admin"
language: en
listen:
-
@@ -84,6 +86,7 @@ listen:
port: WEB_PORT
module: ejabberd_http
request_handlers:
+ "/admin": ejabberd_web_admin
"/api": mod_http_api
"/upload": mod_http_upload
"/captcha": ejabberd_captcha
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.