From a489914f8017677b944f8cc9191a101e266ea8a4 Mon Sep 17 00:00:00 2001 From: Sebastian Messmer Date: Fri, 5 Dec 2014 12:31:49 +0100 Subject: [PATCH] Added test case for Data.FillWithZeroes() --- src/test/blobstore/ondisk/DataTest.cpp | 88 ++++++++++++++++++-------- 1 file changed, 61 insertions(+), 27 deletions(-) diff --git a/src/test/blobstore/ondisk/DataTest.cpp b/src/test/blobstore/ondisk/DataTest.cpp index 1d5159f6..8b933746 100644 --- a/src/test/blobstore/ondisk/DataTest.cpp +++ b/src/test/blobstore/ondisk/DataTest.cpp @@ -1,51 +1,87 @@ #include "gtest/gtest.h" #include "blobstore/implementations/ondisk/Data.h" +#include "test/testutils/VirtualTestFile.h" using ::testing::Test; +using ::testing::WithParamInterface; +using ::testing::Values; using blobstore::ondisk::Data; class DataTest: public Test { public: - void FillData(char *data, size_t size) { - for (size_t i = 0; i < size; ++i) { - data[i] = i; + bool DataIsZeroes(const Data &data) { + for (size_t i = 0; i != data.size(); ++ i) { + if (((char*)data.data())[i] != 0) { + return false; + } } + return true; } - void CheckData(char *data, size_t size) { - for (size_t i = 0; i < size; ++i) { - EXPECT_EQ((char)i, data[i]); - } + void FillData(const VirtualTestFile &fillData, Data *data) { + ASSERT_EQ(fillData.size(), data->size()); + std::memcpy(data->data(), fillData.data(), fillData.size()); + } + + void CheckData(const VirtualTestFile &expectedData, const Data *data) { + ASSERT_EQ(expectedData.size(), data->size()); + EXPECT_EQ(0, std::memcmp(expectedData.data(), data->data(), expectedData.size())); } }; -TEST_F(DataTest, EmptyData) { - Data data(0); -} +class DataTestWithSizeParam: public DataTest, public WithParamInterface { +public: + VirtualTestFile randomData; -TEST_F(DataTest, OneByteData) { - Data data(1); - ((char*)data.data())[0] = 0x3E; + DataTestWithSizeParam(): randomData(GetParam()) {} - EXPECT_EQ(0x3E, ((char*)data.data())[0]); -} + void FillData(Data *data) { + DataTest::FillData(randomData, data); + } -TEST_F(DataTest, MidsizeData) { - Data data(4096); - - FillData((char*)data.data(), 4096); - CheckData((char*)data.data(), 4096); -} + void CheckData(const Data *data) { + DataTest::CheckData(randomData, data); + } +}; +INSTANTIATE_TEST_CASE_P(DataTestWithSizeParam, DataTestWithSizeParam, Values(0, 1, 1024, 4096, 10*1024*1024)); // Working on a large data area without a crash is a good indicator that we // are actually working on memory that was validly allocated for us. -TEST_F(DataTest, LargeData) { - Data data(10 * 1024 * 1024); +TEST_P(DataTestWithSizeParam, WriteAndCheck) { + Data data(GetParam()); - FillData((char*)data.data(), 10 * 1024 * 1024); - CheckData((char*)data.data(), 10 * 1024 * 1024); + FillData(&data); + CheckData(&data); +} + +TEST_P(DataTestWithSizeParam, Size) { + Data data(GetParam()); + EXPECT_EQ(GetParam(), data.size()); +} + +TEST_F(DataTest, InitializeWithZeroes) { + Data data(10*1024); + data.FillWithZeroes(); + EXPECT_TRUE(DataIsZeroes(data)); +} + +TEST_F(DataTest, FillModifiedDataWithZeroes) { + Data data(10*1024); + VirtualTestFile randomData(10*1024); + FillData(randomData, &data); + EXPECT_FALSE(DataIsZeroes(data)); + + data.FillWithZeroes(); + EXPECT_TRUE(DataIsZeroes(data)); +} + +//Needs 64bit for representation. This value isn't in the size param list, because the list is also used for read/write checks. +TEST_F(DataTest, LargesizeSize) { + size_t size = 10L*1024*1024*1024; + Data data(size); + EXPECT_EQ(size, data.size()); } // This test doesn't ensure that the Data class gives the memory region free, @@ -63,5 +99,3 @@ TEST_F(DataTest, InaccessibleAfterDeletion) { } //TODO Test cases for storing/loading -//TODO Test case for FillWithZeroes -//TODO Test case for size()