blob: f628cce0e0bf97a1a71629a0f838815231fd9c2b [file] [log] [blame]
#!/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.
set -e
set -u
set -o pipefail
export LANG=C.UTF-8
export LC_ALL=C.UTF-8
SOURCE_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
if [ "$#" -ne 2 ]; then
echo "Usage: $0 <version> <rc-num>"
exit
fi
. "${SOURCE_DIR}/utils-env.sh"
. "${SOURCE_DIR}/utils-binary.sh"
version=$1
rc=$2
version_with_rc="${version}-rc${rc}"
crossbow_job_prefix="release-${version_with_rc}"
crossbow_package_dir="${SOURCE_DIR}/../../packages"
: "${CROSSBOW_JOB_NUMBER:=0}"
: "${CROSSBOW_JOB_ID:=${crossbow_job_prefix}-${CROSSBOW_JOB_NUMBER}}"
: "${ARROW_ARTIFACTS_DIR:=${crossbow_package_dir}/${CROSSBOW_JOB_ID}}"
: "${GITHUB_REPOSITORY:=apache/arrow}"
if [ ! -e "${ARROW_ARTIFACTS_DIR}" ]; then
echo "${ARROW_ARTIFACTS_DIR} does not exist"
exit 1
fi
if [ ! -d "${ARROW_ARTIFACTS_DIR}" ]; then
echo "${ARROW_ARTIFACTS_DIR} is not a directory"
exit 1
fi
cd "${SOURCE_DIR}"
# By default upload all artifacts.
# To deactivate one category, deactivate the category and all of its dependents.
# To explicitly select one category, set UPLOAD_DEFAULT=0 UPLOAD_X=1.
: "${UPLOAD_DEFAULT:=1}"
: "${UPLOAD_ALMALINUX:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_AMAZON_LINUX:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_CENTOS:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_DEBIAN:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_DOCS:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_PYTHON:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_R:=${UPLOAD_DEFAULT}}"
: "${UPLOAD_UBUNTU:=${UPLOAD_DEFAULT}}"
tmp_dir=binary/tmp
rm -rf "${tmp_dir}"
mkdir -p "${tmp_dir}"
upload_to_github_release() {
local id="$1"
shift
local dist_dir="${tmp_dir}/${id}"
mkdir -p "${dist_dir}"
while [ $# -gt 0 ]; do
local target="$1"
shift
local base_name
base_name="$(basename "${target}")"
cp -a "${target}" "${dist_dir}/${base_name}"
# Skip signing/checksumming .sha512 files (e.g., R binaries already include checksums from CI)
if [[ "${base_name}" != *.sha512 ]]; then
gpg \
--armor \
--detach-sign \
--local-user "${GPG_KEY_ID}" \
--output "${dist_dir}/${base_name}.asc" \
"${target}"
pushd "${dist_dir}"
shasum -a 512 "${base_name}" >"${base_name}.sha512"
popd
fi
done
gh release upload \
--repo apache/arrow \
"apache-arrow-${version}-rc${rc}" \
"${dist_dir}"/*
}
if [ "${UPLOAD_DOCS}" -gt 0 ]; then
upload_to_github_release docs "${ARROW_ARTIFACTS_DIR}"/*-docs/*
fi
if [ "${UPLOAD_PYTHON}" -gt 0 ]; then
upload_to_github_release python \
"${ARROW_ARTIFACTS_DIR}"/{python-sdist,wheel-*}/*
fi
if [ "${UPLOAD_R}" -gt 0 ]; then
upload_to_github_release r \
"${ARROW_ARTIFACTS_DIR}"/r-binary-packages/r-lib*
fi
rake_tasks=()
apt_targets=()
yum_targets=()
if [ "${UPLOAD_ALMALINUX}" -gt 0 ]; then
rake_tasks+=(yum:rc)
yum_targets+=(almalinux)
fi
if [ "${UPLOAD_AMAZON_LINUX}" -gt 0 ]; then
rake_tasks+=(yum:rc)
yum_targets+=(amazon-linux)
fi
if [ "${UPLOAD_CENTOS}" -gt 0 ]; then
rake_tasks+=(yum:rc)
yum_targets+=(centos)
fi
if [ "${UPLOAD_DEBIAN}" -gt 0 ]; then
rake_tasks+=(apt:rc)
apt_targets+=(debian)
fi
if [ "${UPLOAD_UBUNTU}" -gt 0 ]; then
rake_tasks+=(apt:rc)
apt_targets+=(ubuntu)
fi
rake_tasks+=(summary:rc)
source_artifacts_dir="${tmp_dir}/artifacts"
rm -rf "${source_artifacts_dir}"
cp -a "${ARROW_ARTIFACTS_DIR}" "${source_artifacts_dir}"
docker_run \
./runner.sh \
rake \
"${rake_tasks[@]}" \
APT_TARGETS="$(
IFS=,
echo "${apt_targets[*]}"
)" \
ARTIFACTORY_API_KEY="${ARTIFACTORY_API_KEY}" \
ARTIFACTS_DIR="${tmp_dir}/artifacts" \
DEB_PACKAGE_NAME="${DEB_PACKAGE_NAME:-}" \
DRY_RUN="${DRY_RUN:-no}" \
GPG_KEY_ID="${GPG_KEY_ID}" \
RC="${rc}" \
STAGING="${STAGING:-no}" \
VERBOSE="${VERBOSE:-no}" \
VERSION="${version}" \
YUM_TARGETS="$(
IFS=,
echo "${yum_targets[*]}"
)"