mirror of
https://github.com/digital-asset/daml.git
synced 2024-10-26 13:17:54 +03:00
fix daml extension upload (#5780)
With the current setup, we always push whatever version GitHub considers as the latest, which is defined by date. This means that at the moment a patch release could overwrite a less recent but higher-version release, essentially downgrading the SDK to a previous, presumably less good user experience. This patches the upload process to choose the highest-numbered release instead of the most recent one by date. CHANGELOG_BEGIN CHANGELOG_END
This commit is contained in:
parent
8c25bc4de5
commit
681c862d88
@ -108,17 +108,46 @@ jobs:
|
||||
-s \
|
||||
"https://marketplace.visualstudio.com/_apis/gallery/publishers/DigitalAssetHoldingsLLC/extensions/daml?flags=1" \
|
||||
| jq -r '.versions[0].version')
|
||||
GITHUB=$(curl https://api.github.com/repos/digital-asset/daml/releases -s | jq -r '. | map(select(.prerelease == false)) | map(.tag_name)[0]')
|
||||
if [[ "${GITHUB#v}" != "$MARKET" ]] && git merge-base --is-ancestor 798e96c9b9034eac85ace786b9e1955cf380285c $GITHUB; then
|
||||
# This jq expression should ensure that we always upload the
|
||||
# highest-number version. Here is how this works:
|
||||
#
|
||||
# 1. The GitHub API documentation does not specify the order for the
|
||||
# "list releases" endpoint, but does specify that the "latest"
|
||||
# endpoint returns the release that points to the most recent commit.
|
||||
# Assuming the same sort order is applied for the list endpoint
|
||||
# (which empirically seems to hold so far), this means that they may
|
||||
# be out-of-order wrt version numbers, e.g. 1.1.0 may appear after
|
||||
# 1.0.2.
|
||||
# 2. The `.tag_name | .[1:] | split (".") | map(tonumber)` part will
|
||||
# turn "v1.0.2" into an array [1, 0, 2].
|
||||
# 3. jq documents its sort method to sort numbers in numeric order
|
||||
# and arrays in lexical order (ascending in both cases).
|
||||
#
|
||||
# This is required because, while the VSCode Marketplace does show
|
||||
# _a_ version number, it doesn't handle versions at all: we can only
|
||||
# have one version on the marketplace at any given time, and any
|
||||
# upload replaces the existing version.
|
||||
GITHUB=$(curl https://api.github.com/repos/digital-asset/daml/releases -s \
|
||||
| jq -r '. | map(select(.prerelease == false))
|
||||
| .tag_name
|
||||
| .[1:]
|
||||
| split (".")
|
||||
| map(tonumber))
|
||||
| sort
|
||||
| reverse
|
||||
| .[0]
|
||||
| map(tostring)
|
||||
| join(".")')
|
||||
if [[ "$GITHUB" != "$MARKET" ]] && git merge-base --is-ancestor 798e96c9b9034eac85ace786b9e1955cf380285c v$GITHUB; then
|
||||
echo "Publishing $GITHUB to VSCode Marketplace"
|
||||
git checkout $GITHUB
|
||||
git checkout v$GITHUB
|
||||
cd compiler/daml-extension
|
||||
# This produces out/src/extension.js
|
||||
bazel run @nodejs//:yarn
|
||||
bazel run @nodejs//:yarn compile
|
||||
bazel run --run_under="cd $PWD && " @daml_extension_deps//vsce/bin:vsce -- publish ${GITHUB#v} -p $MARKETPLACE_TOKEN
|
||||
bazel run --run_under="cd $PWD && " @daml_extension_deps//vsce/bin:vsce -- publish $GITHUB -p $MARKETPLACE_TOKEN
|
||||
else
|
||||
if [[ "${GITHUB#v}" == "$MARKET" ]]; then
|
||||
if [[ "$GITHUB" == "$MARKET" ]]; then
|
||||
echo "Version on marketplace is already the latest ($GITHUB)."
|
||||
else
|
||||
echo "Latest version is not ready for marketplace publication."
|
||||
|
Loading…
Reference in New Issue
Block a user