X-Git-Url: http://wagner.pp.ru/gitweb/?a=blobdiff_plain;f=CMakeLists.txt;h=c81c55b8a86fa27bd0680950aaa4612ae8a9acb1;hb=eea06158911bb530156ff6e54ec26dcd471e977e;hp=26d2a406d35af488e2d46fc2be36755f78580068;hpb=863de1241ca76321388ccfe1d9a7e886d022cb58;p=openssl-gost%2Fengine.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 26d2a40..c81c55b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -19,7 +19,13 @@ elseif(CMAKE_C_COMPILER_ID MATCHES "MSVC") add_compile_options(/MP /WX /W4 /wd4100 /wd4267 /wd4206 /wd4706 /wd4244 /wd4115) endif() +if (ASAN) + message(STATUS "address sanitizer enabled") + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fsanitize=address -g3 -fno-omit-frame-pointer") +endif() + set(CMAKE_C_STANDARD 90) +list(APPEND CMAKE_REQUIRED_LIBRARIES rt) include (TestBigEndian) TEST_BIG_ENDIAN(IS_BIG_ENDIAN) @@ -128,6 +134,16 @@ target_link_libraries(test_curves gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY add_test(NAME curves COMMAND test_curves) +add_executable(test_params test_params.c) +target_link_libraries(test_params gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) +add_test(NAME parameters + COMMAND test_params) + +add_executable(test_sign test_sign.c) +target_link_libraries(test_sign gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) +add_test(NAME sign/verify + COMMAND test_sign) + add_executable(test_context test_context.c) target_link_libraries(test_context gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) add_test(NAME context @@ -138,10 +154,27 @@ target_link_libraries(test_grasshopper gost_engine gost_core ${OPENSSL_CRYPTO_LI add_test(NAME grasshopper COMMAND test_grasshopper) +add_executable(test_keyexpimp test_keyexpimp.c) +#target_compile_definitions(test_keyexpimp PUBLIC -DOPENSSL_LOAD_CONF) +target_link_libraries(test_keyexpimp gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) +add_test(NAME keyexpimp + COMMAND test_keyexpimp) + +add_executable(test_gost89 test_gost89.c) +target_link_libraries(test_gost89 gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) +add_test(NAME gost89 + COMMAND test_gost89) + +if(NOT ASAN) add_test(NAME engine - COMMAND perl run_tests - WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/test) -set_tests_properties(engine PROPERTIES ENVIRONMENT OPENSSL_ENGINES=${OUTPUT_DIRECTORY}) + COMMAND perl run_tests + WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/test) +set_tests_properties(engine PROPERTIES ENVIRONMENT + "OPENSSL_ROOT_DIR=${OPENSSL_ROOT_DIR};OPENSSL_ENGINES=${OUTPUT_DIRECTORY}") +endif() + +add_executable(sign benchmark/sign.c) +target_link_libraries(sign gost_engine gost_core ${OPENSSL_CRYPTO_LIBRARY}) add_library(gost_core STATIC ${GOST_LIB_SOURCE_FILES}) set_target_properties(gost_core PROPERTIES POSITION_INDEPENDENT_CODE ON) @@ -164,16 +197,14 @@ set(GOST_12_SUM_SOURCE_FILES add_executable(gost12sum ${GOST_12_SUM_SOURCE_FILES}) target_link_libraries(gost12sum gost_core) -add_executable(unit_expimp gost_keyexpimp.c e_gost_err.c) -target_compile_definitions(unit_expimp PUBLIC -DENABLE_UNIT_TESTS) -target_compile_definitions(unit_expimp PUBLIC -DOPENSSL_LOAD_CONF) -target_link_libraries(unit_expimp PUBLIC ${OPENSSL_CRYPTO_LIBRARY}) - set_source_files_properties(tags PROPERTIES GENERATED true) add_custom_target(tags COMMAND ctags -R . ${OPENSSL_ROOT_DIR} WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}) +add_executable(test_tlstree test_tlstree.c) +target_link_libraries(test_tlstree PUBLIC ${OPENSSL_CRYPTO_LIBRARY}) + # install set(OPENSSL_MAN_INSTALL_DIR ${CMAKE_INSTALL_MANDIR}/man1)