From 6232d13f5321b87ddf12a1aa36b4545da45f173d Mon Sep 17 00:00:00 2001 From: Joel Klinghed Date: Wed, 17 Nov 2021 22:34:57 +0100 Subject: Travel3: Simple image and video display site Reads the images and videos from filesystem and builds a site in memroy. --- test/test_urlutil.cc | 95 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 95 insertions(+) create mode 100644 test/test_urlutil.cc (limited to 'test/test_urlutil.cc') diff --git a/test/test_urlutil.cc b/test/test_urlutil.cc new file mode 100644 index 0000000..583370d --- /dev/null +++ b/test/test_urlutil.cc @@ -0,0 +1,95 @@ +#include "common.hh" + +#include "urlutil.hh" + +#include + +TEST(urlutil, escape) { + EXPECT_EQ("", url::escape("")); + EXPECT_EQ("foo", url::escape("foo")); + EXPECT_EQ("%2Ffoo%2F", url::escape("/foo/")); + EXPECT_EQ("%252Ffoo%252F", url::escape("%2Ffoo%2F")); + EXPECT_EQ("%FF%00", url::escape(std::string_view("\xff\x00", 2))); + EXPECT_EQ("/foo%20bar/", url::escape("/foo bar/", + url::EscapeFlags::KEEP_SLASH)); +} + +TEST(urlutil, unescape) { + EXPECT_EQ("", url::unescape("")); + EXPECT_EQ("foo", url::unescape("foo")); + EXPECT_EQ("/foo/", url::unescape("%2Ffoo%2F")); + EXPECT_EQ("%2Ffoo%2F", url::unescape("%252Ffoo%252F")); + EXPECT_EQ(std::string_view("\xff\x00", 2), url::unescape("%FF%00")); +} + +TEST(urlutil, unescape_invalid) { + EXPECT_EQ("%", url::unescape("%")); + EXPECT_EQ("%2", url::unescape("%2")); + EXPECT_EQ("%2X", url::unescape("%2X")); + EXPECT_EQ("%X2", url::unescape("%X2")); + EXPECT_EQ("%%%%%", url::unescape("%%%%%")); +} + +TEST(urlutil, expand_and_unescape_query) { + auto ret = url::expand_and_unescape_query(""); + EXPECT_TRUE(ret.empty()); + + ret = url::expand_and_unescape_query("foo=bar"); + EXPECT_EQ(1, ret.size()); + EXPECT_EQ("bar", ret["foo"]); + + ret = url::expand_and_unescape_query("foo=bar&fum&a=&foo"); + EXPECT_EQ(3, ret.size()); + EXPECT_EQ("bar", ret["foo"]); + EXPECT_EQ("", ret["fum"]); + EXPECT_EQ("", ret["a"]); + + ret = url::expand_and_unescape_query("foo=b%20a%20r&bar=f+o+o"); + EXPECT_EQ(2, ret.size()); + EXPECT_EQ("b a r", ret["foo"]); + EXPECT_EQ("f o o", ret["bar"]); + + ret = url::expand_and_unescape_query("foo=%26amp%3B&%3D=%25"); + EXPECT_EQ(2, ret.size()); + EXPECT_EQ("&", ret["foo"]); + EXPECT_EQ("%", ret["="]); + + ret = url::expand_and_unescape_query("="); + EXPECT_EQ(1, ret.size()); + EXPECT_EQ("", ret[""]); + + ret = url::expand_and_unescape_query("&&=&=&&"); + EXPECT_EQ(1, ret.size()); + EXPECT_EQ("", ret[""]); + + ret = url::expand_and_unescape_query("====="); + EXPECT_EQ(1, ret.size()); + EXPECT_EQ("====", ret[""]); +} + +TEST(urlutil, split_and_unescape_path_and_query) { + std::string path; + std::unordered_map query; + + url::split_and_unescape_path_and_query("", path, query); + EXPECT_EQ("", path); + EXPECT_TRUE(query.empty()); + + url::split_and_unescape_path_and_query("foo", path, query); + EXPECT_EQ("foo", path); + EXPECT_TRUE(query.empty()); + + url::split_and_unescape_path_and_query("?foo=bar", path, query); + EXPECT_EQ("", path); + EXPECT_EQ(1, query.size()); + EXPECT_EQ("bar", query["foo"]); + + url::split_and_unescape_path_and_query("foo?foo=bar", path, query); + EXPECT_EQ("foo", path); + EXPECT_EQ(1, query.size()); + EXPECT_EQ("bar", query["foo"]); + + url::split_and_unescape_path_and_query("%3F%3F%3D", path, query); + EXPECT_EQ("\?\?=", path); + EXPECT_TRUE(query.empty()); +} -- cgit v1.2.3-70-g09d2