Added test case for Data.FillWithZeroes()
This commit is contained in:
parent
b9c2f43afb
commit
a489914f80
@ -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()
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user