Make HTML test fail when --nonet arg is not available.

Also, emit "xmllint" and "xmllint --version" output before
failing so that we can inspect the output from all the
dashboard machines in CDash test results.
This commit is contained in:
David Cole 2010-11-02 10:41:11 -04:00
parent aa350314db
commit bb1df1ec8e
1 changed files with 27 additions and 3 deletions

View File

@ -153,9 +153,33 @@ if(BUILD_TESTING)
${HTML_FILES}
)
else()
add_test(CMake.HTML
${LIBXML2_XMLLINT_EXECUTABLE} --valid --noout ${HTML_FILES}
)
# Intentionally committing this chunk of code for one night's run on the
# Nightly dashboard suite. This will help us identify all machines with
# older versions of xmllint installed. (This should match the set of
# machines where this test is failing at the moment anyhow...)
#
# After we identify all of them, we can decide whether to simply make
# this else block empty, skipping the test, or whether there should be
# some alternative equivalent test on such machines...
#
set(script "${CMAKE_CURRENT_BINARY_DIR}/CMake.HTML.cmake")
set(text "Intentionally fail when xmllint has no --nonet arg.")
set(text "${text} The CMake test suite should avoid network activity")
set(text "${text} when possible.")
if(NOT EXISTS "${script}.in")
file(WRITE "${script}.in" "execute_process(COMMAND
\"${LIBXML2_XMLLINT_EXECUTABLE}\" OUTPUT_VARIABLE noargs)
message(\"\${noargs}\")
execute_process(COMMAND
\"${LIBXML2_XMLLINT_EXECUTABLE}\" --version OUTPUT_VARIABLE version)
message(\"\${version}\")
message(FATAL_ERROR \"${text}\")
")
endif()
configure_file("${script}.in" "${script}" @ONLY)
add_test(CMake.HTML ${CMAKE_CMAKE_COMMAND} -P ${script})
endif()
endif()
endif()