about summary refs log tree commit diff stats
path: root/tangle/001trace.test.cc
blob: 5f0a696e7edefd97a391c12ebc5bcae65c1f2d4d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
void test_trace_check_compares() {
  CHECK_TRACE_CONTENTS("test layer", "");
  trace("test layer") << "foo";
  CHECK_TRACE_CONTENTS("test layer", "foo");
}

void test_trace_check_filters_layers() {
  trace("test layer 1") << "foo";
  trace("test layer 2") << "bar";
  CHECK_TRACE_CONTENTS("test layer 1", "foo");
}

void test_trace_check_ignores_other_lines() {
  trace("test layer 1") << "foo";
  trace("test layer 1") << "bar";
  CHECK_TRACE_CONTENTS("test layer 1", "foo");
}

void test_trace_check_always_finds_empty_lines() {
  CHECK_TRACE_CONTENTS("test layer 1", "");
}

void test_trace_check_treats_empty_layers_as_wildcards() {
  trace("test layer 1") << "foo";
  CHECK_TRACE_CONTENTS("", "foo");
}

void test_trace_check_multiple_lines_at_once() {
  trace("test layer 1") << "foo";
  trace("test layer 2") << "bar";
  CHECK_TRACE_CONTENTS("", "foobar");
}

void test_trace_check_always_finds_empty_lines2() {
  CHECK_TRACE_CONTENTS("test layer 1", "");
}

void test_trace_orders_across_layers() {
  trace("test layer 1") << "foo";
  trace("test layer 2") << "bar";
  trace("test layer 1") << "qux";
  CHECK_TRACE_CONTENTS("", "foobarqux");
}

void test_trace_supports_count() {
  trace("test layer 1") << "foo";
  trace("test layer 1") << "foo";
  CHECK_EQ(trace_count("test layer 1", "foo"), 2);
}

//// helpers

// can't check trace because trace methods call 'split'

void test_split_returns_at_least_one_elem() {
  vector<string> result = split("", ",");
  CHECK_EQ(result.size(), 1);
  CHECK_EQ(result[0], "");
}

void test_split_returns_entire_input_when_no_delim() {
  vector<string> result = split("abc", ",");
  CHECK_EQ(result.size(), 1);
  CHECK_EQ(result[0], "abc");
}

void test_split_works() {
  vector<string> result = split("abc,def", ",");
  CHECK_EQ(result.size(), 2);
  CHECK_EQ(result[0], "abc");
  CHECK_EQ(result[1], "def");
}

void test_split_works2() {
  vector<string> result = split("abc,def,ghi", ",");
  CHECK_EQ(result.size(), 3);
  CHECK_EQ(result[0], "abc");
  CHECK_EQ(result[1], "def");
  CHECK_EQ(result[2], "ghi");
}

void test_split_handles_multichar_delim() {
  vector<string> result = split("abc,,def,,ghi", ",,");
  CHECK_EQ(result.size(), 3);
  CHECK_EQ(result[0], "abc");
  CHECK_EQ(result[1], "def");
  CHECK_EQ(result[2], "ghi");
}
class="n">help); } void cmd_roster_shows_message_when_disconnecting(void **state) { test_with_connection_status(JABBER_DISCONNECTING); } void cmd_roster_shows_message_when_connecting(void **state) { test_with_connection_status(JABBER_CONNECTING); } void cmd_roster_shows_message_when_disconnected(void **state) { test_with_connection_status(JABBER_DISCONNECTED); } void cmd_roster_shows_message_when_undefined(void **state) { test_with_connection_status(JABBER_UNDEFINED); } void cmd_roster_shows_roster_when_no_args(void **state) { mock_cons_show_roster(); CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { NULL }; mock_connection_status(JABBER_CONNECTED); roster_init(); roster_add("bob@server.org", "bob", NULL, "both", FALSE); GSList *roster = roster_get_contacts(); cons_show_roster_expect(roster); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); roster_free(); } void cmd_roster_add_shows_message_when_no_jid(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "add", NULL }; mock_connection_status(JABBER_CONNECTED); expect_cons_show("Usage: some usage"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_add_sends_roster_add_request(void **state) { char *jid = "bob@server.org"; char *nick = "bob"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, nick, NULL }; mock_roster_send_add_new(); mock_connection_status(JABBER_CONNECTED); roster_send_add_new_expect(jid, nick); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_remove_shows_message_when_no_jid(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "remove", NULL }; mock_connection_status(JABBER_CONNECTED); expect_cons_show("Usage: some usage"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_remove_sends_roster_remove_request(void **state) { char *jid = "bob@server.org"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "remove", jid, NULL }; mock_roster_send_remove(); mock_connection_status(JABBER_CONNECTED); roster_send_remove_expect(jid); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_nick_shows_message_when_no_jid(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "nick", NULL }; mock_connection_status(JABBER_CONNECTED); expect_cons_show("Usage: some usage"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_nick_shows_message_when_no_nick(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "nick", "bob@server.org", NULL }; mock_connection_status(JABBER_CONNECTED); expect_cons_show("Usage: some usage"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_nick_shows_message_when_no_contact_exists(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "nick", "bob@server.org", "bobster", NULL }; roster_init(); mock_connection_status(JABBER_CONNECTED); expect_cons_show("Contact not found in roster: bob@server.org"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); roster_free(); } void cmd_roster_nick_sends_name_change_request(void **state) { char *jid = "bob@server.org"; char *nick = "bobster"; mock_cons_show(); mock_roster_send_name_change(); CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "nick", jid, nick, NULL }; roster_init(); GSList *groups = NULL; groups = g_slist_append(groups, "group1"); roster_add(jid, "bob", groups, "both", FALSE); mock_connection_status(JABBER_CONNECTED); roster_send_name_change_expect(jid, nick, groups); expect_cons_show("Nickname for bob@server.org set to: bobster."); gboolean result = cmd_roster(args, *help); assert_true(result); PContact contact = roster_get_contact(jid); assert_string_equal(p_contact_name(contact), nick); free(help); roster_free(); } void cmd_roster_clearnick_shows_message_when_no_jid(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "clearnick", NULL }; mock_connection_status(JABBER_CONNECTED); expect_cons_show("Usage: some usage"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); } void cmd_roster_clearnick_shows_message_when_no_contact_exists(void **state) { mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { "clearnick", "bob@server.org", NULL }; roster_init(); mock_connection_status(JABBER_CONNECTED); expect_cons_show("Contact not found in roster: bob@server.org"); gboolean result = cmd_roster(args, *help); assert_true(result); free(help); roster_free(); } void cmd_roster_clearnick_sends_name_change_request_with_empty_nick(void **state) { char *jid = "bob@server.org"; mock_cons_show(); mock_roster_send_name_change(); CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "clearnick", jid, NULL }; roster_init(); GSList *groups = NULL; groups = g_slist_append(groups, "group1"); roster_add(jid, "bob", groups, "both", FALSE); mock_connection_status(JABBER_CONNECTED); roster_send_name_change_expect(jid, NULL, groups); expect_cons_show("Nickname for bob@server.org removed."); gboolean result = cmd_roster(args, *help); assert_true(result); PContact contact = roster_get_contact(jid); assert_null(p_contact_name(contact)); free(help); roster_free(); }