2011-01-18 16:18:38 +00:00
|
|
|
set(libs
|
2018-11-02 10:13:30 +00:00
|
|
|
mbedcrypto
|
2011-01-18 16:18:38 +00:00
|
|
|
)
|
|
|
|
|
2019-04-29 08:35:06 +00:00
|
|
|
# Set the project root directory if it's not already defined, as may happen if
|
|
|
|
# the tests folder is included directly by a parent project, without including
|
|
|
|
# the top level CMakeLists.txt.
|
|
|
|
if(NOT DEFINED MBEDTLS_DIR)
|
|
|
|
set(MBEDTLS_DIR ${CMAKE_SOURCE_DIR})
|
|
|
|
endif()
|
|
|
|
|
2015-11-14 13:09:01 +00:00
|
|
|
find_package(Perl)
|
|
|
|
if(NOT PERL_FOUND)
|
|
|
|
message(FATAL_ERROR "Cannot build test suites without Perl")
|
|
|
|
endif()
|
|
|
|
|
2017-12-05 12:08:15 +00:00
|
|
|
# Enable definition of various functions used throughout the testsuite
|
2018-06-25 11:10:00 +00:00
|
|
|
# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
|
2017-12-05 12:08:15 +00:00
|
|
|
# on non-POSIX platforms.
|
|
|
|
add_definitions("-D_POSIX_C_SOURCE=200809L")
|
|
|
|
|
2018-11-29 10:15:06 +00:00
|
|
|
# Test suites caught by SKIP_TEST_SUITES are built but not executed.
|
|
|
|
# "foo" as a skip pattern skips "test_suite_foo" and "test_suite_foo.bar"
|
|
|
|
# but not "test_suite_foobar".
|
|
|
|
string(REGEX REPLACE "[ ,;]" "|" SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES}")
|
|
|
|
string(REPLACE "." "\\." SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES_REGEX}")
|
|
|
|
set(SKIP_TEST_SUITES_REGEX "^(${SKIP_TEST_SUITES_REGEX})(\$|\\.)")
|
|
|
|
|
2011-07-13 15:03:10 +00:00
|
|
|
function(add_test_suite suite_name)
|
|
|
|
if(ARGV1)
|
2015-06-25 07:20:03 +00:00
|
|
|
set(data_name ${ARGV1})
|
2011-07-13 15:03:10 +00:00
|
|
|
else()
|
2015-06-25 07:20:03 +00:00
|
|
|
set(data_name ${suite_name})
|
2011-07-13 14:54:54 +00:00
|
|
|
endif()
|
|
|
|
|
2009-06-28 21:50:27 +00:00
|
|
|
add_custom_command(
|
2011-07-13 15:03:10 +00:00
|
|
|
OUTPUT test_suite_${data_name}.c
|
2018-06-29 14:00:11 +00:00
|
|
|
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py -f ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function -d ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data -t ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function -p ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function -s ${CMAKE_CURRENT_SOURCE_DIR}/suites --helpers-file ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function -o .
|
2018-11-02 10:13:30 +00:00
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py mbedcrypto ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data
|
2010-06-18 22:54:05 +00:00
|
|
|
)
|
2013-08-16 11:31:10 +00:00
|
|
|
|
2019-03-07 16:44:54 +00:00
|
|
|
set(exe_name test_suite_${data_name})
|
|
|
|
# Add a prefix to differentiate these tests from those of the parent
|
|
|
|
# module, when this project is built as a submodule.
|
|
|
|
if(USE_CRYPTO_SUBMODULE)
|
|
|
|
set(exe_name crypto.${exe_name})
|
|
|
|
endif()
|
|
|
|
|
2010-06-18 22:54:05 +00:00
|
|
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR})
|
2019-03-07 16:44:54 +00:00
|
|
|
add_executable(${exe_name} test_suite_${data_name}.c)
|
|
|
|
target_link_libraries(${exe_name} ${libs})
|
|
|
|
target_include_directories(${exe_name}
|
2019-04-29 08:35:06 +00:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/include/
|
|
|
|
PUBLIC ${MBEDTLS_DIR}/crypto/include/
|
2019-06-20 16:17:48 +00:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/crypto/library/)
|
2019-03-07 15:32:49 +00:00
|
|
|
|
2018-11-29 10:15:06 +00:00
|
|
|
if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX})
|
|
|
|
message(STATUS "The test suite ${data_name} will not be executed.")
|
|
|
|
else()
|
2019-03-07 16:44:54 +00:00
|
|
|
add_test(${data_name}-suite ${exe_name} --verbose)
|
2018-11-29 10:15:06 +00:00
|
|
|
endif()
|
2009-06-28 21:50:27 +00:00
|
|
|
endfunction(add_test_suite)
|
|
|
|
|
2015-07-01 11:41:35 +00:00
|
|
|
if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
|
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-function")
|
|
|
|
endif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
|
2009-06-28 21:50:27 +00:00
|
|
|
|
2015-07-01 15:06:28 +00:00
|
|
|
if(MSVC)
|
2016-11-03 01:12:50 +00:00
|
|
|
# If a warning level has been defined, suppress all warnings for test code
|
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W0")
|
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-")
|
2015-07-01 15:06:28 +00:00
|
|
|
endif(MSVC)
|
|
|
|
|
2013-04-08 16:09:51 +00:00
|
|
|
add_test_suite(aes aes.ecb)
|
|
|
|
add_test_suite(aes aes.cbc)
|
|
|
|
add_test_suite(aes aes.cfb)
|
2018-11-29 10:55:21 +00:00
|
|
|
add_test_suite(aes aes.ofb)
|
2013-04-08 16:09:51 +00:00
|
|
|
add_test_suite(aes aes.rest)
|
2016-06-09 21:22:58 +00:00
|
|
|
add_test_suite(aes aes.xts)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(arc4)
|
2018-02-20 12:56:54 +00:00
|
|
|
add_test_suite(aria)
|
2019-03-01 17:02:53 +00:00
|
|
|
add_test_suite(asn1parse)
|
2014-05-29 12:26:03 +00:00
|
|
|
add_test_suite(asn1write)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(base64)
|
2012-07-04 11:02:11 +00:00
|
|
|
add_test_suite(blowfish)
|
2009-07-06 06:40:23 +00:00
|
|
|
add_test_suite(camellia)
|
2014-05-02 13:17:29 +00:00
|
|
|
add_test_suite(ccm)
|
2016-05-15 20:28:08 +00:00
|
|
|
add_test_suite(chacha20)
|
2018-05-07 08:43:27 +00:00
|
|
|
add_test_suite(chachapoly)
|
2011-07-13 14:54:54 +00:00
|
|
|
add_test_suite(cipher cipher.aes)
|
2013-08-28 11:50:42 +00:00
|
|
|
add_test_suite(cipher cipher.arc4)
|
2012-07-04 17:10:40 +00:00
|
|
|
add_test_suite(cipher cipher.blowfish)
|
2011-07-13 14:54:54 +00:00
|
|
|
add_test_suite(cipher cipher.camellia)
|
2014-05-15 14:03:07 +00:00
|
|
|
add_test_suite(cipher cipher.ccm)
|
2016-05-15 22:56:20 +00:00
|
|
|
add_test_suite(cipher cipher.chacha20)
|
2018-05-07 08:43:27 +00:00
|
|
|
add_test_suite(cipher cipher.chachapoly)
|
2011-07-13 14:54:54 +00:00
|
|
|
add_test_suite(cipher cipher.des)
|
2013-08-30 16:34:08 +00:00
|
|
|
add_test_suite(cipher cipher.gcm)
|
2019-01-31 13:20:20 +00:00
|
|
|
add_test_suite(cipher cipher.misc)
|
2019-04-17 11:12:24 +00:00
|
|
|
add_test_suite(cipher cipher.nist_kw)
|
2012-02-06 16:45:10 +00:00
|
|
|
add_test_suite(cipher cipher.null)
|
2013-07-24 16:05:00 +00:00
|
|
|
add_test_suite(cipher cipher.padding)
|
2016-10-10 21:03:39 +00:00
|
|
|
add_test_suite(cmac)
|
2011-11-27 14:46:59 +00:00
|
|
|
add_test_suite(ctr_drbg)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(des)
|
|
|
|
add_test_suite(dhm)
|
2013-01-26 15:20:32 +00:00
|
|
|
add_test_suite(ecdh)
|
2013-01-26 18:09:07 +00:00
|
|
|
add_test_suite(ecdsa)
|
2015-08-05 13:44:42 +00:00
|
|
|
add_test_suite(ecjpake)
|
|
|
|
add_test_suite(ecp)
|
2014-05-30 08:38:18 +00:00
|
|
|
add_test_suite(entropy)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(error)
|
2013-10-24 09:57:47 +00:00
|
|
|
add_test_suite(gcm gcm.aes128_en)
|
|
|
|
add_test_suite(gcm gcm.aes192_en)
|
|
|
|
add_test_suite(gcm gcm.aes256_en)
|
|
|
|
add_test_suite(gcm gcm.aes128_de)
|
|
|
|
add_test_suite(gcm gcm.aes192_de)
|
|
|
|
add_test_suite(gcm gcm.aes256_de)
|
2013-10-24 10:59:00 +00:00
|
|
|
add_test_suite(gcm gcm.camellia)
|
2019-01-31 13:20:20 +00:00
|
|
|
add_test_suite(gcm gcm.misc)
|
2016-07-17 07:51:22 +00:00
|
|
|
add_test_suite(hkdf)
|
2014-01-30 20:11:16 +00:00
|
|
|
add_test_suite(hmac_drbg hmac_drbg.misc)
|
2014-01-30 16:22:14 +00:00
|
|
|
add_test_suite(hmac_drbg hmac_drbg.no_reseed)
|
2014-01-31 08:54:14 +00:00
|
|
|
add_test_suite(hmac_drbg hmac_drbg.nopr)
|
2014-01-31 09:16:57 +00:00
|
|
|
add_test_suite(hmac_drbg hmac_drbg.pr)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(md)
|
|
|
|
add_test_suite(mdx)
|
2014-11-27 10:55:27 +00:00
|
|
|
add_test_suite(memory_buffer_alloc)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(mpi)
|
2018-07-15 06:37:28 +00:00
|
|
|
add_test_suite(nist_kw)
|
2019-03-28 16:02:25 +00:00
|
|
|
add_test_suite(oid)
|
2014-04-11 11:28:43 +00:00
|
|
|
add_test_suite(pem)
|
2016-02-12 13:18:20 +00:00
|
|
|
add_test_suite(pkcs1_v15)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(pkcs1_v21)
|
2013-06-24 17:26:38 +00:00
|
|
|
add_test_suite(pkcs5)
|
2013-09-21 10:31:05 +00:00
|
|
|
add_test_suite(pk)
|
2013-09-15 11:01:22 +00:00
|
|
|
add_test_suite(pkparse)
|
2013-09-15 12:54:56 +00:00
|
|
|
add_test_suite(pkwrite)
|
2016-05-16 21:25:45 +00:00
|
|
|
add_test_suite(poly1305)
|
2018-04-04 09:47:52 +00:00
|
|
|
add_test_suite(psa_crypto)
|
2018-11-19 09:53:55 +00:00
|
|
|
add_test_suite(psa_crypto_entropy)
|
2018-10-24 09:45:18 +00:00
|
|
|
add_test_suite(psa_crypto_hash)
|
2018-11-20 19:56:14 +00:00
|
|
|
add_test_suite(psa_crypto_init)
|
2018-10-22 17:11:00 +00:00
|
|
|
add_test_suite(psa_crypto_metadata)
|
2018-06-18 16:27:26 +00:00
|
|
|
add_test_suite(psa_crypto_persistent_key)
|
2019-06-24 11:47:24 +00:00
|
|
|
add_test_suite(psa_crypto_se_driver_hal)
|
2019-07-10 10:45:31 +00:00
|
|
|
add_test_suite(psa_crypto_se_driver_hal_mocks)
|
2018-11-30 17:53:28 +00:00
|
|
|
add_test_suite(psa_crypto_slot_management)
|
2018-11-16 21:24:38 +00:00
|
|
|
add_test_suite(psa_its)
|
2011-05-09 16:17:09 +00:00
|
|
|
add_test_suite(shax)
|
2016-07-19 13:57:00 +00:00
|
|
|
add_test_suite(timing)
|
2009-07-07 20:18:41 +00:00
|
|
|
add_test_suite(rsa)
|
2009-07-08 06:43:10 +00:00
|
|
|
add_test_suite(xtea)
|
2019-03-07 16:01:11 +00:00
|
|
|
if (NOT USE_CRYPTO_SUBMODULE)
|
|
|
|
add_test_suite(version)
|
|
|
|
endif()
|
2014-02-06 14:43:21 +00:00
|
|
|
|
2018-03-21 11:12:47 +00:00
|
|
|
# Make scripts and data files needed for testing available in an
|
|
|
|
# out-of-source build.
|
2014-02-06 14:43:21 +00:00
|
|
|
if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
|
2019-05-06 10:18:24 +00:00
|
|
|
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/seedfile")
|
|
|
|
link_to_source(seedfile)
|
|
|
|
endif()
|
2018-03-21 11:12:47 +00:00
|
|
|
link_to_source(data_files)
|
|
|
|
link_to_source(scripts)
|
2019-01-02 16:29:04 +00:00
|
|
|
link_to_source(suites)
|
2014-02-06 14:43:21 +00:00
|
|
|
endif()
|