9ccb006f61
- Fix clang-tidy warnings from Clang 15
91 lines
3.2 KiB
C++
91 lines
3.2 KiB
C++
#include <gtest/gtest.h>
|
|
#include <cpp-utils/tempfile/TempDir.h>
|
|
#include <cpp-utils/tempfile/TempFile.h>
|
|
#include <cpp-utils/pointer/cast.h>
|
|
#include <blockstore/implementations/ondisk/OnDiskBlockStore2.h>
|
|
#include <cryfs/impl/filesystem/CryDevice.h>
|
|
#include <cryfs/impl/filesystem/CryDir.h>
|
|
#include <cryfs/impl/filesystem/CryFile.h>
|
|
#include <cryfs/impl/filesystem/CryOpenFile.h>
|
|
#include "../testutils/MockConsole.h"
|
|
#include <cryfs/impl/config/CryConfigLoader.h>
|
|
#include <cryfs/impl/config/CryPresetPasswordBasedKeyProvider.h>
|
|
#include <cpp-utils/system/homedir.h>
|
|
#include "../testutils/TestWithFakeHomeDirectory.h"
|
|
#include <cpp-utils/io/NoninteractiveConsole.h>
|
|
|
|
//TODO (whole project) Make constructors explicit when implicit construction not needed
|
|
|
|
using ::testing::Test;
|
|
using std::make_shared;
|
|
using std::shared_ptr;
|
|
using cpputils::TempDir;
|
|
using cpputils::TempFile;
|
|
using cpputils::make_unique_ref;
|
|
using cpputils::unique_ref;
|
|
using cpputils::Random;
|
|
using cpputils::SCrypt;
|
|
using cpputils::Data;
|
|
using cpputils::NoninteractiveConsole;
|
|
using blockstore::ondisk::OnDiskBlockStore2;
|
|
using boost::none;
|
|
using cryfs::CryPresetPasswordBasedKeyProvider;
|
|
|
|
namespace bf = boost::filesystem;
|
|
using namespace cryfs;
|
|
|
|
namespace {
|
|
|
|
class CryFsTest: public Test, public TestWithMockConsole, public TestWithFakeHomeDirectory {
|
|
public:
|
|
CryFsTest(): tempLocalStateDir(), localStateDir(tempLocalStateDir.path()), rootdir(), config(false) {
|
|
}
|
|
|
|
shared_ptr<CryConfigFile> loadOrCreateConfig() {
|
|
auto keyProvider = make_unique_ref<CryPresetPasswordBasedKeyProvider>("mypassword", make_unique_ref<SCrypt>(SCrypt::TestSettings));
|
|
return CryConfigLoader(make_shared<NoninteractiveConsole>(mockConsole()), Random::PseudoRandom(), std::move(keyProvider), localStateDir, none, none, none).loadOrCreate(config.path(), false, false).right().configFile;
|
|
}
|
|
|
|
unique_ref<OnDiskBlockStore2> blockStore() {
|
|
return make_unique_ref<OnDiskBlockStore2>(rootdir.path());
|
|
}
|
|
|
|
cpputils::TempDir tempLocalStateDir;
|
|
LocalStateDir localStateDir;
|
|
TempDir rootdir;
|
|
TempFile config;
|
|
};
|
|
|
|
auto failOnIntegrityViolation() {
|
|
return [] {
|
|
EXPECT_TRUE(false);
|
|
};
|
|
}
|
|
|
|
TEST_F(CryFsTest, CreatedRootdirIsLoadableAfterClosing) {
|
|
{
|
|
CryDevice dev(loadOrCreateConfig(), blockStore(), localStateDir, 0x12345678, false, false, failOnIntegrityViolation());
|
|
dev.setContext(fspp::Context {fspp::relatime()});
|
|
}
|
|
CryDevice dev(loadOrCreateConfig(), blockStore(), localStateDir, 0x12345678, false, false, failOnIntegrityViolation());
|
|
dev.setContext(fspp::Context {fspp::relatime()});
|
|
auto rootDir = dev.LoadDir(bf::path("/"));
|
|
rootDir.value()->children();
|
|
}
|
|
|
|
TEST_F(CryFsTest, LoadingFilesystemDoesntModifyConfigFile) {
|
|
{
|
|
CryDevice dev(loadOrCreateConfig(), blockStore(), localStateDir, 0x12345678, false, false, failOnIntegrityViolation());
|
|
dev.setContext(fspp::Context {fspp::relatime()});
|
|
}
|
|
const Data configAfterCreating = Data::LoadFromFile(config.path()).value();
|
|
{
|
|
CryDevice dev(loadOrCreateConfig(), blockStore(), localStateDir, 0x12345678, false, false, failOnIntegrityViolation());
|
|
dev.setContext(fspp::Context {fspp::relatime()});
|
|
}
|
|
const Data configAfterLoading = Data::LoadFromFile(config.path()).value();
|
|
EXPECT_EQ(configAfterCreating, configAfterLoading);
|
|
}
|
|
|
|
}
|