From 561cc7e64352c9e0f2fcfbbe39bd80566fb13c30 Mon Sep 17 00:00:00 2001 From: Roland Bock Date: Mon, 23 Dec 2024 20:25:04 +0100 Subject: [PATCH] Add serialize test for LEFT OUTER JOIN, see also #614 --- tests/sqlite3/serialize/CMakeLists.txt | 1 + tests/sqlite3/serialize/Join.cpp | 42 ++++++++++++++++++++++++++ 2 files changed, 43 insertions(+) create mode 100644 tests/sqlite3/serialize/Join.cpp diff --git a/tests/sqlite3/serialize/CMakeLists.txt b/tests/sqlite3/serialize/CMakeLists.txt index c0ff4fc1..4b742611 100644 --- a/tests/sqlite3/serialize/CMakeLists.txt +++ b/tests/sqlite3/serialize/CMakeLists.txt @@ -24,6 +24,7 @@ set(test_files Float.cpp + Join.cpp ) create_test_sourcelist(test_sources test_main.cpp ${test_files}) diff --git a/tests/sqlite3/serialize/Join.cpp b/tests/sqlite3/serialize/Join.cpp new file mode 100644 index 00000000..9b8b43c1 --- /dev/null +++ b/tests/sqlite3/serialize/Join.cpp @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2024, Roland Bock + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + * OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include +#include + +#include "../usage/TabSample.h" + +#include "compare.h" + +int Join(int, char*[]) +{ + const auto tab = TabSample{}; + const auto foo = TabFoo{}; + + compare(__LINE__, select(tab.alpha).from(tab.left_outer_join(foo).on(tab.alpha == foo.omega)).unconditionally(), + "SELECT tab_sample.alpha FROM tab_sample LEFT OUTER JOIN tab_foo ON (tab_sample.alpha=tab_foo.omega)"); + + return 0; +}