raulcd commented on code in PR #137: URL: https://github.com/apache/arrow-js/pull/137#discussion_r2131960919
########## dev/release/release.sh: ########## @@ -0,0 +1,121 @@ +#!/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 -eu + +SOURCE_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" +SOURCE_TOP_DIR="$(cd "${SOURCE_DIR}/../../" && pwd)" + +if [ "$#" -ne 1 ]; then + echo "Usage: $0 <rc>" + echo " e.g.: $0 1" + exit 1 +fi + +rc=$1 + +if [ ! -f "${SOURCE_DIR}/.env" ]; then + echo "You must create ${SOURCE_DIR}/.env" + echo "You can use ${SOURCE_DIR}/.env.example as template" + exit 1 +fi +. "${SOURCE_DIR}/.env" + +cd "${SOURCE_TOP_DIR}" + +version=$(jq -r .version package.json) + +git_origin_url="$(git remote get-url origin)" +repository="${git_origin_url#*github.com?}" +repository="${repository%.git}" +case "${git_origin_url}" in [email protected]:apache/arrow-js.git | https://github.com/apache/arrow-js.git) + : # OK + ;; +*) + echo "This script must be ran with working copy of apache/arrow-js." + echo "The origin's URL: ${git_origin_url}" + exit 1 + ;; +esac + +tag="v${version}" +rc_tag="${tag}-rc${rc}" +echo "Tagging for release: ${tag}" +git tag -a -m "${version}" "${tag}" "${rc_tag}^{}" +git push origin "${tag}" + +release_id="apache-arrow-js-${version}" +source_archive="apache-arrow-js-${version}.tar.gz" +dist_url="https://dist.apache.org/repos/dist/release/arrow" +dist_base_dir="dev/release/dist" +dist_dir="${dist_base_dir}/${release_id}" +echo "Checking out ${dist_url}" +rm -rf "${dist_base_dir}" +svn co --depth=empty "${dist_url}" "${dist_base_dir}" +gh release download "${rc_tag}" \ + --dir "${dist_dir}" \ + --pattern "${source_archive}*" \ + --repo "${repository}" \ + --skip-existing + +echo "Uploading to release/" +pushd "${dist_base_dir}" +svn add "${release_id}" +svn ci -m "Apache Arrow JS ${version}" +popd +rm -rf "${dist_base_dir}" + +echo "Keep only the latest versions" +old_releases=$( + svn ls https://dist.apache.org/repos/dist/release/arrow/ | + grep -E '^apache-arrow-js-' | + sort --version-sort --reverse | + tail -n +2 +) +for old_release_version in ${old_releases}; do + echo "Remove old release ${old_release_version}" + svn \ + delete \ + -m "Remove old Apache Arrow JS release: ${old_release_version}" \ + "https://dist.apache.org/repos/dist/release/arrow/${old_release_version}" +done + +echo "Publish to npm" Review Comment: should we have an option to only publish to npm and avoid the rest? I've had to retry the publishing npm script in the past due to timeouts our random failures with OTP login and seems worth to me. Either that or split this in a two steps process? ########## dev/release/README.md: ########## @@ -0,0 +1,220 @@ +<!--- + 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. +--> + +# Release + +## Overview + +1. Test the revision to be released +2. Bump version for new release (detailed later) +3. Prepare RC and vote (detailed later) +4. Publish (detailed later) +5. Announce the new release on the mailing list (detailed later) +6. Announce the new release on social media (detailed later) + +### Prepare release environment + +This step is needed only when you act as a release manager first time. Review Comment: ```suggestion This step is needed only when you act as a release manager the first time. ``` -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: [email protected] For queries about this service, please contact Infrastructure at: [email protected]
