david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 1 | <project |
| 2 | name="Build specific targets and properties" |
| 3 | default="runTest"> |
ndai | b8cedc8 | 2005-09-13 18:00:32 +0000 | [diff] [blame] | 4 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 5 | <!-- Note to be cross-platform, "environment variables" are only appropriate for |
| 6 | some variables, e.g. ones we set, since properties are case sensitive, even if |
| 7 | the environment variables on your operating system are not, e.g. it will |
| 8 | be ${env.Path} not ${env.PATH} on Windows --> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 9 | <property |
| 10 | environment="env" /> |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 11 | <!-- required to get proper value of dropinsFolder --> |
| 12 | <property name="keyCfgFile" value="${env.PROJECT_BUILDERS}/${projectname}/${env.RELENG}/maps/build.cfg" /> |
| 13 | <echo message="keyCfgFile: ${keyCfgFile}" /> |
| 14 | <property file="${keyCfgFile}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 15 | <fail |
| 16 | message="testRoot must be set for this task" |
| 17 | unless="testRoot" /> |
ndai | b8cedc8 | 2005-09-13 18:00:32 +0000 | [diff] [blame] | 18 | |
david_williams | 4308936 | 2008-03-25 05:43:38 +0000 | [diff] [blame] | 19 | <!-- |
| 20 | Steps to do after the build is done. |
| 21 | --> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 22 | <target |
| 23 | name="test"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 24 | <dirname |
| 25 | file="${ant.file}" |
| 26 | property="currentDirectory" /> |
| 27 | <ant |
| 28 | antfile="${ant.file}" |
| 29 | target="runTest" |
| 30 | dir="${currentDirectory}" /> |
| 31 | </target> |
ndai | b8cedc8 | 2005-09-13 18:00:32 +0000 | [diff] [blame] | 32 | |
david_williams | 4308936 | 2008-03-25 05:43:38 +0000 | [diff] [blame] | 33 | <!-- |
| 34 | Steps to do to test the build results |
| 35 | --> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 36 | <target |
| 37 | name="runTest"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 38 | <dirname |
| 39 | file="${ant.file}" |
| 40 | property="test.component.dir" /> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 41 | <ant |
| 42 | antfile="${wtp.builder.home}/scripts/build/label.xml" /> |
| 43 | <property |
| 44 | file="${buildDirectory}/label.properties" /> |
| 45 | <property |
| 46 | file="${wtp.builder.home}/build.properties" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 47 | <fail |
| 48 | message="testRoot must be set for this task" |
| 49 | unless="testRoot" /> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 50 | <mkdir |
| 51 | dir="${testRoot}" /> |
david_williams | f5f131a | 2007-03-17 06:12:13 +0000 | [diff] [blame] | 52 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 53 | <!-- if results already exist, delete them --> |
| 54 | <delete |
| 55 | dir="${testRoot}/results" |
| 56 | failOnError="false" /> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 57 | <mkdir |
| 58 | dir="${testRoot}/results" /> |
| 59 | <mkdir |
| 60 | dir="${testRoot}/results/consolelogs" /> |
| 61 | <mkdir |
| 62 | dir="${testRoot}/results/consolelogs/metadata-logs" /> |
| 63 | <mkdir |
| 64 | dir="${testRoot}/results/consolelogs/configuration-logs" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 65 | <copy |
| 66 | todir="${testRoot}" |
| 67 | overwrite="true"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 68 | <fileset |
david_williams | 4308936 | 2008-03-25 05:43:38 +0000 | [diff] [blame] | 69 | dir="${test.component.dir}/testScripts" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 70 | </copy> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 71 | <echo |
| 72 | message="BASEOS: ${env.BASEOS} BASEWS: ${env.BASEWS} BASEARCH: ${env.BASEARCH} " /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 73 | <ant |
| 74 | antfile="${test.component.dir}/testdependency.xml" |
| 75 | target="get"> |
| 76 | <property |
| 77 | name="dependency.properties" |
| 78 | value="${buildDirectory}/maps/${env.RELENG}/maps/dependencies.properties" /> |
| 79 | <property |
| 80 | name="base.install.dir" |
| 81 | value="${testRoot}" /> |
| 82 | </ant> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 83 | <antcall |
| 84 | target="unzipTests" /> |
| 85 | <antcall |
| 86 | target="runTestEclipse"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 87 | <param |
| 88 | name="testTarget" |
| 89 | value="all" /> |
| 90 | </antcall> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 91 | <antcall |
| 92 | target="postRunTestEclipse"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 93 | <param |
| 94 | name="testTarget" |
| 95 | value="all" /> |
| 96 | </antcall> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 97 | </target> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 98 | <target |
| 99 | name="unzipTests"> |
david_williams | f5f131a | 2007-03-17 06:12:13 +0000 | [diff] [blame] | 100 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 101 | <!--unzip the builds and junit tests |
david_williams | 4308936 | 2008-03-25 05:43:38 +0000 | [diff] [blame] | 102 | we use 'unzip' here, so we can continue on error, if desired. |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 103 | (such as if zip was not created, due to other failures or options). |
| 104 | --> |
| 105 | <exec |
| 106 | dir="${buildDirectory}/${buildLabel}" |
| 107 | executable="unzip" |
| 108 | failonerror="false"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 109 | <arg |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 110 | line="-o -qq wtp-sdk-${buildLabel}.zip -d ${testRoot}${dropinsFolder}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 111 | </exec> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 112 | <exec |
| 113 | dir="${buildDirectory}/${buildLabel}" |
| 114 | executable="unzip" |
| 115 | failonerror="false"> |
| 116 | <arg |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 117 | line="-o -qq wtp-wst-Automated-Tests-${buildLabel}.zip -d ${testRoot}${dropinsFolder}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 118 | </exec> |
| 119 | <exec |
| 120 | dir="${buildDirectory}/${buildLabel}" |
| 121 | executable="unzip" |
| 122 | failonerror="false"> |
| 123 | <arg |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 124 | line="-o -qq wtp-jst-Automated-Tests-${buildLabel}.zip -d ${testRoot}${dropinsFolder}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 125 | </exec> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 126 | <exec |
| 127 | dir="${buildDirectory}/${buildLabel}" |
| 128 | executable="unzip" |
| 129 | failonerror="false"> |
| 130 | <arg |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 131 | line="-o -qq wtp-jpt-sdk-${buildLabel}.zip -d ${testRoot}${dropinsFolder}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 132 | </exec> |
| 133 | <exec |
| 134 | dir="${buildDirectory}/${buildLabel}" |
| 135 | executable="unzip" |
| 136 | failonerror="false"> |
| 137 | <arg |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 138 | line="-o -qq wtp-jpt-Automated-Tests-${buildLabel}.zip -d ${testRoot}${dropinsFolder}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 139 | </exec> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 140 | </target> |
david_williams | f5f131a | 2007-03-17 06:12:13 +0000 | [diff] [blame] | 141 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 142 | <!-- time out may need to be set/adjust for api or performance tests? |
| 143 | This testTimeLimit is the whole, overall limit on tests. There's a shorter |
| 144 | one for individual suites. |
| 145 | |
| 146 | some common values, of milliseconds to more recognizable units: |
david_williams | 64426ec | 2008-03-27 02:26:58 +0000 | [diff] [blame] | 147 | 14400000: 4 hours ... up'd to 4 hours after P2 |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 148 | 7200000: 2 hours |
| 149 | 3600000: 1 hour |
| 150 | 1800000: 30 minutes |
| 151 | 600000: 10 minutes |
| 152 | --> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 153 | <property |
| 154 | name="testTimeLimit" |
david_williams | 64426ec | 2008-03-27 02:26:58 +0000 | [diff] [blame] | 155 | value="14400000" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 156 | <property |
| 157 | name="testFailOnError" |
| 158 | value="false" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 159 | <target |
| 160 | name="runTestEclipse" |
| 161 | description="Run our JUnit's within an instance of antRunner"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 162 | <property |
| 163 | name="test-vm" |
| 164 | value="${env.JAVA_5_HOME}/bin/java" /> |
| 165 | <property |
| 166 | name="plugin-path" |
david_williams | cfd9a4a | 2008-03-27 16:35:01 +0000 | [diff] [blame^] | 167 | value="${testRoot}${dropinsFolder}/eclipse/plugins" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 168 | <property |
| 169 | name="vmargs" |
| 170 | value="-Xms256m -Xmx512m -Dosgi.ws=${env.BASEWS} -Dosgi.os=${env.BASEOS} -Dosgi.arch=${env.BASEARCH} -Dws=${env.BASEWS} -Dos=${env.BASEOS} -Darch=${env.BASEARCH} -Dosgi.clean=true -Dnoclean=true -DbuildBranch=${buildBranch} -DbuildType=${buildType} -DbuildId=${buildId} -DtestRoot=${testRoot} -DtestDir=${testRoot} -DbuildDirectory=${buildDirectory} -Dbuild.home=${env.BUILD_HOME} -DeclipseBuilderDirectory=${pde.builder.path} -DbuildLabel=${buildLabel} -Dtest-vm=${test-vm} -Dperf.buildId=${buildType}${date}-${time}" /> |
david_williams | 9d23a9d | 2007-03-16 02:23:53 +0000 | [diff] [blame] | 171 | |
david_williams | 4b09369 | 2007-03-19 09:41:32 +0000 | [diff] [blame] | 172 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 173 | <!-- set path to eclipse folder. If local folder, use '.'; otherwise, use c:\path\to\eclipse or /path/to/eclipse/ --> |
| 174 | <property |
| 175 | name="eclipse.home" |
| 176 | value="${testRoot}" /> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 177 | <echo |
| 178 | message="Running junits" /> |
david_williams | 9d23a9d | 2007-03-16 02:23:53 +0000 | [diff] [blame] | 179 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 180 | <!-- If there is not exactly one launcher in the stack, |
| 181 | we'd best fail fast, since we are not expecting that, |
| 182 | and may indicate an installation that would produce unpredictable |
| 183 | results --> |
| 184 | <!-- requires ant 1.7, and at this point, we're running 1.6 from |
| 185 | eclipse ... |
| 186 | |
| 187 | <condition property="expectedNumberOfLaunchers"> |
| 188 | <resourcecount when="equal" count="1" > |
| 189 | <fileset dir="${testRoot}/eclipse/plugins"> |
| 190 | <include name="org.eclipse.equinox.launcher_*.jar" /> |
| 191 | </fileset> |
| 192 | </resourcecount> |
| 193 | </condition> |
| 194 | <fail message="Did not find expected number of launcher jars. Check installation." unless="expectedNumberOfLaunchers" /> |
| 195 | --> |
david_williams | fe1d092 | 2008-03-25 03:01:25 +0000 | [diff] [blame] | 196 | |
| 197 | |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 198 | <!-- |
| 199 | Remember: using -debug for org.eclipse.ant.core.antRunner |
| 200 | produces ant debug info to be output ... which is a TON of stuff |
| 201 | --> |
david_williams | 4308936 | 2008-03-25 05:43:38 +0000 | [diff] [blame] | 202 | <echo |
| 203 | message="eclipse.launcher: ${eclipse.launcher}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 204 | <java |
| 205 | taskname="unit-test-masterprocess" |
| 206 | fork="true" |
| 207 | resultProperty="wtpmasterjunitresult" |
| 208 | failonerror="false" |
| 209 | timeout="${testTimeLimit}" |
| 210 | dir="${testRoot}/eclipse" |
| 211 | jvm="${env.JAVA_5_HOME}/bin/java" |
| 212 | classname="org.eclipse.equinox.launcher.Main"> |
| 213 | <classpath> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 214 | <fileset |
| 215 | dir="${testRoot}/eclipse/plugins"> |
| 216 | <include |
| 217 | name="org.eclipse.equinox.launcher_*.jar" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 218 | </fileset> |
| 219 | </classpath> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 220 | <jvmarg |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 221 | value="-Xms512m" /> |
| 222 | <jvmarg |
| 223 | value="-Xmx1024m" /> |
| 224 | <jvmarg |
| 225 | value="-Dosgi.ws=${env.BASEWS}" /> |
| 226 | <jvmarg |
| 227 | value="-Dosgi.os=${env.BASEOS}" /> |
| 228 | <jvmarg |
| 229 | value="-Dosgi.arch=${env.BASEARCH}" /> |
| 230 | <jvmarg |
| 231 | value="-Dws=${env.BASEWS}" /> |
| 232 | <jvmarg |
| 233 | value="-Dos=${env.BASEOS}" /> |
| 234 | <jvmarg |
| 235 | value="-Darch=${env.BASEARCH}" /> |
| 236 | <jvmarg |
| 237 | value="-Dosgi.clean=true" /> |
| 238 | <jvmarg |
| 239 | value="-Dnoclean=true" /> |
| 240 | <jvmarg |
| 241 | value="-DbuildBranch=${buildBranch}" /> |
| 242 | <jvmarg |
| 243 | value="-DbuildType=${buildType}" /> |
| 244 | <jvmarg |
| 245 | value="-DbuildId=${buildId}" /> |
david_williams | 26f3a5f | 2008-03-07 22:56:23 +0000 | [diff] [blame] | 246 | <jvmarg |
| 247 | value="-Djava.io.tmpdir=${env.RECOMMENDED_TMP_DIR}" /> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 248 | <arg |
| 249 | value="-nosplash" /> |
| 250 | <arg |
| 251 | value="-consolelog" /> |
| 252 | <arg |
| 253 | value="-data" /> |
| 254 | <arg |
| 255 | value="${testRoot}/overallTestWorkspace" /> |
| 256 | <arg |
| 257 | value="-application" /> |
| 258 | <arg |
| 259 | value="org.eclipse.ant.core.antRunner" /> |
| 260 | <arg |
| 261 | value="-file" /> |
| 262 | <arg |
| 263 | value="${testRoot}/test.xml" /> |
| 264 | <arg |
| 265 | value="-logger" /> |
| 266 | <arg |
| 267 | value="org.apache.tools.ant.DefaultLogger" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 268 | <env |
| 269 | key="DISPLAY" |
| 270 | value="${env.DISPLAY}" /> |
| 271 | <redirector |
| 272 | output="${testRoot}/results/fullOutput.txt" |
| 273 | error="${testRoot}/results/fullErrorLog.txt" /> |
| 274 | <sysproperty |
| 275 | key="build.home" |
| 276 | value="${env.BUILD_HOME}" /> |
| 277 | <sysproperty |
| 278 | key="buildDirectory" |
| 279 | value="${buildDirectory}" /> |
| 280 | <sysproperty |
| 281 | key="buildLabel" |
| 282 | value="${buildLabel}" /> |
| 283 | <sysproperty |
| 284 | key="baseLocation" |
| 285 | value="${baseLocation}" /> |
| 286 | <sysproperty |
| 287 | key="testRoot" |
| 288 | value="${testRoot}" /> |
| 289 | <sysproperty |
| 290 | key="testDir" |
| 291 | value="${testRoot}" /> |
| 292 | <sysproperty |
| 293 | key="perf.buildId" |
| 294 | value="${buildType}${date}-${time}" /> |
| 295 | <sysproperty |
| 296 | key="eclipseBuilderDirectory" |
| 297 | value="${pde.builder.path}" /> |
| 298 | <sysproperty |
| 299 | key="buildLabel" |
david_williams | 26f3a5f | 2008-03-07 22:56:23 +0000 | [diff] [blame] | 300 | value="${buildLabel}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 301 | </java> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 302 | <echo |
| 303 | message="wtpmasterjunitresult ${wtpmasterjunitresult}" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 304 | </target> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 305 | <target |
| 306 | name="postRunTestEclipse"> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 307 | <copy |
| 308 | todir="${buildDirectory}/${buildLabel}/testResults/consolelogs/testLogs" |
| 309 | overwrite="true" |
| 310 | failonerror="false"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 311 | <fileset |
| 312 | dir="${testRoot}/results"> |
| 313 | <include |
| 314 | name="*output.txt" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 315 | </fileset> |
| 316 | </copy> |
| 317 | <copy |
| 318 | todir="${buildDirectory}/${buildLabel}/testResults/consolelogs/testSysErrorLogs" |
| 319 | overwrite="true" |
| 320 | failonerror="false"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 321 | <fileset |
| 322 | dir="${testRoot}/results"> |
| 323 | <include |
| 324 | name="*error.txt" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 325 | </fileset> |
| 326 | </copy> |
| 327 | <copy |
| 328 | file="${testRoot}/results/fullOutput.txt" |
| 329 | toDir="${buildDirectory}/${buildLabel}/testResults/consolelogs/full" |
| 330 | overwrite="true" |
| 331 | failonerror="false"> |
| 332 | </copy> |
| 333 | <copy |
| 334 | file="${testRoot}/results/fullErrorLog.txt" |
| 335 | toDir="${buildDirectory}/${buildLabel}/testResults/consolelogs/full" |
| 336 | overwrite="true" |
| 337 | failonerror="false"> |
| 338 | </copy> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 339 | <copy |
| 340 | todir="${buildDirectory}/${buildLabel}/testResults/xml" |
| 341 | overwrite="true" |
| 342 | failonerror="false"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 343 | <fileset |
| 344 | dir="${testRoot}/results/xml"> |
| 345 | <include |
| 346 | name="*.xml" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 347 | </fileset> |
| 348 | </copy> |
| 349 | <copy |
| 350 | todir="${buildDirectory}/${buildLabel}/testResults/html" |
| 351 | overwrite="true" |
| 352 | failonerror="false"> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 353 | <fileset |
| 354 | dir="${testRoot}/results/html"> |
| 355 | <include |
| 356 | name="*.html" /> |
david_williams | 403beae | 2007-12-09 02:10:40 +0000 | [diff] [blame] | 357 | </fileset> |
| 358 | </copy> |
| 359 | </target> |
david_williams | ad2097e | 2008-01-28 06:06:12 +0000 | [diff] [blame] | 360 | </project> |