| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248 |
- //
- // DataTest.cpp
- //
- // $Id: //poco/Main/Data/testsuite/src/DataTest.cpp#12 $
- //
- // Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
- // and Contributors.
- //
- // Permission is hereby granted, free of charge, to any person or organization
- // obtaining a copy of the software and accompanying documentation covered by
- // this license (the "Software") to use, reproduce, display, distribute,
- // execute, and transmit the Software, and to prepare derivative works of the
- // Software, and to permit third-parties to whom the Software is furnished to
- // do so, all subject to the following:
- //
- // The copyright notices in the Software and this entire statement, including
- // the above license grant, this restriction and the following disclaimer,
- // must be included in all copies of the Software, in whole or in part, and
- // all derivative works of the Software, unless such copies or derivative
- // works are solely in the form of machine-executable object code generated by
- // a source language processor.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
- // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
- // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
- // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- // DEALINGS IN THE SOFTWARE.
- //
- #include "DataTest.h"
- #include "CppUnit/TestCaller.h"
- #include "CppUnit/TestSuite.h"
- #include "Poco/Data/Session.h"
- #include "Poco/Data/SessionFactory.h"
- #include "Poco/Data/BLOB.h"
- #include "Poco/Data/BLOBStream.h"
- #include "Poco/Data/MetaColumn.h"
- #include "Poco/Data/Column.h"
- #include "Poco/Data/Date.h"
- #include "Poco/Data/Time.h"
- #include "Poco/Data/SimpleRowFormatter.h"
- #include "Connector.h"
- #include "Poco/BinaryReader.h"
- #include "Poco/BinaryWriter.h"
- #include "Poco/DateTime.h"
- #include "Poco/Types.h"
- #include "Poco/Exception.h"
- #include <cstring>
- #include <sstream>
- #include <iomanip>
- #include <set>
- using namespace Poco::Data::Keywords;
- using Poco::BinaryReader;
- using Poco::BinaryWriter;
- using Poco::UInt32;
- using Poco::Int64;
- using Poco::UInt64;
- using Poco::DateTime;
- using Poco::InvalidAccessException;
- using Poco::RangeException;
- using Poco::NotFoundException;
- using Poco::InvalidArgumentException;
- using Poco::NotImplementedException;
- using Poco::Data::Session;
- using Poco::Data::SessionFactory;
- using Poco::Data::Statement;
- using Poco::Data::NotSupportedException;
- using Poco::Data::BLOB;
- using Poco::Data::BLOBInputStream;
- using Poco::Data::BLOBOutputStream;
- using Poco::Data::MetaColumn;
- using Poco::Data::Column;
- using Poco::Data::Row;
- using Poco::Data::SimpleRowFormatter;
- using Poco::Data::Date;
- using Poco::Data::Time;
- using Poco::Data::AbstractExtraction;
- using Poco::Data::AbstractExtractionVec;
- using Poco::Data::AbstractExtractionVecVec;
- using Poco::Data::AbstractBinding;
- using Poco::Data::AbstractBindingVec;
- DataTest::DataTest(const std::string& name): CppUnit::TestCase(name)
- {
- Poco::Data::Test::Connector::addToFactory();
- }
- DataTest::~DataTest()
- {
- Poco::Data::Test::Connector::removeFromFactory();
- }
- void DataTest::testSession()
- {
- Session sess(SessionFactory::instance().create("test", "cs"));
- sess << "DROP TABLE IF EXISTS Test", now;
- int count;
- sess << "SELECT COUNT(*) FROM PERSON", into(count), now;
-
- std::string str;
- Statement stmt = (sess << "SELECT * FROM Strings", into(str), limit(50));
- stmt.execute();
- }
- void DataTest::testStatementFormatting()
- {
- Session sess(SessionFactory::instance().create("test", "cs"));
- Statement stmt = (sess << "SELECT %s%c%s,%d,%u,%f,%s FROM Person WHERE Name LIKE 'Simp%%'",
- "'",'a',"'",-1, 1u, 1.5, "42", now);
-
- assert ("SELECT 'a',-1,1,1.500000,42 FROM Person WHERE Name LIKE 'Simp%'" == stmt.toString());
- }
- void DataTest::testFeatures()
- {
- Session sess(SessionFactory::instance().create("test", "cs"));
-
- sess.setFeature("f1", true);
- assert (sess.getFeature("f1"));
- assert (sess.getFeature("f2"));
-
- try
- {
- sess.setFeature("f2", false);
- }
- catch (NotImplementedException&)
- {
- }
-
- sess.setFeature("f3", false);
- assert (!sess.getFeature("f2"));
-
- try
- {
- sess.setFeature("f3", true);
- }
- catch (NotImplementedException&)
- {
- }
-
- try
- {
- sess.setFeature("f4", false);
- }
- catch (NotSupportedException&)
- {
- }
- }
- void DataTest::testProperties()
- {
- Session sess(SessionFactory::instance().create("test", "cs"));
-
- sess.setProperty("p1", 1);
- Poco::Any v1 = sess.getProperty("p1");
- assert (Poco::AnyCast<int>(v1) == 1);
- Poco::Any v2 = sess.getProperty("p2");
- assert (Poco::AnyCast<int>(v2) == 1);
-
- try
- {
- sess.setProperty("p2", 2);
- }
- catch (NotImplementedException&)
- {
- }
-
- sess.setProperty("p3", 2);
- v1 = sess.getProperty("p2");
- assert (Poco::AnyCast<int>(v1) == 2);
-
- try
- {
- sess.setProperty("p3", 3);
- }
- catch (NotImplementedException&)
- {
- }
-
- try
- {
- sess.setProperty("p4", 4);
- }
- catch (NotSupportedException&)
- {
- }
- }
- void DataTest::testBLOB()
- {
- std::string strDigit = "1234567890";
- std::string strAlpha = "abcdefghijklmnopqrstuvwxyz";
- std::vector<char> vecAlpha(strAlpha.begin(), strAlpha.end());
- std::vector<char> vecDigit(strDigit.begin(), strDigit.end());
-
- BLOB blobNumStr(strDigit.c_str(), strDigit.size());
- assert (blobNumStr.size() == strDigit.size());
- assert (0 == std::strncmp(strDigit.c_str(), blobNumStr.rawContent(), blobNumStr.size()));
- assert (*blobNumStr.begin() == '1');
- assert (*(blobNumStr.end()-1) == '0');
- BLOB blobNumVec(vecDigit);
- assert (blobNumVec.size() == vecDigit.size());
- assert (blobNumVec == blobNumStr);
- blobNumVec.swap(blobNumStr);
- assert (blobNumVec.size() == blobNumStr.size());
- assert (blobNumVec == blobNumStr);
- BLOB blobChrStr(strAlpha.c_str(), strAlpha.size());
- BLOB blobChrVec(vecAlpha);
- assert (blobChrStr.size() == strAlpha.size());
- assert (0 == std::strncmp(strAlpha.c_str(), blobChrStr.rawContent(), blobChrStr.size()));
- assert (*blobChrStr.begin() == 'a');
- assert (*(blobChrStr.end()-1) == 'z');
- assert (blobChrStr == blobChrVec);
- blobNumStr.swap(blobChrStr);
- assert (blobNumStr != blobChrStr);
- assert (&blobNumStr != &blobChrStr);
- assert (blobNumStr.content() != blobChrStr.content());
- assert (&blobNumStr.content() != &blobChrStr.content());
- assert (blobNumStr == blobChrVec);
- Poco::Data::swap(blobNumStr, blobChrVec);
- assert (blobNumStr == blobChrVec);
- std::swap(blobNumStr, blobChrVec);
- assert (blobNumStr == blobChrVec);
- }
- void DataTest::testBLOBStreams()
- {
- BLOB blob;
- assert (0 == blob.size());
- BLOBOutputStream bos(blob);
- BinaryWriter bw(bos);
- assert (0 == blob.size());
- writeToBLOB(bw);
- assert (blob.size() > 0);
- BLOBInputStream bis(blob);
- BinaryReader br(bis);
- readFromBLOB(br);
- }
- void DataTest::writeToBLOB(BinaryWriter& writer)
- {
- writer << true;
- writer << false;
- writer << 'a';
- writer << (short) -100;
- writer << (unsigned short) 50000;
- writer << -123456;
- writer << (unsigned) 123456;
- writer << (long) -1234567890;
- writer << (unsigned long) 1234567890;
-
- writer << (Int64) -1234567890;
- writer << (UInt64) 1234567890;
- writer << (float) 1.5;
- writer << (double) -1.5;
-
- writer << "foo";
- writer << "";
- writer << std::string("bar");
- writer << std::string();
-
- writer.write7BitEncoded((UInt32) 100);
- writer.write7BitEncoded((UInt32) 1000);
- writer.write7BitEncoded((UInt32) 10000);
- writer.write7BitEncoded((UInt32) 100000);
- writer.write7BitEncoded((UInt32) 1000000);
- writer.write7BitEncoded((UInt64) 100);
- writer.write7BitEncoded((UInt64) 1000);
- writer.write7BitEncoded((UInt64) 10000);
- writer.write7BitEncoded((UInt64) 100000);
- writer.write7BitEncoded((UInt64) 1000000);
- writer.writeRaw("RAW");
- }
- void DataTest::readFromBLOB(BinaryReader& reader)
- {
- bool b = false;
- reader >> b;
- assert (b);
- reader >> b;
- assert (!b);
-
- char c = ' ';
- reader >> c;
- assert (c == 'a');
- short shortv = 0;
- reader >> shortv;
- assert (shortv == -100);
- unsigned short ushortv = 0;
- reader >> ushortv;
- assert (ushortv == 50000);
- int intv = 0;
- reader >> intv;
- assert (intv == -123456);
- unsigned uintv = 0;
- reader >> uintv;
- assert (uintv == 123456);
- long longv = 0;
- reader >> longv;
- assert (longv == -1234567890);
- unsigned long ulongv = 0;
- reader >> ulongv;
- assert (ulongv == 1234567890);
- Int64 int64v = 0;
- reader >> int64v;
- assert (int64v == -1234567890);
-
- UInt64 uint64v = 0;
- reader >> uint64v;
- assert (uint64v == 1234567890);
- float floatv = 0.0;
- reader >> floatv;
- assert (floatv == 1.5);
-
- double doublev = 0.0;
- reader >> doublev;
- assert (doublev == -1.5);
- std::string str;
- reader >> str;
- assert (str == "foo");
- reader >> str;
- assert (str == "");
-
- reader >> str;
- assert (str == "bar");
- reader >> str;
- assert (str == "");
- UInt32 uint32v;
- reader.read7BitEncoded(uint32v);
- assert (uint32v == 100);
- reader.read7BitEncoded(uint32v);
- assert (uint32v == 1000);
- reader.read7BitEncoded(uint32v);
- assert (uint32v == 10000);
- reader.read7BitEncoded(uint32v);
- assert (uint32v == 100000);
- reader.read7BitEncoded(uint32v);
- assert (uint32v == 1000000);
- reader.read7BitEncoded(uint64v);
- assert (uint64v == 100);
- reader.read7BitEncoded(uint64v);
- assert (uint64v == 1000);
- reader.read7BitEncoded(uint64v);
- assert (uint64v == 10000);
- reader.read7BitEncoded(uint64v);
- assert (uint64v == 100000);
- reader.read7BitEncoded(uint64v);
- assert (uint64v == 1000000);
- reader.readRaw(3, str);
- assert (str == "RAW");
- }
- void DataTest::testColumnVector()
- {
- MetaColumn mc(0, "mc", MetaColumn::FDT_DOUBLE, 2, 3, true);
- assert (mc.name() == "mc");
- assert (mc.position() == 0);
- assert (mc.length() == 2);
- assert (mc.precision() == 3);
- assert (mc.type() == MetaColumn::FDT_DOUBLE);
- assert (mc.isNullable());
- std::vector<int>* pData = new std::vector<int>;
- pData->push_back(1);
- pData->push_back(2);
- pData->push_back(3);
- pData->push_back(4);
- pData->push_back(5);
-
- Column<std::vector<int> > c(mc, pData);
- assert (c.rowCount() == 5);
- assert (c[0] == 1);
- assert (c[1] == 2);
- assert (c[2] == 3);
- assert (c[3] == 4);
- assert (c[4] == 5);
- assert (c.name() == "mc");
- assert (c.position() == 0);
- assert (c.length() == 2);
- assert (c.precision() == 3);
- assert (c.type() == MetaColumn::FDT_DOUBLE);
- try
- {
- int i; i = c[100]; // to silence gcc
- fail ("must fail");
- }
- catch (RangeException&) { }
- Column<std::vector<int> > c1 = c;
- assert (c1.rowCount() == 5);
- assert (c1[0] == 1);
- assert (c1[1] == 2);
- assert (c1[2] == 3);
- assert (c1[3] == 4);
- assert (c1[4] == 5);
- Column<std::vector<int> > c2(c1);
- assert (c2.rowCount() == 5);
- assert (c2[0] == 1);
- assert (c2[1] == 2);
- assert (c2[2] == 3);
- assert (c2[3] == 4);
- assert (c2[4] == 5);
- std::vector<int> vi;
- vi.assign(c.begin(), c.end());
- assert (vi.size() == 5);
- assert (vi[0] == 1);
- assert (vi[1] == 2);
- assert (vi[2] == 3);
- assert (vi[3] == 4);
- assert (vi[4] == 5);
- c.reset();
- assert (c.rowCount() == 0);
- assert (c1.rowCount() == 0);
- assert (c2.rowCount() == 0);
- std::vector<int>* pV1 = new std::vector<int>;
- pV1->push_back(1);
- pV1->push_back(2);
- pV1->push_back(3);
- pV1->push_back(4);
- pV1->push_back(5);
- std::vector<int>* pV2 = new std::vector<int>;
- pV2->push_back(5);
- pV2->push_back(4);
- pV2->push_back(3);
- pV2->push_back(2);
- pV2->push_back(1);
- Column<std::vector<int> > c3(mc, pV1);
- Column<std::vector<int> > c4(mc, pV2);
-
- Poco::Data::swap(c3, c4);
- assert (c3[0] == 5);
- assert (c3[1] == 4);
- assert (c3[2] == 3);
- assert (c3[3] == 2);
- assert (c3[4] == 1);
- assert (c4[0] == 1);
- assert (c4[1] == 2);
- assert (c4[2] == 3);
- assert (c4[3] == 4);
- assert (c4[4] == 5);
- std::swap(c3, c4);
- assert (c3[0] == 1);
- assert (c3[1] == 2);
- assert (c3[2] == 3);
- assert (c3[3] == 4);
- assert (c3[4] == 5);
- assert (c4[0] == 5);
- assert (c4[1] == 4);
- assert (c4[2] == 3);
- assert (c4[3] == 2);
- assert (c4[4] == 1);
- }
- void DataTest::testColumnVectorBool()
- {
- MetaColumn mc(0, "mc", MetaColumn::FDT_BOOL);
- std::vector<bool>* pData = new std::vector<bool>;
- pData->push_back(true);
- pData->push_back(false);
- pData->push_back(true);
- pData->push_back(false);
- pData->push_back(true);
-
- Column<std::vector<bool> > c(mc, pData);
- assert (c.rowCount() == 5);
- assert (c[0] == true);
- assert (c[1] == false);
- assert (c[2] == true);
- assert (c[3] == false);
- assert (c[4] == true);
- assert (c.type() == MetaColumn::FDT_BOOL);
- try
- {
- bool b; b = c[100]; // to silence gcc
- fail ("must fail");
- }
- catch (RangeException&) { }
- Column<std::vector<bool> > c1 = c;
- assert (c1.rowCount() == 5);
- assert (c1[0] == true);
- assert (c1[1] == false);
- assert (c1[2] == true);
- assert (c1[3] == false);
- assert (c1[4] == true);
- Column<std::vector<bool> > c2(c1);
- assert (c2.rowCount() == 5);
- assert (c2[0] == true);
- assert (c2[1] == false);
- assert (c2[2] == true);
- assert (c2[3] == false);
- assert (c2[4] == true);
- std::vector<bool> vi;
- vi.assign(c.begin(), c.end());
- assert (vi.size() == 5);
- assert (vi[0] == true);
- assert (vi[1] == false);
- assert (vi[2] == true);
- assert (vi[3] == false);
- assert (vi[4] == true);
- c.reset();
- assert (c.rowCount() == 0);
- assert (c1.rowCount() == 0);
- assert (c2.rowCount() == 0);
- }
- void DataTest::testColumnDeque()
- {
- typedef std::deque<int> ContainerType;
- typedef Column<ContainerType> ColumnType;
- MetaColumn mc(0, "mc", MetaColumn::FDT_DOUBLE, 2, 3, true);
- assert (mc.name() == "mc");
- assert (mc.position() == 0);
- assert (mc.length() == 2);
- assert (mc.precision() == 3);
- assert (mc.type() == MetaColumn::FDT_DOUBLE);
- assert (mc.isNullable());
- ContainerType* pData = new ContainerType;
- pData->push_back(1);
- pData->push_back(2);
- pData->push_back(3);
- pData->push_back(4);
- pData->push_back(5);
-
- ColumnType c(mc, pData);
- assert (c.rowCount() == 5);
- assert (c[0] == 1);
- assert (c[1] == 2);
- assert (c[2] == 3);
- assert (c[3] == 4);
- assert (c[4] == 5);
- assert (c.name() == "mc");
- assert (c.position() == 0);
- assert (c.length() == 2);
- assert (c.precision() == 3);
- assert (c.type() == MetaColumn::FDT_DOUBLE);
- try
- {
- int i; i = c[100]; // to silence gcc
- fail ("must fail");
- }
- catch (RangeException&) { }
- ColumnType c1 = c;
- assert (c1.rowCount() == 5);
- assert (c1[0] == 1);
- assert (c1[1] == 2);
- assert (c1[2] == 3);
- assert (c1[3] == 4);
- assert (c1[4] == 5);
- ColumnType c2(c1);
- assert (c2.rowCount() == 5);
- assert (c2[0] == 1);
- assert (c2[1] == 2);
- assert (c2[2] == 3);
- assert (c2[3] == 4);
- assert (c2[4] == 5);
- ContainerType vi;
- vi.assign(c.begin(), c.end());
- assert (vi.size() == 5);
- assert (vi[0] == 1);
- assert (vi[1] == 2);
- assert (vi[2] == 3);
- assert (vi[3] == 4);
- assert (vi[4] == 5);
- c.reset();
- assert (c.rowCount() == 0);
- assert (c1.rowCount() == 0);
- assert (c2.rowCount() == 0);
- ContainerType* pV1 = new ContainerType;
- pV1->push_back(1);
- pV1->push_back(2);
- pV1->push_back(3);
- pV1->push_back(4);
- pV1->push_back(5);
- ContainerType* pV2 = new ContainerType;
- pV2->push_back(5);
- pV2->push_back(4);
- pV2->push_back(3);
- pV2->push_back(2);
- pV2->push_back(1);
- Column<ContainerType> c3(mc, pV1);
- Column<ContainerType> c4(mc, pV2);
-
- Poco::Data::swap(c3, c4);
- assert (c3[0] == 5);
- assert (c3[1] == 4);
- assert (c3[2] == 3);
- assert (c3[3] == 2);
- assert (c3[4] == 1);
- assert (c4[0] == 1);
- assert (c4[1] == 2);
- assert (c4[2] == 3);
- assert (c4[3] == 4);
- assert (c4[4] == 5);
- std::swap(c3, c4);
- assert (c3[0] == 1);
- assert (c3[1] == 2);
- assert (c3[2] == 3);
- assert (c3[3] == 4);
- assert (c3[4] == 5);
- assert (c4[0] == 5);
- assert (c4[1] == 4);
- assert (c4[2] == 3);
- assert (c4[3] == 2);
- assert (c4[4] == 1);
- }
- void DataTest::testColumnList()
- {
- typedef std::list<int> ContainerType;
- typedef Column<ContainerType> ColumnType;
- MetaColumn mc(0, "mc", MetaColumn::FDT_DOUBLE, 2, 3, true);
- assert (mc.name() == "mc");
- assert (mc.position() == 0);
- assert (mc.length() == 2);
- assert (mc.precision() == 3);
- assert (mc.type() == MetaColumn::FDT_DOUBLE);
- assert (mc.isNullable());
- ContainerType* pData = new ContainerType;
- pData->push_back(1);
- pData->push_back(2);
- pData->push_back(3);
- pData->push_back(4);
- pData->push_back(5);
-
- ColumnType c(mc, pData);
- assert (c.rowCount() == 5);
- assert (c[0] == 1);
- assert (c[1] == 2);
- assert (c[2] == 3);
- assert (c[3] == 4);
- assert (c[4] == 5);
- assert (c.name() == "mc");
- assert (c.position() == 0);
- assert (c.length() == 2);
- assert (c.precision() == 3);
- assert (c.type() == MetaColumn::FDT_DOUBLE);
- try
- {
- int i; i = c[100]; // to silence gcc
- fail ("must fail");
- }
- catch (RangeException&) { }
- ColumnType c1 = c;
- assert (c1.rowCount() == 5);
- assert (c1[0] == 1);
- assert (c1[1] == 2);
- assert (c1[2] == 3);
- assert (c1[3] == 4);
- assert (c1[4] == 5);
- ColumnType c2(c1);
- assert (c2.rowCount() == 5);
- assert (c2[0] == 1);
- assert (c2[1] == 2);
- assert (c2[2] == 3);
- assert (c2[3] == 4);
- assert (c2[4] == 5);
- ContainerType vi;
- vi.assign(c.begin(), c.end());
- assert (vi.size() == 5);
- ContainerType::const_iterator it = vi.begin();
- ContainerType::const_iterator end = vi.end();
- for (int i = 1; it != end; ++it, ++i)
- assert (*it == i);
- c.reset();
- assert (c.rowCount() == 0);
- assert (c1.rowCount() == 0);
- assert (c2.rowCount() == 0);
- ContainerType* pV1 = new ContainerType;
- pV1->push_back(1);
- pV1->push_back(2);
- pV1->push_back(3);
- pV1->push_back(4);
- pV1->push_back(5);
- ContainerType* pV2 = new ContainerType;
- pV2->push_back(5);
- pV2->push_back(4);
- pV2->push_back(3);
- pV2->push_back(2);
- pV2->push_back(1);
- Column<ContainerType> c3(mc, pV1);
- Column<ContainerType> c4(mc, pV2);
-
- Poco::Data::swap(c3, c4);
- assert (c3[0] == 5);
- assert (c3[1] == 4);
- assert (c3[2] == 3);
- assert (c3[3] == 2);
- assert (c3[4] == 1);
- assert (c4[0] == 1);
- assert (c4[1] == 2);
- assert (c4[2] == 3);
- assert (c4[3] == 4);
- assert (c4[4] == 5);
- std::swap(c3, c4);
- assert (c3[0] == 1);
- assert (c3[1] == 2);
- assert (c3[2] == 3);
- assert (c3[3] == 4);
- assert (c3[4] == 5);
- assert (c4[0] == 5);
- assert (c4[1] == 4);
- assert (c4[2] == 3);
- assert (c4[3] == 2);
- assert (c4[4] == 1);
- }
- void DataTest::testRow()
- {
- Row row;
- row.append("field0", 0);
- row.append("field1", 1);
- row.append("field2", 2);
- row.append("field3", 3);
- row.append("field4", 4);
- assert (row["field0"] == 0);
- assert (row["field1"] == 1);
- assert (row["field2"] == 2);
- assert (row["field3"] == 3);
- assert (row["field4"] == 4);
- assert (row[0] == 0);
- assert (row[1] == 1);
- assert (row[2] == 2);
- assert (row[3] == 3);
- assert (row[4] == 4);
- try
- {
- int i; i = row[5]; // to silence gcc
- fail ("must fail");
- }catch (RangeException&) {}
- try
- {
- int i; i = row["a bad name"]; // to silence gcc
- fail ("must fail");
- }catch (NotFoundException&) {}
- assert (5 == row.fieldCount());
- assert (row[0] == 0);
- assert (row["field0"] == 0);
- assert (row[1] == 1);
- assert (row["field1"] == 1);
- assert (row[2] == 2);
- assert (row["field2"] == 2);
- assert (row[3] == 3);
- assert (row["field3"] == 3);
- assert (row[4] == 4);
- assert (row["field4"] == 4);
- Row row2;
- row2.append("field0", 5);
- row2.append("field1", 4);
- row2.append("field2", 3);
- row2.append("field3", 2);
- row2.append("field4", 1);
- assert (row != row2);
- Row row3;
- row3.append("field0", 0);
- row3.append("field1", 1);
- row3.append("field2", 2);
- row3.append("field3", 3);
- row3.append("field4", 4);
- assert (row3 == row);
- assert (!(row < row3 | row3 < row));
- Row row4(row3.names());
- try
- {
- row4.set("badfieldname", 0);
- fail ("must fail");
- }catch (NotFoundException&) {}
- row4.set("field0", 0);
- row4.set("field1", 1);
- row4.set("field2", 2);
- row4.set("field3", 3);
- row4.set("field4", 4);
- assert (row3 == row4);
- try
- {
- row4.set(5, 0);
- fail ("must fail");
- }catch (RangeException&) {}
- row4.set("field0", 1);
- assert (row3 != row4);
- assert (row3 < row4);
- }
- void DataTest::testRowSort()
- {
- Row row1;
- row1.append("0", 0);
- row1.append("1", 1);
- row1.append("2", 2);
- row1.append("3", 3);
- row1.append("4", 4);
- Row row2;
- row2.append("0", 0);
- row2.append("1", 1);
- row2.append("2", 2);
- row2.append("3", 3);
- row2.append("4", 4);
- std::multiset<Row> rowSet1;
- rowSet1.insert(row1);
- rowSet1.insert(row2);
- std::multiset<Row>::iterator it1 = rowSet1.begin();
- assert (row1 == *it1);
- ++it1;
- assert (row2 == *it1);
- Row row3;
- row3.append("0", 1);
- row3.append("1", 1);
- row3.append("2", 2);
- row3.append("3", 3);
- row3.append("4", 4);
- Row row4;
- row4.append("0", 0);
- row4.append("1", 1);
- row4.append("2", 2);
- row4.append("3", 3);
- row4.append("4", 4);
- std::set<Row> rowSet2;
- rowSet2.insert(row4);
- rowSet2.insert(row3);
- std::set<Row>::iterator it2 = rowSet2.begin();
- assert (row4 == *it2);
- ++it2;
- assert (row3 == *it2);
- Row row5;
- row5.append("0", 2);
- row5.append("1", 2);
- row5.append("2", 0);
- row5.append("3", 3);
- row5.append("4", 4);
- row5.addSortField("1");
- Row row6;
- row6.append("0", 1);
- row6.append("1", 0);
- row6.append("2", 1);
- row6.append("3", 3);
- row6.append("4", 4);
- row6.addSortField("1");
- Row row7;
- row7.append("0", 0);
- row7.append("1", 1);
- row7.append("2", 2);
- row7.append("3", 3);
- row7.append("4", 4);
- std::set<Row> rowSet3;
- rowSet3.insert(row5);
- rowSet3.insert(row6);
- try
- {
- rowSet3.insert(row7);//has no same sort criteria
- fail ("must fail");
- } catch (InvalidAccessException&) {}
- row7.addSortField("1");
- testRowStrictWeak(row7, row6, row5);
- rowSet3.insert(row7);
- std::set<Row>::iterator it3 = rowSet3.begin();
- assert (row7 == *it3);
- ++it3;
- assert (row6 == *it3);
- ++it3;
- assert (row5 == *it3);
- row5.replaceSortField("0", "2");
- row6.replaceSortField("0", "2");
- row7.replaceSortField("0", "2");
- rowSet3.clear();
- rowSet3.insert(row7);
- rowSet3.insert(row6);
- rowSet3.insert(row5);
- it3 = rowSet3.begin();
- assert (row5 == *it3);
- ++it3;
- assert (row6 == *it3);
- ++it3;
- assert (row7 == *it3);
- row5.resetSort();
- row6.resetSort();
- row7.resetSort();
- rowSet3.clear();
- rowSet3.insert(row5);
- rowSet3.insert(row6);
- rowSet3.insert(row7);
- it3 = rowSet3.begin();
- assert (row7 == *it3);
- ++it3;
- assert (row6 == *it3);
- ++it3;
- assert (row5 == *it3);
- }
- void DataTest::testRowStrictWeak(const Row& row1, const Row& row2, const Row& row3)
- {
- assert (row1 < row2 && !(row2 < row1)); // antisymmetric
- assert (row1 < row2 && row2 < row3 && row1 < row3); // transitive
- assert (!(row1 < row1)); // irreflexive
- }
- void DataTest::testRowFormat()
- {
- Row row1;
- row1.append("field0", 0);
- row1.append("field1", 1);
- row1.append("field2", 2);
- row1.append("field3", 3);
- row1.append("field4", 4);
- SimpleRowFormatter rf;
- std::streamsize sz = rf.getColumnWidth();
- std::string line(sz * 5, '-');
- std::ostringstream os;
- os << std::left << std::setw(sz) << "field0"
- << std::setw(sz) << "field1"
- << std::setw(sz) << "field2"
- << std::setw(sz) << "field3"
- << std::setw(sz) << "field4" << std::endl
- << line << std::endl;
- assert (row1.namesToString() == os.str());
- os.str("");
- os << std::right << std::setw(sz) << "0"
- << std::setw(sz) << "1"
- << std::setw(sz) << "2"
- << std::setw(sz) << "3"
- << std::setw(sz) << "4" << std::endl;
- assert (row1.valuesToString() == os.str());
- }
- void DataTest::testDateAndTime()
- {
- DateTime dt;
- Date d(dt);
- Time t(dt);
- assert (dt.year() == d.year());
- assert (dt.month() == d.month());
- assert (dt.day() == d.day());
- assert (dt.hour() == t.hour());
- assert (dt.minute() == t.minute());
- assert (dt.second() == t.second());
- Date d1(2007, 6, 15);
- d1.assign(d.year() - 1, d.month(), d.day());
- assert (d1 < d); assert (d1 != d);
- if (d.month() > 1)
- d1.assign(d.year(), d.month() - 1, d.day());
- else
- d1.assign(d.year() - 1, 12, d.day());
-
- assert (d1 < d); assert (d1 != d);
- if (d.day() > 1)
- {
- d1.assign(d.year(), d.month(), d.day() - 1);
- assert (d1 < d); assert (d1 != d);
- }
- d1.assign(d.year() + 1, d.month(), d.day());
- assert (d1 > d); assert (d1 != d);
-
- if (d.month() < 12)
- d1.assign(d.year(), d.month() + 1, d.day());
- else
- d1.assign(d.year() + 1, 1, d.day());
- assert (d1 > d); assert (d1 != d);
- if (d.day() < dt.daysOfMonth(dt.year(), dt.month()))
- {
- d1.assign(d.year(), d.month(), d.day() + 1);
- assert (d1 > d); assert (d1 != d);
- }
-
- d1.assign(d.year(), d.month(), d.day());
- assert (d1 == d);
- try { d1.assign(-1, 1, 1); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- try { d1.assign(1, 0, 1); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- try { d1.assign(1, 1, 0); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- Time t1(12, 30, 15);
-
- if (t.hour() > 1)
- {
- t1.assign(t.hour() - 1, t.minute(), t.second());
- assert (t1 < t); assert (t1 != t);
- }
- if (t.minute() > 1)
- {
- t1.assign(t.hour(), t.minute() - 1, t.second());
- assert (t1 < t); assert (t1 != t);
- }
-
- if (t.second() > 1)
- {
- t1.assign(t.hour(), t.minute(), t.second() - 1);
- assert (t1 < t); assert (t1 != t);
- }
- if (t.hour() < 23)
- {
- t1.assign(t.hour() + 1, t.minute(), t.second());
- assert (t1 > t); assert (t1 != t);
- }
- if (t.minute() < 59)
- {
- t1.assign(t.hour(), t.minute() + 1, t.second());
- assert (t1 > t); assert (t1 != t);
- }
- if (t.second() < 59)
- {
- t1.assign(t.hour(), t.minute(), t.second() + 1);
- assert (t1 > t); assert (t1 != t);
- }
- t1.assign(t.hour(), t.minute(), t.second());
- assert (t1 == t);
- try { t1.assign(-1, 0, 0); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- try { t1.assign(0, -1, 0); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- try { t1.assign(0, 0, -1); fail ("must fail"); }
- catch (InvalidArgumentException&) { }
- d1 = dt;
- assert (d1 == dt);
- t1 = dt;
- assert (t1 == dt);
- }
- void DataTest::testExternalBindingAndExtraction()
- {
- AbstractExtractionVecVec extractionVec;
- AbstractExtractionVec extraction;
- AbstractBindingVec binding;
- Session tmp (Poco::Data::Test::Connector::KEY, "dummy.db");
- int i;
- AbstractExtraction* pExt1 = into(i);
- AbstractExtraction* pExt2 = into(i);
- assert (1 == pExt1->referenceCount());
- assert (1 == pExt2->referenceCount());
- {
- Statement stmt(tmp);
- stmt.addExtract(pExt1); // retain external ownership in addition to giving it to statement
- assert (2 == pExt1->referenceCount());
- stmt.addExtract(pExt2, false); // give ownership to statement
- assert (1 == pExt2->referenceCount());
- }
- assert (1 == pExt1->referenceCount()); delete pExt1;
- // pExt2 does not exist any more
- AbstractBinding* pBind1 = use(i, "mybind1");
- AbstractBinding* pBind2 = use(i, "mybind2");
- AbstractBinding* pBind3 = use(i, "mybind3");
- assert (1 == pBind1->referenceCount());
- assert (1 == pBind2->referenceCount());
- assert (1 == pBind3->referenceCount());
- {
- Statement stmt(tmp);
- stmt.addBind(pBind1); // retain external ownership in addition to giving it to statement
- assert (2 == pBind1->referenceCount());
- stmt.addBind(pBind2, false);// give ownership to statement
- assert (1 == pBind2->referenceCount());
- stmt.addBind(pBind3);// give ownership to statement
- assert (2 == pBind3->referenceCount());
- stmt.removeBind(pBind3->name());// take ownership from statement
- assert (1 == pBind3->referenceCount());
- try { stmt.removeBind("a bad name"); fail("must fail"); }
- catch (NotFoundException&) { }
- }
- assert (1 == pBind1->referenceCount()); delete pBind1;
- // pBind2 does not exist any more
- assert (1 == pBind3->referenceCount()); delete pBind3;
- }
- void DataTest::setUp()
- {
- }
- void DataTest::tearDown()
- {
- }
- CppUnit::Test* DataTest::suite()
- {
- CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("DataTest");
- CppUnit_addTest(pSuite, DataTest, testSession);
- CppUnit_addTest(pSuite, DataTest, testStatementFormatting);
- CppUnit_addTest(pSuite, DataTest, testFeatures);
- CppUnit_addTest(pSuite, DataTest, testProperties);
- CppUnit_addTest(pSuite, DataTest, testBLOB);
- CppUnit_addTest(pSuite, DataTest, testBLOBStreams);
- CppUnit_addTest(pSuite, DataTest, testColumnVector);
- CppUnit_addTest(pSuite, DataTest, testColumnVectorBool);
- CppUnit_addTest(pSuite, DataTest, testColumnDeque);
- CppUnit_addTest(pSuite, DataTest, testColumnList);
- CppUnit_addTest(pSuite, DataTest, testRow);
- CppUnit_addTest(pSuite, DataTest, testRowSort);
- CppUnit_addTest(pSuite, DataTest, testRowFormat);
- CppUnit_addTest(pSuite, DataTest, testDateAndTime);
- CppUnit_addTest(pSuite, DataTest, testExternalBindingAndExtraction);
- return pSuite;
- }
|