| #!/bin/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. |
| # |
| |
| ## |
| ## Variables with defaults (if not overwritten by environment) |
| ## |
| MVN=${MVN:-mvn} |
| # fail immediately |
| set -o errexit |
| set -o nounset |
| |
| CURR_DIR=$(pwd) |
| if [ ! -d "$CURR_DIR/packaging" ] ; then |
| echo "You have to call the script from the repository root dir that contains 'packaging/'" |
| exit 1 |
| fi |
| |
| if [ "$#" -gt "1" ]; then |
| echo "Only accept 0 or 1 argument. Use -h to see examples." |
| exit 1 |
| fi |
| |
| declare -a ALL_VERSION_OPTS=( |
| "-Dscala-2.11 -Dspark2 -Dflink1.13" # for legacy bundle name |
| "-Dscala-2.12 -Dspark2 -Dflink1.13" # for legacy bundle name |
| "-Dscala-2.12 -Dspark3 -Dflink1.14" # for legacy bundle name |
| "-Dscala-2.11 -Dspark2.4 -Dflink1.13" |
| "-Dscala-2.11 -Dspark2.4 -Dflink1.14" |
| "-Dscala-2.12 -Dspark2.4 -Dflink1.13" |
| "-Dscala-2.12 -Dspark3.2 -Dflink1.14" |
| "-Dscala-2.12 -Dspark3.1 -Dflink1.14" # run this last to make sure utilities bundle has spark 3.1 |
| ) |
| printf -v joined "'%s'\n" "${ALL_VERSION_OPTS[@]}" |
| |
| if [ "${1:-}" == "-h" ]; then |
| echo " |
| Usage: $(basename "$0") [OPTIONS] |
| |
| Options: |
| <version option> One of the version options below |
| ${joined} |
| -h, --help |
| " |
| exit 0 |
| fi |
| |
| VERSION_OPT=${1:-} |
| valid_version_opt=false |
| for v in "${ALL_VERSION_OPTS[@]}"; do |
| [[ $VERSION_OPT == "$v" ]] && valid_version_opt=true |
| done |
| |
| if [ "$valid_version_opt" = true ]; then |
| # run deploy for only specified version option |
| ALL_VERSION_OPTS=("$VERSION_OPT") |
| elif [ "$#" == "1" ]; then |
| echo "Version option $VERSION_OPT is invalid. Use -h to see examples." |
| exit 1 |
| fi |
| |
| for v in "${ALL_VERSION_OPTS[@]}" |
| do |
| echo "Deploying to repository.apache.org with version option ${v}" |
| COMMON_OPTIONS="${v} -DdeployArtifacts=true -DskipTests -DretryFailedDeploymentCount=10" |
| $MVN clean deploy $COMMON_OPTIONS |
| done |