summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/ejabberd_SUITE.erl1
-rw-r--r--test/ejabberd_SUITE_data/ejabberd.yml12
-rw-r--r--test/ejabberd_SUITE_data/macros.yml1
-rw-r--r--test/stundisco_tests.erl192
-rw-r--r--test/suite.erl1
5 files changed, 207 insertions, 0 deletions
diff --git a/test/ejabberd_SUITE.erl b/test/ejabberd_SUITE.erl
index 6658f673..e471823a 100644
--- a/test/ejabberd_SUITE.erl
+++ b/test/ejabberd_SUITE.erl
@@ -361,6 +361,7 @@ no_db_tests() ->
muc_tests:master_slave_cases(),
proxy65_tests:single_cases(),
proxy65_tests:master_slave_cases(),
+ stundisco_tests:single_cases(),
replaced_tests:master_slave_cases(),
upload_tests:single_cases(),
carbons_tests:single_cases(),
diff --git a/test/ejabberd_SUITE_data/ejabberd.yml b/test/ejabberd_SUITE_data/ejabberd.yml
index 92232560..5f584b6d 100644
--- a/test/ejabberd_SUITE_data/ejabberd.yml
+++ b/test/ejabberd_SUITE_data/ejabberd.yml
@@ -91,6 +91,12 @@ listen:
"/upload": mod_http_upload
"/captcha": ejabberd_captcha
-
+ port: STUN_PORT
+ module: ejabberd_stun
+ transport: udp
+ use_turn: true
+ turn_ip: "203.0.113.3"
+ -
port: COMPONENT_PORT
module: ejabberd_service
password: PASSWORD
@@ -124,6 +130,12 @@ Welcome to this XMPP server."
mod_stream_mgmt:
max_ack_queue: 10
resume_timeout: 3
+ mod_stun_disco:
+ secret: "cryptic"
+ services:
+ -
+ host: "example.com"
+ type: turns
mod_time: []
mod_version: []
mod_http_upload:
diff --git a/test/ejabberd_SUITE_data/macros.yml b/test/ejabberd_SUITE_data/macros.yml
index fdd46758..fd4e09f0 100644
--- a/test/ejabberd_SUITE_data/macros.yml
+++ b/test/ejabberd_SUITE_data/macros.yml
@@ -4,6 +4,7 @@ define_macro:
C2S_PORT: @@c2s_port@@
S2S_PORT: @@s2s_port@@
WEB_PORT: @@web_port@@
+ STUN_PORT: @@stun_port@@
COMPONENT_PORT: @@component_port@@
PROXY_PORT: @@proxy_port@@
PASSWORD: >-
diff --git a/test/stundisco_tests.erl b/test/stundisco_tests.erl
new file mode 100644
index 00000000..8cb026dc
--- /dev/null
+++ b/test/stundisco_tests.erl
@@ -0,0 +1,192 @@
+%%%-------------------------------------------------------------------
+%%% Author : Holger Weiss <holger@zedat.fu-berlin.de>
+%%% Created : 22 Apr 2020 by Holger Weiss <holger@zedat.fu-berlin.de>
+%%%
+%%%
+%%% ejabberd, Copyright (C) 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(stundisco_tests).
+
+%% API
+-compile(export_all).
+-import(suite, [send_recv/2, disconnect/1, is_feature_advertised/2,
+ server_jid/1]).
+
+-include("suite.hrl").
+
+%%%===================================================================
+%%% API
+%%%===================================================================
+%%%===================================================================
+%%% Single user tests
+%%%===================================================================
+single_cases() ->
+ {stundisco_single, [sequence],
+ [single_test(feature_enabled),
+ single_test(stun_service),
+ single_test(turn_service),
+ single_test(turns_service),
+ single_test(turn_credentials),
+ single_test(turns_credentials)]}.
+
+feature_enabled(Config) ->
+ true = is_feature_advertised(Config, ?NS_EXTDISCO_2),
+ disconnect(Config).
+
+stun_service(Config) ->
+ ServerJID = server_jid(Config),
+ Host = {203, 0, 113, 3},
+ Port = ct:get_config(stun_port, 3478),
+ Type = stun,
+ Transport = udp,
+ Request = #services{type = Type},
+ #iq{type = result,
+ sub_els = [#services{
+ type = undefined,
+ list = [#service{host = Host,
+ port = Port,
+ type = Type,
+ transport = Transport,
+ restricted = false,
+ username = <<>>,
+ password = <<>>,
+ expires = undefined,
+ action = undefined,
+ xdata = undefined}]}]} =
+ send_recv(Config, #iq{type = get, to = ServerJID, sub_els = [Request]}),
+ disconnect(Config).
+
+turn_service(Config) ->
+ ServerJID = server_jid(Config),
+ Host = {203, 0, 113, 3},
+ Port = ct:get_config(stun_port, 3478),
+ Type = turn,
+ Transport = udp,
+ Request = #services{type = Type},
+ #iq{type = result,
+ sub_els = [#services{
+ type = undefined,
+ list = [#service{host = Host,
+ port = Port,
+ type = Type,
+ transport = Transport,
+ restricted = true,
+ username = Username,
+ password = Password,
+ expires = Expires,
+ action = undefined,
+ xdata = undefined}]}]} =
+ send_recv(Config, #iq{type = get, to = ServerJID, sub_els = [Request]}),
+ true = check_password(Username, Password),
+ true = check_expires(Expires),
+ disconnect(Config).
+
+turns_service(Config) ->
+ ServerJID = server_jid(Config),
+ Host = <<"example.com">>,
+ Port = 5349,
+ Type = turns,
+ Transport = tcp,
+ Request = #services{type = Type},
+ #iq{type = result,
+ sub_els = [#services{
+ type = undefined,
+ list = [#service{host = Host,
+ port = Port,
+ type = Type,
+ transport = Transport,
+ restricted = true,
+ username = Username,
+ password = Password,
+ expires = Expires,
+ action = undefined,
+ xdata = undefined}]}]} =
+ send_recv(Config, #iq{type = get, to = ServerJID, sub_els = [Request]}),
+ true = check_password(Username, Password),
+ true = check_expires(Expires),
+ disconnect(Config).
+
+turn_credentials(Config) ->
+ ServerJID = server_jid(Config),
+ Host = {203, 0, 113, 3},
+ Port = ct:get_config(stun_port, 3478),
+ Type = turn,
+ Transport = udp,
+ Request = #credentials{services = [#service{host = Host,
+ port = Port,
+ type = Type}]},
+ #iq{type = result,
+ sub_els = [#services{
+ type = undefined,
+ list = [#service{host = Host,
+ port = Port,
+ type = Type,
+ transport = Transport,
+ restricted = true,
+ username = Username,
+ password = Password,
+ expires = Expires,
+ action = undefined,
+ xdata = undefined}]}]} =
+ send_recv(Config, #iq{type = get, to = ServerJID, sub_els = [Request]}),
+ true = check_password(Username, Password),
+ true = check_expires(Expires),
+ disconnect(Config).
+
+turns_credentials(Config) ->
+ ServerJID = server_jid(Config),
+ Host = <<"example.com">>,
+ Port = 5349,
+ Type = turns,
+ Transport = tcp,
+ Request = #credentials{services = [#service{host = Host,
+ port = Port,
+ type = Type}]},
+ #iq{type = result,
+ sub_els = [#services{
+ type = undefined,
+ list = [#service{host = Host,
+ port = Port,
+ type = Type,
+ transport = Transport,
+ restricted = true,
+ username = Username,
+ password = Password,
+ expires = Expires,
+ action = undefined,
+ xdata = undefined}]}]} =
+ send_recv(Config, #iq{type = get, to = ServerJID, sub_els = [Request]}),
+ true = check_password(Username, Password),
+ true = check_expires(Expires),
+ disconnect(Config).
+
+%%%===================================================================
+%%% Internal functions
+%%%===================================================================
+single_test(T) ->
+ list_to_atom("stundisco_" ++ atom_to_list(T)).
+
+check_password(Username, Password) ->
+ Secret = <<"cryptic">>,
+ Password == base64:encode(crypto:hmac(sha, Secret, Username)).
+
+check_expires({_, _, _} = Expires) ->
+ Now = {MegaSecs, Secs, MicroSecs} = erlang:timestamp(),
+ Later = {MegaSecs + 1, Secs, MicroSecs},
+ (Expires > Now) and (Expires < Later).
diff --git a/test/suite.erl b/test/suite.erl
index 78732d00..ca6123c6 100644
--- a/test/suite.erl
+++ b/test/suite.erl
@@ -60,6 +60,7 @@ init_config(Config) ->
{loglevel, 4},
{new_schema, false},
{s2s_port, 5269},
+ {stun_port, 3478},
{component_port, 5270},
{web_port, 5280},
{proxy_port, 7777},