run-tests.test.bat 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. @echo off
  2. REM ********************************************************
  3. REM This batch file receives the follwing parameters:
  4. REM build/rebuild (optional): should the solution file be rebuilded
  5. REM or just builded before test run (default is rebuild)
  6. REM output files name prefix (mandratory) : prefix for naming output xml files
  7. REM test fixture name (optional) : if you want to run some particular test fixture
  8. REM directory to run tests (optional)
  9. REM path back to root directory (opposite to previous param)
  10. REM example run-tests build GhTests Test.Sys.Drawing Test\DrawingTest\Test ..\..\..\
  11. REM will cause to build (and not rebuild) test solutions,
  12. REM running Test.Sys.Drawing fixture in directory Test\DrawingTest\Test
  13. REM with output files named GhTests.Net.xml and GhTests.GH.xml
  14. REM ********************************************************
  15. IF "%1"=="" GOTO USAGE
  16. IF "%VMW_HOME%"=="" GOTO ENVIRONMENT_EXCEPTION
  17. IF "%1"=="" (
  18. set BUILD_OPTION=rebuild
  19. ) ELSE (
  20. set BUILD_OPTION=%1
  21. )
  22. REM ********************************************************
  23. REM Set parameters
  24. REM ********************************************************
  25. set BUILD_OPTION=%1
  26. set OUTPUT_FILE_PREFIX=%2
  27. set RUNNING_FIXTURE=%3
  28. set RUNNING_DIR=%~4
  29. set BACK_TO_ROOT_DIR=%~5
  30. set TEST_J2EE_SOLUTION=Test\System.Drawing.Test20.J2EE.sln
  31. set TEST_NET_SOLUTION=Test\System.Drawing.Test20.sln
  32. set TEST_J2EE_ASSEMBLY=System.Drawing.Test20.J2EE.jar
  33. set TEST_NET_ASSEMBLY=System.Drawing.Test.dll
  34. set PROJECT_J2EE_CONFIGURATION=Debug_Java20
  35. set PROJECT_NET_CONFIGURATION=Debug
  36. set NUNIT_CONSOLE_PATH="C:\Program Files\NUnit-Net-2.0 2.2.8\bin"
  37. set startDate=%date%
  38. set startTime=%time%
  39. set sdy=%startDate:~10%
  40. set /a sdm=1%startDate:~4,2% - 100
  41. set /a sdd=1%startDate:~7,2% - 100
  42. set /a sth=%startTime:~0,2%
  43. set /a stm=1%startTime:~3,2% - 100
  44. set /a sts=1%startTime:~6,2% - 100
  45. set TIMESTAMP=%sdy%_%sdm%_%sdd%_%sth%_%stm%
  46. REM ********************************************************
  47. REM @echo Set environment
  48. REM ********************************************************
  49. set JGAC_PATH=%VMW_HOME%\jgac\vmw4j2ee_110\
  50. set JAVA_HOME=%VMW_HOME%\jre5
  51. set RUNTIME_CLASSPATH=%JGAC_PATH%mscorlib.jar
  52. set RUNTIME_CLASSPATH=%RUNTIME_CLASSPATH%;%JGAC_PATH%System.jar
  53. set RUNTIME_CLASSPATH=%RUNTIME_CLASSPATH%;%JGAC_PATH%System.Xml.jar
  54. set RUNTIME_CLASSPATH=%RUNTIME_CLASSPATH%;%JGAC_PATH%J2SE.Helpers.jar
  55. set RUNTIME_CLASSPATH=%RUNTIME_CLASSPATH%;%JGAC_PATH%jai_imageio.jar
  56. set RUNTIME_CLASSPATH=%RUNTIME_CLASSPATH%;%JGAC_PATH%System.Drawing.jar;
  57. set NUNIT_OPTIONS=/exclude=NotWorking
  58. set COMMON_PREFIX=%TIMESTAMP%_%OUTPUT_FILE_PREFIX%.GH_%GH_VERSION%.1.%USERNAME%
  59. set GH_OUTPUT_XML=%COMMON_PREFIX%.xml
  60. set NET_OUTPUT_XML=%TIMESTAMP%_%OUTPUT_FILE_PREFIX%.Net.1.%USERNAME%.xml
  61. set BUILD_LOG=%COMMON_PREFIX%.build.log
  62. set RUN_LOG=%COMMON_PREFIX%.run.log
  63. set NUNIT_PATH=%BACK_TO_ROOT_DIR%..\..\nunit20\
  64. set NUNIT_CLASSPATH=%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.framework.jar
  65. set NUNIT_CLASSPATH=%NUNIT_CLASSPATH%;%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.util.jar
  66. set NUNIT_CLASSPATH=%NUNIT_CLASSPATH%;%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.core.jar
  67. set NUNIT_CLASSPATH=%NUNIT_CLASSPATH%;%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit-console.jar
  68. set NUNIT_CLASSPATH=%NUNIT_CLASSPATH%;.
  69. set NUNIT_CLASSPATH=%NUNIT_CLASSPATH%;%TEST_ASSEMBLY%
  70. set CLASSPATH="%RUNTIME_CLASSPATH%;%NUNIT_CLASSPATH%"
  71. REM ********************************************************
  72. @echo Building GH solution...
  73. REM ********************************************************
  74. REM devenv Test\DrawingTest\System.Drawing.Test.sln /%BUILD_OPTION% Debug_Java >>%RUNNING_FIXTURE%_build.log.txt 2<&1
  75. msbuild %TEST_J2EE_SOLUTION% /t:%BUILD_OPTION% /p:Configuration=%PROJECT_J2EE_CONFIGURATION% >>%BUILD_LOG% 2<&1
  76. IF %ERRORLEVEL% NEQ 0 GOTO BUILD_EXCEPTION
  77. REM ********************************************************
  78. @echo Building NUnit solution...
  79. REM ********************************************************
  80. if "%NUNIT_BUILD%" == "DONE" goto NUNITSKIP
  81. REM devenv ..\..\nunit20\nunit.java.sln /%BUILD_OPTION% Debug_Java >>%RUNNING_FIXTURE%_build.log.txt 2<&1
  82. msbuild ..\..\nunit20\nunit20.java.sln /t:%BUILD_OPTION% /p:Configuration=%PROJECT_J2EE_CONFIGURATION% >>%BUILD_LOG% 2<&1
  83. goto NUNITREADY
  84. :NUNITSKIP
  85. echo Skipping NUnit Build...
  86. :NUNITREADY
  87. set NUNIT_BUILD=DONE
  88. IF %ERRORLEVEL% NEQ 0 GOTO BUILD_EXCEPTION
  89. REM ********************************************************
  90. @echo Building .Net solution...
  91. REM ********************************************************
  92. REM devenv Test\DrawingTest\System.Drawing.Test.dotnet.sln /%BUILD_OPTION% Debug >%RUNNING_FIXTURE%_build.log.txt 2<&1
  93. msbuild %TEST_NET_SOLUTION% /t:%BUILD_OPTION% /p:Configuration=%PROJECT_NET_CONFIGURATION% >>%BUILD_LOG% 2<&1
  94. IF %ERRORLEVEL% NEQ 0 GOTO BUILD_EXCEPTION
  95. REM ********************************************************
  96. @echo Running Net reference tests...
  97. REM ********************************************************
  98. REM ********************************************************
  99. @echo Running fixture "%RUNNING_FIXTURE%"
  100. REM ********************************************************
  101. if "%RUNNING_DIR%" NEQ "" (
  102. cd %RUNNING_DIR% )
  103. if not exist Exocortex.DSP.v1.dll (
  104. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\Exocortex.DSP.v1.dll .)
  105. if not exist DrawingTest.dll (
  106. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\DrawingTest.dll . )
  107. if not exist %TEST_NET_ASSEMBLY% (
  108. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\%TEST_NET_ASSEMBLY% . )
  109. copy "%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit-console.exe" .
  110. copy "%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.util.dll" .
  111. copy "%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.core.dll" .
  112. copy "%NUNIT_PATH%nunit-console\bin\%PROJECT_J2EE_CONFIGURATION%\nunit.framework.dll" .
  113. %NUNIT_CONSOLE_PATH%\nunit-console.exe /fixture:%RUNNING_FIXTURE% %TEST_NET_ASSEMBLY% %NUNIT_OPTIONS% /xml=%NET_OUTPUT_XML% >>%RUN_LOG% 2<&1
  114. REM ********************************************************
  115. @echo Running GH tests...
  116. REM ********************************************************
  117. REM ********************************************************
  118. @echo Running fixture "%RUNNING_FIXTURE%"
  119. REM ********************************************************
  120. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\bin\%PROJECT_J2EE_CONFIGURATION%\Exocortex.DSP.v1.jar .
  121. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\bin\%PROJECT_J2EE_CONFIGURATION%\DrawingTest.jar .
  122. copy %BACK_TO_ROOT_DIR%Test\DrawingTest\Test\bin\%PROJECT_J2EE_CONFIGURATION%\%TEST_J2EE_ASSEMBLY% .
  123. REM @echo on
  124. "%JAVA_HOME%\bin\java" -Xmx1024M -cp %CLASSPATH% NUnit.Console.ConsoleUi %TEST_J2EE_ASSEMBLY% /fixture=%RUNNING_FIXTURE% %NUNIT_OPTIONS% /xml=%GH_OUTPUT_XML% >>%RUN_LOG% 2<&1
  125. REM @echo off
  126. if "%RUNNING_DIR%" NEQ "" (
  127. copy %NET_OUTPUT_XML% %BACK_TO_ROOT_DIR%
  128. copy %GH_OUTPUT_XML% %BACK_TO_ROOT_DIR%
  129. copy %RUN_LOG% %BACK_TO_ROOT_DIR%
  130. cd %BACK_TO_ROOT_DIR% )
  131. REM ********************************************************
  132. @echo Build XmlTool
  133. REM ********************************************************
  134. set XML_TOOL_PATH=..\..\tools\mono-xmltool
  135. REM devenv %XML_TOOL_PATH%\XmlTool.sln /%BUILD_OPTION% Debug_Java >>%RUNNING_FIXTURE%_build.log.txt 2<&1
  136. msbuild %XML_TOOL_PATH%\XmlTool20.vmwcsproj /t:%BUILD_OPTION% /p:Configuration=%PROJECT_J2EE_CONFIGURATION% >>%BUILD_LOG% 2<&1
  137. IF %ERRORLEVEL% NEQ 0 GOTO BUILD_EXCEPTION
  138. copy %XML_TOOL_PATH%\bin\%PROJECT_J2EE_CONFIGURATION%\xmltool.exe .
  139. copy %XML_TOOL_PATH%\nunit_transform.xslt .
  140. REM ********************************************************
  141. @echo Analyze and print results
  142. REM ********************************************************
  143. @echo on
  144. xmltool.exe --transform nunit_transform.xslt %GH_OUTPUT_XML%
  145. @echo off
  146. :FINALLY
  147. GOTO END
  148. :ENVIRONMENT_EXCEPTION
  149. @echo This test requires environment variable VMW_HOME to be defined
  150. GOTO END
  151. :BUILD_EXCEPTION
  152. @echo Error in building solutions. See %BUILD_LOG% for details...
  153. REM EXIT 1
  154. GOTO END
  155. :RUN_EXCEPTION
  156. @echo Error in running fixture %RUNNING_FIXTURE%. See %RUN_LOG% for details...
  157. REM EXIT 1
  158. GOTO END
  159. :USAGE
  160. @echo Parameters: "[build|rebuild] <output_file_name_prefix> <test_fixture> <relative_Working_directory> <back_path (..\..\.....) >"
  161. GOTO END
  162. :END
  163. copy %RUN_LOG% ..\%BACK_TO_ROOT_DIR%
  164. copy %BUILD_LOG% ..\%BACK_TO_ROOT_DIR%
  165. copy %GH_OUTPUT_XML% ..\%BACK_TO_ROOT_DIR%
  166. REM EXIT 0