ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/build.xml
(Generate patch)

Comparing jsr166/build.xml (file contents):
Revision 1.168 by jsr166, Wed Sep 2 02:14:59 2015 UTC vs.
Revision 1.188 by jsr166, Mon Oct 12 01:53:54 2015 UTC

# Line 1 | Line 1
1 < <project name="jsr166" default="usage">
1 > <project name="jsr166" default="usage"
2 >  xmlns:if="ant:if" xmlns:unless="ant:unless">
3  
4    <description>
5   ------------------------------------------------------------------------------
# Line 28 | Line 29
29    Alternatively, define ant variables thus:
30    ant -Djdk$N.home=...
31    for $N in 6 7 8 9 ...
32 +
33 +  As of 2015-09, there is incomplete hacky support for jigsaw
34 +  Build for jigsaw using something like:
35 +  ant -Djdk9.home="$HOME/jdk/jigsaw" -Djdk9.src.dir="$HOME/jdk/src/jigsaw" clean test dist
36 +  "docs" target is still broken.
37   ------------------------------------------------------------------------------
38    </description>
39  
# Line 38 | Line 44
44      </java>
45    </target>
46  
47 +  <!-- HOWTO printf debug: <echo message="prop=${prop}"/> -->
48  
49    <!-- User-specific settings -->
50    <property file="user.properties"/>
# Line 50 | Line 57
57    <property name="build.deprecation"    value="false"/>
58    <property name="build.javadoc.access" value="protected"/>
59  
53  <!-- Tck options; see JSR166TestCase.java
54   To profile a single tck test class:
55   ant -Djsr166.profileTests=true -Djsr166.profileThreshold=100 -Djsr166.tckTestClass=CompletableFutureTest test-tck
56   To stress test a single tck test class:
57   ant -Djsr166.tckTestClass=CountedCompleterTest -Djsr166.runsPerTest=100 test-tck
58  -->
59  <property name="jsr166.profileTests"     value="false"/>
60  <property name="jsr166.profileThreshold" value="100"/>
61  <property name="jsr166.runsPerTest"      value="1"/>
62  <property name="jsr166.tckTestClass"     value="JSR166TestCase"/>
63
60    <!-- Build locations -->
61    <property name="build.dir"                   location="build"/>
62    <property name="build.classes.dir"           location="${build.dir}/classes"/>
# Line 93 | Line 89
89      <property name="java@{v}"       location="${jdk@{v}.home}/bin/java"/>
90      <property name="javac@{v}"      location="${jdk@{v}.home}/bin/javac"/>
91      <property name="javadoc@{v}"    location="${jdk@{v}.home}/bin/javadoc"/>
92 <    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"/>
92 >    <local name="have.java.base"/>
93 >    <available property="have.java.base"
94 >      file="${jdks.home}/src/jdk@{v}/jdk/src/java.base/share/classes" type="dir"/>
95 >    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/java.base/share/classes"
96 >      if:set="have.java.base"/>
97 >    <property name="jdk@{v}src.dir" location="${jdks.home}/src/jdk@{v}/jdk/src/share/classes"
98 >      unless:set="have.java.base"/>
99 >    <local name="modules"/>
100 >    <available property="modules" file="${jdk@{v}.home}/jmods" type="dir"/>
101      <local name="boot.jar.dir"/>
102 <    <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib"/>
103 <    <path id="bootclasspath@{v}">
102 >    <property name="boot.jar.dir"   location="${jdk@{v}.home}/jre/lib" unless:set="modules"/>
103 >    <path id="bootclasspath@{v}" unless:set="modules">
104        <pathelement path="${boot.jar.dir}/resources.jar"/>
105        <pathelement path="${boot.jar.dir}/rt.jar"/>
106        <pathelement path="${boot.jar.dir}/jsse.jar"/>
107        <pathelement path="${boot.jar.dir}/jce.jar"/>
108        <pathelement path="${boot.jar.dir}/charsets.jar"/>
109      </path>
110 <    <property name="bootclasspath@{v}" value="${toString:bootclasspath@{v}}"/>
110 >    <property name="bootclasspath@{v}" value="${toString:bootclasspath@{v}}" unless:set="modules"/>
111      </sequential>
112    </macrodef>
113  
# Line 129 | Line 133
133    <property name="test.src.dir"         location="${basedir}/src/test"/>
134    <property name="loops.src.dir"        location="${basedir}/src/loops"/>
135    <property name="tck.src.dir"          location="${test.src.dir}/tck"/>
136 <  <property name="jtreg.src.dir"        location="${test.src.dir}/jtreg"/>
136 >  <property name="jtreg7.src.dir"       location="${test.src.dir}/jtreg-jdk7"/>
137 >  <property name="jtreg8.src.dir"       location="${test.src.dir}/jtreg"/>
138 >  <property name="jtreg9.src.dir"       location="${test.src.dir}/jtreg"/>
139 >  <property name="jtreg.src.dir"        location="${jtreg9.src.dir}"/>
140    <property name="lib.dir"              location="${basedir}/lib"/>
141    <property name="dist.dir"             location="${basedir}/dist"/>
142    <property name="topsrc.dir"           location="${basedir}/src"/>
# Line 187 | Line 194
194    <taskdef name="jtreg" classname="com.sun.javatest.regtest.Main$$Ant"
195             classpath="${lib.dir}/jtreg.jar" />
196  
197 <  <!-- Test classpath -->
198 <  <path id="test.classpath">
199 <    <pathelement location="${build.testcases.dir}"/>
200 <    <pathelement location="${junit.jar}"/>
201 <  </path>
202 <
197 >  <!-- Tck options; see JSR166TestCase.java
198 >   To profile a single tck test class:
199 >   ant -Djsr166.profileTests=true -Djsr166.profileThreshold=10 -Djsr166.tckTestClass=CompletableFutureTest tck
200 >   To stress test a single tck test class:
201 >   ant -Djsr166.tckTestClass=CountedCompleterTest -Djsr166.runsPerTest=100 tck
202 >   To stress test a single tck test method:
203 >   ant -Djsr166.tckTestClass=RecursiveTaskTest -Djsr166.runsPerTest=1000 -Djsr166.methodFilter=testAbnormalInvokeAll3 tck
204 >  -->
205 >  <property name="jsr166.tckTestClass"     value="JSR166TestCase"/>
206    <macrodef name="run-tck-tests">
207      <attribute name="tck.src.dir" default="${tck.src.dir}"/>
208      <attribute name="target"/>
# Line 201 | Line 211
211      <attribute name="classes"/>
212      <attribute name="jvmflags" default="-ea -esa -Djsr166.testImplementationDetails=true"/>
213      <element name="javac-elements" optional="true"/>
214 +
215      <sequential>
216  
217 +    <local name="modules"/>
218 +    <condition property="modules">
219 +      <available file="${jdk@{compile-target}.home}/jmods" type="dir"/>
220 +    </condition>
221 +
222      <mkdir dir="@{workdir}/tck-classes"/>
223  
224      <javac srcdir="@{tck.src.dir}"
# Line 220 | Line 236
236  
237        <include name="*.java"/>
238        <compilerarg value="-XDignore.symbol.file=true"/>
239 <      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation"/>
240 <      <compilerarg value="-Xbootclasspath/p:@{classes}"/>
239 >      <compilerarg value="-Xlint:all,-unchecked,-rawtypes,-serial,-deprecation,-try"/>
240 >      <compilerarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
241 >      <compilerarg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
242        <compilerarg line="${build.args}"/>
243        <javac-elements/>
244  
# Line 231 | Line 248
248            failonerror="true"
249            jvm="${java@{target}}"
250            fork="true">
251 <        <jvmarg value="-Xbootclasspath/p:@{classes}"/>
251 >        <jvmarg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
252 >        <jvmarg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
253          <jvmarg line="@{jvmflags}"/>
254  
255 <        <!-- ant -Djava.util.concurrent.ForkJoinPool.common.parallelism=1 test-tck -->
256 <        <syspropertyset id="java.util.concurrent.ForkJoinPool-properties">
255 >        <!-- ant -Djava.util.concurrent.ForkJoinPool.common.parallelism=1 tck -->
256 >        <syspropertyset id="system-properties-used-by-tck">
257            <propertyref prefix="java.util.concurrent.ForkJoinPool"/>
258 +          <propertyref prefix="jsr166."/>
259          </syspropertyset>
260  
242        <sysproperty key="jsr166.profileTests"     value="${jsr166.profileTests}"/>
243        <sysproperty key="jsr166.profileThreshold" value="${jsr166.profileThreshold}"/>
244        <sysproperty key="jsr166.runsPerTest"      value="${jsr166.runsPerTest}"/>
261          <classpath>
262            <pathelement location="${junit.jar}"/>
263            <pathelement location="@{workdir}/tck-classes"/>
# Line 252 | Line 268
268    </macrodef>
269  
270    <!-- Define jtreg test sets for different jdk versions -->
271 <  <fileset dir="${jtreg.src.dir}">
271 >  <fileset dir="${jtreg9.src.dir}">
272      <patternset id="jdk9.jtreg.tests">
273        <include name="**/*.java"/>
274      </patternset>
275    </fileset>
276  
277 <  <fileset dir="${jtreg.src.dir}">
277 >  <fileset dir="${jtreg8.src.dir}">
278      <patternset id="jdk8.jtreg.tests">
279        <include name="**/*.java"/>
280 <      <exclude name="util/Spliterator/SpliteratorCharacteristics.java"/>
280 >      <exclude name="**/SpliteratorCharacteristics.java"/>
281        <!-- https://bugs.openjdk.java.net/browse/JDK-6842353 -->
282 <      <exclude name="util/WeakHashMap/GCDuringIteration.java"/>
282 >      <exclude name="**/GCDuringIteration.java"/>
283      </patternset>
284    </fileset>
285  
286 <  <fileset dir="${jtreg.src.dir}">
286 >  <fileset dir="${jtreg7.src.dir}">
287      <patternset id="jdk7.jtreg.tests">
288        <include name="**/*.java"/>
273      <exclude name="util/Collection/CollectionDefaults.java"/>
274      <exclude name="util/List/ListDefaults.java"/>
275      <exclude name="util/Spliterator/**/*.java"/>
276      <exclude name="util/concurrent/CompletableFuture/**/*.java"/>
277      <exclude name="util/concurrent/forkjoin/SubmissionTest.java"/>
278      <exclude name="util/concurrent/locks/StampedLock/**/*.java"/>
289      </patternset>
290    </fileset>
291  
292    <macrodef name="run-jtreg-tests">
293 <    <!-- ant -Djtreg.src.dir=src/test/jtreg/util/concurrent/CompletableFuture test-jtreg -->
284 <    <attribute name="jtreg.src.dir" default="${jtreg.src.dir}"/>
293 >    <!-- ant -Djtreg9.src.dir=src/test/jtreg/util/concurrent/CompletableFuture jtreg -->
294      <attribute name="source" default="7"/>
295      <attribute name="target"/>
296      <attribute name="workdir"/>
297      <attribute name="classes"/>
298      <attribute name="jtregflags" default=""/>
299 +
300      <sequential>
301 +
302 +    <!-- ant -Djtreg.verbose=time,fail,error jtreg -->
303 +    <property name="jtreg.verbose" value="nopass,fail,error"/>
304 +
305 +    <local name="modules"/>
306 +    <condition property="modules">
307 +      <available file="${jdk@{target}.home}/jmods" type="dir"/>
308 +    </condition>
309 +
310      <delete dir="@{workdir}/JTwork"   quiet="true"/>
311      <delete dir="@{workdir}/JTreport" quiet="true"/>
312      <mkdir dir="@{workdir}/JTwork/scratch"/>
313      <mkdir dir="@{workdir}/JTreport"/>
314 <    <jtreg dir="@{jtreg.src.dir}"
314 >    <jtreg dir="${jtreg@{target}.src.dir}"
315             jdk="${jdk@{target}.home}"
316             workDir="@{workdir}/JTwork"
317             reportDir="@{workdir}/JTreport">
318        <patternset refid="jdk@{target}.jtreg.tests"/>
319 <      <arg value="-Xbootclasspath/p:@{classes}"/>
319 >      <arg value="-Xbootclasspath/p:@{classes}" unless:set="modules"/>
320 >      <arg value="-Xoverride:${build.classes.dir}" if:set="modules"/>
321        <arg value="-agentvm"/>
322 <      <arg value="-v:nopass,fail"/>
322 >      <arg value="-verbose:${jtreg.verbose}"/>
323        <arg value="-vmoptions:-esa -ea"/>
324        <arg value="-automatic"/>
325        <arg value="-k:!ignore"/>
# Line 330 | Line 350
350            depends="configure-compiler"
351            description="Compiles src/main sources to build dir">
352  
353 <    <mkdir dir="${build.classes.dir}"/>
353 >    <local name="modules"/>
354 >    <condition property="modules">
355 >      <and>
356 >        <available file="${jdk9.home}/jmods" type="dir"/>
357 >        <equals arg1="9" arg2="${build.main.java.version}"/>
358 >      </and>
359 >    </condition>
360 >
361 >    <local name="destdir"/>
362 >    <property name="destdir" value="${build.classes.dir}/java.base" if:set="modules"/>
363 >    <property name="destdir" value="${build.classes.dir}" unless:set="modules"/>
364 >
365 >    <mkdir dir="${destdir}"/>
366  
367      <javac srcdir="${src.dir}"
368 <           destdir="${build.classes.dir}"
368 >           destdir="${destdir}"
369             debug="${build.debug}"
370             debuglevel="${build.debuglevel}"
371             deprecation="${build.deprecation}"
# Line 344 | Line 376
376             fork="true">
377  
378        <include name="**/*.java"/>
379 +      <compilerarg value="-Xmodule:java.base" if:set="modules"/>
380        <compilerarg value="-Xprefer:source"/>
381        <compilerarg value="-XDignore.symbol.file=true"/>
382        <compilerarg value="-Xlint:all"/>
# Line 362 | Line 395
395  
396      <jar destfile="${product.jar}">
397        <fileset dir="${build.classes.dir}"/>
398 +      <manifest>
399 +        <attribute name="Built-By" value="${user.name}"/>
400 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
401 +      </manifest>
402      </jar>
403    </target>
404  
# Line 389 | Line 426
426        <arg line="-Xdocrootparent ${java9.docroot.url}"/>
427        <arg line="-Xmaxerrs 1000 -Xmaxwarns 1000"/>
428        <arg value="-XDignore.symbol.file=true"/>
429 + <!--  TODO     <arg value="-Xmodule:java.base"/> -->
430        <arg value="-tag"/>
431        <arg value="${javadoc.jls.option}"/>
432        <arg value="-tag"/>
# Line 420 | Line 458
458        <exclude name="src/emulation/**"/>
459        <exclude name="**/SyntaxTest.java"/>
460        <exclude name="**/SuperfluousAbstract.java"/>
461 +      <manifest>
462 +        <attribute name="Built-By" value="${user.name}"/>
463 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
464 +      </manifest>
465      </jar>
466    </target>
467  
# Line 451 | Line 493
493      <mirror-dir src="${docs.dir}" dst="${dist.docs.dir}"/>
494    </target>
495  
496 <  <target name="tck" depends="test-tck" description="alias for test-tck"/>
455 <  <target name="test-tck"
496 >  <target name="tck"
497            depends="jar"
498            description="Runs tck tests for main directly">
499  
# Line 462 | Line 503
503        classes="${product.jar}"/>
504    </target>
505  
506 <  <target name="test-tck-parallelism-1"
507 <          description="Runs test-tck with given common pool parallelism">
508 <    <antcall target="test-tck">
506 >  <target name="tck-parallelism-1"
507 >          description="Runs tck with given common pool parallelism">
508 >    <antcall target="tck">
509        <param name="java.util.concurrent.ForkJoinPool.common.parallelism" value="1"/>
510      </antcall>
511    </target>
512  
513 <  <target name="test-tck-parallelism-0"
514 <          description="Runs test-tck with given common pool parallelism">
515 <    <antcall target="test-tck">
513 >  <target name="tck-parallelism-0"
514 >          description="Runs tck with given common pool parallelism">
515 >    <antcall target="tck">
516        <param name="java.util.concurrent.ForkJoinPool.common.parallelism" value="0"/>
517      </antcall>
518    </target>
519  
520 <  <target name="jtreg" depends="test-jtreg" description="alias for test-jtreg"/>
480 <  <target name="test-jtreg"
520 >  <target name="jtreg"
521            depends="jar"
522            description="Runs jtreg tests for main using the jtreg ant task">
523      <run-jtreg-tests
# Line 487 | Line 527
527    </target>
528  
529    <target name="test"
530 <          depends="test-tck, test-tck-parallelism-1, test-jtreg"
530 >          depends="tck, tck-parallelism-1, jtreg"
531            description="Runs tck and jtreg tests for main">
532    </target>
533  
# Line 520 | Line 560
560  
561  
562    <target name="configure-compiler">
563 +    <fail message="ant version too old">
564 +      <condition>
565 +        <not> <antversion atleast="1.9.1"/> </not>
566 +      </condition>
567 +    </fail>
568  
569      <property name="unchecked.option" value="-Xlint:unchecked"/>
570  
# Line 659 | Line 704
704  
705      <jar destfile="${4jdk7product.jar}">
706        <fileset dir="${build.4jdk7.classes.dir}"/>
707 +      <manifest>
708 +        <attribute name="Built-By" value="${user.name}"/>
709 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
710 +      </manifest>
711      </jar>
712  
713    </target>
714  
715  
716 <  <target name="4jdk7-test-tck"
716 >  <target name="4jdk7-tck"
717            depends="4jdk7jar"
718            description="Runs tck tests for jsr166-4jdk7 directly">
719  
# Line 676 | Line 725
725          <!-- JDK8+ test classes -->
726          <exclude name="*8Test.java"/>
727          <exclude name="*9Test.java"/>
728 +        <exclude name="*10Test.java"/>
729          <exclude name="DoubleAccumulatorTest.java"/>
730          <exclude name="DoubleAdderTest.java"/>
731          <exclude name="LongAccumulatorTest.java"/>
# Line 683 | Line 733
733          <exclude name="CompletableFutureTest.java"/>
734          <exclude name="SplittableRandomTest.java"/>
735          <exclude name="StampedLockTest.java"/>
736 +        <exclude name="SubmissionPublisherTest.java"/>
737        </javac-elements>
738      </run-tck-tests>
739    </target>
740  
741  
742 <  <target name="4jdk7-test-tck-junit"
742 >  <target name="4jdk7-tck-junit"
743            depends="4jdk7compile"
744            description="Runs tck tests for jsr166-4jdk7 via junit task (experimental)">
745  
# Line 716 | Line 767
767      </junit>
768    </target>
769  
770 <  <target name="4jdk7-test-jtreg"
770 >  <target name="4jdk7-jtreg"
771            depends="4jdk7jar"
772            description="Runs jtreg tests for jsr166-4jdk7 using the jtreg ant task">
773      <run-jtreg-tests
# Line 727 | Line 778
778  
779  
780    <target name="4jdk7-test"
781 <          depends="4jdk7-test-tck, 4jdk7-test-jtreg"
781 >          depends="4jdk7-tck, 4jdk7-jtreg"
782            description="Runs tck and jtreg tests for jsr166-4jdk7">
783    </target>
784  
# Line 817 | Line 868
868  
869      <jar destfile="${jsr166x.jar}">
870        <fileset dir="${build.jsr166x.classes.dir}"/>
871 +      <manifest>
872 +        <attribute name="Built-By" value="${user.name}"/>
873 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
874 +      </manifest>
875      </jar>
876  
877    </target>
# Line 904 | Line 959
959  
960      <jar destfile="${jsr166y.jar}" index="true">
961        <fileset dir="${build.jsr166y.classes.dir}"/>
962 +      <manifest>
963 +        <attribute name="Built-By" value="${user.name}"/>
964 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
965 +      </manifest>
966      </jar>
967  
968    </target>
# Line 992 | Line 1051
1051  
1052      <jar destfile="${extra166y.jar}" index="true">
1053        <fileset dir="${build.extra166y.classes.dir}"/>
1054 +      <manifest>
1055 +        <attribute name="Built-By" value="${user.name}"/>
1056 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1057 +      </manifest>
1058      </jar>
1059  
1060    </target>
# Line 1107 | Line 1170
1170  
1171      <jar destfile="${jsr166e.jar}" index="true">
1172        <fileset dir="${build.jsr166e.classes.dir}"/>
1173 +      <manifest>
1174 +        <attribute name="Built-By" value="${user.name}"/>
1175 +        <attribute name="Implementation-Vendor" value="JCP JSR-166 Expert Group."/>
1176 +      </manifest>
1177      </jar>
1178  
1179    </target>
# Line 1132 | Line 1199
1199    </target>
1200  
1201  
1202 <  <target name="jsr166e-test-tck-one-java-version"
1202 >  <target name="jsr166e-tck-one-java-version"
1203            depends="jsr166ejar">
1204  
1205      <echo message="Testing with jdk${build.jsr166e.java.version} ..."/>
# Line 1144 | Line 1211
1211        classes="${jsr166e.jar}"/>
1212    </target>
1213  
1214 <  <target name="jsr166e-test-tck"
1214 >  <target name="jsr166e-tck"
1215            description="Runs tck tests for jsr166e for multiple java versions">
1216  
1217   <!--     <antcall target="clean"/> -->
1218 < <!--     <antcall target="jsr166e-test-tck-one-java-version"> -->
1218 > <!--     <antcall target="jsr166e-tck-one-java-version"> -->
1219   <!--       <param name="build.jsr166e.java.version" value="8"/> -->
1220   <!--       <param name="build.jsr166e.javac" value="${javac8}"/> -->
1221   <!--     </antcall> -->
1222  
1223      <antcall target="clean"/>
1224 <    <antcall target="jsr166e-test-tck-one-java-version">
1224 >    <antcall target="jsr166e-tck-one-java-version">
1225        <param name="build.jsr166e.java.version" value="7"/>
1226        <param name="build.jsr166e.javac" value="${javac7}"/>
1227      </antcall>
1228  
1229      <antcall target="clean"/>
1230 <    <antcall target="jsr166e-test-tck-one-java-version">
1230 >    <antcall target="jsr166e-tck-one-java-version">
1231        <param name="build.jsr166e.java.version" value="6"/>
1232        <param name="build.jsr166e.javac" value="${javac6}"/>
1233      </antcall>
# Line 1168 | Line 1235
1235  
1236  
1237    <target name="jsr166e-test"
1238 <          depends="jsr166e-test-tck"
1238 >          depends="jsr166e-tck"
1239            description="Runs all tests for jsr166e">
1240    </target>
1241  

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines