mirror of
https://github.com/boostorg/url.git
synced 2026-01-22 17:52:25 +00:00
256 lines
6.6 KiB
C++
256 lines
6.6 KiB
C++
//
|
|
// Copyright (c) 2019 Vinnie Falco (vinnie.falco@gmail.com)
|
|
//
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
//
|
|
// Official repository: https://github.com/CPPAlliance/url
|
|
//
|
|
|
|
// Test that header file is self-contained.
|
|
#include <boost/url/params_view.hpp>
|
|
|
|
#include <boost/url/url_view.hpp>
|
|
#include <boost/url/static_pool.hpp>
|
|
#include "test_suite.hpp"
|
|
|
|
namespace boost {
|
|
namespace urls {
|
|
|
|
class params_view_test
|
|
{
|
|
public:
|
|
using pool_t = static_pool<4096>;
|
|
pool_t pa;
|
|
|
|
void
|
|
testMembers()
|
|
{
|
|
// default constructor
|
|
{
|
|
params_view ps;
|
|
BOOST_TEST(ps.empty());
|
|
BOOST_TEST_EQ(ps.size(), 0u);
|
|
BOOST_TEST(
|
|
ps.begin() == ps.end());
|
|
}
|
|
|
|
// operator=(params_view const&)
|
|
{
|
|
url_view u1;
|
|
url_view u2;
|
|
params_view p1 = u1.params();
|
|
params_view p2 = u2.params();
|
|
p2 = p1;
|
|
BOOST_TEST_EQ(p1.begin(), p2.begin());
|
|
}
|
|
}
|
|
|
|
void
|
|
testElements()
|
|
{
|
|
// at(string_view)
|
|
// at(Key)
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"?k0=0&k1=1&k2=&k3&k4=4444#f").value();
|
|
params_view p = u.params();
|
|
BOOST_TEST_EQ(p.at("k0"), "0");
|
|
BOOST_TEST_EQ(p.at("k1"), "1");
|
|
BOOST_TEST_EQ(p.at("k2"), "");
|
|
BOOST_TEST_THROWS(p.at("k3") == "0",
|
|
std::out_of_range);
|
|
BOOST_TEST_EQ(p.at("k4"), "4444");
|
|
BOOST_TEST_THROWS(p.at("k5"),
|
|
std::out_of_range);
|
|
}
|
|
}
|
|
|
|
void
|
|
testCapacity()
|
|
{
|
|
// empty
|
|
// size
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"?k0=0&k1=1&k2=&k3&k4=4444#f").value();
|
|
params_view p = u.params();
|
|
BOOST_TEST(! p.empty());
|
|
BOOST_TEST_EQ(p.size(), 5u);
|
|
}
|
|
{
|
|
url_view u;
|
|
params_view p = u.params();
|
|
BOOST_TEST(p.empty());
|
|
BOOST_TEST_EQ(p.size(), 0u);
|
|
}
|
|
}
|
|
|
|
void
|
|
testLookup()
|
|
{
|
|
// count(string_view)
|
|
// count(Key)
|
|
// find(string_view)
|
|
// find(Key)
|
|
// find(iterator, string_view)
|
|
// find(iterator, Key)
|
|
// contains(string_view)
|
|
// contains(Key)
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"/?a=1&%62=2&c=3&c=4&c=5&d=6&e=7&d=8&f=9#f").value();
|
|
params_view p = u.params();
|
|
BOOST_TEST_EQ(p.count("a"), 1u);
|
|
BOOST_TEST_EQ(p.count("b"), 1u);
|
|
BOOST_TEST_EQ(p.count("c"), 3u);
|
|
BOOST_TEST_EQ(p.count("d"), 2u);
|
|
BOOST_TEST_EQ(p.count("e"), 1u);
|
|
BOOST_TEST_EQ(p.count("f"), 1u);
|
|
BOOST_TEST_EQ(p.count("g"), 0u);
|
|
|
|
BOOST_TEST(p.find("b") ==
|
|
std::next(p.begin()));
|
|
BOOST_TEST(p.find(
|
|
std::next(p.begin(), 6), "d") ==
|
|
std::next(p.begin(), 7));
|
|
|
|
BOOST_TEST(p.contains("a"));
|
|
BOOST_TEST(p.contains("b"));
|
|
BOOST_TEST(p.contains("c"));
|
|
BOOST_TEST(p.contains("d"));
|
|
BOOST_TEST(p.contains("e"));
|
|
BOOST_TEST(p.contains("f"));
|
|
BOOST_TEST(! p.contains("g"));
|
|
}
|
|
}
|
|
|
|
void
|
|
testIterators()
|
|
{
|
|
// operator++
|
|
// operator++(int)
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"/?a=1&bb=22&ccc=333&dddd=4444#f").value();
|
|
params_view p = u.params();
|
|
auto it = p.begin();
|
|
BOOST_TEST_EQ((*it).key, "a");
|
|
BOOST_TEST_EQ((*++it).key, "bb");
|
|
BOOST_TEST_EQ((*it++).key, "bb");
|
|
BOOST_TEST_EQ((*it).key, "ccc");
|
|
auto it2 = p.end();
|
|
BOOST_TEST_EQ(it2, p.end());
|
|
BOOST_TEST_NE(it, it2);
|
|
}
|
|
|
|
// operator*
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"/?&x&y=&z=3#f").value();
|
|
params_view p = u.params();
|
|
BOOST_TEST_EQ(p.size(), 4u);
|
|
auto it = p.begin();
|
|
|
|
params_view::value_type v;
|
|
|
|
v = *it++;
|
|
BOOST_TEST_EQ(v.key, "");
|
|
BOOST_TEST_EQ(v.value, "");
|
|
BOOST_TEST_EQ(v.has_value, false);
|
|
|
|
v = *it++;
|
|
BOOST_TEST_EQ(v.key, "x");
|
|
BOOST_TEST_EQ(v.value, "");
|
|
BOOST_TEST_EQ(v.has_value, false);
|
|
|
|
v = *it++;
|
|
BOOST_TEST_EQ(v.key, "y");
|
|
BOOST_TEST_EQ(v.value, "");
|
|
BOOST_TEST_EQ(v.has_value, true);
|
|
|
|
v = *it++;
|
|
BOOST_TEST_EQ(v.key, "z");
|
|
BOOST_TEST_EQ(v.value, "3");
|
|
BOOST_TEST_EQ(v.has_value, true);
|
|
}
|
|
|
|
// value_type outlives reference
|
|
{
|
|
url_view u = parse_uri_reference(
|
|
"/?a=1&bb=22&ccc=333&dddd=4444#f").value();
|
|
params_view::value_type v;
|
|
{
|
|
params_view ps = u.params();
|
|
params_view::reference r = *ps.begin();
|
|
v = params_view::value_type(r);
|
|
}
|
|
BOOST_TEST_EQ(v.key, "a");
|
|
BOOST_TEST_EQ(v.value, "1");
|
|
BOOST_TEST_EQ(v.has_value, true);
|
|
}
|
|
}
|
|
|
|
void
|
|
testEncoding()
|
|
{
|
|
{
|
|
params_view u = parse_query_params(
|
|
"a=1&b=2+2&c=%61%70%70%6c%65").value().decoded();
|
|
BOOST_TEST_EQ(u.at("b"), "2 2");
|
|
BOOST_TEST_EQ(u.at("c"), "apple");
|
|
}
|
|
}
|
|
|
|
void
|
|
testRange()
|
|
{
|
|
// issue 129
|
|
// empty range iterates once
|
|
{
|
|
url_view u = parse_uri(
|
|
"http://example.com/index.htm").value();
|
|
auto const r = u.params();
|
|
BOOST_TEST(
|
|
r.begin() == r.end());
|
|
}
|
|
}
|
|
|
|
void
|
|
testEmpty()
|
|
{
|
|
// issue 129
|
|
// empty range iterates once
|
|
{
|
|
url_view u( "x:?" );
|
|
auto const v = u.params();
|
|
auto it = v.begin();
|
|
auto t = *it++;
|
|
BOOST_TEST(it == v.end());
|
|
BOOST_TEST(t.has_value == false);
|
|
BOOST_TEST(t.key.empty());
|
|
BOOST_TEST(t.value.empty());
|
|
}
|
|
}
|
|
|
|
void
|
|
run()
|
|
{
|
|
testMembers();
|
|
testElements();
|
|
testCapacity();
|
|
testLookup();
|
|
testIterators();
|
|
testEncoding();
|
|
testRange();
|
|
testEmpty();
|
|
}
|
|
};
|
|
|
|
TEST_SUITE(
|
|
params_view_test,
|
|
"boost.url.params_view");
|
|
|
|
} // urls
|
|
} // boost
|