diff options
author | David Cole <david.cole@kitware.com> | 2009-10-03 16:01:10 (GMT) |
---|---|---|
committer | David Cole <david.cole@kitware.com> | 2009-10-03 16:01:10 (GMT) |
commit | 517e1e3c0f90712c1234ef03086e4a7d43be3be2 (patch) | |
tree | 672f58a9f2ebe11b864d41040f14a0ba7ee83ba4 /Tests | |
parent | eb91859d6fa9ef2784977568fc43052fbc1084d9 (diff) | |
download | CMake-517e1e3c0f90712c1234ef03086e4a7d43be3be2.zip CMake-517e1e3c0f90712c1234ef03086e4a7d43be3be2.tar.gz CMake-517e1e3c0f90712c1234ef03086e4a7d43be3be2.tar.bz2 |
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.
Diffstat (limited to 'Tests')
-rw-r--r-- | Tests/CMakeTests/ExecuteScriptTests.cmake | 62 | ||||
-rw-r--r-- | Tests/CMakeTests/StringTest.cmake.in | 92 | ||||
-rw-r--r-- | Tests/CMakeTests/StringTestScript.cmake | 147 |
3 files changed, 184 insertions, 117 deletions
diff --git a/Tests/CMakeTests/ExecuteScriptTests.cmake b/Tests/CMakeTests/ExecuteScriptTests.cmake new file mode 100644 index 0000000..415614f --- /dev/null +++ b/Tests/CMakeTests/ExecuteScriptTests.cmake @@ -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() diff --git a/Tests/CMakeTests/StringTest.cmake.in b/Tests/CMakeTests/StringTest.cmake.in index 7e9756c..54fee7f 100644 --- a/Tests/CMakeTests/StringTest.cmake.in +++ b/Tests/CMakeTests/StringTest.cmake.in @@ -1,74 +1,18 @@ -function(test_string_command testname expected_result) - message("testname=[${testname}]") - - 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 - ) - - 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 "StringTestScript 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 "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) +# Execute each test listed in StringTestScript.cmake: +# +set(scriptname "@CMAKE_CURRENT_SOURCE_DIR@/StringTestScript.cmake") +set(number_of_tests_expected 52) + +include("@CMAKE_CURRENT_SOURCE_DIR@/ExecuteScriptTests.cmake") +execute_all_script_tests(${scriptname} number_of_tests_executed) + +# 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(number_of_tests_executed LESS number_of_tests_expected) + message(FATAL_ERROR "error: some test cases were skipped") +endif() diff --git a/Tests/CMakeTests/StringTestScript.cmake b/Tests/CMakeTests/StringTestScript.cmake index 8233113..652d81b 100644 --- a/Tests/CMakeTests/StringTestScript.cmake +++ b/Tests/CMakeTests/StringTestScript.cmake @@ -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() |