mirror of
https://github.com/guanzhi/GmSSL.git
synced 2026-06-27 15:43:42 +08:00
Update tests
This commit is contained in:
56
cmake/tool_sm4.cmake
Normal file
56
cmake/tool_sm4.cmake
Normal file
@@ -0,0 +1,56 @@
|
||||
include("${CMAKE_CURRENT_LIST_DIR}/tool_helpers.cmake")
|
||||
|
||||
set(SM4_KEY 0123456789abcdeffedcba9876543210)
|
||||
set(SM4_IV 00000000000000000000000000000000)
|
||||
set(SM4_HMAC_KEY 0123456789abcdeffedcba98765432100123456789abcdeffedcba98765432100123456789abcdeffedcba9876543210)
|
||||
set(SM4_XTS_KEY 0123456789abcdeffedcba987654321000112233445566778899aabbccddeeff)
|
||||
set(SM4_TEXT "0123456789abcdef0123456789abcdef")
|
||||
|
||||
function(gmssl_symmetric_roundtrip name)
|
||||
file(WRITE "${name}.plain" "${SM4_TEXT}")
|
||||
gmssl_run(${ARGN} -encrypt -in "${name}.plain" -out "${name}.cipher")
|
||||
gmssl_run(${ARGN} -decrypt -in "${name}.cipher" -out "${name}.decrypt")
|
||||
gmssl_files_equal("${name}.plain" "${name}.decrypt")
|
||||
endfunction()
|
||||
|
||||
file(WRITE tool_sm4_cbc_kat.plain "0123456789abcdef")
|
||||
gmssl_run(sm4_cbc -encrypt -key ${SM4_KEY} -iv ${SM4_IV}
|
||||
-in tool_sm4_cbc_kat.plain -out tool_sm4_cbc_kat.cipher)
|
||||
gmssl_expect_file_hex(tool_sm4_cbc_kat.cipher
|
||||
"e6887b77dbabb572ffa07fed7548b192ceaace11f2b90b94c2b7a4d9382e471e")
|
||||
gmssl_run(sm4_cbc -decrypt -key ${SM4_KEY} -iv ${SM4_IV}
|
||||
-in tool_sm4_cbc_kat.cipher -out tool_sm4_cbc_kat.decrypt)
|
||||
gmssl_files_equal(tool_sm4_cbc_kat.plain tool_sm4_cbc_kat.decrypt)
|
||||
|
||||
gmssl_symmetric_roundtrip(tool_sm4_cbc sm4_cbc -key ${SM4_KEY} -iv ${SM4_IV})
|
||||
gmssl_symmetric_roundtrip(tool_sm4_ctr sm4_ctr -key ${SM4_KEY} -iv ${SM4_IV})
|
||||
gmssl_symmetric_roundtrip(tool_sm4_gcm sm4_gcm -key ${SM4_KEY} -iv 000000000000000000000000 -aad_hex 001122 -taglen 16)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_cbc_sm3_hmac sm4_cbc_sm3_hmac -key ${SM4_HMAC_KEY} -iv ${SM4_IV} -aad_hex 001122)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_ctr_sm3_hmac sm4_ctr_sm3_hmac -key ${SM4_HMAC_KEY} -iv ${SM4_IV} -aad_hex 001122)
|
||||
|
||||
if(ENABLE_SM4_ECB)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_ecb sm4_ecb -key ${SM4_KEY})
|
||||
endif()
|
||||
if(ENABLE_SM4_CFB)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_cfb sm4_cfb -sbytes 16 -key ${SM4_KEY} -iv ${SM4_IV})
|
||||
endif()
|
||||
if(ENABLE_SM4_OFB)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_ofb sm4_ofb -key ${SM4_KEY} -iv ${SM4_IV})
|
||||
endif()
|
||||
if(ENABLE_SM4_CCM)
|
||||
gmssl_symmetric_roundtrip(tool_sm4_ccm sm4_ccm -key ${SM4_KEY} -iv 000000000000000000000000 -aad_hex 001122 -taglen 16)
|
||||
endif()
|
||||
if(ENABLE_SM4_XTS)
|
||||
file(WRITE tool_sm4_xts.plain "0123456789abcdef0123456789abcdef")
|
||||
gmssl_run(sm4_xts -encrypt -key ${SM4_XTS_KEY} -iv ${SM4_IV} -data_unit_size 32
|
||||
-in tool_sm4_xts.plain -out tool_sm4_xts.cipher)
|
||||
gmssl_run(sm4_xts -decrypt -key ${SM4_XTS_KEY} -iv ${SM4_IV} -data_unit_size 32
|
||||
-in tool_sm4_xts.cipher -out tool_sm4_xts.decrypt)
|
||||
gmssl_files_equal(tool_sm4_xts.plain tool_sm4_xts.decrypt)
|
||||
endif()
|
||||
if(ENABLE_SM4_CBC_MAC)
|
||||
gmssl_expect_stdout("9054fccff72871fdad5202c821dbea05\n"
|
||||
sm4_cbc_mac -key ${SM4_KEY} -in_str abc)
|
||||
gmssl_run(sm4_cbc_mac -key ${SM4_KEY} -bin -in_str abc -out tool_sm4_cbc_mac.bin)
|
||||
gmssl_expect_file_hex(tool_sm4_cbc_mac.bin "9054fccff72871fdad5202c821dbea05")
|
||||
endif()
|
||||
Reference in New Issue
Block a user