#include "Utils.h" #include #include #include #include #include "test.h" namespace { using namespace SBF; using namespace Test; using namespace std; } // End namespace TestResults test_get_index_of() { string long_text = "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's " "standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to " "make a type specimen book. It has survived not only five centuries, but also the leap into electronic " "typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset " "sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker " "including versions of Lorem Ipsum."; return execute_suite(make_test_suite( "SBF::Utils::get_index_of", get_index_of, vector>({ make_test( "should get 0 for the first word in a string", 0, make_tuple(long_text, string("Lorem"), size_t(0))), make_test("should get the location of a word in the larger string", 22, make_tuple(long_text, string("dummy"), size_t(0))), make_test( "should get -1 for the location of a word that is not int the string", -1, make_tuple(long_text, string("acid"), size_t(0))), make_test( "should should get the location of a subsequent word within the string", 120, make_tuple(long_text, string("dummy"), size_t(100))), make_test( "should get -1 for the location of a word that is before start location in the string", -1, make_tuple(long_text, string("dummy"), size_t(long_text.size()))), make_test("should get the location of a word within a simple string", 6, make_tuple(string("these are words"), string("are"), size_t(0))), make_test("should get the first location of a word within the string", 4, make_tuple(string("one two one two"), string("two"), size_t(0))), make_test("should get the second location of a word within the string", 12, make_tuple(string("one two one two"), string("two"), size_t(5))), }))); } TestResults test_get_substring() { return execute_suite(make_test_suite( "SBF::Utils::get_substring", get_substring, vector>({ make_test( "should get an empty string if start is too big", "", make_tuple(string("asdf"), size_t(6), size_t(2))), make_test( "should get an empty string if count is 0", "", make_tuple(string("asdf"), size_t(0), size_t(0))), make_test( "should get a string that starts at 0", "as", make_tuple(string("asdf"), size_t(0), size_t(2))), make_test( "should get the whole string", "asdf", make_tuple(string("asdf"), size_t(0), size_t(4))), make_test("should get a partial string if count is too big", "asdf", make_tuple(string("asdf"), size_t(0), size_t(8))), make_test( "should get a substring", "234", make_tuple(string("1234567890"), size_t(1), size_t(3))), make_test( "should get a word", "Paris", make_tuple(string("Where is Paris?"), size_t(9), size_t(5))), }))); } TestResults test_left() { return execute_suite(make_test_suite( "SBF::Utils::left", SBF::left, vector>({ make_test( "should get a substring", "Micro", make_tuple(string("Microsoft QBasic"), size_t(5))), make_test("should get the whole string if length is equal to text.size()", "Microsoft QBasic", make_tuple(string("Microsoft QBasic"), size_t(16))), make_test("should get the whole string if length is greater than text.size()", "Microsoft QBasic", make_tuple(string("Microsoft QBasic"), size_t(20))), make_test( "should get an empty string if length is 0", "", make_tuple(string("Microsoft QBasic"), size_t(0))), make_test( "should get an empty string if text is empty", "", make_tuple(string(""), size_t(1))), }))); } TestResults test_right() { return execute_suite(make_test_suite( "SBF::Utils::right", SBF::right, vector>({ make_test( "should get a substring", "Basic", make_tuple(string("Microsoft QBasic"), size_t(5))), make_test("should get the whole string if length is equal to text.size()", "Microsoft QBasic", make_tuple(string("Microsoft QBasic"), size_t(16))), make_test("should get the whole string if length is greater than text.size()", "Microsoft QBasic", make_tuple(string("Microsoft QBasic"), size_t(20))), make_test( "should get an empty string if length is 0", "", make_tuple(string("Microsoft QBasic"), size_t(0))), make_test( "should get an empty string if text is empty", "", make_tuple(string(""), size_t(1))), }))); } TestResults test_make_fit_c() { return execute_suite(make_test_suite( "SBF::Utils::make_fit_c", make_fit_c, vector>({ make_test( "should truncate a string that is too long", "soft ", make_tuple(string("Microsoft QBasic"), 5, 'A')), make_test( "should pad a string that is too short", "AAMicroAAA", make_tuple(string("Micro"), 10, 'A')), make_test( "should return a string that is perfectly sized", "Micro", make_tuple(string("Micro"), 5, 'A')), make_test("should pad the string with spaces if padCh is the null character", " Micro ", make_tuple(string("Micro"), 10, '\0')), make_test( "should return a padded string even if text is empty", "ZZZZZZZZZZ", make_tuple(string(""), 10, 'Z')), }))); } TestResults test_make_fit_l() { return execute_suite(make_test_suite( "SBF::Utils::make_fit_l", make_fit_l, vector>({ make_test( "should truncate a string that is too long", "Micro", make_tuple(string("Microsoft QBasic"), 5, 'A')), make_test( "should pad a string that is too short", "MicroAAAAA", make_tuple(string("Micro"), 10, 'A')), make_test( "should return a string that is perfectly sized", "Micro", make_tuple(string("Micro"), 5, 'A')), make_test("should pad the string with spaces if padCh is the null character", "Micro ", make_tuple(string("Micro"), 10, '\0')), make_test( "should return a padded string even if text is empty", "ZZZZZZZZZZ", make_tuple(string(""), 10, 'Z')), }))); } TestResults test_make_fit_r() { return execute_suite(make_test_suite( "SBF::Utils::make_fit_r", make_fit_r, vector>({ make_test( "should truncate a string that is too long", "Basic", make_tuple(string("Microsoft QBasic"), 5, 'A')), make_test( "should pad a string that is too short", "AAAAAMicro", make_tuple(string("Micro"), 10, 'A')), make_test( "should return a string that is perfectly sized", "Micro", make_tuple(string("Micro"), 5, 'A')), make_test("should pad the string with spaces if padCh is the null character", " Micro", make_tuple(string("Micro"), 10, '\0')), make_test( "should return a padded string even if text is empty", "ZZZZZZZZZZ", make_tuple(string(""), 10, 'Z')), }))); } TestResults test_left_trim() { return execute_suite(make_test_suite( "SBF::Utils::left_trim", left_trim, vector>({ make_test("should trim a string with spaces", "this is a string with spaces on either end ", make_tuple(string(" this is a string with spaces on either end "))), make_test("should trim a string with tabs", "this is a string with tabs on either end\t\t\t\t", make_tuple(string("\t\t\t\tthis is a string with tabs on either end\t\t\t\t"))), make_test("should trim a string with newlines", "this is a string with newlines on either end\n\n\n\n", make_tuple(string("\n\n\n\nthis is a string with newlines on either end\n\n\n\n"))), make_test( "should trim a string with carrige returns", "this is a string with carriage returns on either end\r\r\r\r", make_tuple(string("\r\r\r\rthis is a string with carriage returns on either end\r\r\r\r"))), make_test( "should trim a string with mixed whitespace", "this is a string with mixed whitespace on either end\f\v\r\n\t ", make_tuple(string(" \t\n\r\v\fthis is a string with mixed whitespace on either end\f\v\r\n\t "))), make_test("should get an unmodified string if there is nothing to trim", "this is a string that won't be trimmed", make_tuple(string("this is a string that won't be trimmed"))), make_test("should get an empty string for an empty string", "", make_tuple(string(""))), make_test( "should get an empty string for an all whitespace string", "", make_tuple(string(" \t\n\r\r\n\t "))), }))); } TestResults test_right_trim() { return execute_suite(make_test_suite( "SBF::Utils::right_trim", right_trim, vector>({ make_test("should trim a string with spaces", " this is a string with spaces on either end", make_tuple(string(" this is a string with spaces on either end "))), make_test("should trim a string with tabs", "\t\t\t\tthis is a string with tabs on either end", make_tuple(string("\t\t\t\tthis is a string with tabs on either end\t\t\t\t"))), make_test("should trim a string with newlines", "\n\n\n\nthis is a string with newlines on either end", make_tuple(string("\n\n\n\nthis is a string with newlines on either end\n\n\n\n"))), make_test( "should trim a string with carrige returns", "\r\r\r\rthis is a string with carriage returns on either end", make_tuple(string("\r\r\r\rthis is a string with carriage returns on either end\r\r\r\r"))), make_test( "should trim a string with mixed whitespace", " \t\n\r\v\fthis is a string with mixed whitespace on either end", make_tuple(string(" \t\n\r\v\fthis is a string with mixed whitespace on either end\f\v\r\n\t "))), make_test("should get an unmodified string if there is nothing to trim", "this is a string that won't be trimmed", make_tuple(string("this is a string that won't be trimmed"))), make_test("should get an empty string for an empty string", "", make_tuple(string(""))), make_test( "should get an empty string for an all whitespace string", "", make_tuple(string(" \t\n\r\r\n\t "))), }))); } TestResults test_string_dollar() { return execute_suite(make_test_suite( "SBF::Utils::string_dollar", string_dollar, vector>({ make_test("should make a string", "YYYYY", make_tuple(size_t(5), 'Y')), make_test( "should make a string of spaces if ch is the null character", " ", make_tuple(size_t(5), '\0')), make_test("should make an empty string if length is 0", "", make_tuple(size_t(0), 'C')), }))); } TestResults test_word_wrap() { // TODO: Treat newlines and tabs in text as spaces. auto fnToTest = [](string text, int32_t column_width, vector expected) -> string { ostringstream error_message; try { vector actual = word_wrap(text, column_width); compare(error_message, expected, actual); } catch (const exception& ex) { error_message << ex.what(); } catch (...) { error_message << "threw something that was not an exception"; } string error_string = error_message.str(); if (error_string.size() > 0) { return error_message.str(); } return "no errors"; }; return execute_suite>(make_test_suite( "SBF::Utils::word_wrap", fnToTest, vector>>({ make_test>("should return the string if it is shorter than max_width", "no errors", make_tuple(string("0123"), 5, vector({"0123_"}))), make_test>( "should return the string if its length is equal to max_width", "no errors", make_tuple(string("01234"), 5, vector({"01234"}))), make_test>( "should wrap a string to two lines if it has no whitespace", "no errors", make_tuple(string("012345"), 5, vector({"01234", "5____"}))), make_test>( "should wrap a string to three lines if it has no whitespace", "no errors", make_tuple(string("01234567890"), 5, vector({"01234", "56789", "0____"}))), make_test>( "should wrap a string with even spacing", "no errors", make_tuple(string("01 23 45 67 89 01"), 5, vector({"01 23", "45 67", "89 01"}))), make_test>( "should collapse whitespace to a single space", "no errors", make_tuple( string("01 34 67 90 23 56 89 "), 5, vector({"01 34", "67 90", "23 56", "89___"}))), }))); } int main(int argc, char* argv[]) { TestResults results; results += test_get_index_of(); results += test_get_substring(); results += test_left(); results += test_left_trim(); results += test_make_fit_c(); results += test_make_fit_l(); results += test_make_fit_r(); results += test_right(); results += test_right_trim(); results += test_string_dollar(); results += test_word_wrap(); PrintResults(cout, results); return results.failed() + results.errors(); }