Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: move upgrade assure scripts to cmd and improve ci workflow #480

Merged
merged 28 commits into from
May 8, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
8136885
ci: move upgrade assure scripts to cmd and improve ci workflow
cosmic-vagabond May 7, 2024
26d120d
ci: fix build old binaries step
cosmic-vagabond May 7, 2024
1f14e2c
ci: add cache for snapshot retrieval
cosmic-vagabond May 7, 2024
e792677
ci: always download info.json
cosmic-vagabond May 7, 2024
953d8da
ci: use block height as cache key
cosmic-vagabond May 7, 2024
201ad2c
ci: fix variable
cosmic-vagabond May 7, 2024
c63a280
ci: use awk instead of jq as json file invalid
cosmic-vagabond May 7, 2024
e8c3f7d
ci: use env
cosmic-vagabond May 7, 2024
649e209
ci: fix variable
cosmic-vagabond May 7, 2024
fcbe1e7
ci: skip steps if snapshot cache valid and fix old upgrade assure bin…
cosmic-vagabond May 7, 2024
c711366
ci: increase timeouts
cosmic-vagabond May 7, 2024
23e7bc7
ci: update actions versions
cosmic-vagabond May 7, 2024
ba8fb50
ci: skip more steps if snapshot cache valid and limit memory usage
cosmic-vagabond May 7, 2024
0645e05
ci: reduce memory usage
cosmic-vagabond May 7, 2024
162be80
ci: save up space
cosmic-vagabond May 7, 2024
52f5915
ci: sanitize head ref and unbond second validator power
cosmic-vagabond May 7, 2024
bd045b4
ci: use latest tag as cache key
cosmic-vagabond May 7, 2024
b506d8c
ci: reduce memory usage in last step
cosmic-vagabond May 7, 2024
f423f7f
ci: fix unbond validator cmd
cosmic-vagabond May 7, 2024
7dc1e72
ci: set env vars
cosmic-vagabond May 8, 2024
c4cd1fb
ci: remove snapshot file
cosmic-vagabond May 8, 2024
ffec1c1
ci: retry 3 times for steps that fails from time to time
cosmic-vagabond May 8, 2024
c549be8
ci: use retry action
cosmic-vagabond May 8, 2024
6c93958
ci: fix typo
cosmic-vagabond May 8, 2024
a13d5ae
ci: stamp new snapshot file name with date and time
cosmic-vagabond May 8, 2024
16fcf24
ci: fix create new snapshot file command
cosmic-vagabond May 8, 2024
e2945a9
ci: add new snapshot URL
cosmic-vagabond May 8, 2024
a260b01
ci: fix snapshot url
cosmic-vagabond May 8, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
189 changes: 176 additions & 13 deletions .github/workflows/software-upgrade-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ on:
jobs:
software-upgrade-test:
runs-on: ubuntu-latest
timeout-minutes: 60
timeout-minutes: 120

steps:
- name: Checkout repository
Expand All @@ -16,49 +16,212 @@ jobs:
fetch-tags: true

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version: "1.21"

- name: Get latest tag
run: |
git fetch --tags
LATEST_TAG=$(git describe --tags `git rev-list --tags --max-count=1`)
echo "LATEST_TAG=$LATEST_TAG" >> $GITHUB_ENV
echo "Latest tag: $LATEST_TAG"

- name: Retrieve info.json and set snapshot path
run: |
DOWNLOAD_URL=https://snapshots-testnet.stake-town.com/elys/info.json
curl -L $DOWNLOAD_URL -o /tmp/info.json
echo "Info.json downloaded to check snapshot version."

# retrieve blockHeight field value from info.json
SNAPSHOT_BLOCK_HEIGHT=$(cat /tmp/info.json | awk -F'"' '/"blockHeight":/{print $4}')
echo "SNAPSHOT_BLOCK_HEIGHT=$SNAPSHOT_BLOCK_HEIGHT" >> $GITHUB_ENV
echo "Snapshot block height: $SNAPSHOT_BLOCK_HEIGHT"

# set snapshot path
SNAPSHOT_PATH=/tmp/snapshot.tar.lz4
echo "SNAPSHOT_PATH=$SNAPSHOT_PATH" >> $GITHUB_ENV

- name: Cache Directories
uses: actions/cache@v4
id: cache-directories
with:
path: |
~/.elys
~/.elys2
key: ${{ runner.os }}-directories-${{ env.LATEST_TAG }}

- name: Retrieve latest snapshot
run: |
DOWNLOAD_URL=https://snapshots-testnet.stake-town.com/elys/elystestnet-1_latest.tar.lz4
SNAPSHOT_PATH=/tmp/snapshot.tar.lz4
curl -L $DOWNLOAD_URL -o $SNAPSHOT_PATH
echo "SNAPSHOT_PATH=$SNAPSHOT_PATH" >> $GITHUB_ENV
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Retrieve latest binary
run: |
LATEST_TAG=$(git describe --tags `git rev-list --tags --max-count=1`)
DOWNLOAD_URL=https://github.com/elys-network/elys/releases/download/$LATEST_TAG/elysd-$LATEST_TAG-linux-amd64
OLD_BINARY_PATH=/tmp/elysd-$LATEST_TAG
curl -L $DOWNLOAD_URL -o $OLD_BINARY_PATH && chmod +x $OLD_BINARY_PATH
echo "LATEST_TAG=$LATEST_TAG" >> $GITHUB_ENV
echo "OLD_BINARY_PATH=$OLD_BINARY_PATH" >> $GITHUB_ENV

# TODO: retrieve upgrade-assure and upload-snapshot binaries
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Create git tag
run: git tag v999.999.999

- name: Run make build
- name: Build new binaries
run: |
# build new elys binary
make build
NEW_BINARY_PATH=./build/elysd
echo "NEW_BINARY_PATH=$NEW_BINARY_PATH" >> $GITHUB_ENV

- name: Copy upgrade-assure scripts
run: cp -a scripts/upgrade-assure scripts/upgrade-assure-skip
# build new upgrade assure binary
make build-upgrade-assure
NEW_UPGRADE_ASSURE_BINARY_PATH=./build/new-upgrade-assure
mv ./build/upgrade-assure $NEW_UPGRADE_ASSURE_BINARY_PATH
echo "NEW_UPGRADE_ASSURE_BINARY_PATH=$NEW_UPGRADE_ASSURE_BINARY_PATH" >> $GITHUB_ENV

# build upload snapshot binary
make build-upload-snapshot
UPLOAD_SNAPSHOT_BINARY_PATH=./build/upload-snapshot
echo "UPLOAD_SNAPSHOT_BINARY_PATH=$UPLOAD_SNAPSHOT_BINARY_PATH" >> $GITHUB_ENV

# TODO: to remove when upgrade-assure binary is available in previous release
- name: Copy upgrade assure folder
run: |
cp -a ./cmd/upgrade-assure ./cmd/upgrade-assure-skip
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Check out latest tag
run: git checkout $LATEST_TAG
if: steps.cache-directories.outputs.cache-hit != 'true'

# TODO: to remove when upgrade-assure binary is available in previous release
- name: Copy old upgrade assure types.go file
run: |
cp -a ./scripts/upgrade-assure/types.go ./cmd/upgrade-assure-skip/types.go
if: steps.cache-directories.outputs.cache-hit != 'true'

# TODO: to remove when upgrade-assure binary is available in previous release
- name: Build old binaries
run: |
# build old upgrade assure binary
go build -o build ./cmd/upgrade-assure-skip
OLD_UPGRADE_ASSURE_BINARY_PATH=./build/old-upgrade-assure
mv ./build/upgrade-assure-skip $OLD_UPGRADE_ASSURE_BINARY_PATH
echo "OLD_UPGRADE_ASSURE_BINARY_PATH=$OLD_UPGRADE_ASSURE_BINARY_PATH" >> $GITHUB_ENV
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Chain snapshot and export
run: |
GOMEMLIMIT=8GiB $OLD_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH \
--skip-chain-init \
--skip-node-start \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Chain initialization
run: |
cp -a scripts/upgrade-assure/types.go scripts/upgrade-assure-skip/types.go
GOMEMLIMIT=16GiB go run ./scripts/upgrade-assure-skip/... $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH --skip-node-start
GOMEMLIMIT=8GiB $OLD_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH \
--skip-snapshot \
--skip-node-start \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Check out new branch
run: git checkout ${{ github.head_ref }}

- name: Software upgrade
- name: Create second validator
uses: nick-fields/retry@v3
with:
timeout_minutes: 30
max_attempts: 3
command: |
GOMEMLIMIT=8GiB $NEW_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH \
--skip-snapshot \
--skip-chain-init \
--skip-prepare-validator-data \
--skip-submit-proposal \
--skip-upgrade-to-new-binary \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Save up space
run: |
rm -rf /tmp/genesis.json
rm -rf ~/.elys/config/genesis.json
rm -rf $SNAPSHOT_PATH

- name: Prepare second validator data
run: |
GOMEMLIMIT=8GiB $NEW_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH \
--skip-snapshot \
--skip-chain-init \
--skip-create-validator \
--skip-submit-proposal \
--skip-upgrade-to-new-binary \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Submit new proposal
uses: nick-fields/retry@v3
with:
timeout_minutes: 30
max_attempts: 3
command: |
GOMEMLIMIT=8GiB $NEW_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH \
--skip-snapshot \
--skip-chain-init \
--skip-create-validator \
--skip-prepare-validator-data \
--skip-upgrade-to-new-binary \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000
if: steps.cache-directories.outputs.cache-hit != 'true'

- name: Upgrade to new binary
uses: nick-fields/retry@v3
with:
timeout_minutes: 30
max_attempts: 3
command: |
GOMEMLIMIT=8GiB $NEW_UPGRADE_ASSURE_BINARY_PATH $SNAPSHOT_PATH $NEW_BINARY_PATH $NEW_BINARY_PATH \
--skip-snapshot \
--skip-chain-init \
--skip-create-validator \
--skip-prepare-validator-data \
--skip-submit-proposal \
--timeout-next-block 100000 \
--timeout-wait-for-node 100000

- name: Create new snapshot file
run: |
SANITIZED_HEAD_REF=$(echo "${{ github.head_ref }}" | sed 's|/|_|g')
CURRENT_DATE=$(date +'%Y%m%d-%H%M%S')
NEW_SNAPSHOT_FILENAME="elys-snapshot-${SANITIZED_HEAD_REF}-${CURRENT_DATE}.tar.lz4"
NEW_SNAPSHOT_PATH="/tmp/${NEW_SNAPSHOT_FILENAME}"
echo "NEW_SNAPSHOT_FILENAME=$NEW_SNAPSHOT_FILENAME" >> $GITHUB_ENV
echo "NEW_SNAPSHOT_PATH=$NEW_SNAPSHOT_PATH" >> $GITHUB_ENV
tar -cf - ~/.elys | lz4 -z - > "$NEW_SNAPSHOT_PATH"

- name: Upload snapshot
run: |
export R2_ACCESS_KEY=${{ secrets.R2_ACCESS_KEY }}
export R2_SECRET_KEY=${{ secrets.R2_SECRET_KEY }}
export R2_ENDPOINT=${{ secrets.R2_ENDPOINT }}
export R2_BUCKET_NAME=${{ secrets.R2_BUCKET_NAME }}
$UPLOAD_SNAPSHOT_BINARY_PATH $NEW_SNAPSHOT_PATH

- name: Remove snapshot file
run: |
rm -f $NEW_SNAPSHOT_PATH

- name: Info about the snapshot
run: |
GOMEMLIMIT=16GiB go run ./scripts/upgrade-assure/... $SNAPSHOT_PATH $OLD_BINARY_PATH $NEW_BINARY_PATH --skip-snapshot --skip-chain-init
echo "Snapshot URL: https://snapshots.elys.network/$NEW_SNAPSHOT_FILENAME"
2 changes: 1 addition & 1 deletion .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ jobs:
uses: actions/checkout@v4

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version: "1.21"

Expand Down
24 changes: 24 additions & 0 deletions .goreleaser.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,30 @@ builds:
- muslc
- osusergo
- pebbledb
- id: upgrade-assure-linux-amd64
main: ./cmd/upgrade-assure
binary: upgrade-assure
goos:
- linux
goarch:
- amd64
env:
- CC=x86_64-linux-gnu-gcc
flags:
- -mod=readonly
- -trimpath
- id: upload-snapshot-linux-amd64
main: ./cmd/upload-snapshot
binary: upload-snapshot
goos:
- linux
goarch:
- amd64
env:
- CC=x86_64-linux-gnu-gcc
flags:
- -mod=readonly
- -trimpath
universal_binaries:
- id: elysd-darwin-universal
ids:
Expand Down
15 changes: 13 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,18 @@ build: check-version go.sum
@-mkdir -p $(BUILD_FOLDER) 2> /dev/null
@GOFLAGS=$(GOFLAGS) go build $(BUILD_FLAGS) -o $(BUILD_FOLDER) ./cmd/$(BINARY)

## build-upgrade-assure: Build the binary for upgrade assure
build-upgrade-assure: check-version go.sum
@echo Building Upgrade assure binary...
@-mkdir -p $(BUILD_FOLDER) 2> /dev/null
@GOFLAGS=$(GOFLAGS) go build -o $(BUILD_FOLDER) ./cmd/upgrade-assure

## build-upload-snapshot: Build the binary for upload snapshot
build-upload-snapshot: check-version go.sum
@echo Building Upload snapshot binary...
@-mkdir -p $(BUILD_FOLDER) 2> /dev/null
@GOFLAGS=$(GOFLAGS) go build -o $(BUILD_FOLDER) ./cmd/upload-snapshot

## build-all: Build binaries for all platforms
build-all:
@echo Building Elysd binaries for all platforms...
Expand All @@ -79,7 +91,7 @@ do-checksum:
## build-with-checksum: Build binaries for all platforms and generate checksums
build-with-checksum: build-all do-checksum

.PHONY: install build build-all do-checksum build-with-checksum
.PHONY: install build build-all do-checksum build-with-checksum build-upgrade-assure build-upload-snapshot

## mocks: Generate mocks
mocks:
Expand Down Expand Up @@ -168,7 +180,6 @@ stop-docker:

GORELEASER_IMAGE := ghcr.io/goreleaser/goreleaser-cross:v$(GO_VERSION)
COSMWASM_VERSION := $(shell go list -m github.com/CosmWasm/wasmvm | sed 's/.* //')
ROCKSDB_VERSION := 8.9.1

## release: Build binaries for all platforms and generate checksums
ifdef GITHUB_TOKEN
Expand Down
Loading