2016-02-10 00:58:03 +01:00
|
|
|
#include <gtest/gtest.h>
|
2016-02-11 12:53:42 +01:00
|
|
|
#include "cpp-utils/crypto/kdf/Scrypt.h"
|
2015-10-27 22:19:06 +01:00
|
|
|
|
2015-10-27 23:19:11 +01:00
|
|
|
using namespace cpputils;
|
2016-02-22 02:38:06 +01:00
|
|
|
using std::string;
|
2015-10-27 22:19:06 +01:00
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
class SCryptTest : public ::testing::Test {
|
|
|
|
public:
|
2018-10-21 22:53:53 +02:00
|
|
|
bool keyEquals(const EncryptionKey& lhs, const EncryptionKey& rhs) {
|
|
|
|
ASSERT(lhs.binaryLength() == rhs.binaryLength(), "Keys must have equal size to be comparable");
|
|
|
|
return 0 == std::memcmp(lhs.data(), rhs.data(), lhs.binaryLength());
|
2018-09-11 18:53:21 -07:00
|
|
|
}
|
2016-02-22 02:38:06 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(SCryptTest, GeneratedKeyIsReproductible_448) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(56, "mypassword");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(56, "mypassword", derivedKey.kdfParameters);
|
|
|
|
EXPECT_TRUE(keyEquals(derivedKey.key, rederivedKey));
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2023-05-23 18:07:11 -07:00
|
|
|
TEST_F(SCryptTest, BackwardsCompatibility_448) {
|
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
2023-05-23 18:32:50 -07:00
|
|
|
auto kdfParameters = Data::FromString("00040000000000000100000002000000E429AFB0500BD5D172089598B76E6B9ED6D0DDAF3B08F99AA05357F96F4F7823");
|
2023-05-23 18:07:11 -07:00
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(56, "mypassword", kdfParameters);
|
2023-05-23 18:32:50 -07:00
|
|
|
EXPECT_EQ("70416B4E1569E2335442F7FE740E6A8ADC149514B7B6D7838A996AE0E2125F743341E72FF9F44C91A9675EAE459C0C0126FDB6CE220436E0", rederivedKey.ToString());
|
2023-05-23 18:07:11 -07:00
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, GeneratedKeyIsReproductible_256) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(32, "mypassword");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(32, "mypassword", derivedKey.kdfParameters);
|
|
|
|
EXPECT_TRUE(keyEquals(derivedKey.key, rederivedKey));
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2023-05-23 18:07:11 -07:00
|
|
|
TEST_F(SCryptTest, BackwardsCompatibility_256) {
|
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
2023-05-23 18:32:50 -07:00
|
|
|
auto kdfParameters = Data::FromString("000400000000000001000000020000007D65C035E0C4250003A24ED11ABD41F6101DEEC104F6875EE1B808A6683535BD");
|
2023-05-23 18:07:11 -07:00
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(32, "mypassword", kdfParameters);
|
2023-05-23 18:32:50 -07:00
|
|
|
EXPECT_EQ("A423A0176F99A3197722D4B8686110FC2E2C04FF5E37AE43A7241097598F599D", rederivedKey.ToString());
|
2023-05-23 18:07:11 -07:00
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, GeneratedKeyIsReproductible_128) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(16, "mypassword");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(16, "mypassword", derivedKey.kdfParameters);
|
|
|
|
EXPECT_TRUE(keyEquals(derivedKey.key, rederivedKey));
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2023-05-23 18:07:11 -07:00
|
|
|
TEST_F(SCryptTest, BackwardsCompatibility_128) {
|
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
2023-05-23 18:32:50 -07:00
|
|
|
auto kdfParameters = Data::FromString("000400000000000001000000020000008514339A7F583D80C9865C9EA01B698EE8AEAF99AE5F7AE79C8817D2E73D553D");
|
2023-05-23 18:07:11 -07:00
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(16, "mypassword", kdfParameters);
|
2023-05-23 18:32:50 -07:00
|
|
|
EXPECT_EQ("2EF2F0A4EC335C961D4BE58BFB722F75", rederivedKey.ToString());
|
2023-05-23 18:07:11 -07:00
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, GeneratedKeyIsReproductible_DefaultSettings) {
|
2023-05-23 18:47:40 -07:00
|
|
|
SCrypt scrypt(SCrypt::DefaultSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(32, "mypassword");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(32, "mypassword", derivedKey.kdfParameters);
|
2018-10-21 19:31:08 -07:00
|
|
|
EXPECT_TRUE(keyEquals(derivedKey.key, rederivedKey));
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2023-05-23 18:47:40 -07:00
|
|
|
TEST_F(SCryptTest, BackwardsCompatibility_DefaultSettings) {
|
|
|
|
SCrypt scrypt(SCrypt::DefaultSettings);
|
|
|
|
auto kdfParameters = Data::FromString("00001000000000000400000008000000D04ACF9519113E1F4E4D7FB39EFBF257CD71CF8536A468B546C2F5A65C6B622C");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(32, "mypassword", kdfParameters);
|
|
|
|
EXPECT_EQ("AB70B1923F3EB9EB8A75C15FD665AC3494C5EBAB80323D864135DBB2911ECF59", rederivedKey.ToString());
|
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, DifferentPasswordResultsInDifferentKey) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(16, "mypassword");
|
|
|
|
auto rederivedKey = scrypt.deriveExistingKey(16, "mypassword2", derivedKey.kdfParameters);
|
|
|
|
EXPECT_FALSE(keyEquals(derivedKey.key, rederivedKey));
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, UsesCorrectSettings) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::TestSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(16, "mypassword");
|
|
|
|
auto parameters = SCryptParameters::deserialize(derivedKey.kdfParameters);
|
2016-02-22 02:38:06 +01:00
|
|
|
EXPECT_EQ(SCrypt::TestSettings.SALT_LEN, parameters.salt().size());
|
2021-04-20 23:09:00 -07:00
|
|
|
EXPECT_EQ(SCrypt::TestSettings.N, parameters.n());
|
2016-02-22 02:38:06 +01:00
|
|
|
EXPECT_EQ(SCrypt::TestSettings.r, parameters.r());
|
|
|
|
EXPECT_EQ(SCrypt::TestSettings.p, parameters.p());
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|
|
|
|
|
2016-02-22 02:38:06 +01:00
|
|
|
TEST_F(SCryptTest, UsesCorrectDefaultSettings) {
|
2018-10-21 19:31:08 -07:00
|
|
|
SCrypt scrypt(SCrypt::DefaultSettings);
|
|
|
|
auto derivedKey = scrypt.deriveNewKey(16, "mypassword");
|
|
|
|
auto parameters = SCryptParameters::deserialize(derivedKey.kdfParameters);
|
2016-02-22 02:38:06 +01:00
|
|
|
EXPECT_EQ(SCrypt::DefaultSettings.SALT_LEN, parameters.salt().size());
|
2021-04-20 23:09:00 -07:00
|
|
|
EXPECT_EQ(SCrypt::DefaultSettings.N, parameters.n());
|
2016-02-22 02:38:06 +01:00
|
|
|
EXPECT_EQ(SCrypt::DefaultSettings.r, parameters.r());
|
|
|
|
EXPECT_EQ(SCrypt::DefaultSettings.p, parameters.p());
|
2015-10-27 22:19:06 +01:00
|
|
|
}
|