about summary refs log tree commit diff stats
path: root/tests
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2013-12-15 21:31:27 +0000
committerJames Booth <boothj5@gmail.com>2013-12-15 21:31:27 +0000
commit5ec2d3cf7cf6fa6e0930c308376fc088ff4fdec2 (patch)
treea4f700bb674d3cae2655b416f29b063eefb33dbe /tests
parentcae2979a0b5601ae7c1b39a5b28f4ceb77218bfa (diff)
downloadprofani-tty-5ec2d3cf7cf6fa6e0930c308376fc088ff4fdec2.tar.gz
Added tests for connecting with account
Diffstat (limited to 'tests')
-rw-r--r--tests/test_cmd_connect.c33
-rw-r--r--tests/test_cmd_connect.h1
-rw-r--r--tests/testsuite.c1
-rw-r--r--tests/xmpp/mock_xmpp.c1
4 files changed, 35 insertions, 1 deletions
diff --git a/tests/test_cmd_connect.c b/tests/test_cmd_connect.c
index ad76da79..54852803 100644
--- a/tests/test_cmd_connect.c
+++ b/tests/test_cmd_connect.c
@@ -162,6 +162,8 @@ void cmd_connect_asks_password_when_not_in_account(void **state)
     will_return(ui_ask_password, strdup("password"));
 
     expect_any(cons_show, output);
+
+    expect_any(jabber_connect_with_account, account);
     will_return(jabber_connect_with_account, JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
@@ -187,6 +189,35 @@ void cmd_connect_shows_message_when_connecting_with_account(void **state)
     will_return(accounts_create_full_jid, strdup("user@jabber.org/laptop"));
 
     expect_string(cons_show, output, "Connecting with account jabber_org as user@jabber.org/laptop");
+
+    expect_any(jabber_connect_with_account, account);
+    will_return(jabber_connect_with_account, JABBER_CONNECTING);
+
+    gboolean result = cmd_connect(args, *help);
+    assert_true(result);
+
+    free(help);
+    free(account);
+}
+
+void cmd_connect_connects_with_account(void **state)
+{
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "jabber_org", NULL };
+    ProfAccount *account = malloc(sizeof(ProfAccount));
+    account->password = "password";
+    account->name = "jabber_org";
+
+    will_return(jabber_get_connection_status, JABBER_DISCONNECTED);
+
+    expect_any(accounts_get_account, name);
+    will_return(accounts_get_account, account);
+
+    will_return(accounts_create_full_jid, strdup("user@jabber.org/laptop"));
+
+    expect_any(cons_show, output);
+
+    expect_memory(jabber_connect_with_account, account, account, sizeof(ProfAccount));
     will_return(jabber_connect_with_account, JABBER_CONNECTING);
 
     gboolean result = cmd_connect(args, *help);
@@ -194,5 +225,5 @@ void cmd_connect_shows_message_when_connecting_with_account(void **state)
 
     free(help);
     free(account);
-    
+
 }
diff --git a/tests/test_cmd_connect.h b/tests/test_cmd_connect.h
index 9bb525cf..967d0652 100644
--- a/tests/test_cmd_connect.h
+++ b/tests/test_cmd_connect.h
@@ -8,3 +8,4 @@ void cmd_connect_fail_message(void **state);
 void cmd_connect_lowercases_argument(void **state);
 void cmd_connect_asks_password_when_not_in_account(void **state);
 void cmd_connect_shows_message_when_connecting_with_account(void **state);
+void cmd_connect_connects_with_account(void **state);
diff --git a/tests/testsuite.c b/tests/testsuite.c
index 1c6c1d0a..060fe8b2 100644
--- a/tests/testsuite.c
+++ b/tests/testsuite.c
@@ -24,6 +24,7 @@ int main(int argc, char* argv[]) {
         unit_test(cmd_connect_lowercases_argument),
         unit_test(cmd_connect_asks_password_when_not_in_account),
         unit_test(cmd_connect_shows_message_when_connecting_with_account),
+        unit_test(cmd_connect_connects_with_account),
 
         unit_test(cmd_rooms_shows_message_when_disconnected),
         unit_test(cmd_rooms_shows_message_when_disconnecting),
diff --git a/tests/xmpp/mock_xmpp.c b/tests/xmpp/mock_xmpp.c
index 26c9c72d..8907c13e 100644
--- a/tests/xmpp/mock_xmpp.c
+++ b/tests/xmpp/mock_xmpp.c
@@ -40,6 +40,7 @@ jabber_conn_status_t jabber_connect_with_details(const char * const jid,
 
 jabber_conn_status_t jabber_connect_with_account(const ProfAccount * const account)
 {
+    check_expected(account);
     return (jabber_conn_status_t)mock();
 }