summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMax Wipfli <mail@maxwipfli.ch>2021-05-29 21:52:13 +0200
committerAndreas Kling <kling@serenityos.org>2021-06-01 09:28:05 +0200
commitc7857f35729ac898d4efcb3e50ccefce6f4db9bb (patch)
treed133829c80026554940d212dd9024cffdaf556e1
parentebf074ca2980316b6071e504bba524af2d55ae01 (diff)
downloadserenity-c7857f35729ac898d4efcb3e50ccefce6f4db9bb.zip
Tests: Add more tests for AK::URL
This adds more tests for AK::URL. Furthermore, this also changes some tests to conform to what the reworked URL class does (and the URL specification mostly expects).
-rw-r--r--Tests/AK/TestURL.cpp223
1 files changed, 165 insertions, 58 deletions
diff --git a/Tests/AK/TestURL.cpp b/Tests/AK/TestURL.cpp
index c92ee4fc5b..3fd1413f1d 100644
--- a/Tests/AK/TestURL.cpp
+++ b/Tests/AK/TestURL.cpp
@@ -18,37 +18,37 @@ TEST_CASE(basic)
{
URL url("http://www.serenityos.org");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "http");
+ EXPECT_EQ(url.scheme(), "http");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 80);
EXPECT_EQ(url.path(), "/");
- EXPECT_EQ(url.query(), "");
- EXPECT_EQ(url.fragment(), "");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
}
{
URL url("https://www.serenityos.org/index.html");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "https");
+ EXPECT_EQ(url.scheme(), "https");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 443);
EXPECT_EQ(url.path(), "/index.html");
- EXPECT_EQ(url.query(), "");
- EXPECT_EQ(url.fragment(), "");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
}
{
URL url("https://localhost:1234/~anon/test/page.html");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "https");
+ EXPECT_EQ(url.scheme(), "https");
EXPECT_EQ(url.host(), "localhost");
EXPECT_EQ(url.port(), 1234);
EXPECT_EQ(url.path(), "/~anon/test/page.html");
- EXPECT_EQ(url.query(), "");
- EXPECT_EQ(url.fragment(), "");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
}
{
URL url("http://www.serenityos.org/index.html?#");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "http");
+ EXPECT_EQ(url.scheme(), "http");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 80);
EXPECT_EQ(url.path(), "/index.html");
@@ -58,27 +58,27 @@ TEST_CASE(basic)
{
URL url("http://www.serenityos.org/index.html?foo=1&bar=2");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "http");
+ EXPECT_EQ(url.scheme(), "http");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 80);
EXPECT_EQ(url.path(), "/index.html");
EXPECT_EQ(url.query(), "foo=1&bar=2");
- EXPECT_EQ(url.fragment(), "");
+ EXPECT(url.fragment().is_null());
}
{
URL url("http://www.serenityos.org/index.html#fragment");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "http");
+ EXPECT_EQ(url.scheme(), "http");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 80);
EXPECT_EQ(url.path(), "/index.html");
- EXPECT_EQ(url.query(), "");
+ EXPECT(url.query().is_null());
EXPECT_EQ(url.fragment(), "fragment");
}
{
URL url("http://www.serenityos.org/index.html?foo=1&bar=2&baz=/?#frag/ment?test#");
EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "http");
+ EXPECT_EQ(url.scheme(), "http");
EXPECT_EQ(url.host(), "www.serenityos.org");
EXPECT_EQ(url.port(), 80);
EXPECT_EQ(url.path(), "/index.html");
@@ -89,10 +89,7 @@ TEST_CASE(basic)
TEST_CASE(some_bad_urls)
{
- EXPECT_EQ(URL("http:serenityos.org").is_valid(), false);
- EXPECT_EQ(URL("http:/serenityos.org").is_valid(), false);
EXPECT_EQ(URL("http//serenityos.org").is_valid(), false);
- EXPECT_EQ(URL("http:///serenityos.org").is_valid(), false);
EXPECT_EQ(URL("serenityos.org").is_valid(), false);
EXPECT_EQ(URL("://serenityos.org").is_valid(), false);
EXPECT_EQ(URL("://:80").is_valid(), false);
@@ -101,90 +98,154 @@ TEST_CASE(some_bad_urls)
EXPECT_EQ(URL("http://serenityos.org:abc").is_valid(), false);
EXPECT_EQ(URL("http://serenityos.org:abc:80").is_valid(), false);
EXPECT_EQ(URL("http://serenityos.org:abc:80/").is_valid(), false);
- EXPECT_EQ(URL("http://serenityos.org:/abc/").is_valid(), false);
EXPECT_EQ(URL("data:").is_valid(), false);
- EXPECT_EQ(URL("file:").is_valid(), false);
- EXPECT_EQ(URL("about:").is_valid(), false);
}
TEST_CASE(serialization)
{
- EXPECT_EQ(URL("http://www.serenityos.org/").to_string(), "http://www.serenityos.org/");
- EXPECT_EQ(URL("http://www.serenityos.org:0/").to_string(), "http://www.serenityos.org/");
- EXPECT_EQ(URL("http://www.serenityos.org:80/").to_string(), "http://www.serenityos.org/");
- EXPECT_EQ(URL("http://www.serenityos.org:81/").to_string(), "http://www.serenityos.org:81/");
- EXPECT_EQ(URL("https://www.serenityos.org:443/foo/bar.html?query#fragment").to_string(), "https://www.serenityos.org/foo/bar.html?query#fragment");
+ EXPECT_EQ(URL("http://www.serenityos.org/").serialize(), "http://www.serenityos.org/");
+ EXPECT_EQ(URL("http://www.serenityos.org:0/").serialize(), "http://www.serenityos.org/");
+ EXPECT_EQ(URL("http://www.serenityos.org:80/").serialize(), "http://www.serenityos.org/");
+ EXPECT_EQ(URL("http://www.serenityos.org:81/").serialize(), "http://www.serenityos.org:81/");
+ EXPECT_EQ(URL("https://www.serenityos.org:443/foo/bar.html?query#fragment").serialize(), "https://www.serenityos.org/foo/bar.html?query#fragment");
}
TEST_CASE(file_url_with_hostname)
{
+ URL url("file://courage/my/file");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.host(), "courage");
+ EXPECT_EQ(url.port(), 0);
+ EXPECT_EQ(url.path(), "/my/file");
+ EXPECT_EQ(url.serialize(), "file://courage/my/file");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
+}
+
+TEST_CASE(file_url_with_localhost)
+{
URL url("file://localhost/my/file");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.host(), "localhost");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.host(), "");
EXPECT_EQ(url.path(), "/my/file");
- EXPECT_EQ(url.to_string(), "file://localhost/my/file");
+ EXPECT_EQ(url.serialize(), "file:///my/file");
}
TEST_CASE(file_url_without_hostname)
{
URL url("file:///my/file");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "file");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
EXPECT_EQ(url.host(), "");
EXPECT_EQ(url.path(), "/my/file");
- EXPECT_EQ(url.to_string(), "file:///my/file");
+ EXPECT_EQ(url.serialize(), "file:///my/file");
+}
+
+TEST_CASE(file_url_with_encoded_characters)
+{
+ URL url("file:///my/file/test%23file.txt");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.path(), "/my/file/test#file.txt");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
+}
+
+TEST_CASE(file_url_with_fragment)
+{
+ URL url("file:///my/file#fragment");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.path(), "/my/file");
+ EXPECT(url.query().is_null());
+ EXPECT_EQ(url.fragment(), "fragment");
+}
+
+TEST_CASE(file_url_with_root_path)
+{
+ URL url("file:///");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.path(), "/");
+}
+
+TEST_CASE(file_url_serialization)
+{
+ EXPECT_EQ(URL("file://courage/my/file").serialize(), "file://courage/my/file");
+ EXPECT_EQ(URL("file://localhost/my/file").serialize(), "file:///my/file");
+ EXPECT_EQ(URL("file:///my/file").serialize(), "file:///my/file");
+ EXPECT_EQ(URL("file:///my/directory/").serialize(), "file:///my/directory/");
+ EXPECT_EQ(URL("file:///my/file%23test").serialize(), "file:///my/file%23test");
+ EXPECT_EQ(URL("file:///my/file#fragment").serialize(), "file:///my/file#fragment");
}
TEST_CASE(about_url)
{
URL url("about:blank");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "about");
- EXPECT_EQ(url.host(), "");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "about");
+ EXPECT(url.host().is_null());
EXPECT_EQ(url.path(), "blank");
- EXPECT_EQ(url.to_string(), "about:blank");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
+ EXPECT_EQ(url.serialize(), "about:blank");
+}
+
+TEST_CASE(mailto_url)
+{
+ URL url("mailto:mail@example.com");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "mailto");
+ EXPECT(url.host().is_null());
+ EXPECT_EQ(url.port(), 0);
+ EXPECT_EQ(url.paths().size(), 1u);
+ EXPECT_EQ(url.paths()[0], "mail@example.com");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
+ EXPECT_EQ(url.serialize(), "mailto:mail@example.com");
}
TEST_CASE(data_url)
{
URL url("data:text/html,test");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "data");
- EXPECT_EQ(url.host(), "");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "data");
+ EXPECT(url.host().is_null());
EXPECT_EQ(url.data_mime_type(), "text/html");
EXPECT_EQ(url.data_payload(), "test");
- EXPECT_EQ(url.to_string(), "data:text/html,test");
+ EXPECT_EQ(url.serialize(), "data:text/html,test");
}
TEST_CASE(data_url_encoded)
{
URL url("data:text/html,Hello%20friends%2C%0X%X0");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "data");
- EXPECT_EQ(url.host(), "");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "data");
+ EXPECT(url.host().is_null());
EXPECT_EQ(url.data_mime_type(), "text/html");
EXPECT_EQ(url.data_payload(), "Hello friends,%0X%X0");
- // FIXME: Surely this should be URL-encoded again?!
- EXPECT_EQ(url.to_string(), "data:text/html,Hello friends,%0X%X0");
+ EXPECT_EQ(url.serialize(), "data:text/html,Hello friends,%0X%X0");
}
TEST_CASE(data_url_base64_encoded)
{
URL url("data:text/html;base64,test");
- EXPECT_EQ(url.is_valid(), true);
- EXPECT_EQ(url.protocol(), "data");
- EXPECT_EQ(url.host(), "");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "data");
+ EXPECT(url.host().is_null());
EXPECT_EQ(url.data_mime_type(), "text/html");
EXPECT_EQ(url.data_payload(), "test");
- EXPECT_EQ(url.to_string(), "data:text/html;base64,test");
+ EXPECT_EQ(url.serialize(), "data:text/html;base64,test");
}
TEST_CASE(trailing_slash_with_complete_url)
{
- EXPECT_EQ(URL("http://a/b/").complete_url("c/").to_string(), "http://a/b/c/");
- EXPECT_EQ(URL("http://a/b/").complete_url("c").to_string(), "http://a/b/c");
- EXPECT_EQ(URL("http://a/b").complete_url("c/").to_string(), "http://a/c/");
- EXPECT_EQ(URL("http://a/b").complete_url("c").to_string(), "http://a/c");
+ EXPECT_EQ(URL("http://a/b/").complete_url("c/").serialize(), "http://a/b/c/");
+ EXPECT_EQ(URL("http://a/b/").complete_url("c").serialize(), "http://a/b/c");
+ EXPECT_EQ(URL("http://a/b").complete_url("c/").serialize(), "http://a/c/");
+ EXPECT_EQ(URL("http://a/b").complete_url("c").serialize(), "http://a/c");
}
TEST_CASE(trailing_port)
@@ -193,10 +254,56 @@ TEST_CASE(trailing_port)
EXPECT_EQ(url.port(), 8086);
}
-TEST_CASE(port_int_overflow_wrap)
+TEST_CASE(port_overflow)
+{
+ EXPECT_EQ(URL("http://example.com:123456789/").is_valid(), false);
+}
+
+TEST_CASE(equality)
+{
+ EXPECT(URL("http://serenityos.org").equals("http://serenityos.org#test", URL::ExcludeFragment::Yes));
+ EXPECT_EQ(URL("http://example.com/index.html"), URL("http://ex%61mple.com/index.html"));
+ EXPECT_EQ(URL("file:///my/file"), URL("file://localhost/my/file"));
+ EXPECT_NE(URL("http://serenityos.org/index.html"), URL("http://serenityos.org/test.html"));
+}
+
+TEST_CASE(create_with_file_scheme)
{
- auto expected_port = 80;
- URL url(String::formatted("http://example.com:{}/", (u32)((65536 * 1000) + expected_port)));
- EXPECT_EQ(url.port(), expected_port);
- EXPECT_EQ(url.is_valid(), true);
+ auto url = URL::create_with_file_scheme("/home/anon/README.md");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "file");
+ EXPECT_EQ(url.port(), 0);
+ EXPECT_EQ(url.paths().size(), 3u);
+ EXPECT_EQ(url.paths()[0], "home");
+ EXPECT_EQ(url.paths()[1], "anon");
+ EXPECT_EQ(url.paths()[2], "README.md");
+ EXPECT_EQ(url.path(), "/home/anon/README.md");
+ EXPECT(url.query().is_null());
+ EXPECT(url.fragment().is_null());
+
+ url = URL::create_with_file_scheme("/home/anon/");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.paths().size(), 3u);
+ EXPECT_EQ(url.paths()[0], "home");
+ EXPECT_EQ(url.paths()[1], "anon");
+ EXPECT_EQ(url.paths()[2], "");
+ EXPECT_EQ(url.path(), "/home/anon/");
+
+ url = URL("file:///home/anon/");
+ EXPECT_EQ(url.path(), "/home/anon/");
+}
+
+TEST_CASE(complete_url)
+{
+ URL base_url("http://serenityos.org/index.html#fragment");
+ URL url = base_url.complete_url("test.html");
+ EXPECT(url.is_valid());
+ EXPECT_EQ(url.scheme(), "http");
+ EXPECT_EQ(url.host(), "serenityos.org");
+ EXPECT_EQ(url.path(), "/test.html");
+ EXPECT(url.query().is_null());
+ EXPECT(url.query().is_null());
+ EXPECT_EQ(url.cannot_be_a_base_url(), false);
+
+ EXPECT(base_url.complete_url("../index.html#fragment").equals(base_url));
}