2016-02-11 16:39:42 +01:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <gmock/gmock.h>
|
|
|
|
#include <cryfs/config/CryConfigCreator.h>
|
|
|
|
#include <cryfs/config/CryCipher.h>
|
|
|
|
#include <cpp-utils/crypto/symmetric/ciphers.h>
|
2015-10-22 18:48:14 +02:00
|
|
|
#include "../testutils/MockConsole.h"
|
2016-03-27 00:09:07 +08:00
|
|
|
#include <gitversion/gitversion.h>
|
2015-10-22 18:48:14 +02:00
|
|
|
|
|
|
|
using namespace cryfs;
|
|
|
|
|
|
|
|
using boost::optional;
|
|
|
|
using boost::none;
|
|
|
|
using cpputils::Console;
|
|
|
|
using cpputils::unique_ref;
|
|
|
|
using cpputils::make_unique_ref;
|
|
|
|
using std::string;
|
|
|
|
using std::vector;
|
2016-01-17 14:57:40 +01:00
|
|
|
using std::shared_ptr;
|
|
|
|
using std::make_shared;
|
2015-10-22 18:48:14 +02:00
|
|
|
using ::testing::_;
|
|
|
|
using ::testing::Return;
|
|
|
|
using ::testing::Invoke;
|
|
|
|
using ::testing::ValuesIn;
|
|
|
|
using ::testing::HasSubstr;
|
|
|
|
using ::testing::UnorderedElementsAreArray;
|
|
|
|
using ::testing::WithParamInterface;
|
|
|
|
|
2016-03-01 17:45:48 +01:00
|
|
|
#define EXPECT_ASK_TO_USE_DEFAULT_SETTINGS() \
|
|
|
|
EXPECT_CALL(*console, askYesNo("Use default settings?")).Times(1)
|
|
|
|
#define EXPECT_DOES_NOT_ASK_TO_USE_DEFAULT_SETTINGS() \
|
|
|
|
EXPECT_CALL(*console, askYesNo("Use default settings?")).Times(0)
|
|
|
|
#define EXPECT_ASK_FOR_CIPHER() \
|
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block cipher"), UnorderedElementsAreArray(CryCiphers::supportedCipherNames()))).Times(1)
|
|
|
|
#define EXPECT_DOES_NOT_ASK_FOR_CIPHER() \
|
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block cipher"), _)).Times(0)
|
|
|
|
#define EXPECT_ASK_FOR_BLOCKSIZE() \
|
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block size"), _)).Times(1)
|
|
|
|
#define EXPECT_DOES_NOT_ASK_FOR_BLOCKSIZE() \
|
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block size"), _)).Times(0)
|
2016-06-26 23:24:32 -07:00
|
|
|
#define EXPECT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION() \
|
|
|
|
EXPECT_CALL(*console, askYesNo(HasSubstr("missing block"))).Times(1)
|
|
|
|
#define EXPECT_DOES_NOT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION() \
|
|
|
|
EXPECT_CALL(*console, askYesNo(HasSubstr("missing block"))).Times(0)
|
|
|
|
#define IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION() \
|
|
|
|
EXPECT_CALL(*console, askYesNo(HasSubstr("missing block")))
|
2016-03-01 17:45:48 +01:00
|
|
|
|
2015-10-22 18:48:14 +02:00
|
|
|
class CryConfigCreatorTest: public ::testing::Test {
|
|
|
|
public:
|
|
|
|
CryConfigCreatorTest()
|
2016-01-17 14:57:40 +01:00
|
|
|
: console(make_shared<MockConsole>()),
|
2016-02-21 01:34:21 +01:00
|
|
|
creator(console, cpputils::Random::PseudoRandom(), false),
|
|
|
|
noninteractiveCreator(console, cpputils::Random::PseudoRandom(), true) {
|
2016-03-01 17:45:48 +01:00
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block cipher"), _)).WillRepeatedly(ChooseAnyCipher());
|
|
|
|
EXPECT_CALL(*console, ask(HasSubstr("block size"), _)).WillRepeatedly(Return(0));
|
2015-10-22 18:48:14 +02:00
|
|
|
}
|
2016-01-17 14:57:40 +01:00
|
|
|
shared_ptr<MockConsole> console;
|
2015-10-22 18:48:14 +02:00
|
|
|
CryConfigCreator creator;
|
2016-02-21 01:34:21 +01:00
|
|
|
CryConfigCreator noninteractiveCreator;
|
2015-10-22 18:48:14 +02:00
|
|
|
|
2016-03-01 17:45:48 +01:00
|
|
|
void AnswerNoToDefaultSettings() {
|
|
|
|
EXPECT_ASK_TO_USE_DEFAULT_SETTINGS().WillOnce(Return(false));
|
|
|
|
}
|
|
|
|
|
|
|
|
void AnswerYesToDefaultSettings() {
|
|
|
|
EXPECT_ASK_TO_USE_DEFAULT_SETTINGS().WillOnce(Return(true));
|
|
|
|
}
|
|
|
|
};
|
2015-10-22 18:48:14 +02:00
|
|
|
|
2015-10-30 19:53:15 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesAskForCipherIfNotSpecified) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2016-01-25 14:33:40 +01:00
|
|
|
EXPECT_ASK_FOR_CIPHER().WillOnce(ChooseAnyCipher());
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2015-10-30 19:53:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForCipherIfSpecified) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2016-01-25 14:33:40 +01:00
|
|
|
EXPECT_DOES_NOT_ASK_FOR_CIPHER();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(string("aes-256-gcm"), none, none).config;
|
2015-10-22 18:48:14 +02:00
|
|
|
}
|
|
|
|
|
2016-03-01 17:45:48 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForCipherIfUsingDefaultSettings) {
|
|
|
|
AnswerYesToDefaultSettings();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_CIPHER();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2016-03-01 17:45:48 +01:00
|
|
|
}
|
|
|
|
|
2016-02-21 01:34:21 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForCipherIfNoninteractive) {
|
2016-03-01 17:45:48 +01:00
|
|
|
EXPECT_DOES_NOT_ASK_TO_USE_DEFAULT_SETTINGS();
|
2016-02-21 01:34:21 +01:00
|
|
|
EXPECT_DOES_NOT_ASK_FOR_CIPHER();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = noninteractiveCreator.create(none, none, none).config;
|
2016-02-21 01:34:21 +01:00
|
|
|
}
|
|
|
|
|
2016-03-01 17:45:48 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesAskForBlocksizeIfNotSpecified) {
|
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2016-03-01 17:45:48 +01:00
|
|
|
EXPECT_ASK_FOR_BLOCKSIZE().WillOnce(Return(1));
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2016-03-01 17:45:48 +01:00
|
|
|
}
|
|
|
|
|
2016-03-04 23:12:41 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForBlocksizeIfSpecified) {
|
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2016-03-04 23:12:41 +01:00
|
|
|
EXPECT_DOES_NOT_ASK_FOR_BLOCKSIZE();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, 10*1024u, none).config;
|
2016-03-04 23:12:41 +01:00
|
|
|
}
|
2016-03-01 17:45:48 +01:00
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForBlocksizeIfNoninteractive) {
|
|
|
|
EXPECT_DOES_NOT_ASK_TO_USE_DEFAULT_SETTINGS();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_BLOCKSIZE();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = noninteractiveCreator.create(none, none, none).config;
|
2016-03-01 17:45:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForBlocksizeIfUsingDefaultSettings) {
|
|
|
|
AnswerYesToDefaultSettings();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_BLOCKSIZE();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesAskWhetherMissingBlocksAreIntegrityViolationsIfNotSpecified) {
|
|
|
|
AnswerNoToDefaultSettings();
|
|
|
|
EXPECT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION().WillOnce(Return(true));
|
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskWhetherMissingBlocksAreIntegrityViolationsIfSpecified_True) {
|
|
|
|
AnswerNoToDefaultSettings();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
|
|
|
CryConfig config = creator.create(none, none, true).config;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskWhetherMissingBlocksAreIntegrityViolationsIfSpecified_False) {
|
|
|
|
AnswerNoToDefaultSettings();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
|
|
|
CryConfig config = creator.create(none, none, false).config;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskWhetherMissingBlocksAreIntegrityViolationsIfNoninteractive) {
|
|
|
|
EXPECT_DOES_NOT_ASK_TO_USE_DEFAULT_SETTINGS();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
|
|
|
CryConfig config = noninteractiveCreator.create(none, none, none).config;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskWhetherMissingBlocksAreIntegrityViolationsIfUsingDefaultSettings) {
|
|
|
|
AnswerYesToDefaultSettings();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2016-03-01 17:45:48 +01:00
|
|
|
}
|
|
|
|
|
2015-10-22 18:48:14 +02:00
|
|
|
TEST_F(CryConfigCreatorTest, ChoosesEmptyRootBlobId) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2015-10-22 18:48:14 +02:00
|
|
|
EXPECT_EQ("", config.RootBlob()); // This tells CryFS to create a new root blob
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, ChoosesValidEncryptionKey_448) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2015-10-22 18:48:14 +02:00
|
|
|
EXPECT_ASK_FOR_CIPHER().WillOnce(ChooseCipher("mars-448-gcm"));
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2015-10-27 23:46:54 +01:00
|
|
|
cpputils::Mars448_GCM::EncryptionKey::FromString(config.EncryptionKey()); // This crashes if invalid
|
2015-10-22 18:48:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, ChoosesValidEncryptionKey_256) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2015-10-22 18:48:14 +02:00
|
|
|
EXPECT_ASK_FOR_CIPHER().WillOnce(ChooseCipher("aes-256-gcm"));
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2015-10-30 19:53:15 +01:00
|
|
|
cpputils::AES256_GCM::EncryptionKey::FromString(config.EncryptionKey()); // This crashes if invalid
|
2015-10-22 18:48:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, ChoosesValidEncryptionKey_128) {
|
2016-03-01 17:45:48 +01:00
|
|
|
AnswerNoToDefaultSettings();
|
2016-06-26 23:24:32 -07:00
|
|
|
IGNORE_ASK_FOR_MISSINGBLOCKISINTEGRITYVIOLATION();
|
2015-10-22 18:48:14 +02:00
|
|
|
EXPECT_ASK_FOR_CIPHER().WillOnce(ChooseCipher("aes-128-gcm"));
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = creator.create(none, none, none).config;
|
2015-10-30 19:53:15 +01:00
|
|
|
cpputils::AES128_GCM::EncryptionKey::FromString(config.EncryptionKey()); // This crashes if invalid
|
2015-10-22 18:48:14 +02:00
|
|
|
}
|
2016-03-01 17:45:48 +01:00
|
|
|
|
2016-03-04 23:12:41 +01:00
|
|
|
TEST_F(CryConfigCreatorTest, DoesNotAskForAnythingIfEverythingIsSpecified) {
|
|
|
|
EXPECT_DOES_NOT_ASK_TO_USE_DEFAULT_SETTINGS();
|
|
|
|
EXPECT_DOES_NOT_ASK_FOR_CIPHER();
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = noninteractiveCreator.create(string("aes-256-gcm"), 10*1024u, none).config;
|
2016-03-04 23:12:41 +01:00
|
|
|
}
|
|
|
|
|
2016-03-27 00:09:07 +08:00
|
|
|
TEST_F(CryConfigCreatorTest, SetsCorrectCreatedWithVersion) {
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = noninteractiveCreator.create(none, none, none).config;
|
2016-03-27 00:09:07 +08:00
|
|
|
EXPECT_EQ(gitversion::VersionString(), config.CreatedWithVersion());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(CryConfigCreatorTest, SetsCorrectVersion) {
|
2016-06-26 23:24:32 -07:00
|
|
|
CryConfig config = noninteractiveCreator.create(none, none, none).config;
|
2016-03-27 00:09:07 +08:00
|
|
|
EXPECT_EQ(gitversion::VersionString(), config.Version());
|
|
|
|
}
|
|
|
|
|
2016-03-01 17:45:48 +01:00
|
|
|
//TODO Add test cases ensuring that the values entered are correctly taken
|