parent
0a8a64008c
commit
782469d788
@ -0,0 +1,60 @@
|
||||
// SPDX-License-Identifier: GPL-2.0-only
|
||||
/*
|
||||
* Digital Voice Modem - Test Suite
|
||||
* GPLv2 Open Source. Use is subject to license terms.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* Copyright (C) 2026 Bryan Biedenkapp, N2PLL
|
||||
*
|
||||
*/
|
||||
#include "host/Defines.h"
|
||||
#include "common/DESCrypto.h"
|
||||
#include "common/Log.h"
|
||||
#include "common/Utils.h"
|
||||
|
||||
using namespace crypto;
|
||||
|
||||
#include <catch2/catch_test_macros.hpp>
|
||||
#include <stdlib.h>
|
||||
#include <time.h>
|
||||
|
||||
TEST_CASE("DES Crypto Test", "[des][crypto_test]") {
|
||||
bool failed = false;
|
||||
|
||||
INFO("DES Crypto Test");
|
||||
|
||||
srand((unsigned int)time(NULL));
|
||||
|
||||
// key (K) - DES uses 8-byte (64-bit) keys
|
||||
uint8_t K[8] =
|
||||
{
|
||||
0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF
|
||||
};
|
||||
|
||||
// message - DES operates on 8-byte blocks
|
||||
uint8_t message[8] =
|
||||
{
|
||||
0x90, 0x56, 0x00, 0x00, 0x2D, 0x75, 0xE6, 0x8D
|
||||
};
|
||||
|
||||
// perform crypto
|
||||
DES* des = new DES();
|
||||
|
||||
Utils::dump(2U, "DES_Crypto_Test, Message", message, 8);
|
||||
|
||||
uint8_t* crypted = des->encryptBlock(message, K);
|
||||
Utils::dump(2U, "DES_Crypto_Test, Encrypted", crypted, 8);
|
||||
|
||||
uint8_t* decrypted = des->decryptBlock(crypted, K);
|
||||
Utils::dump(2U, "DES_Crypto_Test, Decrypted", decrypted, 8);
|
||||
|
||||
for (uint32_t i = 0; i < 8U; i++) {
|
||||
if (decrypted[i] != message[i]) {
|
||||
::LogError("T", "DES_Crypto_Test, INVALID AT IDX %d", i);
|
||||
failed = true;
|
||||
}
|
||||
}
|
||||
|
||||
delete des;
|
||||
REQUIRE(failed==false);
|
||||
}
|
||||
Loading…
Reference in new issue