# LYX_ROOT = ${TOP_SRC_DIR}/lib/{doc,examples,templates}
# LYX_USERDIR_VER = Name of environment variable for the user directory
# lyx =
-# format = lyx16x|lyx21x|xhtml
-# extension = 16.lyx|21.lyx|xhtml
+# format = lyx16x|lyx21x|lyx22x|xhtml
+# extension = 16.lyx|21.lyx|22.lyx|xhtml
# file = xxx
#
# Script should be called like:
# -Dinverted=[01] \
# -DTOP_SRC_DIR=${TOP_SRC_DIR}
# -DPERL_EXECUTABLE=${PERL_EXECUTABLE}
+# -DXMLLINT_EXECUTABLE=${XMLLINT_EXECUTABLE}
# -P "${TOP_SRC_DIR}/development/autotests/export.cmake"
#
endif()
endif()
+function(get_md5sum msource mresult mreserr)
+ execute_process(
+ COMMAND ${CMAKE_COMMAND} -E md5sum ${${msource}}
+ OUTPUT_VARIABLE msource_md5sum_x
+ RESULT_VARIABLE mres_err)
+ if (NOT mres_err)
+ string(REGEX REPLACE " .*" "" msource_md5sum ${msource_md5sum_x})
+ set(${mresult} ${msource_md5sum} PARENT_SCOPE)
+ message(STATUS "MD5SUM of \"${${msource}}\" is ${msource_md5sum}")
+ else()
+ set(${mresult} "xx" PARENT_SCOPE)
+ message(STATUS "Error getting MD5SUM of \"${${msource}}\"")
+ endif()
+ set(${mreserr} ${mres_err} PARENT_SCOPE)
+endfunction()
+
set(ENV{${LYX_USERDIR_VER}} "${LYX_TESTS_USERDIR}")
+set(ENV{LANG} "en") # to get all error-messages in english
+set(ENV{LC_ALL} "C")
if (extension MATCHES "\\.lyx$")
- set(ENV{${LYX_USERDIR_VER}} "${LYX_TESTS_USERDIR}")
- set(ENV{LANG} "en") # to get all error-messages in english
-
include(${TOP_SRC_DIR}/development/autotests/CheckLoadErrors.cmake)
- execute_process(
- COMMAND ${CMAKE_COMMAND} -E md5sum "${LYX_SOURCE}"
- OUTPUT_VARIABLE source_md5sum_x
- RESULT_VARIABLE _err
- ERROR_VARIABLE lyxerr)
- string(REGEX REPLACE " .*" "" source_md5sum ${source_md5sum_x})
- message(STATUS "MD5SUM of \"${LYX_SOURCE}\" is ${source_md5sum}")
+ get_md5sum(LYX_SOURCE source_md5sum _err)
foreach(_lv RANGE 1 5)
set(result_file_base "${result_file_base}.${LYX_FORMAT_NUM}")
set(result_file_name "${result_file_base}.lyx")
+ message(STATUS "check structures of ${LYX_SOURCE}")
+ execute_process(
+ COMMAND ${PERL_EXECUTABLE} ${Structure_Script} "${WORKDIR}/${result_file_name}"
+ RESULT_VARIABLE _err)
+ if(_err)
+ break()
+ endif()
file(REMOVE "${result_file_name}" "${result_file_name}.emergency" )
message(STATUS "Executing ${lyx} -userdir \"${LYX_TESTS_USERDIR}\" -E ${format} ${result_file_name} \"${LYX_SOURCE}\"")
+ message(STATUS "This implicitly checks load of ${LYX_SOURCE}")
execute_process(
COMMAND ${lyx} -userdir "${LYX_TESTS_USERDIR}" -E ${format} ${result_file_name} "${LYX_SOURCE}"
RESULT_VARIABLE _err
ERROR_VARIABLE lyxerr)
if(_err)
break()
+ elseif(NOT EXISTS "${result_file_name}")
+ message(STATUS "Expected result file \"${result_file_name}\" does not exist")
+ set(_err -1)
+ break()
else()
- if (NOT EXISTS "${result_file_name}")
- message(STATUS "Expected result file \"${result_file_name}\" does not exist")
- set(_err -1)
+ message(STATUS "Expected result file \"${result_file_name}\" exists")
+ checkLoadErrors(lyxerr "${TOP_SRC_DIR}/development/autotests" _err)
+ if(_err)
break()
- else()
- message(STATUS "Expected result file \"${result_file_name}\" exists")
- checkLoadErrors(lyxerr "${TOP_SRC_DIR}/development/autotests" _err)
- if(_err)
- break()
- endif()
endif()
endif()
- execute_process(
- COMMAND ${CMAKE_COMMAND} -E md5sum ${result_file_name}
- OUTPUT_VARIABLE result_md5sum_x
- RESULT_VARIABLE _err
- ERROR_VARIABLE lyxerr)
- string(REGEX REPLACE " .*" "" result_md5sum ${result_md5sum_x})
- message(STATUS "MD5SUM of \"${result_file_name}\" is ${result_md5sum}")
- if(_err)
- break()
- endif()
- message(STATUS "check structures of ${result_file_name}")
- execute_process(
- COMMAND ${PERL_EXECUTABLE} ${Structure_Script} "${WORKDIR}/${result_file_name}"
- RESULT_VARIABLE _err
- ERROR_VARIABLE lyxerr)
- if(_err)
- break()
- endif()
- message(STATUS "check load of ${result_file_name}")
- execute_process(
- COMMAND ${lyx} -batch -userdir "${LYX_TESTS_USERDIR}" ${result_file_name}
- RESULT_VARIABLE _err
- ERROR_VARIABLE lyxerr)
- if(_err)
- break()
- endif()
- checkLoadErrors(lyxerr "${TOP_SRC_DIR}/development/autotests" _err)
+ get_md5sum(result_file_name result_md5sum _err)
if(_err)
+ # Somehow the created file is not readable?
break()
endif()
# Check if result file identical to source file
set(_err -1)
else()
message(STATUS "Expected result file \"${result_file_name}\" exists")
+ if (format MATCHES "xhtml")
+ if (XMLLINT_EXECUTABLE)
+ message(STATUS "Calling: ${XMLLINT_EXECUTABLE} --sax --html --valid")
+ # check the created xhtml file
+ execute_process(
+ COMMAND ${XMLLINT_EXECUTABLE} --sax --html --valid "${result_file_name}"
+ OUTPUT_VARIABLE xmlout
+ ERROR_VARIABLE xmlerr
+ RESULT_VARIABLE _err)
+ file(WRITE "${result_file_name}.sax_out" ${xmlout})
+ if (NOT _err)
+ # check if sax-parser output contains error messages
+ message(STATUS "Check the output: ${PERL_EXECUTABLE} ${TOP_SRC_DIR}/development/autotests/examineXmllintOutput.pl")
+ execute_process(
+ COMMAND ${PERL_EXECUTABLE} "${TOP_SRC_DIR}/development/autotests/examineXmllintOutput.pl" "${result_file_name}.sax_out"
+ OUTPUT_VARIABLE xmlout
+ RESULT_VARIABLE _err)
+ endif()
+ if (NOT _err)
+ if (NOT "${xmlout}" STREQUAL "")
+ message(STATUS "${xmlout}")
+ set(_err -1)
+ endif()
+ endif()
+ endif()
+ endif()
endif()
endif()
endif()