Commit 2c3eb5b8 authored by Max Kellermann's avatar Max Kellermann

test/TestUriRelative: new unit test

parent 58363cf4
/*
* Unit tests for src/util/UriRelative.hxx
*/
#include "util/UriRelative.hxx"
#include <gtest/gtest.h>
TEST(UriRelative, IsChild)
{
static constexpr struct {
const char *parent;
const char *child;
bool is_child;
bool is_child_or_same;
} tests[] = {
{ "/foo", "/foo", false, true },
{ "/foo", "/foo/bar", true, true },
{ "/foo/", "/foo/bar", true, true },
{ "/foo/", "/foo/", false, true },
{ "/foo/", "/foo", false, false },
{ "/bar", "/foo", false, false },
{ "/foo", "/foobar", false, false },
};
for (const auto &i : tests) {
EXPECT_EQ(uri_is_child(i.parent, i.child), i.is_child);
EXPECT_EQ(uri_is_child_or_same(i.parent, i.child),
i.is_child_or_same);
}
}
TEST(UriRelative, ApplyBase)
{
static constexpr struct {
const char *uri;
const char *base;
const char *result;
} tests[] = {
{ "foo", "bar", "bar/foo" },
{ "foo", "/bar", "/bar/foo" },
{ "/foo", "/bar", "/foo" },
{ "/foo", "bar", "/foo" },
{ "/foo", "http://localhost/bar", "http://localhost/foo" },
{ "/foo", "http://localhost/", "http://localhost/foo" },
{ "/foo", "http://localhost", "http://localhost/foo" },
};
for (const auto &i : tests) {
EXPECT_STREQ(uri_apply_base(i.uri, i.base).c_str(), i.result);
}
}
......@@ -39,6 +39,7 @@ test('TestUtil', executable(
'TestSplitString.cxx',
'TestUriExtract.cxx',
'TestUriQueryParser.cxx',
'TestUriRelative.cxx',
'TestUriUtil.cxx',
'test_byte_reverse.cxx',
include_directories: inc,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment