Add a few more cases to the new StringTest for even better coverage. Re-factor the scripts to make it easier to add new cases to this test. Re-factoring also enables the test driver in ExecuteScriptTests to be re-used when adding new tests in the future.
This commit is contained in:
parent
eb91859d6f
commit
517e1e3c0f
|
@ -0,0 +1,62 @@
|
|||
# This function calls the ${scriptname} file to execute one test case:
|
||||
#
|
||||
function(execute_one_script_test scriptname testname expected_result)
|
||||
message("execute_one_script_test")
|
||||
message("testname=[${testname}]")
|
||||
|
||||
execute_process(
|
||||
COMMAND ${CMAKE_COMMAND}
|
||||
-D "testname:STRING=${testname}"
|
||||
-P "${scriptname}"
|
||||
OUTPUT_VARIABLE out
|
||||
ERROR_VARIABLE err
|
||||
RESULT_VARIABLE result
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_STRIP_TRAILING_WHITESPACE
|
||||
)
|
||||
|
||||
message("out=[${out}]")
|
||||
message("err=[${err}]")
|
||||
|
||||
if(expected_result STREQUAL "fail")
|
||||
# case expected to fail, result should be non-0...
|
||||
# error if it's 0
|
||||
if("${result}" STREQUAL "0")
|
||||
message(SEND_ERROR "script failed: testname='${testname}' [${result}] actually passed, but expected to fail...")
|
||||
endif()
|
||||
else()
|
||||
# case expected to pass, result should be 0...
|
||||
# error if it's non-0
|
||||
if(NOT "${result}" STREQUAL "0")
|
||||
message(SEND_ERROR "script failed: testname='${testname}' [${result}] actually failed, but expected to pass...")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
message("")
|
||||
endfunction()
|
||||
|
||||
|
||||
# This function reads the script file and calls execute_one_script_test for
|
||||
# each testname case listed in the script. To add new cases, simply edit the
|
||||
# script file and add an elseif() clause that matches 'regex' below.
|
||||
#
|
||||
function(execute_all_script_tests scriptname result)
|
||||
file(READ "${scriptname}" script)
|
||||
|
||||
string(REPLACE ";" "\\\\;" script "${script}")
|
||||
string(REPLACE "\n" "E;" script "${script}")
|
||||
|
||||
set(count 0)
|
||||
set(regex "^ *(if|elseif) *\\( *testname +STREQUAL +\\\"*([^\\\"\\)]+)\\\"* *\\) *# *(fail|pass) *E$")
|
||||
|
||||
foreach(line ${script})
|
||||
if(line MATCHES "${regex}")
|
||||
math(EXPR count "${count} + 1")
|
||||
string(REGEX REPLACE "${regex}" "\\2" testname "${line}")
|
||||
string(REGEX REPLACE "${regex}" "\\3" expected_result "${line}")
|
||||
execute_one_script_test(${scriptname} ${testname} ${expected_result})
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
set(${result} ${count} PARENT_SCOPE)
|
||||
endfunction()
|
|
@ -1,74 +1,18 @@
|
|||
function(test_string_command testname expected_result)
|
||||
message("testname=[${testname}]")
|
||||
# Execute each test listed in StringTestScript.cmake:
|
||||
#
|
||||
set(scriptname "@CMAKE_CURRENT_SOURCE_DIR@/StringTestScript.cmake")
|
||||
set(number_of_tests_expected 52)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${CMAKE_COMMAND}
|
||||
-D "testname:STRING=${testname}"
|
||||
-P "@CMAKE_CURRENT_SOURCE_DIR@/StringTestScript.cmake"
|
||||
OUTPUT_VARIABLE out
|
||||
ERROR_VARIABLE err
|
||||
RESULT_VARIABLE result
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_STRIP_TRAILING_WHITESPACE
|
||||
)
|
||||
include("@CMAKE_CURRENT_SOURCE_DIR@/ExecuteScriptTests.cmake")
|
||||
execute_all_script_tests(${scriptname} number_of_tests_executed)
|
||||
|
||||
message("out=[${out}]")
|
||||
message("err=[${err}]")
|
||||
# And verify that number_of_tests_executed is at least as many as we know
|
||||
# about as of this writing...
|
||||
#
|
||||
message(STATUS "scriptname='${scriptname}'")
|
||||
message(STATUS "number_of_tests_executed='${number_of_tests_executed}'")
|
||||
message(STATUS "number_of_tests_expected='${number_of_tests_expected}'")
|
||||
|
||||
if(expected_result STREQUAL "fail")
|
||||
# case expected to fail, result should be non-0...
|
||||
# error if it's 0
|
||||
if("${result}" STREQUAL "0")
|
||||
message(SEND_ERROR "StringTestScript failed: testname='${testname}' [${result}] actually passed, but expected to fail...")
|
||||
if(number_of_tests_executed LESS number_of_tests_expected)
|
||||
message(FATAL_ERROR "error: some test cases were skipped")
|
||||
endif()
|
||||
else()
|
||||
# case expected to pass, result should be 0...
|
||||
# error if it's non-0
|
||||
if(NOT "${result}" STREQUAL "0")
|
||||
message(SEND_ERROR "StringTestScript failed: testname='${testname}' [${result}] actually failed, but expected to pass...")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
message("")
|
||||
endfunction()
|
||||
|
||||
|
||||
test_string_command(empty fail)
|
||||
test_string_command(bogus fail)
|
||||
test_string_command(random pass)
|
||||
test_string_command(toupper_no_variable fail)
|
||||
test_string_command(ascii_no_variable fail)
|
||||
test_string_command(ascii_bad_code fail)
|
||||
test_string_command(configure_no_input fail)
|
||||
test_string_command(configure_no_variable fail)
|
||||
test_string_command(configure_escape_quotes pass)
|
||||
test_string_command(configure_bogus fail)
|
||||
test_string_command(regex_no_mode fail)
|
||||
test_string_command(regex_match_not_enough_args fail)
|
||||
test_string_command(regex_matchall_not_enough_args fail)
|
||||
test_string_command(regex_replace_not_enough_args fail)
|
||||
test_string_command(regex_bogus_mode fail)
|
||||
test_string_command(regex_match_multiple_inputs pass)
|
||||
test_string_command(regex_match_bad_regex fail)
|
||||
test_string_command(regex_match_empty_string fail)
|
||||
test_string_command(regex_matchall_multiple_inputs pass)
|
||||
test_string_command(regex_matchall_bad_regex fail)
|
||||
test_string_command(regex_matchall_empty_string fail)
|
||||
test_string_command(regex_replace_ends_with_backslash fail)
|
||||
test_string_command(regex_replace_ends_with_escaped_backslash pass)
|
||||
test_string_command(regex_replace_has_linefeed pass)
|
||||
test_string_command(regex_replace_has_bogus_escape fail)
|
||||
test_string_command(regex_replace_bad_regex fail)
|
||||
test_string_command(regex_replace_empty_string fail)
|
||||
test_string_command(compare_no_mode fail)
|
||||
test_string_command(compare_bogus_mode fail)
|
||||
test_string_command(compare_not_enough_args fail)
|
||||
test_string_command(replace_not_enough_args fail)
|
||||
test_string_command(replace_multiple_inputs pass)
|
||||
test_string_command(substring_not_enough_args fail)
|
||||
test_string_command(substring_bad_begin fail)
|
||||
test_string_command(substring_bad_end fail)
|
||||
test_string_command(length_not_enough_args fail)
|
||||
|
||||
|
||||
test_string_command(no_such_testname fail)
|
||||
|
|
|
@ -1,131 +1,192 @@
|
|||
message(STATUS "testname='${testname}'")
|
||||
|
||||
|
||||
if(testname STREQUAL empty)
|
||||
if(testname STREQUAL empty) # fail
|
||||
string()
|
||||
|
||||
elseif(testname STREQUAL bogus)
|
||||
elseif(testname STREQUAL bogus) # fail
|
||||
string(BOGUS)
|
||||
|
||||
elseif(testname STREQUAL random)
|
||||
elseif(testname STREQUAL random) # pass
|
||||
string(RANDOM r)
|
||||
message(STATUS "r='${r}'")
|
||||
|
||||
elseif(testname STREQUAL toupper_no_variable)
|
||||
elseif(testname STREQUAL toupper_no_variable) # fail
|
||||
string(TOUPPER)
|
||||
|
||||
elseif(testname STREQUAL ascii_no_variable)
|
||||
elseif(testname STREQUAL ascii_no_variable) # fail
|
||||
string(ASCII)
|
||||
|
||||
elseif(testname STREQUAL ascii_bad_code)
|
||||
elseif(testname STREQUAL ascii_code_too_small) # fail
|
||||
string(ASCII -1 bummer)
|
||||
|
||||
elseif(testname STREQUAL ascii_code_too_large) # fail
|
||||
string(ASCII 288 bummer)
|
||||
|
||||
elseif(testname STREQUAL configure_no_input)
|
||||
elseif(testname STREQUAL configure_no_input) # fail
|
||||
string(CONFIGURE)
|
||||
|
||||
elseif(testname STREQUAL configure_no_variable)
|
||||
elseif(testname STREQUAL configure_no_variable) # fail
|
||||
string(CONFIGURE "this is @testname@")
|
||||
|
||||
elseif(testname STREQUAL configure_escape_quotes)
|
||||
elseif(testname STREQUAL configure_escape_quotes) # pass
|
||||
string(CONFIGURE "this is @testname@" v ESCAPE_QUOTES)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL configure_bogus)
|
||||
elseif(testname STREQUAL configure_bogus) # fail
|
||||
string(CONFIGURE "this is @testname@" v ESCAPE_QUOTES BOGUS)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_no_mode)
|
||||
elseif(testname STREQUAL regex_no_mode) # fail
|
||||
string(REGEX)
|
||||
|
||||
elseif(testname STREQUAL regex_match_not_enough_args)
|
||||
elseif(testname STREQUAL regex_match_not_enough_args) # fail
|
||||
string(REGEX MATCH)
|
||||
|
||||
elseif(testname STREQUAL regex_matchall_not_enough_args)
|
||||
elseif(testname STREQUAL regex_matchall_not_enough_args) # fail
|
||||
string(REGEX MATCHALL)
|
||||
|
||||
elseif(testname STREQUAL regex_replace_not_enough_args)
|
||||
elseif(testname STREQUAL regex_replace_not_enough_args) # fail
|
||||
string(REGEX REPLACE)
|
||||
|
||||
elseif(testname STREQUAL regex_bogus_mode)
|
||||
elseif(testname STREQUAL regex_bogus_mode) # fail
|
||||
string(REGEX BOGUS)
|
||||
|
||||
elseif(testname STREQUAL regex_match_multiple_inputs)
|
||||
elseif(testname STREQUAL regex_match_multiple_inputs) # pass
|
||||
string(REGEX MATCH ".*" v input1 input2 input3 input4)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_match_bad_regex)
|
||||
elseif(testname STREQUAL regex_match_bad_regex) # fail
|
||||
string(REGEX MATCH "(.*" v input)
|
||||
|
||||
elseif(testname STREQUAL regex_match_empty_string)
|
||||
elseif(testname STREQUAL regex_match_empty_string) # fail
|
||||
string(REGEX MATCH "x*" v "")
|
||||
|
||||
elseif(testname STREQUAL regex_matchall_multiple_inputs)
|
||||
elseif(testname STREQUAL regex_match_no_match) # pass
|
||||
string(REGEX MATCH "xyz" v "abc")
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_matchall_multiple_inputs) # pass
|
||||
string(REGEX MATCHALL "input" v input1 input2 input3 input4)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_matchall_bad_regex)
|
||||
elseif(testname STREQUAL regex_matchall_bad_regex) # fail
|
||||
string(REGEX MATCHALL "(.*" v input)
|
||||
|
||||
elseif(testname STREQUAL regex_matchall_empty_string)
|
||||
elseif(testname STREQUAL regex_matchall_empty_string) # fail
|
||||
string(REGEX MATCHALL "x*" v "")
|
||||
|
||||
elseif(testname STREQUAL regex_replace_ends_with_backslash)
|
||||
elseif(testname STREQUAL regex_replace_ends_with_backslash) # fail
|
||||
string(REGEX REPLACE "input" "output\\" v input1 input2 input3 input4)
|
||||
|
||||
elseif(testname STREQUAL regex_replace_ends_with_escaped_backslash)
|
||||
elseif(testname STREQUAL regex_replace_ends_with_escaped_backslash) # pass
|
||||
string(REGEX REPLACE "input" "output\\\\" v input1 input2 input3 input4)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_replace_has_linefeed)
|
||||
elseif(testname STREQUAL regex_replace_has_linefeed) # pass
|
||||
string(REGEX REPLACE "input" "output\\n" v input1 input2 input3 input4)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL regex_replace_has_bogus_escape)
|
||||
elseif(testname STREQUAL regex_replace_has_bogus_escape) # fail
|
||||
string(REGEX REPLACE "input" "output\\a" v input1 input2 input3 input4)
|
||||
|
||||
elseif(testname STREQUAL regex_replace_bad_regex)
|
||||
elseif(testname STREQUAL regex_replace_bad_regex) # fail
|
||||
string(REGEX REPLACE "this (.*" "with that" v input)
|
||||
|
||||
elseif(testname STREQUAL regex_replace_empty_string)
|
||||
elseif(testname STREQUAL regex_replace_empty_string) # fail
|
||||
string(REGEX REPLACE "x*" "that" v "")
|
||||
|
||||
elseif(testname STREQUAL regex_replace_out_of_range)
|
||||
elseif(testname STREQUAL regex_replace_index_too_small) # fail
|
||||
string(REGEX REPLACE "^this (.*)$" "with \\1 \\-1" v "this input")
|
||||
|
||||
elseif(testname STREQUAL regex_replace_index_too_large) # fail
|
||||
string(REGEX REPLACE "^this (.*)$" "with \\1 \\2" v "this input")
|
||||
|
||||
elseif(testname STREQUAL compare_no_mode)
|
||||
elseif(testname STREQUAL compare_no_mode) # fail
|
||||
string(COMPARE)
|
||||
|
||||
elseif(testname STREQUAL compare_bogus_mode)
|
||||
elseif(testname STREQUAL compare_bogus_mode) # fail
|
||||
string(COMPARE BOGUS)
|
||||
|
||||
elseif(testname STREQUAL compare_not_enough_args)
|
||||
elseif(testname STREQUAL compare_not_enough_args) # fail
|
||||
string(COMPARE EQUAL)
|
||||
|
||||
elseif(testname STREQUAL replace_not_enough_args)
|
||||
elseif(testname STREQUAL replace_not_enough_args) # fail
|
||||
string(REPLACE)
|
||||
|
||||
elseif(testname STREQUAL replace_multiple_inputs)
|
||||
elseif(testname STREQUAL replace_multiple_inputs) # pass
|
||||
string(REPLACE "input" "output" v input1 input2 input3 input4)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL substring_not_enough_args)
|
||||
elseif(testname STREQUAL substring_not_enough_args) # fail
|
||||
string(SUBSTRING)
|
||||
|
||||
elseif(testname STREQUAL substring_bad_begin)
|
||||
elseif(testname STREQUAL substring_begin_too_large) # fail
|
||||
string(SUBSTRING "abcdefg" 25 100 v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL substring_bad_end)
|
||||
elseif(testname STREQUAL substring_end_too_large) # fail
|
||||
string(SUBSTRING "abcdefg" 1 100 v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL length_not_enough_args)
|
||||
elseif(testname STREQUAL substring_begin_less_than_zero) # fail
|
||||
string(SUBSTRING "abcdefg" -2 4 v)
|
||||
|
||||
elseif(testname STREQUAL substring_end_less_than_begin) # fail
|
||||
string(SUBSTRING "abcdefg" 6 3 v)
|
||||
|
||||
elseif(testname STREQUAL length_not_enough_args) # fail
|
||||
string(LENGTH)
|
||||
|
||||
elseif(testname STREQUAL strip_not_enough_args)
|
||||
elseif(testname STREQUAL strip_not_enough_args) # fail
|
||||
string(STRIP)
|
||||
|
||||
else()
|
||||
elseif(testname STREQUAL random_not_enough_args) # fail
|
||||
string(RANDOM)
|
||||
|
||||
elseif(testname STREQUAL random_3_args) # fail
|
||||
string(RANDOM LENGTH 9)
|
||||
|
||||
elseif(testname STREQUAL random_5_args) # fail
|
||||
string(RANDOM LENGTH 9 ALPHABET "aceimnorsuvwxz")
|
||||
|
||||
elseif(testname STREQUAL random_with_length) # pass
|
||||
string(RANDOM LENGTH 9 v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL random_with_alphabet) # pass
|
||||
string(RANDOM ALPHABET "aceimnorsuvwxz" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL random_bad_length) # fail
|
||||
string(RANDOM LENGTH 0 v)
|
||||
|
||||
elseif(testname STREQUAL random_empty_alphabet) # pass
|
||||
string(RANDOM ALPHABET "" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL random_with_length_and_alphabet) # pass
|
||||
string(RANDOM LENGTH 9 ALPHABET "aceimnorsuvwxz" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
elseif(testname STREQUAL random_with_various_alphabets) # pass
|
||||
# small alphabet
|
||||
string(RANDOM LENGTH 32 ALPHABET "ACGT" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
# smaller alphabet
|
||||
string(RANDOM LENGTH 32 ALPHABET "AB" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
# smallest alphabet
|
||||
string(RANDOM LENGTH 32 ALPHABET "Z" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
# smallest length and alphabet
|
||||
string(RANDOM LENGTH 1 ALPHABET "Q" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
# alphabet of many colors - use all the crazy keyboard characters
|
||||
string(RANDOM LENGTH 78 ALPHABET "~`!@#$%^&*()_-+={}[]\\|:\\;'\",.<>/?" v)
|
||||
message(STATUS "v='${v}'")
|
||||
|
||||
else() # fail
|
||||
message(FATAL_ERROR "testname='${testname}' - error: no such test in '${CMAKE_CURRENT_LIST_FILE}'")
|
||||
|
||||
endif()
|
||||
|
|
Loading…
Reference in New Issue