2
0
mirror of https://github.com/boostorg/url.git synced 2026-01-20 05:02:43 +00:00
Files
url/test/unit/segments_encoded_view.cpp
2025-11-04 19:07:09 -05:00

208 lines
5.7 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/boostorg/url
//
// Test that header file is self-contained.
#include <boost/url/segments_encoded_view.hpp>
#include <boost/url/parse.hpp>
#include <boost/url/parse_path.hpp>
#include <boost/url/url_view.hpp>
#include <boost/core/detail/static_assert.hpp>
#include <boost/core/ignore_unused.hpp>
#include "test_suite.hpp"
#include <sstream>
#include <string>
#ifdef assert
#undef assert
#endif
#define assert BOOST_TEST
namespace boost {
namespace urls {
BOOST_CORE_STATIC_ASSERT(
std::is_default_constructible<
segments_encoded_view>::value);
BOOST_CORE_STATIC_ASSERT(
std::is_copy_constructible<
segments_encoded_view>::value);
BOOST_CORE_STATIC_ASSERT(
std::is_copy_assignable<
segments_encoded_view>::value);
BOOST_CORE_STATIC_ASSERT(
std::is_default_constructible<
segments_encoded_view::iterator>::value);
struct segments_const_encoded_view_test
{
void
testSpecialMembers()
{
// segments_encoded_view()
{
segments_encoded_view ps;
BOOST_TEST(ps.empty());
BOOST_TEST(! ps.is_absolute());
BOOST_TEST_EQ(ps.buffer(), "");
BOOST_TEST_EQ(ps.size(), 0);
}
// segments_encoded_view(segments_encoded_view)
{
segments_encoded_view ps0 =
parse_path("/path/to/file.txt").value();
segments_encoded_view ps1(ps0);
BOOST_TEST_EQ(
ps0.buffer().data(),
ps1.buffer().data());
}
// segments_encoded_view(core::string_view)
{
try
{
core::string_view s = "/path/to/file.txt";
segments_encoded_view ps(s);
BOOST_TEST_PASS();
BOOST_TEST_EQ(
ps.buffer().data(), s.data());
BOOST_TEST_EQ(ps.buffer(), s);
}
catch(std::exception const&)
{
BOOST_TEST_FAIL();
}
// reserved character
BOOST_TEST_THROWS(segments_encoded_view("?"), system::system_error);
// invalid percent-escape
BOOST_TEST_THROWS(segments_encoded_view("%"), system::system_error);
BOOST_TEST_THROWS(segments_encoded_view("%F"), system::system_error);
BOOST_TEST_THROWS(segments_encoded_view("%FX"), system::system_error);
BOOST_TEST_THROWS(segments_encoded_view("%%"), system::system_error);
BOOST_TEST_THROWS(segments_encoded_view("FA%"), system::system_error);
}
// segments_encoded_view(iterator, iterator)
{
segments_encoded_view ps = parse_path("/a/b/c").value();
auto first = std::next(ps.begin());
auto last = ps.end();
segments_encoded_view sub(first, last);
BOOST_TEST_EQ(sub.size(), 2u);
BOOST_TEST(sub.is_absolute());
BOOST_TEST_EQ(sub.buffer(), "/b/c");
auto it = sub.begin();
BOOST_TEST_EQ(*it++, "b");
BOOST_TEST_EQ(*it++, "c");
BOOST_TEST(it == sub.end());
}
// relative source: mid slices become absolute
{
segments_encoded_view ps = parse_path("a/b/c").value();
segments_encoded_view head(ps.begin(), std::next(ps.begin()));
BOOST_TEST(!head.is_absolute());
BOOST_TEST_EQ(head.buffer(), "a");
segments_encoded_view tail(std::next(ps.begin()), ps.end());
BOOST_TEST(tail.is_absolute());
BOOST_TEST_EQ(tail.buffer(), "/b/c");
std::string rebuilt(
head.buffer().data(),
head.buffer().size());
rebuilt.append(
tail.buffer().data(),
tail.buffer().size());
BOOST_TEST_EQ(rebuilt, ps.buffer());
BOOST_TEST_EQ(
head.buffer().decoded_size() +
tail.buffer().decoded_size(),
ps.buffer().decoded_size());
}
// operator=(segments_encoded_view)
{
segments_encoded_view ps0("/path/to/file.txt");
segments_encoded_view ps1("/index.htm");
ps0 = ps1;
BOOST_TEST_EQ(
ps0.buffer().data(),
ps1.buffer().data());
}
// operator segments_view()
{
segments_encoded_view ps0 =
parse_path( "/path/to/file.txt" ).value();
segments_view ps1(ps0);
BOOST_TEST_EQ(
ps0.buffer().data(),
ps1.buffer().data());
}
// ostream
{
segments_encoded_view ps = parse_path(
"/path/to/file.txt").value();
std::stringstream ss;
ss << ps;
BOOST_TEST_EQ(ss.str(),
"/path/to/file.txt");
}
}
void
testJavadocs()
{
// {class}
{
url_view u( "/path/to/file.txt" );
segments_encoded_view ps = u.encoded_segments();
assert( ps.buffer().data() == u.buffer().data() );
ignore_unused(ps);
}
// operator segments_view()
{
segments_view ps = parse_path( "/path/to/file.txt" ).value();
ignore_unused(ps);
}
}
void
run()
{
testSpecialMembers();
testJavadocs();
}
};
TEST_SUITE(
segments_const_encoded_view_test,
"boost.url.segments_encoded_view");
} // urls
} // boost