Merge pull request 'ci: upload to gitea packages instead of s3' (#16) from jixunmoe/um-web:ci/use-gitea-packages into master

Reviewed-on: https://git.unlock-music.dev/um/web/pulls/16
This commit is contained in:
鲁树人 2022-11-27 00:48:19 +00:00
commit 5bb3c7851e
4 changed files with 69 additions and 52 deletions

View File

@ -4,34 +4,27 @@ type: docker
name: default name: default
steps: steps:
- name: build-wasm
image: emscripten/emsdk:3.0.0
commands:
- ./scripts/build-wasm.sh
- name: build - name: build
image: node:16.18-bullseye image: node:16.18-bullseye
commands: commands:
- apt-get update - apt-get update
- apt-get install -y cmake jq zip - apt-get install -y jq zip
- ./scripts/build-wasm.sh
- npm ci - npm ci
- npm run test - npm run test
- ./scripts/build-and-package.sh legacy - ./scripts/build-and-package.sh legacy
- ./scripts/build-and-package.sh extension - ./scripts/build-and-package.sh extension
- ./scripts/build-and-package.sh modern - ./scripts/build-and-package.sh modern
- sha256sum *.zip > sha256sum.txt
- mkdir -p upload
- mv *.zip sha256sum.txt upload/
- name: upload - name: upload artifact
image: "plugins/s3" image: node:16.18-bullseye
settings: environment:
path_style: true DRONE_GITEA_SERVER: https://git.unlock-music.dev
endpoint: GITEA_API_KEY:
from_secret: S3_ENDPOINT from_secret: GITEA_API_KEY
access_key: commands:
from_secret: S3_ACCESS_KEY - ./scripts/upload-packages.sh
secret_key:
from_secret: S3_SECRET_KEY
bucket:
from_secret: S3_BUCKET
region: "auto"
source: "upload/*"
strip_prefix: "upload/"
target: "${DRONE_REPO}/${DRONE_BUILD_NUMBER}/"

19
scripts/upload-packages.sh Executable file
View File

@ -0,0 +1,19 @@
#!/bin/sh
set -ex
cd "$(git rev-parse --show-toplevel)"
if [ -z "$GITEA_API_KEY" ]; then
echo "GITEA_API_KEY is empty, skip upload."
exit 0
fi
URL_BASE="$DRONE_GITEA_SERVER/api/packages/${DRONE_REPO_NAMESPACE}/generic/${DRONE_REPO_NAME}-build"
for ZIP_NAME in *.zip; do
UPLOAD_URL="${URL_BASE}/${DRONE_BUILD_NUMBER}/${ZIP_NAME}"
sha256sum "${ZIP_NAME}"
curl -sLifu "um-release-bot:$GITEA_API_KEY" -T "${ZIP_NAME}" "${UPLOAD_URL}"
echo "Uploaded to: ${UPLOAD_URL}"
done

View File

@ -11,18 +11,20 @@ if [ -z "$BUILD_TYPE" ]; then
BUILD_TYPE=Release BUILD_TYPE=Release
fi fi
mkdir -p build/wasm # CI: already had emsdk installed.
if ! command -v emcc; then
if [ ! -d ../../build/emsdk ]; then if [ ! -d ../../build/emsdk ]; then
git clone https://github.com/emscripten-core/emsdk.git ../../build/emsdk git clone https://github.com/emscripten-core/emsdk.git ../../build/emsdk
fi fi
pushd ../../build/emsdk pushd ../../build/emsdk
#git pull
./emsdk install 3.0.0 ./emsdk install 3.0.0
./emsdk activate 3.0.0 ./emsdk activate 3.0.0
source ./emsdk_env.sh source ./emsdk_env.sh
popd # ../../build/emsdk popd # ../../build/emsdk
fi
mkdir -p build/wasm
pushd build/wasm pushd build/wasm
emcmake cmake -DCMAKE_BUILD_TYPE="$BUILD_TYPE" ../.. emcmake cmake -DCMAKE_BUILD_TYPE="$BUILD_TYPE" ../..
make -j make -j

View File

@ -11,7 +11,8 @@ if [ -z "$BUILD_TYPE" ]; then
BUILD_TYPE=Release BUILD_TYPE=Release
fi fi
mkdir -p build/wasm # CI: already had emsdk installed.
if ! command -v emcc; then
if [ ! -d ../../build/emsdk ]; then if [ ! -d ../../build/emsdk ]; then
git clone https://github.com/emscripten-core/emsdk.git ../../build/emsdk git clone https://github.com/emscripten-core/emsdk.git ../../build/emsdk
fi fi
@ -21,7 +22,9 @@ pushd ../../build/emsdk
./emsdk activate 3.0.0 ./emsdk activate 3.0.0
source ./emsdk_env.sh source ./emsdk_env.sh
popd # ../../build/emsdk popd # ../../build/emsdk
fi
mkdir -p build/wasm
pushd build/wasm pushd build/wasm
emcmake cmake -DCMAKE_BUILD_TYPE="$BUILD_TYPE" ../.. emcmake cmake -DCMAKE_BUILD_TYPE="$BUILD_TYPE" ../..
make -j make -j