extend unit tests

This commit is contained in:
Arvid Norberg 2013-02-23 06:58:28 +00:00
parent 0c6654f484
commit cfa25b66e8
1 changed files with 38 additions and 0 deletions

View File

@ -1120,6 +1120,21 @@ int test_main()
TEST_CHECK(parse_url_components("http://[2001:ff00::1]:42/path/to/file", ec) TEST_CHECK(parse_url_components("http://[2001:ff00::1]:42/path/to/file", ec)
== make_tuple("http", "", "[2001:ff00::1]", 42, "/path/to/file")); == make_tuple("http", "", "[2001:ff00::1]", 42, "/path/to/file"));
// leading spaces are supposed to be stripped
TEST_CHECK(parse_url_components(" \thttp://[2001:ff00::1]:42/path/to/file", ec)
== make_tuple("http", "", "[2001:ff00::1]", 42, "/path/to/file"));
parse_url_components("http://[2001:ff00::1:42/path/to/file", ec);
TEST_CHECK(ec == error_code(errors::expected_close_bracket_in_address));
parse_url_components("http:/", ec);
TEST_CHECK(ec == error_code(errors::unsupported_url_protocol));
ec.clear();
parse_url_components("http:", ec);
TEST_CHECK(ec == error_code(errors::unsupported_url_protocol));
ec.clear();
// base64 test vectors from http://www.faqs.org/rfcs/rfc4648.html // base64 test vectors from http://www.faqs.org/rfcs/rfc4648.html
TEST_CHECK(base64encode("") == ""); TEST_CHECK(base64encode("") == "");
@ -1181,6 +1196,7 @@ int test_main()
TEST_CHECK(unescape_string(escape_path(test_string, strlen(test_string)), ec) == test_string); TEST_CHECK(unescape_string(escape_path(test_string, strlen(test_string)), ec) == test_string);
TEST_CHECK(!ec); TEST_CHECK(!ec);
if (ec) fprintf(stderr, "%s\n", ec.message().c_str());
// need_encoding // need_encoding
char const* test_string2 = "!@$&()-_/,.%?"; char const* test_string2 = "!@$&()-_/,.%?";
@ -1197,6 +1213,27 @@ int test_main()
TEST_CHECK(unescape_string(escape_string(test_string, strlen(test_string)), ec) TEST_CHECK(unescape_string(escape_string(test_string, strlen(test_string)), ec)
== test_string); == test_string);
std::cerr << unescape_string(escape_string(test_string, strlen(test_string)), ec) << std::endl; std::cerr << unescape_string(escape_string(test_string, strlen(test_string)), ec) << std::endl;
// prematurely terminated string
unescape_string("%", ec);
TEST_CHECK(ec == error_code(errors::invalid_escaped_string));
unescape_string("%0", ec);
TEST_CHECK(ec == error_code(errors::invalid_escaped_string));
// invalid hex character
unescape_string("%GE", ec);
TEST_CHECK(ec == error_code(errors::invalid_escaped_string));
unescape_string("%eg", ec);
TEST_CHECK(ec == error_code(errors::invalid_escaped_string));
ec.clear();
std::string path = "a\\b\\c";
convert_path_to_posix(path);
TEST_EQUAL(path, "a/b/c");
#ifdef TORRENT_WINDOWS
convert_path_to_windows(path);
TEST_EQUAL(path, "a\\b\\c");
#endif
// verify_encoding // verify_encoding
test = "\b?filename=4"; test = "\b?filename=4";
@ -1219,6 +1256,7 @@ int test_main()
TEST_CHECK(f.open("test_file", file::read_write, ec)); TEST_CHECK(f.open("test_file", file::read_write, ec));
#endif #endif
TEST_CHECK(!ec); TEST_CHECK(!ec);
if (ec) fprintf(stderr, "%s\n", ec.message().c_str());
file::iovec_t b = {(void*)"test", 4}; file::iovec_t b = {(void*)"test", 4};
TEST_CHECK(f.writev(0, &b, 1, ec) == 4); TEST_CHECK(f.writev(0, &b, 1, ec) == 4);
TEST_CHECK(!ec); TEST_CHECK(!ec);