2015-02-18 00:57:37 +00:00
|
|
|
|
void test_trace_check_compares() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer") << "foo" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer: foo");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-05-21 18:37:50 +00:00
|
|
|
|
void test_trace_check_ignores_other_layers() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 2") << "bar" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: foo");
|
|
|
|
|
CHECK_TRACE_DOESNT_CONTAIN("test layer 2: foo");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-12-24 23:36:12 +00:00
|
|
|
|
void test_trace_check_ignores_leading_whitespace() {
|
|
|
|
|
trace("test layer 1") << " foo" << end();
|
2016-09-03 00:57:43 +00:00
|
|
|
|
CHECK_EQ(trace_count("test layer 1", /*too little whitespace*/"foo"), 1);
|
|
|
|
|
CHECK_EQ(trace_count("test layer 1", /*too much whitespace*/" foo"), 1);
|
2015-12-24 23:36:12 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-02-18 00:57:37 +00:00
|
|
|
|
void test_trace_check_ignores_other_lines() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 1") << "bar" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: foo");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-05-21 18:37:50 +00:00
|
|
|
|
void test_trace_check_ignores_other_lines2() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 1") << "bar" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: bar");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-05-21 18:37:50 +00:00
|
|
|
|
void test_trace_ignores_trailing_whitespace() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo\n" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: foo");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-05-21 19:36:59 +00:00
|
|
|
|
void test_trace_ignores_trailing_whitespace2() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo " << end();
|
2015-05-21 19:36:59 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: foo");
|
|
|
|
|
}
|
|
|
|
|
|
2015-02-18 00:57:37 +00:00
|
|
|
|
void test_trace_orders_across_layers() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 2") << "bar" << end();
|
|
|
|
|
trace("test layer 1") << "qux" << end();
|
2015-05-21 18:37:50 +00:00
|
|
|
|
CHECK_TRACE_CONTENTS("test layer 1: footest layer 2: bartest layer 1: qux");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_trace_supports_count() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 1") << "foo" << end();
|
2015-02-18 00:57:37 +00:00
|
|
|
|
CHECK_EQ(trace_count("test layer 1", "foo"), 2);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_trace_supports_count2() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo" << end();
|
|
|
|
|
trace("test layer 1") << "bar" << end();
|
2015-02-18 00:57:37 +00:00
|
|
|
|
CHECK_EQ(trace_count("test layer 1"), 2);
|
|
|
|
|
}
|
|
|
|
|
|
2015-06-28 01:06:28 +00:00
|
|
|
|
void test_trace_count_ignores_trailing_whitespace() {
|
2015-07-25 07:02:20 +00:00
|
|
|
|
trace("test layer 1") << "foo\n" << end();
|
2016-09-03 00:57:43 +00:00
|
|
|
|
CHECK_EQ(trace_count("test layer 1", "foo"), 1);
|
2015-06-28 01:06:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-02-18 00:57:37 +00:00
|
|
|
|
// pending: DUMP tests
|
|
|
|
|
// pending: readable_contents() adds newline if necessary.
|
2015-02-18 18:49:46 +00:00
|
|
|
|
// pending: raise also prints to stderr.
|
2015-10-07 05:15:45 +00:00
|
|
|
|
// pending: raise doesn't print to stderr if Hide_errors is set.
|
|
|
|
|
// pending: raise doesn't have to be saved if Hide_errors is set, just printed.
|
2015-02-18 18:49:46 +00:00
|
|
|
|
// pending: raise prints to stderr if Trace_stream is NULL.
|
2015-10-07 05:15:45 +00:00
|
|
|
|
// pending: raise prints to stderr if Trace_stream is NULL even if Hide_errors is set.
|
2015-02-18 00:57:37 +00:00
|
|
|
|
|
|
|
|
|
// 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);
|
2015-05-07 22:49:40 +00:00
|
|
|
|
CHECK_EQ(result.at(0), "");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_split_returns_entire_input_when_no_delim() {
|
|
|
|
|
vector<string> result = split("abc", ",");
|
|
|
|
|
CHECK_EQ(result.size(), 1);
|
2015-05-07 22:49:40 +00:00
|
|
|
|
CHECK_EQ(result.at(0), "abc");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_split_works() {
|
|
|
|
|
vector<string> result = split("abc,def", ",");
|
|
|
|
|
CHECK_EQ(result.size(), 2);
|
2015-05-07 22:49:40 +00:00
|
|
|
|
CHECK_EQ(result.at(0), "abc");
|
|
|
|
|
CHECK_EQ(result.at(1), "def");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_split_works2() {
|
|
|
|
|
vector<string> result = split("abc,def,ghi", ",");
|
|
|
|
|
CHECK_EQ(result.size(), 3);
|
2015-05-07 22:49:40 +00:00
|
|
|
|
CHECK_EQ(result.at(0), "abc");
|
|
|
|
|
CHECK_EQ(result.at(1), "def");
|
|
|
|
|
CHECK_EQ(result.at(2), "ghi");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void test_split_handles_multichar_delim() {
|
|
|
|
|
vector<string> result = split("abc,,def,,ghi", ",,");
|
|
|
|
|
CHECK_EQ(result.size(), 3);
|
2015-05-07 22:49:40 +00:00
|
|
|
|
CHECK_EQ(result.at(0), "abc");
|
|
|
|
|
CHECK_EQ(result.at(1), "def");
|
|
|
|
|
CHECK_EQ(result.at(2), "ghi");
|
2015-02-18 00:57:37 +00:00
|
|
|
|
}
|
2015-05-21 19:36:59 +00:00
|
|
|
|
|
|
|
|
|
void test_trim() {
|
|
|
|
|
CHECK_EQ(trim(""), "");
|
|
|
|
|
CHECK_EQ(trim(" "), "");
|
|
|
|
|
CHECK_EQ(trim(" "), "");
|
|
|
|
|
CHECK_EQ(trim("a"), "a");
|
|
|
|
|
CHECK_EQ(trim(" a"), "a");
|
|
|
|
|
CHECK_EQ(trim(" a"), "a");
|
|
|
|
|
CHECK_EQ(trim(" ab"), "ab");
|
|
|
|
|
CHECK_EQ(trim("a "), "a");
|
|
|
|
|
CHECK_EQ(trim("a "), "a");
|
|
|
|
|
CHECK_EQ(trim("ab "), "ab");
|
|
|
|
|
CHECK_EQ(trim(" a "), "a");
|
|
|
|
|
CHECK_EQ(trim(" a "), "a");
|
|
|
|
|
CHECK_EQ(trim(" ab "), "ab");
|
|
|
|
|
}
|