Blame SOURCES/0044-crypto-tests-Add-unit-test-for-s3crypt_sha512.patch

cdf651
From f0d437220d5c76f6b09dee5c5744397549fc3813 Mon Sep 17 00:00:00 2001
cdf651
From: Lukas Slebodnik <lslebodn@redhat.com>
cdf651
Date: Tue, 31 Jul 2018 20:44:16 +0000
cdf651
Subject: [PATCH] crypto-tests: Add unit test for s3crypt_sha512
cdf651
cdf651
Resolves:
cdf651
https://pagure.io/SSSD/sssd/issue/3791
cdf651
cdf651
Merges: https://pagure.io/SSSD/sssd/pull-request/3792
cdf651
cdf651
Reviewed-by: Jakub Hrozek <jhrozek@redhat.com>
cdf651
---
cdf651
 src/tests/crypto-tests.c | 32 ++++++++++++++++++++++++++++++++
cdf651
 1 file changed, 32 insertions(+)
cdf651
cdf651
diff --git a/src/tests/crypto-tests.c b/src/tests/crypto-tests.c
cdf651
index 2e826a41b3c1302b87c7136cc37b7c4df02a0584..6f5e22a878ad9e40b73b23915d08395b3f6f2e3d 100644
cdf651
--- a/src/tests/crypto-tests.c
cdf651
+++ b/src/tests/crypto-tests.c
cdf651
@@ -201,6 +201,37 @@ START_TEST(test_sss_encrypt_decrypt)
cdf651
 }
cdf651
 END_TEST
cdf651
 
cdf651
+START_TEST(test_s3crypt_sha512)
cdf651
+{
cdf651
+    int ret;
cdf651
+    char *salt;
cdf651
+    char *userhash;
cdf651
+    char *comphash;
cdf651
+    const char *password = "password123";
cdf651
+    const char *expected_hash = "$6$tU67Q/9h3tm5WJ.U$aL9gjCfiSZQewHTI6A4/MHCVWrMCiJZ.gNXEIw6HO39XGbg.s2nTyGlYXeoQyQtDll3XSbIZN41fJEC3v7ELy0";
cdf651
+
cdf651
+    test_ctx = talloc_new(NULL);
cdf651
+    fail_if(test_ctx == NULL);
cdf651
+
cdf651
+    ret = s3crypt_gen_salt(test_ctx, &salt);
cdf651
+    fail_if(ret != 0);
cdf651
+
cdf651
+    ret = s3crypt_sha512(test_ctx, password, salt, &userhash);
cdf651
+    fail_if(ret != 0);
cdf651
+
cdf651
+    ret = s3crypt_sha512(test_ctx, password, userhash, &comphash);
cdf651
+    fail_if(ret != 0);
cdf651
+    ck_assert_str_eq(userhash, comphash);
cdf651
+    talloc_free(comphash);
cdf651
+
cdf651
+    ret = s3crypt_sha512(test_ctx, password, expected_hash, &comphash);
cdf651
+    fail_if(ret != 0);
cdf651
+    ck_assert_str_eq(expected_hash, comphash);
cdf651
+
cdf651
+    talloc_free(test_ctx);
cdf651
+}
cdf651
+END_TEST
cdf651
+
cdf651
 Suite *crypto_suite(void)
cdf651
 {
cdf651
     Suite *s = suite_create("sss_crypto");
cdf651
@@ -216,6 +247,7 @@ Suite *crypto_suite(void)
cdf651
     tcase_add_test(tc, test_base64_encode);
cdf651
     tcase_add_test(tc, test_base64_decode);
cdf651
     tcase_add_test(tc, test_sss_encrypt_decrypt);
cdf651
+    tcase_add_test(tc, test_s3crypt_sha512);
cdf651
     /* Add all test cases to the test suite */
cdf651
     suite_add_tcase(s, tc);
cdf651
 
cdf651
-- 
cdf651
2.14.4
cdf651