about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--tests/test_cmd_connect.c68
-rw-r--r--tests/xmpp/mock_xmpp.c74
-rw-r--r--tests/xmpp/mock_xmpp.h12
3 files changed, 102 insertions, 52 deletions
diff --git a/tests/test_cmd_connect.c b/tests/test_cmd_connect.c
index 6657c745..d47666ef 100644
--- a/tests/test_cmd_connect.c
+++ b/tests/test_cmd_connect.c
@@ -17,38 +17,6 @@
 #include "config/accounts.h"
 #include "config/mock_accounts.h"
 
-static jabber_conn_status_t _mock_jabber_connect_with_details_no_altdomain(const char * const jid,
-    const char * const passwd, const char * const altdomain)
-{
-    check_expected(jid);
-    check_expected(passwd);
-    return (jabber_conn_status_t)mock();
-}
-
-static jabber_conn_status_t _mock_jabber_connect_with_details_altdomain(const char * const jid,
-    const char * const passwd, const char * const altdomain)
-{
-    check_expected(altdomain);
-    return (jabber_conn_status_t)mock();
-}
-
-static jabber_conn_status_t _mock_jabber_connect_with_details_result(const char * const jid,
-    const char * const passwd, const char * const altdomain)
-{
-    return (jabber_conn_status_t)mock();
-}
-
-static jabber_conn_status_t _mock_jabber_connect_with_account_result(const ProfAccount * const account)
-{
-    return (jabber_conn_status_t)mock();
-}
-
-static jabber_conn_status_t _mock_jabber_connect_with_account_result_check(const ProfAccount * const account)
-{
-    check_expected(account);
-    return (jabber_conn_status_t)mock();
-}
-
 static void test_with_connection_status(jabber_conn_status_t status)
 {
     mock_cons_show();
@@ -89,6 +57,7 @@ void cmd_connect_when_no_account(void **state)
     mock_cons_show();
     mock_accounts_get_account();
     mock_ui_ask_password();
+    mock_jabber_connect_with_details();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "user@server.org", NULL };
 
@@ -100,10 +69,7 @@ void cmd_connect_when_no_account(void **state)
 
     expect_cons_show("Connecting as user@server.org");
 
-    jabber_connect_with_details = _mock_jabber_connect_with_details_no_altdomain;
-    expect_string(_mock_jabber_connect_with_details_no_altdomain, jid, "user@server.org");
-    expect_string(_mock_jabber_connect_with_details_no_altdomain, passwd, "password");
-    will_return(_mock_jabber_connect_with_details_no_altdomain, JABBER_CONNECTING);
+    jabber_connect_with_username_password_expect_and_return("user@server.org", "password", JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -116,6 +82,7 @@ void cmd_connect_with_altdomain_when_provided(void **state)
     stub_ui_ask_password();
     stub_cons_show();
     mock_accounts_get_account();
+    mock_jabber_connect_with_details();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "user@server.org", "altdomain" };
 
@@ -123,9 +90,7 @@ void cmd_connect_with_altdomain_when_provided(void **state)
 
     accounts_get_account_return(NULL);
 
-    jabber_connect_with_details = _mock_jabber_connect_with_details_altdomain;
-    expect_string(_mock_jabber_connect_with_details_altdomain, altdomain, "altdomain");
-    will_return(_mock_jabber_connect_with_details_altdomain, JABBER_CONNECTING);
+    jabber_connect_with_altdomain_expect_and_return("altdomain", JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -139,6 +104,7 @@ void cmd_connect_fail_message(void **state)
     mock_cons_show_error();
     stub_ui_ask_password();
     mock_accounts_get_account();
+    mock_jabber_connect_with_details();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "user@server.org", NULL };
 
@@ -146,8 +112,7 @@ void cmd_connect_fail_message(void **state)
 
     accounts_get_account_return(NULL);
 
-    jabber_connect_with_details = _mock_jabber_connect_with_details_result;
-    will_return(_mock_jabber_connect_with_details_result, JABBER_DISCONNECTED);
+    jabber_connect_with_details_return(JABBER_DISCONNECTED);
 
     expect_cons_show_error("Connection attempt for user@server.org failed.");
 
@@ -162,6 +127,7 @@ void cmd_connect_lowercases_argument(void **state)
     stub_cons_show();
     stub_ui_ask_password();
     mock_accounts_get_account();
+    mock_jabber_connect_with_details();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "USER@server.ORG", NULL };
 
@@ -169,8 +135,7 @@ void cmd_connect_lowercases_argument(void **state)
 
     accounts_get_account_expect_and_return("user@server.org", NULL);
 
-    jabber_connect_with_details = _mock_jabber_connect_with_details_result;
-    will_return(_mock_jabber_connect_with_details_result, JABBER_CONNECTING);
+    jabber_connect_with_details_return(JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -184,6 +149,7 @@ void cmd_connect_asks_password_when_not_in_account(void **state)
     stub_ui_ask_password();
     mock_accounts_get_account();
     mock_accounts_create_full_jid();
+    mock_jabber_connect_with_account();
     stub_accounts_free_account();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "jabber_org", NULL };
@@ -196,8 +162,7 @@ void cmd_connect_asks_password_when_not_in_account(void **state)
 
     accounts_create_full_jid_return("user@jabber.org");
 
-    jabber_connect_with_account = _mock_jabber_connect_with_account_result;
-    will_return(_mock_jabber_connect_with_account_result, JABBER_CONNECTING);
+    jabber_connect_with_account_return(JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -211,6 +176,7 @@ void cmd_connect_shows_message_when_connecting_with_account(void **state)
     mock_cons_show();
     mock_accounts_get_account();
     mock_accounts_create_full_jid();
+    mock_jabber_connect_with_account();
     stub_accounts_free_account();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "jabber_org", NULL };
@@ -226,8 +192,7 @@ void cmd_connect_shows_message_when_connecting_with_account(void **state)
 
     expect_cons_show("Connecting with account jabber_org as user@jabber.org/laptop");
 
-    jabber_connect_with_account = _mock_jabber_connect_with_account_result;
-    will_return(_mock_jabber_connect_with_account_result, JABBER_CONNECTING);
+    jabber_connect_with_account_return(JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -241,6 +206,7 @@ void cmd_connect_connects_with_account(void **state)
     stub_cons_show();
     mock_accounts_get_account();
     mock_accounts_create_full_jid();
+    mock_jabber_connect_with_account();
     stub_accounts_free_account();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "jabber_org", NULL };
@@ -254,9 +220,7 @@ void cmd_connect_connects_with_account(void **state)
 
     accounts_create_full_jid_return("user@jabber.org/laptop");
 
-    jabber_connect_with_account = _mock_jabber_connect_with_account_result_check;
-    expect_memory(_mock_jabber_connect_with_account_result_check, account, account, sizeof(ProfAccount));
-    will_return(_mock_jabber_connect_with_account_result_check, JABBER_CONNECTING);
+    jabber_connect_with_account_expect_and_return(account, JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
     assert_true(result);
@@ -270,6 +234,7 @@ void cmd_connect_frees_account_after_connecting(void **state)
     stub_cons_show();
     mock_accounts_get_account();
     mock_accounts_create_full_jid();
+    mock_jabber_connect_with_account();
     mock_accounts_free_account();
     CommandHelp *help = malloc(sizeof(CommandHelp));
     gchar *args[] = { "jabber_org", NULL };
@@ -281,8 +246,7 @@ void cmd_connect_frees_account_after_connecting(void **state)
 
     accounts_create_full_jid_return("user@jabber.org/laptop");
 
-    jabber_connect_with_account = _mock_jabber_connect_with_account_result;
-    will_return(_mock_jabber_connect_with_account_result, JABBER_CONNECTING);
+    jabber_connect_with_account_return(JABBER_CONNECTING);
 
     accounts_free_account_expect(account);
 
diff --git a/tests/xmpp/mock_xmpp.c b/tests/xmpp/mock_xmpp.c
index ab0f7856..c405ae48 100644
--- a/tests/xmpp/mock_xmpp.c
+++ b/tests/xmpp/mock_xmpp.c
@@ -26,6 +26,35 @@ _mock_iq_room_list_request(gchar *conf_server)
     check_expected(conf_server);
 }
 
+static jabber_conn_status_t
+_mock_jabber_connect_with_details(const char * const jid,
+    const char * const passwd, const char * const altdomain)
+{
+    check_expected(jid);
+    check_expected(passwd);
+    check_expected(altdomain);
+    return (jabber_conn_status_t)mock();
+}
+
+static jabber_conn_status_t
+_mock_jabber_connect_with_account(const ProfAccount * const account)
+{
+    check_expected(account);
+    return (jabber_conn_status_t)mock();
+}
+
+void
+mock_jabber_connect_with_details(void)
+{
+    jabber_connect_with_details = _mock_jabber_connect_with_details;
+}
+
+void
+mock_jabber_connect_with_account(void)
+{
+    jabber_connect_with_account = _mock_jabber_connect_with_account;
+}
+
 void
 mock_connection_status(jabber_conn_status_t status)
 {
@@ -46,3 +75,48 @@ expect_room_list_request(char *conf_server)
     iq_room_list_request = _mock_iq_room_list_request;
     expect_string(_mock_iq_room_list_request, conf_server, conf_server);
 }
+
+void
+jabber_connect_with_username_password_expect_and_return(char *jid,
+    char *password, jabber_conn_status_t result)
+{
+    expect_string(_mock_jabber_connect_with_details, jid, jid);
+    expect_string(_mock_jabber_connect_with_details, passwd, password);
+    expect_any(_mock_jabber_connect_with_details, altdomain);
+    will_return(_mock_jabber_connect_with_details, result);
+}
+
+void
+jabber_connect_with_altdomain_expect_and_return(char *altdomain,
+    jabber_conn_status_t result)
+{
+    expect_any(_mock_jabber_connect_with_details, jid);
+    expect_any(_mock_jabber_connect_with_details, passwd);
+    expect_string(_mock_jabber_connect_with_details, altdomain, altdomain);
+    will_return(_mock_jabber_connect_with_details, result);
+}
+
+void
+jabber_connect_with_details_return(jabber_conn_status_t result)
+{
+    expect_any(_mock_jabber_connect_with_details, jid);
+    expect_any(_mock_jabber_connect_with_details, passwd);
+    expect_any(_mock_jabber_connect_with_details, altdomain);
+    will_return(_mock_jabber_connect_with_details, result);
+}
+
+void
+jabber_connect_with_account_expect_and_return(ProfAccount *account,
+    jabber_conn_status_t result)
+{
+    expect_memory(_mock_jabber_connect_with_account, account, account, sizeof(ProfAccount));
+    will_return(_mock_jabber_connect_with_account, result);
+}
+
+void
+jabber_connect_with_account_return(ProfAccount *account,
+    jabber_conn_status_t result)
+{
+    expect_any(_mock_jabber_connect_with_account, account);
+    will_return(_mock_jabber_connect_with_account, result);
+}
diff --git a/tests/xmpp/mock_xmpp.h b/tests/xmpp/mock_xmpp.h
index 89096836..678fa25d 100644
--- a/tests/xmpp/mock_xmpp.h
+++ b/tests/xmpp/mock_xmpp.h
@@ -7,4 +7,16 @@ void mock_connection_status(jabber_conn_status_t status);
 void mock_connection_account_name(char *name);
 void expect_room_list_request(char *conf_server);
 
+void mock_jabber_connect_with_details(void);
+void jabber_connect_with_username_password_expect_and_return(char *jid,
+    char *password, jabber_conn_status_t result);
+void jabber_connect_with_altdomain_expect_and_return(char *altdomain,
+    jabber_conn_status_t result);
+void jabber_connect_with_details_return(jabber_conn_status_t result);
+
+void mock_jabber_connect_with_account(void);
+void jabber_connect_with_account_expect_and_return(ProfAccount *account,
+    jabber_conn_status_t result);
+void jabber_connect_with_account_return(jabber_conn_status_t result);
+
 #endif