summaryrefslogtreecommitdiff
path: root/libpqpp/unittests/testpq.cpp
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2019-10-19 15:38:00 +0100
committerDan Goodliffe <dan@randomdan.homeip.net>2019-10-19 15:38:00 +0100
commit43705039aac98e4b8065353da3f828d894dd6f00 (patch)
tree3a65a0ed58335ef1ec99c6efc162929dff789793 /libpqpp/unittests/testpq.cpp
parentModernize build (diff)
downloadlibdbpp-postgresql-43705039aac98e4b8065353da3f828d894dd6f00.tar.bz2
libdbpp-postgresql-43705039aac98e4b8065353da3f828d894dd6f00.tar.xz
libdbpp-postgresql-43705039aac98e4b8065353da3f828d894dd6f00.zip
Refactor to ease testing
Diffstat (limited to 'libpqpp/unittests/testpq.cpp')
-rw-r--r--libpqpp/unittests/testpq.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/libpqpp/unittests/testpq.cpp b/libpqpp/unittests/testpq.cpp
index e78a079..67ce07a 100644
--- a/libpqpp/unittests/testpq.cpp
+++ b/libpqpp/unittests/testpq.cpp
@@ -441,6 +441,22 @@ BOOST_AUTO_TEST_CASE( largeBlob )
}
}
+BOOST_AUTO_TEST_CASE( bulkPerfTest )
+{
+ auto ro = DB::ConnectionPtr(DB::MockDatabase::openConnectionTo("PQmock"));
+ auto sel = ro->select(R"SQL(select s a, cast(s as numeric(7,1)) b, cast(s as text) c,
+ make_interval(secs => s) d, make_timestamp(2019,1,1,1,1,1) + make_interval(mins=>s) e,
+ s % 2 = 0 f
+ from generate_series(1, 1000) s)SQL");
+
+ int64_t tot = 0;
+ for (const auto & [a,b,c,d,e,f] : sel->as<int64_t, double, std::string_view,
+ boost::posix_time::time_duration, boost::posix_time::ptime, bool>()) {
+ tot += a + b + c.length() + d.hours() + e.time_of_day().hours() + f;
+ }
+ BOOST_REQUIRE_EQUAL(tot, 1013265);
+}
+
BOOST_AUTO_TEST_SUITE_END();
BOOST_AUTO_TEST_CASE( connfail )