1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
|
/*
* Copyright (C) 2009 Emweb bvba, Kessel-Lo, Belgium.
*
* See the LICENSE file for terms of use.
*/
#include <boost/test/unit_test.hpp>
#include <Wt/Dbo/Dbo>
#include <Wt/WDate>
#include <Wt/WDateTime>
#include <Wt/WTime>
#include <Wt/Dbo/WtSqlTraits>
#include <Wt/Dbo/ptr_tuple>
#include "DboFixture.h"
#include <string>
namespace dbo = Wt::Dbo;
class CustomerAddress;
class Customer
{
public:
Wt::Dbo::collection< Wt::Dbo::ptr<CustomerAddress> > addresses;
Wt::Dbo::ptr<CustomerAddress> default_address;
template<class Action>
void persist(Action &action)
{
Wt::Dbo::hasMany(action, addresses, Wt::Dbo::ManyToOne);
Wt::Dbo::belongsTo(action, default_address, "default_customer_address");
}
};
class CustomerAddress
{
public:
Wt::Dbo::ptr<Customer> customer;
//Wt::Dbo::collection< Wt::Dbo::ptr<Customer> > customers;
Wt::Dbo::weak_ptr<Customer> default_customer;
template<class Action>
void persist(Action &action)
{
Wt::Dbo::belongsTo(action, customer);
//Wt::Dbo::hasMany(action, customers, Wt::Dbo::ManyToOne, "default_customer_address");
Wt::Dbo::hasOne(action, default_customer, "default_customer_address");
}
};
class FuncTest : public Wt::Dbo::Dbo<FuncTest>
{
public:
int intC;
double doubleC;
template<class Action>
void persist(Action &a)
{
Wt::Dbo::field(a, intC, "intC");
Wt::Dbo::field(a, doubleC, "doubleC");
}
static const char *TableName()
{
return "func";
}
};
struct Dbo3Fixture : DboFixtureBase
{
Dbo3Fixture() :
DboFixtureBase()
{
session_->mapClass<Customer>("c");
session_->mapClass<CustomerAddress>("ca");
session_->mapClass<FuncTest>(FuncTest::TableName());
try {
session_->dropTables(); //todo:remove
} catch (...) {
}
std::cout << "-------------------------- end of drop ----------------------*********" << std::endl;
session_->createTables();
}
};
BOOST_AUTO_TEST_CASE( dbo3_test2 )
{
Dbo3Fixture f;
dbo::Session& session = *f.session_;
{
dbo::Transaction transaction(session);
FuncTest *f1 = new FuncTest;
f1->intC = 1;
f1->doubleC = 1.1;
session.add(f1);
FuncTest *f2 = new FuncTest;
f2->intC = 2;
f2->doubleC = 2.2;
session.add(f2);
FuncTest *f3 = new FuncTest;
f3->intC = 3;
f3->doubleC = 3.3;
session.add(f3);
transaction.commit();
}
typedef boost::tuple<int, double> tupel;
dbo::Transaction transaction(session);
tupel tupe;
#ifdef SQLITE3
/*
* Odd enough Sqlite3 thinks this is legal SQL, but postgres
* complains (rightfully) that you can't combine aggregate and
* non-aggregate fields.
*/
tupe = session.query<tupel>(std::string(
"SELECT SUM(\"intC\") as sc, \"doubleC\" FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(tupe.get<0>() == 6);
#endif
tupe = session.query<tupel>(std::string(
"SELECT SUM(\"intC\") as sc, SUM(\"doubleC\") as dc FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(tupe.get<0>() == 6);
// NOTE: can fail w/valgrind due to precision of emulated floating point
BOOST_REQUIRE(std::abs(tupe.get<1>() - 6.6) < 0.001);
double d = session.query<double>(std::string(
"SELECT SUM(\"doubleC\" * \"intC\") as sc FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(std::abs(d - 15.4) < 0.001);//d == 15.4
d = session.query<double>(std::string(
"SELECT MAX(\"doubleC\" * \"intC\") as m FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(std::abs(d - 9.9) < 0.001);
double i = session.query<double>(std::string(
"SELECT AVG(\"intC\") as a FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(i == 2.0);
i = session.query<int>(std::string(
"SELECT COUNT(\"intC\") as c FROM \"") +
FuncTest::TableName() + "\"").limit(1);
BOOST_REQUIRE(i == 3);
transaction.commit();
}
|