[KYUUBI #4274] [INFRA] Introduce mvnd to speed up CI jobs of Dependency, Licence and Style Check
### _Why are the changes needed?_ #### Motivation: - speed up maven building and testing with `mvnd` (https://github.com/apache/maven-mvnd). `mvnd` itself embeds exactly the same distribution of maven with more improvements and features on the client side and compilation server in daemon mode. - also inspired by custom github action for mvnd installing in Apache Camel (https://github.com/apache/camel/blob/main/.github/actions/install-mvnd/action.yml) #### Changes in this PR: - introducing `mvnd` by adding `build/mvnd` script - use `mvnd` version `0.9.0` which embeds `maven` 3.8.7. The maven version embedded in `mvnd` is also check and guaranteed the same as maven version required in pom by `build/mvnd` script. - use mvnd in CI jobs of Depedency Check and Style Check #### Comparision - CI jobs (both with maven dependencies cached in local repo) Job | with `build/mvn` | with `build/mvnd` --- | --- | --- Dependency Check | 9min1sec;[see log](https://github.com/apache/kyuubi/actions/runs/3966175262/jobs/6796688187) | 6min 46 sec ; [see log](https://github.com/apache/kyuubi/actions/runs/4124518481/jobs/7123867015) Style Check | 10min32sec ; [see log](https://github.com/apache/kyuubi/actions/runs/4122613274/jobs/7119603428) | 7min50s ; [see log](https://github.com/apache/kyuubi/actions/runs/4125013599/jobs/7125006946) Licence Check | 32s ; [see log](https://github.com/apache/kyuubi/actions/runs/4130799867/jobs/7137835062) | 21s ; [see log](https://github.com/apache/kyuubi/actions/runs/4130923126/jobs/7138088114) - building entire maven project on local machine (skipping test running and style checking with `fast` profile) `build/mvnd clean install -Pfast` <img width="645" alt="Pasted Graphic" src="https://user-images.githubusercontent.com/1935105/217001594-52dfd19d-6c57-4bc4-8336-90bb0c030bd4.png"> `build/mvn clean install -Pfast` <img width="643" alt="Pasted Graphic 1" src="https://user-images.githubusercontent.com/1935105/217001619-c2ebe7e3-bd14-4f5c-bb02-2ae4ae99cf7f.png"> ### _How was this patch tested?_ - [ ] Add some test cases that check the changes thoroughly including negative and positive cases if possible - [ ] Add screenshots for manual tests if appropriate - [x] [Run test](https://kyuubi.readthedocs.io/en/master/develop_tools/testing.html#running-tests) locally before make a pull request Closes #4274 from bowenliang123/ci-mvnd. Closes #4274 380c1c9ea [liangbowen] update cache key a93bba7b7 [liangbowen] style bc8da133e [Bowen Liang] Merge branch 'master' into ci-mvnd 97becc035 [liangbowen] add `build/maven-mvnd-*/**` to rat-excludes 5b61f50b9 [liangbowen] apply mvnd to license check 7be181d0f [liangbowen] typo in build/mvnd c52861df8 [liangbowen] update f6d0eb28c [liangbowen] introduce mvnd Lead-authored-by: liangbowen <liangbowen@gf.com.cn> Co-authored-by: Bowen Liang <bowenliang@apache.org> Signed-off-by: Cheng Pan <chengpan@apache.org>
This commit is contained in:
parent
4e226ac3cc
commit
d862272645
32
.github/actions/setup-mvnd/action.yaml
vendored
Normal file
32
.github/actions/setup-mvnd/action.yaml
vendored
Normal file
@ -0,0 +1,32 @@
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
# contributor license agreements. See the NOTICE file distributed with
|
||||
# this work for additional information regarding copyright ownership.
|
||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
# (the "License"); you may not use this file except in compliance with
|
||||
# the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
name: 'setup-mvnd'
|
||||
description: 'Setup the maven daemon'
|
||||
runs:
|
||||
using: composite
|
||||
steps:
|
||||
- name: Cache Mvnd
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: |
|
||||
build/maven-mvnd-*
|
||||
build/apache-maven-*
|
||||
key: setup-mvnd-${{ runner.os }}-mvnd
|
||||
- name: Check Mvnd
|
||||
run: build/mvnd -v
|
||||
shell: bash
|
||||
5
.github/workflows/dep.yml
vendored
5
.github/workflows/dep.yml
vendored
@ -26,6 +26,7 @@ on:
|
||||
# when pom or dependency workflow changes
|
||||
- '**/pom.xml'
|
||||
- '.github/workflows/dep.yml'
|
||||
- .github/actions/setup-mvnd/*.yaml
|
||||
|
||||
concurrency:
|
||||
group: dep-${{ github.head_ref || github.run_id }}
|
||||
@ -44,11 +45,13 @@ jobs:
|
||||
java-version: 8
|
||||
cache: 'maven'
|
||||
check-latest: false
|
||||
- name: Setup Mvnd
|
||||
uses: ./.github/actions/setup-mvnd
|
||||
- name: build
|
||||
env:
|
||||
MAVEN_OPTS: -Dorg.slf4j.simpleLogger.defaultLogLevel=error
|
||||
run: >-
|
||||
build/mvn clean install
|
||||
build/mvnd clean install
|
||||
-Pflink-provided,spark-provided,hive-provided
|
||||
-Dmaven.javadoc.skip=true
|
||||
-Drat.skip=true
|
||||
|
||||
4
.github/workflows/license.yml
vendored
4
.github/workflows/license.yml
vendored
@ -42,8 +42,10 @@ jobs:
|
||||
java-version: 8
|
||||
cache: 'maven'
|
||||
check-latest: false
|
||||
- name: Setup Mvnd
|
||||
uses: ./.github/actions/setup-mvnd
|
||||
- run: >-
|
||||
build/mvn org.apache.rat:apache-rat-plugin:check
|
||||
build/mvnd org.apache.rat:apache-rat-plugin:check
|
||||
-Ptpcds -Pspark-block-cleaner -Pkubernetes-it
|
||||
-Pspark-3.1 -Pspark-3.2 -Pspark-3.3
|
||||
- name: Upload rat report
|
||||
|
||||
16
.github/workflows/style.yml
vendored
16
.github/workflows/style.yml
vendored
@ -45,14 +45,16 @@ jobs:
|
||||
java-version: 8
|
||||
cache: 'maven'
|
||||
check-latest: false
|
||||
- name: Setup Mvnd
|
||||
uses: ./.github/actions/setup-mvnd
|
||||
- name: Setup Python 3
|
||||
uses: actions/setup-python@v4
|
||||
with:
|
||||
python-version: '3.9'
|
||||
cache: 'pip'
|
||||
- name: Check kyuubi modules avaliable
|
||||
- name: Check kyuubi modules available
|
||||
id: modules-check
|
||||
run: build/mvn dependency:resolve -DincludeGroupIds="org.apache.kyuubi" -DincludeScope="compile" -DexcludeTransitive=true ${{ matrix.profiles }}
|
||||
run: build/mvnd dependency:resolve -DincludeGroupIds="org.apache.kyuubi" -DincludeScope="compile" -DexcludeTransitive=true ${{ matrix.profiles }}
|
||||
continue-on-error: true
|
||||
|
||||
- name: Install
|
||||
@ -61,13 +63,13 @@ jobs:
|
||||
if: steps.modules-check.conclusion == 'success' && steps.modules-check.outcome == 'failure'
|
||||
run: |
|
||||
MVN_OPT="-DskipTests -Dorg.slf4j.simpleLogger.defaultLogLevel=warn -Dmaven.javadoc.skip=true -Drat.skip=true -Dscalastyle.skip=true -Dspotless.check.skip"
|
||||
build/mvn clean install ${MVN_OPT} -Pflink-provided,hive-provided,spark-provided,spark-block-cleaner,spark-3.2,tpcds
|
||||
build/mvn clean install ${MVN_OPT} -pl extensions/spark/kyuubi-extension-spark-3-1 -Pspark-3.1
|
||||
build/mvn clean install ${MVN_OPT} -pl extensions/spark/kyuubi-extension-spark-3-3,extensions/spark/kyuubi-spark-connector-kudu,extensions/spark/kyuubi-spark-connector-hive -Pspark-3.3
|
||||
build/mvnd clean install ${MVN_OPT} -Pflink-provided,hive-provided,spark-provided,spark-block-cleaner,spark-3.2,tpcds
|
||||
build/mvnd clean install ${MVN_OPT} -pl extensions/spark/kyuubi-extension-spark-3-1 -Pspark-3.1
|
||||
build/mvnd clean install ${MVN_OPT} -pl extensions/spark/kyuubi-extension-spark-3-3,extensions/spark/kyuubi-spark-connector-kudu,extensions/spark/kyuubi-spark-connector-hive -Pspark-3.3
|
||||
|
||||
- name: Scalastyle with maven
|
||||
id: scalastyle-check
|
||||
run: build/mvn scalastyle:check ${{ matrix.profiles }}
|
||||
run: build/mvnd scalastyle:check ${{ matrix.profiles }}
|
||||
- name: Print scalastyle error report
|
||||
if: failure() && steps.scalastyle-check.outcome != 'success'
|
||||
run: >-
|
||||
@ -81,7 +83,7 @@ jobs:
|
||||
run: |
|
||||
SPOTLESS_BLACK_VERSION=$(build/mvn help:evaluate -Dexpression=spotless.python.black.version -q -DforceStdout)
|
||||
pip install black==$SPOTLESS_BLACK_VERSION
|
||||
build/mvn spotless:check ${{ matrix.profiles }} -Pspotless-python
|
||||
build/mvnd spotless:check ${{ matrix.profiles }} -Pspotless-python
|
||||
- name: setup npm
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
|
||||
1
.gitignore
vendored
1
.gitignore
vendored
@ -40,6 +40,7 @@
|
||||
.scala_dependencies
|
||||
.settings
|
||||
build/apache-maven*
|
||||
build/maven-mvnd*
|
||||
build/release/tmp
|
||||
build/scala*
|
||||
build/test
|
||||
|
||||
@ -32,6 +32,7 @@
|
||||
NOTICE*
|
||||
docs/**
|
||||
build/apache-maven-*/**
|
||||
build/maven-mvnd-*/**
|
||||
build/scala-*/**
|
||||
**/**/operation_logs/**/**
|
||||
**/**/server_operation_logs/**/**
|
||||
|
||||
134
build/mvnd
Executable file
134
build/mvnd
Executable file
@ -0,0 +1,134 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
# contributor license agreements. See the NOTICE file distributed with
|
||||
# this work for additional information regarding copyright ownership.
|
||||
# The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
# (the "License"); you may not use this file except in compliance with
|
||||
# the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
# Determine the current working directory
|
||||
_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
# Preserve the calling directory
|
||||
_CALLING_DIR="$(pwd)"
|
||||
# Options used during compilation
|
||||
_COMPILE_JVM_OPTS="-Xms2g -Xmx2g -XX:ReservedCodeCacheSize=1g -Xss128m"
|
||||
|
||||
if [ "$CI" ]; then
|
||||
export MAVEN_CLI_OPTS="--no-transfer-progress --errors --fail-fast"
|
||||
fi
|
||||
|
||||
# Installs any application tarball given a URL, the expected tarball name,
|
||||
# and, optionally, a checkable binary path to determine if the binary has
|
||||
# already been installed
|
||||
## Arg1 - URL
|
||||
## Arg2 - Tarball Name
|
||||
## Arg3 - Checkable Binary
|
||||
install_app() {
|
||||
local remote_tarball="$1/$2"
|
||||
local local_tarball="${_DIR}/$2"
|
||||
local binary="${_DIR}/$3"
|
||||
|
||||
# setup `curl` and `wget` silent options if we're running on Jenkins
|
||||
local curl_opts="-L"
|
||||
local wget_opts=""
|
||||
curl_opts="--progress-bar ${curl_opts}"
|
||||
wget_opts="--progress=bar:force ${wget_opts}"
|
||||
|
||||
if [ -z "$3" ] || [ ! -f "$binary" ]; then
|
||||
# check if we already have the tarball
|
||||
# check if we have curl installed
|
||||
# download application
|
||||
rm -f "$local_tarball"
|
||||
[ ! -f "${local_tarball}" ] && [ "$(command -v curl)" ] && \
|
||||
echo "exec: curl ${curl_opts} ${remote_tarball}" 1>&2 && \
|
||||
curl ${curl_opts} "${remote_tarball}" > "${local_tarball}"
|
||||
# if the file still doesn't exist, lets try `wget` and cross our fingers
|
||||
[ ! -f "${local_tarball}" ] && [ "$(command -v wget)" ] && \
|
||||
echo "exec: wget ${wget_opts} ${remote_tarball}" 1>&2 && \
|
||||
wget ${wget_opts} -O "${local_tarball}" "${remote_tarball}"
|
||||
# if both were unsuccessful, exit
|
||||
[ ! -f "${local_tarball}" ] && \
|
||||
echo -n "ERROR: Cannot download $2 with cURL or wget; " && \
|
||||
echo "please install manually and try again." && \
|
||||
exit 2
|
||||
cd "${_DIR}" && tar -xzf "$2"
|
||||
rm -rf "$local_tarball"
|
||||
fi
|
||||
}
|
||||
|
||||
function get_os_type() {
|
||||
local unameOsOut=$(uname -s)
|
||||
local osType
|
||||
case "${unameOsOut}" in
|
||||
Linux*) osType=linux ;;
|
||||
Darwin*) osType=darwin ;;
|
||||
CYGWIN*) osType=windows ;;
|
||||
MINGW*) osType=windows ;;
|
||||
*) osType="UNKNOWN:${unameOsOut}" ;;
|
||||
esac
|
||||
echo "$osType"
|
||||
}
|
||||
|
||||
function get_os_arch() {
|
||||
local unameArchOut="$(uname -m)"
|
||||
local arch
|
||||
case "${unameArchOut}" in
|
||||
x86_64*) arch=amd64 ;;
|
||||
arm64*) arch=aarch64 ;;
|
||||
*) arch="UNKNOWN:${unameOsOut}" ;;
|
||||
esac
|
||||
echo "$arch"
|
||||
}
|
||||
|
||||
# Determine the Mvnd version from the root pom.xml file and
|
||||
# install mvnd under the build/ folder if needed.
|
||||
function install_mvnd() {
|
||||
local MVND_VERSION=$(grep "<mvnd.version>" "${_DIR}/../pom.xml" | head -n1 | awk -F '[<>]' '{print $3}')
|
||||
local MVN_VERSION=$(grep "<maven.version>" "${_DIR}/../pom.xml" | head -n1 | awk -F '[<>]' '{print $3}')
|
||||
MVND_BIN="$(command -v mvnd)"
|
||||
if [ "$MVND_BIN" ]; then
|
||||
local MVND_DETECTED_VERSION="$(mvnd -v 2>&1 | grep '(mvnd)' | awk '{print $5}')"
|
||||
local MVN_DETECTED_VERSION="$(mvnd -v 2>&1 | grep 'Apache Maven' | awk 'NR==2 {print $3}')"
|
||||
fi
|
||||
# See simple version normalization: http://stackoverflow.com/questions/16989598/bash-comparing-version-numbers
|
||||
function version { echo "$@" | awk -F. '{ printf("%03d%03d%03d\n", $1,$2,$3); }'; }
|
||||
|
||||
if [ $(version $MVND_DETECTED_VERSION) -ne $(version $MVND_VERSION) ]; then
|
||||
local APACHE_MIRROR=${APACHE_MIRROR:-'https://downloads.apache.org'}
|
||||
local OS_TYPE=$(get_os_type)
|
||||
local ARCH=$(get_os_arch)
|
||||
|
||||
install_app \
|
||||
"${APACHE_MIRROR}/maven/mvnd/${MVND_VERSION}" \
|
||||
"maven-mvnd-${MVND_VERSION}-${OS_TYPE}-${ARCH}.tar.gz" \
|
||||
"maven-mvnd-${MVND_VERSION}-${OS_TYPE}-${ARCH}/bin/mvnd"
|
||||
|
||||
MVND_BIN="${_DIR}/maven-mvnd-${MVND_VERSION}-${OS_TYPE}-${ARCH}/bin/mvnd"
|
||||
else
|
||||
if [ "$(version $MVN_DETECTED_VERSION)" -ne "$(version $MVN_VERSION)" ]; then
|
||||
echo "Mvnd $MVND_DETECTED_VERSION embedded maven version $MVN_DETECTED_VERSION is not equivalent to $MVN_VERSION required in pom."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
install_mvnd
|
||||
|
||||
cd "${_CALLING_DIR}"
|
||||
|
||||
# Set any `mvn` options if not already present
|
||||
export MAVEN_OPTS=${MAVEN_OPTS:-"$_COMPILE_JVM_OPTS"}
|
||||
|
||||
echo "Using \`mvnd\` from path: $MVND_BIN" 1>&2
|
||||
${MVND_BIN} $MAVEN_CLI_OPTS "$@"
|
||||
1
pom.xml
1
pom.xml
@ -109,6 +109,7 @@
|
||||
<properties>
|
||||
<java.version>1.8</java.version>
|
||||
<maven.version>3.8.7</maven.version>
|
||||
<mvnd.version>0.9.0</mvnd.version>
|
||||
<maven.compiler.source>${java.version}</maven.compiler.source>
|
||||
<maven.compiler.target>${java.version}</maven.compiler.target>
|
||||
<scala.version>2.12.17</scala.version>
|
||||
|
||||
Loading…
Reference in New Issue
Block a user