2017-11-09 19:34:51 +01:00
|
|
|
/*
|
|
|
|
|
* This file is part of the Flowee project
|
|
|
|
|
* Copyright (C) 2012-2015 The Bitcoin Core developers
|
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
2015-09-07 15:22:23 -07:00
|
|
|
|
2015-10-22 21:33:06 -04:00
|
|
|
#include "dbwrapper.h"
|
2015-09-07 15:22:23 -07:00
|
|
|
#include "random.h"
|
|
|
|
|
#include "test/test_bitcoin.h"
|
|
|
|
|
|
|
|
|
|
#include <boost/assign/std/vector.hpp> // for 'operator+=()'
|
|
|
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
|
|
|
|
|
|
using namespace boost::assign; // bring 'operator+=()' into scope
|
|
|
|
|
using namespace boost::filesystem;
|
|
|
|
|
|
|
|
|
|
// Test if a string consists entirely of null characters
|
2017-08-15 11:07:01 -06:00
|
|
|
bool is_null_key(const std::vector<unsigned char>& key) {
|
2015-09-07 15:22:23 -07:00
|
|
|
bool isnull = true;
|
|
|
|
|
|
|
|
|
|
for (unsigned int i = 0; i < key.size(); i++)
|
|
|
|
|
isnull &= (key[i] == '\x00');
|
|
|
|
|
|
|
|
|
|
return isnull;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-22 21:02:20 -04:00
|
|
|
BOOST_FIXTURE_TEST_SUITE(dbwrapper_tests, BasicTestingSetup)
|
2015-09-07 15:22:23 -07:00
|
|
|
|
2015-10-22 21:02:20 -04:00
|
|
|
BOOST_AUTO_TEST_CASE(dbwrapper)
|
2015-09-07 15:22:23 -07:00
|
|
|
{
|
2017-08-29 21:04:09 +02:00
|
|
|
path ph = temp_directory_path() / unique_path();
|
2018-11-02 20:42:45 +01:00
|
|
|
CDBWrapper dbw(ph, (1 << 20), true, false);
|
2017-08-29 21:04:09 +02:00
|
|
|
char key = 'k';
|
|
|
|
|
uint256 in = GetRandHash();
|
|
|
|
|
uint256 res;
|
2015-09-07 15:22:23 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
BOOST_CHECK(dbw.Write(key, in));
|
|
|
|
|
BOOST_CHECK(dbw.Read(key, res));
|
|
|
|
|
BOOST_CHECK_EQUAL(res.ToString(), in.ToString());
|
2015-09-07 15:22:23 -07:00
|
|
|
}
|
2015-10-08 01:22:50 -07:00
|
|
|
|
|
|
|
|
// Test batch operations
|
2015-10-22 21:02:20 -04:00
|
|
|
BOOST_AUTO_TEST_CASE(dbwrapper_batch)
|
2015-10-08 01:22:50 -07:00
|
|
|
{
|
2017-08-29 21:04:09 +02:00
|
|
|
path ph = temp_directory_path() / unique_path();
|
|
|
|
|
CDBWrapper dbw(ph, (1 << 20), true, false);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
char key = 'i';
|
|
|
|
|
uint256 in = GetRandHash();
|
|
|
|
|
char key2 = 'j';
|
|
|
|
|
uint256 in2 = GetRandHash();
|
|
|
|
|
char key3 = 'k';
|
|
|
|
|
uint256 in3 = GetRandHash();
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
uint256 res;
|
2018-11-02 20:42:45 +01:00
|
|
|
CDBBatch batch;
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
batch.Write(key, in);
|
|
|
|
|
batch.Write(key2, in2);
|
|
|
|
|
batch.Write(key3, in3);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
// Remove key3 before it's even been written
|
|
|
|
|
batch.Erase(key3);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
dbw.WriteBatch(batch);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
BOOST_CHECK(dbw.Read(key, res));
|
|
|
|
|
BOOST_CHECK_EQUAL(res.ToString(), in.ToString());
|
|
|
|
|
BOOST_CHECK(dbw.Read(key2, res));
|
|
|
|
|
BOOST_CHECK_EQUAL(res.ToString(), in2.ToString());
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
// key3 never should've been written
|
|
|
|
|
BOOST_CHECK(dbw.Read(key3, res) == false);
|
2015-10-08 01:22:50 -07:00
|
|
|
}
|
|
|
|
|
|
2015-10-22 21:02:20 -04:00
|
|
|
BOOST_AUTO_TEST_CASE(dbwrapper_iterator)
|
2015-10-08 01:22:50 -07:00
|
|
|
{
|
2017-08-29 21:04:09 +02:00
|
|
|
path ph = temp_directory_path() / unique_path();
|
|
|
|
|
CDBWrapper dbw(ph, (1 << 20), true, false);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
// The two keys are intentionally chosen for ordering
|
|
|
|
|
char key = 'j';
|
|
|
|
|
uint256 in = GetRandHash();
|
|
|
|
|
BOOST_CHECK(dbw.Write(key, in));
|
|
|
|
|
char key2 = 'k';
|
|
|
|
|
uint256 in2 = GetRandHash();
|
|
|
|
|
BOOST_CHECK(dbw.Write(key2, in2));
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
boost::scoped_ptr<CDBIterator> it(const_cast<CDBWrapper*>(&dbw)->NewIterator());
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
// Be sure to seek past the obfuscation key (if it exists)
|
|
|
|
|
it->Seek(key);
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
char key_res;
|
|
|
|
|
uint256 val_res;
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
it->GetKey(key_res);
|
|
|
|
|
it->GetValue(val_res);
|
|
|
|
|
BOOST_CHECK_EQUAL(key_res, key);
|
|
|
|
|
BOOST_CHECK_EQUAL(val_res.ToString(), in.ToString());
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
it->Next();
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
it->GetKey(key_res);
|
|
|
|
|
it->GetValue(val_res);
|
|
|
|
|
BOOST_CHECK_EQUAL(key_res, key2);
|
|
|
|
|
BOOST_CHECK_EQUAL(val_res.ToString(), in2.ToString());
|
2015-10-08 01:22:50 -07:00
|
|
|
|
2017-08-29 21:04:09 +02:00
|
|
|
it->Next();
|
|
|
|
|
BOOST_CHECK_EQUAL(it->Valid(), false);
|
2015-10-08 01:22:50 -07:00
|
|
|
}
|
2015-09-07 15:22:23 -07:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_SUITE_END()
|