mirror of
https://gitlab.isc.org/isc-projects/kea
synced 2025-10-13 14:06:26 +00:00
[trac1061] Tests for finding of the zone.
This commit is contained in:
@@ -70,7 +70,7 @@ public:
|
|||||||
* be returned - the ID is only passed back to the connection as
|
* be returned - the ID is only passed back to the connection as
|
||||||
* an opaque handle.
|
* an opaque handle.
|
||||||
*/
|
*/
|
||||||
virtual std::pair<bool, int> getZone(const isc::dns::Name& name) const;
|
virtual std::pair<bool, int> getZone(const isc::dns::Name& name) const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -146,6 +146,24 @@ public:
|
|||||||
isc::dns::RRsetList* target = NULL,
|
isc::dns::RRsetList* target = NULL,
|
||||||
const FindOptions options = FIND_DEFAULT)
|
const FindOptions options = FIND_DEFAULT)
|
||||||
const = 0;
|
const = 0;
|
||||||
|
/**
|
||||||
|
* \brief The zone ID
|
||||||
|
*
|
||||||
|
* This function provides the stored zone ID as passed to the
|
||||||
|
* constructor. This is meant for testing purposes and normal
|
||||||
|
* applications shouldn't need it.
|
||||||
|
*/
|
||||||
|
int zone_id() const { return (zone_id_); }
|
||||||
|
/**
|
||||||
|
* \brief The database connection.
|
||||||
|
*
|
||||||
|
* This function provides the database connection stored inside as
|
||||||
|
* passed to the constructor. This is meant for testing purposes and
|
||||||
|
* normal applications shouldn't need it.
|
||||||
|
*/
|
||||||
|
const DatabaseConnection& connection() const {
|
||||||
|
return (connection_);
|
||||||
|
}
|
||||||
private:
|
private:
|
||||||
DatabaseConnection& connection_;
|
DatabaseConnection& connection_;
|
||||||
const int zone_id_;
|
const int zone_id_;
|
||||||
|
@@ -28,6 +28,7 @@ run_unittests_SOURCES += rbtree_unittest.cc
|
|||||||
run_unittests_SOURCES += zonetable_unittest.cc
|
run_unittests_SOURCES += zonetable_unittest.cc
|
||||||
run_unittests_SOURCES += memory_datasrc_unittest.cc
|
run_unittests_SOURCES += memory_datasrc_unittest.cc
|
||||||
run_unittests_SOURCES += logger_unittest.cc
|
run_unittests_SOURCES += logger_unittest.cc
|
||||||
|
run_unittests_SOURCES += database_unittest.cc
|
||||||
|
|
||||||
run_unittests_CPPFLAGS = $(AM_CPPFLAGS) $(GTEST_INCLUDES)
|
run_unittests_CPPFLAGS = $(AM_CPPFLAGS) $(GTEST_INCLUDES)
|
||||||
run_unittests_LDFLAGS = $(AM_LDFLAGS) $(GTEST_LDFLAGS)
|
run_unittests_LDFLAGS = $(AM_LDFLAGS) $(GTEST_LDFLAGS)
|
||||||
|
93
src/lib/datasrc/tests/database_unittest.cc
Normal file
93
src/lib/datasrc/tests/database_unittest.cc
Normal file
@@ -0,0 +1,93 @@
|
|||||||
|
// Copyright (C) 2011 Internet Systems Consortium, Inc. ("ISC")
|
||||||
|
//
|
||||||
|
// Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
// purpose with or without fee is hereby granted, provided that the above
|
||||||
|
// copyright notice and this permission notice appear in all copies.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
||||||
|
// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
// AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
||||||
|
// INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||||
|
// LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
||||||
|
// OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
// PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#include <dns/name.h>
|
||||||
|
|
||||||
|
#include <datasrc/database.h>
|
||||||
|
|
||||||
|
using namespace isc::datasrc;
|
||||||
|
using namespace std;
|
||||||
|
using namespace boost;
|
||||||
|
using isc::dns::Name;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A virtual database connection that pretends it contains single zone --
|
||||||
|
* example.org.
|
||||||
|
*/
|
||||||
|
class MockConnection : public DatabaseConnection {
|
||||||
|
public:
|
||||||
|
virtual std::pair<bool, int> getZone(const Name& name) const {
|
||||||
|
if (name == Name("zone.example.org")) {
|
||||||
|
return (std::pair<bool, int>(true, 42));
|
||||||
|
} else {
|
||||||
|
return (std::pair<bool, int>(false, 0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class DatabaseClientTest : public ::testing::Test {
|
||||||
|
public:
|
||||||
|
DatabaseClientTest() {
|
||||||
|
createClient();
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* We initialize the client from a function, so we can call it multiple
|
||||||
|
* times per test.
|
||||||
|
*/
|
||||||
|
void createClient() {
|
||||||
|
current_connection_ = new MockConnection();
|
||||||
|
client_.reset(new DatabaseClient(auto_ptr<DatabaseConnection>(
|
||||||
|
current_connection_)));
|
||||||
|
}
|
||||||
|
// Will be deleted by client_, just keep the current value for comparison.
|
||||||
|
MockConnection* current_connection_;
|
||||||
|
auto_ptr<DatabaseClient> client_;
|
||||||
|
/**
|
||||||
|
* Check the zone finder is a valid one and references the zone ID and
|
||||||
|
* connection available here.
|
||||||
|
*/
|
||||||
|
void checkZoneFinder(const DataSourceClient::FindResult& zone) {
|
||||||
|
ASSERT_NE(ZoneFinderPtr(), zone.zone_finder) << "No zone finder";
|
||||||
|
shared_ptr<DatabaseClient::Finder> finder(
|
||||||
|
dynamic_pointer_cast<DatabaseClient::Finder>(zone.zone_finder));
|
||||||
|
ASSERT_NE(shared_ptr<DatabaseClient::Finder>(), finder) <<
|
||||||
|
"Wrong type of finder";
|
||||||
|
EXPECT_EQ(42, finder->zone_id());
|
||||||
|
EXPECT_EQ(current_connection_, &finder->connection());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_F(DatabaseClientTest, zoneNotFound) {
|
||||||
|
DataSourceClient::FindResult zone(client_->findZone(Name("example.com")));
|
||||||
|
EXPECT_EQ(result::NOTFOUND, zone.code);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(DatabaseClientTest, exactZone) {
|
||||||
|
DataSourceClient::FindResult zone(client_->findZone(Name("example.org")));
|
||||||
|
EXPECT_EQ(result::SUCCESS, zone.code);
|
||||||
|
checkZoneFinder(zone);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(DatabaseClientTest, superZone) {
|
||||||
|
DataSourceClient::FindResult zone(client_->findZone(Name(
|
||||||
|
"sub.example.org")));
|
||||||
|
EXPECT_EQ(result::PARTIALMATCH, zone.code);
|
||||||
|
checkZoneFinder(zone);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Reference in New Issue
Block a user