2012-12-18 00:56:40 -05:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#include <stdio.h> /* printf */
|
|
|
|
#include <stdlib.h> /* abort */
|
|
|
|
#include <string.h> /* memset */
|
2012-12-18 00:56:40 -05:00
|
|
|
|
|
|
|
extern "C" {
|
2013-05-19 11:38:18 +02:00
|
|
|
#include "pios_flash.h" /* PIOS_FLASH_* API */
|
2012-12-18 00:56:40 -05:00
|
|
|
#include "pios_flash_ut_priv.h"
|
|
|
|
|
|
|
|
extern struct pios_flash_ut_cfg flash_config;
|
|
|
|
|
|
|
|
#include "pios_flashfs_logfs_priv.h"
|
|
|
|
|
2013-04-18 23:32:52 -04:00
|
|
|
extern struct flashfs_logfs_cfg flashfs_config_partition_a;
|
|
|
|
extern struct flashfs_logfs_cfg flashfs_config_partition_b;
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#include "pios_flashfs.h" /* PIOS_FLASHFS_* */
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#define OBJ0_ID 0xAA55AA55
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#define OBJ1_ID 0x12345678
|
2012-12-18 00:56:40 -05:00
|
|
|
#define OBJ1_SIZE 76
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#define OBJ2_ID 0xABCDEFAB
|
2012-12-18 00:56:40 -05:00
|
|
|
#define OBJ2_SIZE 123
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#define OBJ3_ID 0x99999999
|
2012-12-18 00:56:40 -05:00
|
|
|
#define OBJ3_SIZE (256 - 12) // leave room for the slot header
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
#define OBJ4_ID 0x90901111
|
|
|
|
#define OBJ4_SIZE (768) // only fits in partition b slots
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2012-12-18 00:56:40 -05:00
|
|
|
// To use a test fixture, derive a class from testing::Test.
|
|
|
|
class LogfsTestRaw : public testing::Test {
|
|
|
|
protected:
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void SetUp()
|
|
|
|
{
|
|
|
|
/* create an empty, appropriately sized flash filesystem */
|
|
|
|
FILE *theflash = fopen(FLASH_IMAGE_FILE, "wb");
|
|
|
|
uint8_t sector[flash_config.size_of_sector];
|
|
|
|
|
|
|
|
memset(sector, 0xFF, sizeof(sector));
|
|
|
|
for (uint32_t i = 0; i < flash_config.size_of_flash / flash_config.size_of_sector; i++) {
|
|
|
|
fwrite(sector, sizeof(sector), 1, theflash);
|
|
|
|
}
|
|
|
|
fclose(theflash);
|
|
|
|
|
|
|
|
/* Set up obj1 */
|
|
|
|
for (uint32_t i = 0; i < sizeof(obj1); i++) {
|
|
|
|
obj1[i] = 0x10 + (i % 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set up a second version of obj1 with different data */
|
|
|
|
for (uint32_t i = 0; i < sizeof(obj1_alt); i++) {
|
|
|
|
obj1_alt[i] = 0xA0 + (i % 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set up obj2 */
|
|
|
|
for (uint32_t i = 0; i < sizeof(obj2); i++) {
|
|
|
|
obj2[i] = 0x20 + (i % 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set up obj3 */
|
|
|
|
for (uint32_t i = 0; i < sizeof(obj3); i++) {
|
|
|
|
obj3[i] = 0x30 + (i % 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set up obj4 */
|
|
|
|
for (uint32_t i = 0; i < sizeof(obj4); i++) {
|
|
|
|
obj4[i] = 0x40 + (i % 10);
|
|
|
|
}
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void TearDown()
|
|
|
|
{
|
|
|
|
unlink("theflash.bin");
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1[OBJ1_SIZE];
|
|
|
|
unsigned char obj1_alt[OBJ1_SIZE];
|
|
|
|
unsigned char obj2[OBJ2_SIZE];
|
|
|
|
unsigned char obj3[OBJ3_SIZE];
|
|
|
|
unsigned char obj4[OBJ4_SIZE];
|
2012-12-18 00:56:40 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(LogfsTestRaw, FlashInit) {
|
2013-05-19 11:38:18 +02:00
|
|
|
uintptr_t flash_id;
|
|
|
|
|
|
|
|
EXPECT_EQ(0, PIOS_Flash_UT_Init(&flash_id, &flash_config));
|
|
|
|
PIOS_Flash_UT_Destroy(flash_id);
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestRaw, LogfsInit) {
|
2013-05-19 11:38:18 +02:00
|
|
|
uintptr_t flash_id;
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_Flash_UT_Init(&flash_id, &flash_config));
|
|
|
|
|
|
|
|
uintptr_t fs_id;
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Logfs_Init(&fs_id, &flashfs_config_partition_a, &pios_ut_flash_driver, flash_id));
|
|
|
|
PIOS_FLASHFS_Logfs_Destroy(fs_id);
|
|
|
|
PIOS_Flash_UT_Destroy(flash_id);
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
class LogfsTestCooked : public LogfsTestRaw {
|
|
|
|
protected:
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void SetUp()
|
|
|
|
{
|
|
|
|
/* First, we need to set up the super fixture (LogfsTestRaw) */
|
|
|
|
LogfsTestRaw::SetUp();
|
|
|
|
|
|
|
|
/* Init the flash and the flashfs so we don't need to repeat this in every test */
|
|
|
|
EXPECT_EQ(0, PIOS_Flash_UT_Init(&flash_id, &flash_config));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Logfs_Init(&fs_id, &flashfs_config_partition_a, &pios_ut_flash_driver, flash_id));
|
|
|
|
}
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void TearDown()
|
|
|
|
{
|
|
|
|
PIOS_FLASHFS_Logfs_Destroy(fs_id);
|
|
|
|
PIOS_Flash_UT_Destroy(flash_id);
|
|
|
|
}
|
2013-04-16 21:15:06 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
uintptr_t flash_id;
|
|
|
|
uintptr_t fs_id;
|
2012-12-18 00:56:40 -05:00
|
|
|
};
|
|
|
|
|
2013-04-16 21:15:06 -04:00
|
|
|
TEST_F(LogfsTestCooked, BadIdLogfsFormat) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(-1, PIOS_FLASHFS_Format(fs_id + 1));
|
2013-04-16 21:15:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, BadIdSave) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(-1, PIOS_FLASHFS_ObjSave(fs_id + 1, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
2013-04-16 21:15:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, BadIdLoad) {
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(-1, PIOS_FLASHFS_ObjLoad(fs_id + 1, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
2013-04-16 21:15:06 -04:00
|
|
|
}
|
|
|
|
|
2012-12-18 00:56:40 -05:00
|
|
|
TEST_F(LogfsTestCooked, LogfsFormat) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Format(fs_id));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteOne) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteVerifyOne) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteVerifyDeleteVerifyOne) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjDelete(fs_id, OBJ1_ID, 0));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(-3, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteTwoVerifyOneA) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write obj1 then obj2 */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
|
|
|
|
/* Read back obj1 */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteTwoVerifyOneB) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write obj2 then obj1 */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
|
|
|
|
/* Read back obj1 */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteZeroSize) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write a zero length object */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ0_ID, 0, NULL, 0));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteVerifyZeroLength) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write a zero length object */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ0_ID, 0, NULL, 0));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Read back a zero length object -- effectively an existence check */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ0_ID, 0, NULL, 0));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteMaxSize) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write a max length object */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ3_ID, 0, obj3, sizeof(obj3)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, ReadNonexistent) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Read back a zero length object -- basically an existence check */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(-3, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteVerifyMultiInstance) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write instance zero */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Write a non-zero instance ID */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 123, obj1_alt, sizeof(obj1_alt)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Read back instance 123 */
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 123, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1_alt, obj1_check, sizeof(obj1_alt)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Read back instance 0 */
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, FillFilesystemAndGarbageCollect) {
|
2013-05-19 11:38:18 +02:00
|
|
|
/* Fill up the entire filesystem with multiple instances of obj1 */
|
|
|
|
for (uint32_t i = 0; i < (flashfs_config_partition_a.arena_size / flashfs_config_partition_a.slot_size) - 1; i++) {
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, i, obj1, sizeof(obj1)));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Should fail to add a new object since the filesystem is full */
|
|
|
|
EXPECT_EQ(-4, PIOS_FLASHFS_ObjSave(fs_id, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
|
|
|
|
/* Now save a new version of an existing object which should trigger gc and succeed */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1_alt, sizeof(obj1_alt)));
|
|
|
|
|
|
|
|
/* Read back one of the original obj1 instances */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 1, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
|
|
|
|
|
|
|
/* Read back the new version of obj1 written after gc */
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1_alt, obj1_check, sizeof(obj1_alt)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCooked, WriteManyVerify) {
|
2013-05-19 11:38:18 +02:00
|
|
|
for (uint32_t i = 0; i < 10000; i++) {
|
|
|
|
/* Write a collection of objects */
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ0_ID, 0, NULL, 0));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ1_ID, 123, obj1_alt, sizeof(obj1_alt)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id, OBJ3_ID, 0, obj3, sizeof(obj3)));
|
|
|
|
}
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ0_ID, 0, NULL, 0));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj1_alt_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_alt_check, 0, sizeof(obj1_alt_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ1_ID, 123, obj1_alt_check, sizeof(obj1_alt_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1_alt, obj1_alt_check, sizeof(obj1_alt)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj2_check[OBJ2_SIZE];
|
|
|
|
memset(obj2_check, 0, sizeof(obj2_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ2_ID, 0, obj2_check, sizeof(obj2_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj2, obj2_check, sizeof(obj2)));
|
2012-12-18 00:56:40 -05:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
unsigned char obj3_check[OBJ3_SIZE];
|
|
|
|
memset(obj3_check, 0, sizeof(obj3_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id, OBJ3_ID, 0, obj3_check, sizeof(obj3_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj3, obj3_check, sizeof(obj3)));
|
2012-12-18 00:56:40 -05:00
|
|
|
}
|
2013-04-18 23:32:52 -04:00
|
|
|
|
|
|
|
class LogfsTestCookedMultiPart : public LogfsTestRaw {
|
|
|
|
protected:
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void SetUp()
|
|
|
|
{
|
|
|
|
/* First, we need to set up the super fixture (LogfsTestRaw) */
|
|
|
|
LogfsTestRaw::SetUp();
|
|
|
|
|
|
|
|
/* Init the flash and the flashfs so we don't need to repeat this in every test */
|
|
|
|
EXPECT_EQ(0, PIOS_Flash_UT_Init(&flash_id, &flash_config));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Logfs_Init(&fs_id_a, &flashfs_config_partition_a, &pios_ut_flash_driver, flash_id));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Logfs_Init(&fs_id_b, &flashfs_config_partition_b, &pios_ut_flash_driver, flash_id));
|
|
|
|
}
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
virtual void TearDown()
|
|
|
|
{
|
|
|
|
PIOS_FLASHFS_Logfs_Destroy(fs_id_b);
|
|
|
|
PIOS_FLASHFS_Logfs_Destroy(fs_id_a);
|
|
|
|
PIOS_Flash_UT_Destroy(flash_id);
|
|
|
|
}
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
uintptr_t flash_id;
|
|
|
|
uintptr_t fs_id_a;
|
|
|
|
uintptr_t fs_id_b;
|
2013-04-18 23:32:52 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCookedMultiPart, WriteOneWriteOneVerify) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_a, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_b, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
|
|
|
|
/* OBJ1 found in A */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id_a, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj1, obj1_check, sizeof(obj1)));
|
|
|
|
|
|
|
|
/* OBJ2 found in B */
|
|
|
|
unsigned char obj2_check[OBJ2_SIZE];
|
|
|
|
memset(obj2_check, 0, sizeof(obj2_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id_b, OBJ2_ID, 0, obj2_check, sizeof(obj2_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj2, obj2_check, sizeof(obj2)));
|
2013-04-18 23:32:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCookedMultiPart, WriteOneWriteOneFormatOneVerify) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_a, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_b, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_Format(fs_id_a));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* OBJ2 still found in B */
|
|
|
|
unsigned char obj2_check[OBJ2_SIZE];
|
|
|
|
memset(obj2_check, 0, sizeof(obj2_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id_b, OBJ2_ID, 0, obj2_check, sizeof(obj2_check)));
|
|
|
|
EXPECT_EQ(0, memcmp(obj2, obj2_check, sizeof(obj2)));
|
2013-04-18 23:32:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCookedMultiPart, WriteOneWriteOneNoCross) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_a, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_b, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
|
|
|
|
|
|
|
/* OBJ1 not found in B */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(-3, PIOS_FLASHFS_ObjLoad(fs_id_b, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
|
|
|
|
|
|
|
/* OBJ2 not found in A */
|
|
|
|
unsigned char obj2_check[OBJ2_SIZE];
|
|
|
|
memset(obj2_check, 0, sizeof(obj2_check));
|
|
|
|
EXPECT_EQ(-3, PIOS_FLASHFS_ObjLoad(fs_id_a, OBJ2_ID, 0, obj2_check, sizeof(obj2_check)));
|
2013-04-18 23:32:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCookedMultiPart, WriteOneWriteOneDeleteOne) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_a, OBJ1_ID, 0, obj1, sizeof(obj1)));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_b, OBJ2_ID, 0, obj2, sizeof(obj2)));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjDelete(fs_id_a, OBJ1_ID, 0));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* OBJ1 not found in A */
|
|
|
|
unsigned char obj1_check[OBJ1_SIZE];
|
|
|
|
memset(obj1_check, 0, sizeof(obj1_check));
|
|
|
|
EXPECT_EQ(-3, PIOS_FLASHFS_ObjLoad(fs_id_a, OBJ1_ID, 0, obj1_check, sizeof(obj1_check)));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* OBJ2 still found in B */
|
|
|
|
unsigned char obj2_check[OBJ2_SIZE];
|
|
|
|
memset(obj2_check, 0, sizeof(obj2_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id_b, OBJ2_ID, 0, obj2_check, sizeof(obj2_check)));
|
2013-04-18 23:32:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(LogfsTestCookedMultiPart, WriteLarge) {
|
2013-05-19 11:38:18 +02:00
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjSave(fs_id_b, OBJ4_ID, 0, obj4, sizeof(obj4)));
|
2013-04-18 23:32:52 -04:00
|
|
|
|
2013-05-19 11:38:18 +02:00
|
|
|
/* OBJ4 found in B */
|
|
|
|
unsigned char obj4_check[OBJ4_SIZE];
|
|
|
|
memset(obj4_check, 0, sizeof(obj4_check));
|
|
|
|
EXPECT_EQ(0, PIOS_FLASHFS_ObjLoad(fs_id_b, OBJ4_ID, 0, obj4_check, sizeof(obj4_check)));
|
2013-04-18 23:32:52 -04:00
|
|
|
}
|