/* * Copyright (c) 2015-2016, 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 "MockDb.h" #include "Sample.h" #include namespace { constexpr auto t = test::TabBar{}; constexpr auto f = test::TabFoo{}; template void print_type_on_error(std::true_type) { } template void print_type_on_error(std::false_type) { T::_print_me_; } template void join_static_check(const Lhs& lhs, const Rhs& rhs) { using CheckResult = sqlpp::check_cross_join_t; using ExpectedCheckResult = std::is_same; print_type_on_error(ExpectedCheckResult{}); static_assert(ExpectedCheckResult::value, "Unexpected check result"); using JoinType = decltype(join(lhs, rhs)); using InnerJoinType = decltype(inner_join(lhs, rhs)); using LeftOuterJoinType = decltype(left_outer_join(lhs, rhs)); using RightOuterJoinType = decltype(right_outer_join(lhs, rhs)); using OuterJoinType = decltype(outer_join(lhs, rhs)); using ExpectedReturnType = sqlpp::logic::all_t::value and std::is_same::value and std::is_same::value and std::is_same::value and std::is_same::value)>; print_type_on_error(ExpectedReturnType{}); print_type_on_error(ExpectedReturnType{}); print_type_on_error(ExpectedReturnType{}); print_type_on_error(ExpectedReturnType{}); print_type_on_error(ExpectedReturnType{}); static_assert(ExpectedReturnType::value, "Unexpected return type"); } /* template void join_dynamic_check(const Expression& expression) { static auto db = MockDb{}; using CheckResult = sqlpp::check_join_dynamic_t; using ExpectedCheckResult = std::is_same; print_type_on_error(ExpectedCheckResult{}); static_assert(ExpectedCheckResult::value, "Unexpected check result"); using ReturnType = decltype(dynamic_select(db, t.alpha).dynamic_join(expression)); using ExpectedReturnType = sqlpp::logic::all_t::value>; print_type_on_error(ExpectedReturnType{}); static_assert(ExpectedReturnType::value, "Unexpected return type"); } */ void static_join() { // OK: Join two different tables join_static_check(t, f); join_static_check(t, f.as(sqlpp::alias::a)); join_static_check(t.as(sqlpp::alias::a), f.as(sqlpp::alias::b)); // OK: Self join join_static_check(t.as(sqlpp::alias::a), t.as(sqlpp::alias::b)); join_static_check(t, t.as(sqlpp::alias::b)); join_static_check(t.as(sqlpp::alias::a), t); // Prepare a join for tests: const auto j = join(t.as(sqlpp::alias::a), t.as(sqlpp::alias::b)).unconditionally(); // OK: Add a third table join_static_check(j, f); join_static_check(j, t.as(sqlpp::alias::c)); join_static_check(j, t); // Try a bunch of non-tables join_static_check(t, 7); join_static_check(t, t.alpha); join_static_check(t, t.beta); join_static_check(t, t.gamma); join_static_check(t, t.delta); join_static_check(7, t); join_static_check(t.alpha, t); join_static_check(t.beta, t); join_static_check(t.gamma, t); join_static_check(t.delta, t); // Try to join with join (rhs) join_static_check(t, j); join_static_check(f, j); join_static_check(t.as(sqlpp::alias::left), j); // Try to join identical table names join_static_check(t, t); join_static_check(f, f); join_static_check(t.as(f), f); join_static_check(t, f.as(t)); join_static_check(t.as(sqlpp::alias::a), f.as(sqlpp::alias::a)); join_static_check(j, f.as(sqlpp::alias::a)); join_static_check(j, f.as(sqlpp::alias::b)); join_static_check(j, t.as(sqlpp::alias::a)); join_static_check(j, t.as(sqlpp::alias::b)); } void dynamic_join() { /* // OK join_dynamic_check(t); join_dynamic_check(t.join(f).unconditionally()); join_dynamic_check(t.join(f).on(t.alpha > f.omega)); // Try a bunch of non-tables join_dynamic_check(7); join_dynamic_check(t.alpha); join_dynamic_check(t.beta); join_dynamic_check(t.gamma); join_dynamic_check(t.delta); // Try cross joins (missing condition) join_dynamic_check(t.join(f)); */ } } int main(int, char* []) { static_join(); dynamic_join(); }