From a2d1ffffe6f1068c6417006dfe7be3fab7d003e6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pawe=C5=82=20Chmielowski?= Date: Mon, 23 Mar 2020 10:52:07 +0100 Subject: [PATCH] Add baisc tests for webadmin --- test/ejabberd_SUITE.erl | 4 ++ test/ejabberd_SUITE_data/ejabberd.yml | 3 ++ test/webadmin_tests.erl | 73 +++++++++++++++++++++++++++ 3 files changed, 80 insertions(+) create mode 100644 test/webadmin_tests.erl diff --git a/test/ejabberd_SUITE.erl b/test/ejabberd_SUITE.erl index 25e42a9d4..ee19dd4b8 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 cea93fe90..922325609 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 000000000..6ed1d11f3 --- /dev/null +++ b/test/webadmin_tests.erl @@ -0,0 +1,73 @@ +%%%------------------------------------------------------------------- +%%% Author : Pawel Chmielowski +%%% Created : 23 Mar 2020 by Pawel Chmielowski +%%% +%%% +%%% 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.