You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by br...@apache.org on 2021/07/25 16:41:45 UTC
[cassandra] 03/10: Offline build mode
This is an automated email from the ASF dual-hosted git repository.
brandonwilliams pushed a commit to branch cassandra-3.11
in repository https://gitbox.apache.org/repos/asf/cassandra.git
commit e6950518d15da7c0b5a1bb6304f911c056426df5
Author: Mick Semb Wever <mc...@apache.org>
AuthorDate: Sat Apr 3 02:06:46 2021 +0200
Offline build mode
When all dependencies are already in the local `~/.m2/repository/` we should not be needing an internet connection. ("Offline" mode should be automatic)
patch by Mick Semb Wever; reviewed by Brandon Williams for CASSANDRA-16559
---
.build/build-resolver.xml | 64 +++++++++++++++++++++--------------------------
build.xml | 16 ++++++------
2 files changed, 35 insertions(+), 45 deletions(-)
diff --git a/.build/build-resolver.xml b/.build/build-resolver.xml
index 61ddb94..20f4244 100644
--- a/.build/build-resolver.xml
+++ b/.build/build-resolver.xml
@@ -15,47 +15,49 @@
limitations under the License.
-->
<project basedir="." name="apache-cassandra--resolver-tasks"
- xmlns:resolver="antlib:org.apache.maven.resolver.ant">
+ xmlns:resolver="antlib:org.apache.maven.resolver.ant"
+ xmlns:if="ant:if"
+ xmlns:unless="ant:unless">
<!-- details of what version of Resolver ANT Tasks to fetch -->
<property name="resolver-ant-tasks.version" value="1.3.0" />
- <property name="resolver-ant-tasks.local" value="${user.home}/.m2/repository/org/apache/maven/resolver/maven-resolver-ant-tasks"/>
+ <property name="resolver-ant-tasks.local" value="${user.home}/.m2/repository/org/apache/maven/resolver/maven-resolver-ant-tasks/${resolver-ant-tasks.version}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}.jar"/>
<property name="resolver-ant-tasks.url" value="https://repo1.maven.org/maven2/org/apache/maven/resolver/maven-resolver-ant-tasks" />
<!-- version of lib/ downloads -->
<property name="lib.download.sha" value="6c29ee84a2f62ccd05c328bbaa0c364eb1a7a821"/>
+
<condition property="resolver-ant-tasks.jar.exists">
- <available file="${build.dir}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar" />
+ <available file="${resolver-ant-tasks.local}" />
</condition>
- <condition property="resolver-ant-tasks.jar.local">
- <available file="${resolver-ant-tasks.local}/${resolver-ant-tasks.version}/maven-resolver-${resolver-ant-tasks.version}-uber.jar" />
+ <!-- version of lib/ downloads -->
+ <property name="lib.download.sha" value="1371883db3d8bf7d7c54e0baaca89c6c2d2a5abe"/>
+
+ <!-- jstackunit is not in maven central -->
+ <property name="jstackunit.local" value="${user.home}/.m2/repository/org/krummas/junit/jstackjunit/0.0.1/jstackjunit-0.0.1.jar"/>
+ <condition property="jstackunit.jar.exists">
+ <available file="${jstackunit.local}" />
</condition>
- <path id="resolver-ant-tasks.classpath" path="${build.dir}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar" />
+ <path id="resolver-ant-tasks.classpath" path="${resolver-ant-tasks.local}" />
<!--
- Fetch Resolver Ant Tasks and Cassandra's dependencies
- These targets are intentionally free of dependencies so that they
- can be run stand-alone from a binary release artifact.
+ Fetch Resolver Ant Tasks and Cassandra's dependencies.
-->
- <target name="_resolver_localrepo" unless="resolver-ant-tasks.jar.exists" if="resolver-ant-tasks.jar.local"
- depends="init" description="Fetch Resolver ANT Tasks from Maven Local Repository">
- <copy file="${resolver-ant-tasks.local}/${resolver-ant-tasks.version}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar"
- tofile="${build.dir}/resolver-ant-tasks-${resolver-ant-tasks.version}.jar" quiet="true"/>
+ <target name="_resolver_download" unless="resolver-ant-tasks.jar.exists" description="Fetch Resolver ANT Tasks from Maven Central Repository">
+ <echo>Downloading Resolver ANT Tasks...</echo>
+ <mkdir dir="${user.home}/.m2/repository/org/apache/maven/resolver/maven-resolver-ant-tasks/${resolver-ant-tasks.version}" />
- <property name="resolver-ant-tasks.jar.exists" value="true"/>
+ <get src="${resolver-ant-tasks.url}/${resolver-ant-tasks.version}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar"
+ dest="${resolver-ant-tasks.local}" usetimestamp="true" quiet="true"/>
</target>
- <target name="_resolver_download" depends="init,_resolver_localrepo" unless="resolver-ant-tasks.jar.exists"
- description="Fetch Resolver ANT Tasks from Maven Central Repositroy">
-
- <echo>Downloading Resolver ANT Tasks...</echo>
- <get src="${resolver-ant-tasks.url}/${resolver-ant-tasks.version}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar"
- dest="${build.dir}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar" usetimestamp="true" quiet="true"/>
- <copy file="${build.dir}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}-uber.jar"
- tofile="${resolver-ant-tasks.local}/${resolver-ant-tasks.version}/maven-resolver-ant-tasks-${resolver-ant-tasks.version}.jar" quiet="true"/>
+ <target name="_jstackunit_download" unless="jstackunit.jar.exists" description="Fetch jstackunit">
+ <echo>Downloading jstackunit...</echo>
+ <mkdir dir="${user.home}/.m2/repository/org/krummas/junit/jstackjunit/0.0.1" />
+ <get src="https://github.com/krummas/jstackjunit/releases/download/v0.0.1/jstackjunit-0.0.1.jar" dest="${jstackunit.local}" usetimestamp="true" quiet="true"/>
</target>
<target name="resolver-init" depends="init,_resolver_download" unless="resolver-ant-tasks.initialized" description="Initialize Resolver ANT Tasks">
@@ -143,7 +145,7 @@
<property name="resolver-ant-tasks.initialized" value="true"/>
</target>
- <target name="resolver-retrieve-build" depends="resolver-init,write-poms">
+ <target name="resolver-retrieve-build" depends="resolver-init,_jstackunit_download,write-poms">
<resolver:pom file="${build.dir}/${final.name}.pom" id="all-pom"/>
<resolver:pom file="${build.dir}/${ant.project.name}-thrift-${version}.pom" id="thrift-pom"/>
<resolver:pom file="${build.dir}/tmp-${final.name}-deps.pom" id="pom-deps"/>
@@ -160,24 +162,14 @@
</resolver:resolve>
<resolver:resolve>
<remoterepos refid="all"/>
- <dependencies pomRef="pom-deps">
- <exclusion artifactId="tools"/>
- <exclusion artifactId="asm"/>
- <exclusion artifactId="asm-analysis"/>
- <exclusion artifactId="asm-commons"/>
- <exclusion artifactId="asm-tree"/>
- <exclusion artifactId="asm-util"/>
- <exclusion artifactId="asm-xml"/>
- </dependencies>
+ <dependencies pomRef="pom-deps"/>
<files dir="${test.lib}/jars" layout="{artifactId}-{version}-{classifier}.{extension}" scopes="test,!provide,!system"/>
</resolver:resolve>
- <mkdir dir="${user.home}/.m2/repository/org/krummas/junit/jstackjunit/0.0.1" />
- <get src="https://github.com/krummas/jstackjunit/releases/download/v0.0.1/jstackjunit-0.0.1.jar" dest="${user.home}/.m2/repository/org/krummas/junit/jstackjunit/0.0.1/jstackjunit-0.0.1.jar" usetimestamp="true" quiet="true"/>
- <copy todir="${test.lib}/jars/" file="${user.home}/.m2/repository/org/krummas/junit/jstackjunit/0.0.1/jstackjunit-0.0.1.jar" quiet="true"/>
+ <copy todir="${test.lib}/jars/" file="${jstackunit.local}" quiet="true"/>
<!-- jacoco agent jar comes wrapped in a jar -->
- <unzip src="${test.lib}/jars/org.jacoco.agent-${jacoco.version}.jar" dest="${build.dir.lib}/jars">
+ <unzip src="${user.home}/.m2/repository/org/jacoco/org.jacoco.agent/${jacoco.version}/org.jacoco.agent-${jacoco.version}.jar" dest="${build.dir.lib}/jars">
<patternset>
<include name="*.jar"/>
</patternset>
diff --git a/build.xml b/build.xml
index 76fc7f7..3b43cdc 100644
--- a/build.xml
+++ b/build.xml
@@ -115,6 +115,7 @@
<property name="byteman.version" value="3.0.3"/>
<property name="bytebuddy.version" value="1.10.10"/>
+ <property name="jamm.version" value="0.3.0"/>
<property name="ecj.version" value="4.4.2"/>
<property name="asm.version" value="5.0.4"/>
@@ -154,21 +155,15 @@
<pathelement location="${build.classes.thrift}" />
<fileset dir="${build.dir.lib}">
<include name="**/*.jar" />
- <exclude name="**/*-sources.jar"/>
- <exclude name="**/ant-*.jar"/>
</fileset>
</path>
<path id="cassandra.classpath.test">
<file file="${build.dir}/${final.name}.jar"/> <!-- we need the jar for tests and benchmarks (multi-version jar) -->
<fileset dir="${build.dir.lib}">
<include name="**/*.jar" />
- <exclude name="**/*-sources.jar"/>
- <exclude name="**/ant-*.jar"/>
</fileset>
<fileset dir="${test.lib}/jars">
<include name="**/*.jar" />
- <exclude name="**/*-sources.jar"/>
- <exclude name="**/ant-*.jar"/>
</fileset>
</path>
@@ -359,8 +354,7 @@
<dependency groupId="com.fasterxml.jackson.core" artifactId="jackson-annotations" version="2.9.10"/>
<dependency groupId="com.googlecode.json-simple" artifactId="json-simple" version="1.1"/>
<dependency groupId="com.boundary" artifactId="high-scale-lib" version="1.0.6"/>
- <dependency groupId="com.github.jbellis" artifactId="jamm" version="0.3.0"/>
-
+ <dependency groupId="com.github.jbellis" artifactId="jamm" version="${jamm.version}"/>
<dependency groupId="com.thinkaurelius.thrift" artifactId="thrift-server" version="0.3.7">
<exclusion groupId="org.slf4j" artifactId="slf4j-log4j12"/>
<exclusion groupId="junit" artifactId="junit"/>
@@ -371,7 +365,9 @@
<exclusion groupId="org.apache.httpcomponents" artifactId="httpclient"/>
<exclusion groupId="org.apache.httpcomponents" artifactId="httpcore"/>
</dependency>
- <dependency groupId="junit" artifactId="junit" version="4.12" scope="test"/>
+ <dependency groupId="junit" artifactId="junit" version="4.12" scope="test">
+ <exclusion groupId="org.hamcrest" artifactId="hamcrest-core"/>
+ </dependency>
<dependency groupId="org.mockito" artifactId="mockito-core" version="3.2.4" scope="test"/>
<dependency groupId="org.apache.cassandra" artifactId="dtest-api" version="0.0.8" scope="test"/>
<dependency groupId="org.reflections" artifactId="reflections" version="0.9.12" scope="test"/>
@@ -452,6 +448,7 @@
<dependency groupId="org.junit" artifactId="junit-bom" version="5.6.0" type="pom"/>
<!-- when updating assertj, make sure to also update the corresponding junit-bom dependency -->
<dependency groupId="org.assertj" artifactId="assertj-core" version="3.15.0" scope="test"/>
+ <dependency groupId="org.hamcrest" artifactId="hamcrest" version="2.2" scope="test"/>
</dependencyManagement>
<developer id="adelapena" name="Andres de la Peña"/>
<developer id="alakshman" name="Avinash Lakshman"/>
@@ -528,6 +525,7 @@
<dependency groupId="org.junit" artifactId="junit-bom" type="pom" scope="test"/>
<dependency groupId="org.assertj" artifactId="assertj-core" scope="test"/>
+ <dependency groupId="org.hamcrest" artifactId="hamcrest" scope="test"/>
<!-- coverage debs -->
<dependency groupId="org.jacoco" artifactId="org.jacoco.agent" scope="test"/>
<dependency groupId="org.jacoco" artifactId="org.jacoco.ant" scope="test"/>
---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscribe@cassandra.apache.org
For additional commands, e-mail: commits-help@cassandra.apache.org