summaryrefslogtreecommitdiff
path: root/subprojects/boost-sqlite/test/collation.cpp
diff options
context:
space:
mode:
authorJohn Turner <jturner.usa@gmail.com>2025-09-14 00:16:10 -0400
committerJohn Turner <jturner.usa@gmail.com>2025-09-14 00:16:10 -0400
commit13e0821fd783a1d5083d825af53cf20e8dcbfd76 (patch)
tree1ea363b0f13b3e87d177100e6ae6b9f30a2de1b8 /subprojects/boost-sqlite/test/collation.cpp
parentaa55cb93036a89c64c08e08f4e1de4fa1fd5a775 (diff)
parentefcea3a80da7c4479d5fe168435ecc9fd06bdc72 (diff)
downloadsqlite-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.cpp45
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