Added test case for Data.FillWithZeroes()

This commit is contained in:
Sebastian Messmer 2014-12-05 12:31:49 +01:00
parent b9c2f43afb
commit a489914f80

View File

@ -1,51 +1,87 @@
#include "gtest/gtest.h" #include "gtest/gtest.h"
#include "blobstore/implementations/ondisk/Data.h" #include "blobstore/implementations/ondisk/Data.h"
#include "test/testutils/VirtualTestFile.h"
using ::testing::Test; using ::testing::Test;
using ::testing::WithParamInterface;
using ::testing::Values;
using blobstore::ondisk::Data; using blobstore::ondisk::Data;
class DataTest: public Test { class DataTest: public Test {
public: public:
void FillData(char *data, size_t size) { bool DataIsZeroes(const Data &data) {
for (size_t i = 0; i < size; ++i) { for (size_t i = 0; i != data.size(); ++ i) {
data[i] = i; if (((char*)data.data())[i] != 0) {
return false;
}
} }
return true;
} }
void CheckData(char *data, size_t size) { void FillData(const VirtualTestFile &fillData, Data *data) {
for (size_t i = 0; i < size; ++i) { ASSERT_EQ(fillData.size(), data->size());
EXPECT_EQ((char)i, data[i]); 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) { class DataTestWithSizeParam: public DataTest, public WithParamInterface<size_t> {
Data data(0); public:
} VirtualTestFile randomData;
TEST_F(DataTest, OneByteData) { DataTestWithSizeParam(): randomData(GetParam()) {}
Data data(1);
((char*)data.data())[0] = 0x3E;
EXPECT_EQ(0x3E, ((char*)data.data())[0]); void FillData(Data *data) {
} DataTest::FillData(randomData, data);
}
TEST_F(DataTest, MidsizeData) { void CheckData(const Data *data) {
Data data(4096); DataTest::CheckData(randomData, data);
}
FillData((char*)data.data(), 4096); };
CheckData((char*)data.data(), 4096); 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 // 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. // are actually working on memory that was validly allocated for us.
TEST_F(DataTest, LargeData) { TEST_P(DataTestWithSizeParam, WriteAndCheck) {
Data data(10 * 1024 * 1024); Data data(GetParam());
FillData((char*)data.data(), 10 * 1024 * 1024); FillData(&data);
CheckData((char*)data.data(), 10 * 1024 * 1024); 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, // 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 cases for storing/loading
//TODO Test case for FillWithZeroes
//TODO Test case for size()