2015-10-23 12:16:23 +02:00
|
|
|
#include <google/gtest/gtest.h>
|
|
|
|
#include "../../src/config/CryConfigLoader.h"
|
|
|
|
#include "../testutils/MockConsole.h"
|
|
|
|
#include <messmer/cpp-utils/tempfile/TempFile.h>
|
|
|
|
#include <messmer/cpp-utils/random/Random.h>
|
|
|
|
#include <messmer/blockstore/implementations/encrypted/ciphers/ciphers.h>
|
|
|
|
|
|
|
|
using cpputils::unique_ref;
|
|
|
|
using cpputils::make_unique_ref;
|
|
|
|
using cpputils::TempFile;
|
2015-10-24 19:35:37 +02:00
|
|
|
using boost::optional;
|
|
|
|
using boost::none;
|
2015-10-23 12:16:23 +02:00
|
|
|
using std::string;
|
|
|
|
using ::testing::Return;
|
|
|
|
using ::testing::_;
|
|
|
|
|
|
|
|
using namespace cryfs;
|
|
|
|
|
|
|
|
class CryConfigLoaderTest: public ::testing::Test, public TestWithMockConsole {
|
|
|
|
public:
|
2015-10-24 19:35:37 +02:00
|
|
|
CryConfigLoaderTest(): file(false) {}
|
2015-10-23 12:16:23 +02:00
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
CryConfigLoader loader(const string &password) {
|
|
|
|
return CryConfigLoader(mockConsole(), cpputils::Random::PseudoRandom(), [password] {return password;});
|
|
|
|
}
|
|
|
|
|
|
|
|
CryConfigFile Create(const string &password = "mypassword") {
|
2015-10-23 12:16:23 +02:00
|
|
|
EXPECT_FALSE(file.exists());
|
2015-10-24 19:35:37 +02:00
|
|
|
return loader(password).loadOrCreate(file.path());
|
2015-10-23 12:16:23 +02:00
|
|
|
}
|
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
CryConfigFile Load(const string &password = "mypassword") {
|
2015-10-23 12:16:23 +02:00
|
|
|
EXPECT_TRUE(file.exists());
|
2015-10-24 19:35:37 +02:00
|
|
|
return loader(password).loadOrCreate(file.path());
|
2015-10-23 12:16:23 +02:00
|
|
|
}
|
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
void CreateWithRootBlob(const string &rootBlob, const string &password = "mypassword") {
|
|
|
|
auto cfg = loader(password).loadOrCreate(file.path());
|
2015-10-23 12:16:23 +02:00
|
|
|
cfg.config()->SetRootBlob(rootBlob);
|
|
|
|
cfg.save();
|
|
|
|
}
|
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
void CreateWithCipher(const string &cipher, const string &password = "mypassword") {
|
|
|
|
auto cfg = loader(password).loadOrCreate(file.path());
|
2015-10-23 12:16:23 +02:00
|
|
|
cfg.config()->SetCipher(cipher);
|
|
|
|
cfg.save();
|
|
|
|
}
|
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
void CreateWithEncryptionKey(const string &encKey, const string &password = "mypassword") {
|
|
|
|
auto cfg = loader(password).loadOrCreate(file.path());
|
2015-10-23 12:16:23 +02:00
|
|
|
cfg.config()->SetEncryptionKey(encKey);
|
|
|
|
cfg.save();
|
|
|
|
}
|
|
|
|
|
|
|
|
TempFile file;
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, CreatesNewIfNotExisting) {
|
|
|
|
EXPECT_FALSE(file.exists());
|
|
|
|
Create();
|
|
|
|
EXPECT_TRUE(file.exists());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, DoesntCrashIfExisting) {
|
|
|
|
Create();
|
|
|
|
Load();
|
|
|
|
}
|
|
|
|
|
2015-10-24 19:35:37 +02:00
|
|
|
TEST_F(CryConfigLoaderTest, DoesntLoadIfWrongPassword) {
|
|
|
|
Create("mypassword");
|
2015-10-25 19:00:30 +01:00
|
|
|
EXPECT_EXIT(
|
2015-10-24 19:35:37 +02:00
|
|
|
Load("mypassword2"),
|
2015-10-25 19:00:30 +01:00
|
|
|
::testing::ExitedWithCode(1),
|
2015-10-24 19:35:37 +02:00
|
|
|
"Wrong password"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-10-23 12:16:23 +02:00
|
|
|
TEST_F(CryConfigLoaderTest, RootBlob_Load) {
|
|
|
|
CreateWithRootBlob("rootblobid");
|
|
|
|
auto loaded = Load();
|
|
|
|
EXPECT_EQ("rootblobid", loaded.config()->RootBlob());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, RootBlob_Create) {
|
|
|
|
auto created = Create();
|
|
|
|
EXPECT_EQ("", created.config()->RootBlob());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, EncryptionKey_Load) {
|
|
|
|
CreateWithEncryptionKey("encryptionkey");
|
|
|
|
auto loaded = Load();
|
|
|
|
EXPECT_EQ("encryptionkey", loaded.config()->EncryptionKey());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, EncryptionKey_Create) {
|
|
|
|
auto created = Create();
|
|
|
|
//aes-256-gcm is the default cipher chosen by mockConsole()
|
|
|
|
blockstore::encrypted::AES256_GCM::EncryptionKey::FromString(created.config()->EncryptionKey()); // This crashes if key is invalid
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, Cipher_Load) {
|
|
|
|
CreateWithCipher("ciphername");
|
|
|
|
auto loaded = Load();
|
|
|
|
EXPECT_EQ("ciphername", loaded.config()->Cipher());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigLoaderTest, Cipher_Create) {
|
|
|
|
auto created = Create();
|
|
|
|
//aes-256-gcm is the default cipher chosen by mockConsole()
|
|
|
|
EXPECT_EQ("aes-256-gcm", created.config()->Cipher());
|
|
|
|
}
|