2017-09-28 07:41:08 +01:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
2019-01-25 23:38:34 -08:00
|
|
|
#include <cryfs/impl/localstate/BasedirMetadata.h>
|
|
|
|
#include <cryfs/impl/localstate/LocalStateDir.h>
|
|
|
|
#include <cryfs/impl/config/CryConfig.h>
|
2017-09-28 07:41:08 +01:00
|
|
|
#include <cpp-utils/tempfile/TempDir.h>
|
2017-09-30 09:03:19 +01:00
|
|
|
#include "../testutils/TestWithFakeHomeDirectory.h"
|
2017-09-28 07:41:08 +01:00
|
|
|
|
|
|
|
using cpputils::TempDir;
|
|
|
|
using cryfs::BasedirMetadata;
|
|
|
|
using std::ofstream;
|
|
|
|
namespace bf = boost::filesystem;
|
|
|
|
using FilesystemID = cryfs::CryConfig::FilesystemID ;
|
|
|
|
|
2017-09-30 09:03:19 +01:00
|
|
|
class BasedirMetadataTest : public ::testing::Test, TestWithFakeHomeDirectory {
|
2017-09-28 07:41:08 +01:00
|
|
|
public:
|
2018-04-21 22:04:21 -07:00
|
|
|
TempDir tempLocalStateDir;
|
|
|
|
cryfs::LocalStateDir localStateDir;
|
|
|
|
|
2017-09-28 07:41:08 +01:00
|
|
|
TempDir tempdir;
|
|
|
|
bf::path basedir1;
|
|
|
|
bf::path basedir2;
|
|
|
|
const FilesystemID id1;
|
|
|
|
const FilesystemID id2;
|
|
|
|
|
|
|
|
BasedirMetadataTest()
|
2018-04-21 22:04:21 -07:00
|
|
|
: tempLocalStateDir()
|
|
|
|
, localStateDir(tempLocalStateDir.path())
|
|
|
|
, tempdir()
|
2017-09-28 07:41:08 +01:00
|
|
|
, basedir1(tempdir.path() / "my/basedir")
|
|
|
|
, basedir2(tempdir.path() / "my/other/basedir")
|
|
|
|
, id1(FilesystemID::FromString("1491BB4932A389EE14BC7090AC772972"))
|
|
|
|
, id2(FilesystemID::FromString("A1491BB493214BC7090C772972A389EE"))
|
|
|
|
{
|
|
|
|
// Create basedirs so bf::canonical() works
|
|
|
|
bf::create_directories(basedir1);
|
|
|
|
bf::create_directories(basedir2);
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenEmptyState_whenCalled_thenSucceeds) {
|
2018-04-21 22:04:21 -07:00
|
|
|
EXPECT_TRUE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id1));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenStateWithBasedir_whenCalledForDifferentBasedir_thenSucceeds) {
|
2018-04-21 22:04:21 -07:00
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir2, id1).save();
|
|
|
|
EXPECT_TRUE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id1));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenStateWithBasedir_whenCalledWithSameId_thenSucceeds) {
|
2018-04-21 22:04:21 -07:00
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id1).save();
|
|
|
|
EXPECT_TRUE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id1));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenStateWithBasedir_whenCalledWithDifferentId_thenFails) {
|
2018-04-21 22:04:21 -07:00
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id2).save();
|
|
|
|
EXPECT_FALSE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id1));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenStateWithUpdatedBasedir_whenCalledWithSameId_thenSucceeds) {
|
2018-04-21 22:04:21 -07:00
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id2).save();
|
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id1).save();
|
|
|
|
EXPECT_TRUE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id1));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BasedirMetadataTest, givenStateWithUpdatedBasedir_whenCalledWithDifferentId_thenFails) {
|
2018-04-21 22:04:21 -07:00
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id2).save();
|
|
|
|
BasedirMetadata::load(localStateDir).updateFilesystemIdForBasedir(basedir1, id1).save();
|
|
|
|
EXPECT_FALSE(BasedirMetadata::load(localStateDir).filesystemIdForBasedirIsCorrect(basedir1, id2));
|
2017-09-28 07:41:08 +01:00
|
|
|
}
|