diff options
author | John Turner <jturner.usa@gmail.com> | 2025-09-14 00:16:10 -0400 |
---|---|---|
committer | John Turner <jturner.usa@gmail.com> | 2025-09-14 00:16:10 -0400 |
commit | 13e0821fd783a1d5083d825af53cf20e8dcbfd76 (patch) | |
tree | 1ea363b0f13b3e87d177100e6ae6b9f30a2de1b8 /subprojects/boost-sqlite/test/collation.cpp | |
parent | aa55cb93036a89c64c08e08f4e1de4fa1fd5a775 (diff) | |
parent | efcea3a80da7c4479d5fe168435ecc9fd06bdc72 (diff) | |
download | sqlite-kv-bench-13e0821fd783a1d5083d825af53cf20e8dcbfd76.tar.gz |
Merge commit 'efcea3a80da7c4479d5fe168435ecc9fd06bdc72' as 'subprojects/boost-sqlite'
Diffstat (limited to 'subprojects/boost-sqlite/test/collation.cpp')
-rw-r--r-- | subprojects/boost-sqlite/test/collation.cpp | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/subprojects/boost-sqlite/test/collation.cpp b/subprojects/boost-sqlite/test/collation.cpp new file mode 100644 index 0000000..8893e42 --- /dev/null +++ b/subprojects/boost-sqlite/test/collation.cpp @@ -0,0 +1,45 @@ +// +// Copyright (c) 2022 Klemens Morgenstern (klemens.morgenstern@gmx.net) +// +// 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) +// + +#include <boost/sqlite/collation.hpp> +#include <string> +#include <vector> + +#include "test.hpp" + +using namespace boost; + +struct collate_length +{ + int operator()(core::string_view l, core::string_view r) noexcept + { + return std::stoull(r) - l.size(); + } +}; + +BOOST_AUTO_TEST_CASE(collation) +{ + sqlite::connection conn(":memory:"); + conn.execute( +#include "test-db.sql" + ); + + sqlite::create_collation(conn, "length", collate_length{}); + + std::vector<std::string> names; + + // language=sqlite + for (auto r : conn.query("select first_name from author where first_name = 5 collate length order by last_name asc;")) + names.emplace_back(r.at(0).get_text()); + + std::vector<std::string> cmp = {"peter", "ruben"}; + BOOST_CHECK(names == cmp); + + sqlite::delete_collation(conn, "length"); + + BOOST_CHECK_THROW(conn.query("select first_name from author where first_name = 5 collate length order by last_name asc;"), system::system_error); +}
\ No newline at end of file |