|
@@ -12,7 +12,7 @@
|
|
|
// OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
|
// PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
|
-#include <datasrc/memory/zone_reloader.h>
|
|
|
+#include <datasrc/memory/zone_writer.h>
|
|
|
#include <datasrc/memory/zone_table_segment.h>
|
|
|
#include <datasrc/memory/zone_data.h>
|
|
|
|
|
@@ -35,16 +35,16 @@ namespace {
|
|
|
|
|
|
class TestException {};
|
|
|
|
|
|
-class ZoneReloaderLocalTest : public ::testing::Test {
|
|
|
+class ZoneWriterLocalTest : public ::testing::Test {
|
|
|
public:
|
|
|
- ZoneReloaderLocalTest() :
|
|
|
+ ZoneWriterLocalTest() :
|
|
|
// FIXME: The NullElement probably isn't the best one, but we don't
|
|
|
// know how the config will look, so it just fills the argument
|
|
|
// (which is currently ignored)
|
|
|
segment_(ZoneTableSegment::create(isc::data::NullElement())),
|
|
|
- reloader_(new
|
|
|
- ZoneReloaderLocal(segment_.get(),
|
|
|
- bind(&ZoneReloaderLocalTest::loadAction, this,
|
|
|
+ writer_(new
|
|
|
+ ZoneWriterLocal(segment_.get(),
|
|
|
+ bind(&ZoneWriterLocalTest::loadAction, this,
|
|
|
_1),
|
|
|
Name("example.org"), RRClass::IN())),
|
|
|
load_called_(false),
|
|
@@ -57,8 +57,8 @@ public:
|
|
|
RRClass::IN()));
|
|
|
}
|
|
|
void TearDown() {
|
|
|
- // Release the reloader
|
|
|
- reloader_.reset();
|
|
|
+ // Release the writer
|
|
|
+ writer_.reset();
|
|
|
// Release the table we used
|
|
|
ZoneTable::destroy(segment_->getMemorySegment(),
|
|
|
segment_->getHeader().getTable(), RRClass::IN());
|
|
@@ -67,7 +67,7 @@ public:
|
|
|
}
|
|
|
protected:
|
|
|
scoped_ptr<ZoneTableSegment> segment_;
|
|
|
- scoped_ptr<ZoneReloaderLocal> reloader_;
|
|
|
+ scoped_ptr<ZoneWriterLocal> writer_;
|
|
|
bool load_called_;
|
|
|
bool load_throw_;
|
|
|
bool load_null_;
|
|
@@ -94,112 +94,112 @@ private:
|
|
|
|
|
|
// We call it the way we are supposed to, check every callback is called in the
|
|
|
// right moment.
|
|
|
-TEST_F(ZoneReloaderLocalTest, correctCall) {
|
|
|
+TEST_F(ZoneWriterLocalTest, correctCall) {
|
|
|
// Nothing called before we call it
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
// Just the load gets called now
|
|
|
- EXPECT_NO_THROW(reloader_->load());
|
|
|
+ EXPECT_NO_THROW(writer_->load());
|
|
|
EXPECT_TRUE(load_called_);
|
|
|
load_called_ = false;
|
|
|
|
|
|
- EXPECT_NO_THROW(reloader_->install());
|
|
|
+ EXPECT_NO_THROW(writer_->install());
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
// We don't check explicitly how this works, but call it to free memory. If
|
|
|
// everything is freed should be checked inside the TearDown.
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
}
|
|
|
|
|
|
-TEST_F(ZoneReloaderLocalTest, loadTwice) {
|
|
|
+TEST_F(ZoneWriterLocalTest, loadTwice) {
|
|
|
// Load it the first time
|
|
|
- EXPECT_NO_THROW(reloader_->load());
|
|
|
+ EXPECT_NO_THROW(writer_->load());
|
|
|
EXPECT_TRUE(load_called_);
|
|
|
load_called_ = false;
|
|
|
|
|
|
// The second time, it should not be possible
|
|
|
- EXPECT_THROW(reloader_->load(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->load(), isc::Unexpected);
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
// The object should not be damaged, try installing and clearing now
|
|
|
- EXPECT_NO_THROW(reloader_->install());
|
|
|
+ EXPECT_NO_THROW(writer_->install());
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
// We don't check explicitly how this works, but call it to free memory. If
|
|
|
// everything is freed should be checked inside the TearDown.
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
}
|
|
|
|
|
|
// Try loading after call to install and call to cleanup. Both is
|
|
|
// forbidden.
|
|
|
-TEST_F(ZoneReloaderLocalTest, loadLater) {
|
|
|
+TEST_F(ZoneWriterLocalTest, loadLater) {
|
|
|
// Load first, so we can install
|
|
|
- EXPECT_NO_THROW(reloader_->load());
|
|
|
- EXPECT_NO_THROW(reloader_->install());
|
|
|
+ EXPECT_NO_THROW(writer_->load());
|
|
|
+ EXPECT_NO_THROW(writer_->install());
|
|
|
// Reset so we see nothing is called now
|
|
|
load_called_ = false;
|
|
|
|
|
|
- EXPECT_THROW(reloader_->load(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->load(), isc::Unexpected);
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
// Cleanup and try loading again. Still shouldn't work.
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
|
|
|
- EXPECT_THROW(reloader_->load(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->load(), isc::Unexpected);
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
}
|
|
|
|
|
|
// Try calling install at various bad times
|
|
|
-TEST_F(ZoneReloaderLocalTest, invalidInstall) {
|
|
|
+TEST_F(ZoneWriterLocalTest, invalidInstall) {
|
|
|
// Nothing loaded yet
|
|
|
- EXPECT_THROW(reloader_->install(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->install(), isc::Unexpected);
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
|
|
|
- EXPECT_NO_THROW(reloader_->load());
|
|
|
+ EXPECT_NO_THROW(writer_->load());
|
|
|
load_called_ = false;
|
|
|
// This install is OK
|
|
|
- EXPECT_NO_THROW(reloader_->install());
|
|
|
+ EXPECT_NO_THROW(writer_->install());
|
|
|
// But we can't call it second time now
|
|
|
- EXPECT_THROW(reloader_->install(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->install(), isc::Unexpected);
|
|
|
EXPECT_FALSE(load_called_);
|
|
|
}
|
|
|
|
|
|
// We check we can clean without installing first and nothing bad
|
|
|
// happens. We also misuse the testcase to check we can't install
|
|
|
// after cleanup.
|
|
|
-TEST_F(ZoneReloaderLocalTest, cleanWithoutInstall) {
|
|
|
- EXPECT_NO_THROW(reloader_->load());
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+TEST_F(ZoneWriterLocalTest, cleanWithoutInstall) {
|
|
|
+ EXPECT_NO_THROW(writer_->load());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
|
|
|
EXPECT_TRUE(load_called_);
|
|
|
|
|
|
// We cleaned up, no way to install now
|
|
|
- EXPECT_THROW(reloader_->install(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->install(), isc::Unexpected);
|
|
|
}
|
|
|
|
|
|
// Test the case when load callback throws
|
|
|
-TEST_F(ZoneReloaderLocalTest, loadThrows) {
|
|
|
+TEST_F(ZoneWriterLocalTest, loadThrows) {
|
|
|
load_throw_ = true;
|
|
|
- EXPECT_THROW(reloader_->load(), TestException);
|
|
|
+ EXPECT_THROW(writer_->load(), TestException);
|
|
|
|
|
|
// We can't install now
|
|
|
- EXPECT_THROW(reloader_->install(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->install(), isc::Unexpected);
|
|
|
EXPECT_TRUE(load_called_);
|
|
|
|
|
|
// But we can cleanup
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
}
|
|
|
|
|
|
-// Check the reloader defends itsefl when load action returns NULL
|
|
|
-TEST_F(ZoneReloaderLocalTest, loadNull) {
|
|
|
+// Check the writer defends itsefl when load action returns NULL
|
|
|
+TEST_F(ZoneWriterLocalTest, loadNull) {
|
|
|
load_null_ = true;
|
|
|
- EXPECT_THROW(reloader_->load(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->load(), isc::Unexpected);
|
|
|
|
|
|
// We can't install that
|
|
|
- EXPECT_THROW(reloader_->install(), isc::Unexpected);
|
|
|
+ EXPECT_THROW(writer_->install(), isc::Unexpected);
|
|
|
|
|
|
// It should be possible to clean up safely
|
|
|
- EXPECT_NO_THROW(reloader_->cleanup());
|
|
|
+ EXPECT_NO_THROW(writer_->cleanup());
|
|
|
}
|
|
|
|
|
|
}
|