* grub-core/tests/pbkdf2_test.c: New test.
This commit is contained in:
parent
2def66169e
commit
41f26e0ebc
4 changed files with 107 additions and 0 deletions
|
@ -1,3 +1,7 @@
|
|||
2013-11-12 Vladimir Serbinenko <phcoder@gmail.com>
|
||||
|
||||
* grub-core/tests/pbkdf2_test.c: New test.
|
||||
|
||||
2013-11-12 Vladimir Serbinenko <phcoder@gmail.com>
|
||||
|
||||
* grub-core/lib/xzembed/xz_dec_stream.c: Remove variable length arrays.
|
||||
|
|
|
@ -1916,6 +1916,11 @@ module = {
|
|||
common = tests/xnu_uuid_test.c;
|
||||
};
|
||||
|
||||
module = {
|
||||
name = pbkdf2_test;
|
||||
common = tests/pbkdf2_test.c;
|
||||
};
|
||||
|
||||
module = {
|
||||
name = div_test;
|
||||
common = tests/div_test.c;
|
||||
|
|
|
@ -60,6 +60,7 @@ grub_functional_all_tests (grub_extcmd_context_t ctxt __attribute__ ((unused)),
|
|||
grub_dl_load ("cmdline_cat_test");
|
||||
grub_dl_load ("div_test");
|
||||
grub_dl_load ("xnu_uuid_test");
|
||||
grub_dl_load ("pbkdf2_test");
|
||||
|
||||
FOR_LIST_ELEMENTS (test, grub_test_list)
|
||||
ok = !grub_test_run (test) && ok;
|
||||
|
|
97
grub-core/tests/pbkdf2_test.c
Normal file
97
grub-core/tests/pbkdf2_test.c
Normal file
|
@ -0,0 +1,97 @@
|
|||
/*
|
||||
* GRUB -- GRand Unified Bootloader
|
||||
* Copyright (C) 2013 Free Software Foundation, Inc.
|
||||
*
|
||||
* GRUB is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* GRUB is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <grub/test.h>
|
||||
#include <grub/dl.h>
|
||||
#include <grub/misc.h>
|
||||
#include <grub/crypto.h>
|
||||
|
||||
GRUB_MOD_LICENSE ("GPLv3+");
|
||||
|
||||
struct
|
||||
{
|
||||
const char *P;
|
||||
grub_size_t Plen;
|
||||
const char *S;
|
||||
grub_size_t Slen;
|
||||
unsigned int c;
|
||||
grub_size_t dkLen;
|
||||
const char *DK;
|
||||
} vectors[] = {
|
||||
/* RFC6070. */
|
||||
{
|
||||
"password", 8,
|
||||
"salt", 4,
|
||||
1, 20,
|
||||
"\x0c\x60\xc8\x0f\x96\x1f\x0e\x71\xf3\xa9\xb5\x24\xaf\x60\x12"
|
||||
"\x06\x2f\xe0\x37\xa6"
|
||||
},
|
||||
{
|
||||
"password", 8,
|
||||
"salt", 4,
|
||||
2, 20,
|
||||
"\xea\x6c\x01\x4d\xc7\x2d\x6f\x8c"
|
||||
"\xcd\x1e\xd9\x2a\xce\x1d\x41\xf0"
|
||||
"\xd8\xde\x89\x57"
|
||||
},
|
||||
{
|
||||
"password", 8,
|
||||
"salt", 4,
|
||||
4096, 20,
|
||||
"\x4b\x00\x79\x01\xb7\x65\x48\x9a\xbe\xad\x49\xd9\x26\xf7"
|
||||
"\x21\xd0\x65\xa4\x29\xc1"
|
||||
},
|
||||
{
|
||||
"passwordPASSWORDpassword", 24,
|
||||
"saltSALTsaltSALTsaltSALTsaltSALTsalt", 36,
|
||||
4096, 25,
|
||||
"\x3d\x2e\xec\x4f\xe4\x1c\x84\x9b\x80\xc8\xd8\x36\x62\xc0"
|
||||
"\xe4\x4a\x8b\x29\x1a\x96\x4c\xf2\xf0\x70\x38"
|
||||
},
|
||||
{
|
||||
"pass\0word", 9,
|
||||
"sa\0lt", 5,
|
||||
4096, 16,
|
||||
"\x56\xfa\x6a\xa7\x55\x48\x09\x9d\xcc\x37\xd7\xf0\x34\x25\xe0\xc3"
|
||||
}
|
||||
};
|
||||
|
||||
static void
|
||||
pbkdf2_test (void)
|
||||
{
|
||||
grub_size_t i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE (vectors); i++)
|
||||
{
|
||||
gcry_err_code_t err;
|
||||
grub_uint8_t DK[32];
|
||||
err = grub_crypto_pbkdf2 (GRUB_MD_SHA1,
|
||||
(const grub_uint8_t *) vectors[i].P,
|
||||
vectors[i].Plen,
|
||||
(const grub_uint8_t *) vectors[i].S,
|
||||
vectors[i].Slen,
|
||||
vectors[i].c,
|
||||
DK, vectors[i].dkLen);
|
||||
grub_test_assert (err == 0, "gcry error %d", err);
|
||||
grub_test_assert (grub_memcmp (DK, vectors[i].DK, vectors[i].dkLen) == 0,
|
||||
"PBKDF2 mismatch");
|
||||
}
|
||||
}
|
||||
|
||||
/* Register example_test method as a functional test. */
|
||||
GRUB_FUNCTIONAL_TEST (pbkdf2_test, pbkdf2_test);
|
Loading…
Reference in a new issue