aboutsummaryrefslogtreecommitdiff
path: root/.woodpecker
diff options
context:
space:
mode:
authorAlex <alex@adnab.me>2024-02-08 17:46:00 +0000
committerAlex <alex@adnab.me>2024-02-08 17:46:00 +0000
commit304a89c57b1e951481cd0bf2e56582b41b6d73e4 (patch)
tree00730627bea8498735d4478844f7cf3064b5078f /.woodpecker
parent710680da1523921f518d12e19f8a2e27628e2da2 (diff)
parent25c2f37667eb3b06bb14869129e33f78a9705b1b (diff)
downloadgarage-304a89c57b1e951481cd0bf2e56582b41b6d73e4.tar.gz
garage-304a89c57b1e951481cd0bf2e56582b41b6d73e4.zip
Merge pull request 'convert drone pipelines to woodpecker' (#708) from woodpecker into main
Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/708
Diffstat (limited to '.woodpecker')
-rw-r--r--.woodpecker/debug.yaml44
-rw-r--r--.woodpecker/publish.yaml32
-rw-r--r--.woodpecker/release.yaml67
3 files changed, 143 insertions, 0 deletions
diff --git a/.woodpecker/debug.yaml b/.woodpecker/debug.yaml
new file mode 100644
index 00000000..9486f672
--- /dev/null
+++ b/.woodpecker/debug.yaml
@@ -0,0 +1,44 @@
+when:
+ event:
+ - push
+ - tag
+ - pull_request
+ - deployment
+ - cron
+
+steps:
+ - name: check formatting
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-shell --attr rust --run "cargo fmt -- --check"
+
+ - name: build
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-build --no-build-output --attr clippy.amd64 --argstr git_version ${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+
+ - name: unit + func tests
+ image: nixpkgs/nix:nixos-22.05
+ environment:
+ GARAGE_TEST_INTEGRATION_EXE: result-bin/bin/garage
+ GARAGE_TEST_INTEGRATION_PATH: tmp-garage-integration
+ commands:
+ - nix-build --no-build-output --attr clippy.amd64 --argstr git_version ${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+ - nix-build --no-build-output --attr test.amd64
+ - ./result/bin/garage_db-*
+ - ./result/bin/garage_api-*
+ - ./result/bin/garage_model-*
+ - ./result/bin/garage_rpc-*
+ - ./result/bin/garage_table-*
+ - ./result/bin/garage_util-*
+ - ./result/bin/garage_web-*
+ - ./result/bin/garage-*
+ - ./result/bin/integration-* || (cat tmp-garage-integration/stderr.log; false)
+ - rm result
+ - rm -rv tmp-garage-integration
+
+ - name: integration tests
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-build --no-build-output --attr clippy.amd64 --argstr git_version ${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+ - nix-shell --attr integration --run ./script/test-smoke.sh || (cat /tmp/garage.log; false)
diff --git a/.woodpecker/publish.yaml b/.woodpecker/publish.yaml
new file mode 100644
index 00000000..b45d379c
--- /dev/null
+++ b/.woodpecker/publish.yaml
@@ -0,0 +1,32 @@
+when:
+ event:
+ - deployment
+ - cron
+
+depends_on:
+ - release
+
+steps:
+ - name: refresh-index
+ image: nixpkgs/nix:nixos-22.05
+ secrets:
+ - source: garagehq_aws_access_key_id
+ target: AWS_ACCESS_KEY_ID
+ - source: garagehq_aws_secret_access_key
+ target: AWS_SECRET_ACCESS_KEY
+ commands:
+ - mkdir -p /etc/nix && cp nix/nix.conf /etc/nix/nix.conf
+ - nix-shell --attr release --run "refresh_index"
+
+# - name: multiarch-docker
+# image: nixpkgs/nix:nixos-22.05
+# environment:
+# HOME: "/root"
+# secrets:
+# - docker_auth
+# commands:
+# - mkdir -p /root/.docker
+# - echo $DOCKER_AUTH > /root/.docker/config.json
+# - sha512sum /root/.docker/config.json
+# - export CONTAINER_TAG=${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+# - nix-shell --attr release --run "multiarch_docker"
diff --git a/.woodpecker/release.yaml b/.woodpecker/release.yaml
new file mode 100644
index 00000000..8580441c
--- /dev/null
+++ b/.woodpecker/release.yaml
@@ -0,0 +1,67 @@
+when:
+ event:
+ - deployment
+ - cron
+
+matrix:
+ include:
+ - ARCH: amd64
+ TARGET: x86_64-unknown-linux-musl
+ - ARCH: i386
+ TARGET: i686-unknown-linux-musl
+ - ARCH: arm64
+ TARGET: aarch64-unknown-linux-musl
+ - ARCH: arm
+ TARGET: armv6l-unknown-linux-musleabihf
+
+steps:
+ - name: build
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-build --no-build-output --attr pkgs.${ARCH}.release --argstr git_version ${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+ - nix-shell --attr rust --run "./script/not-dynamic.sh result-bin/bin/garage"
+
+ - name: integration tests
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-shell --attr integration --run ./script/test-smoke.sh || (cat /tmp/garage.log; false)
+ when:
+ - matrix:
+ ARCH: amd64
+ - matrix:
+ ARCH: i386
+
+ - name: upgrade tests
+ image: nixpkgs/nix:nixos-22.05
+ commands:
+ - nix-shell --attr integration --run "./script/test-upgrade.sh v0.8.4 x86_64-unknown-linux-musl" || (cat /tmp/garage.log; false)
+ when:
+ - matrix:
+ ARCH: amd64
+
+ - name: push static binary
+ image: nixpkgs/nix:nixos-22.05
+ environment:
+ TARGET: "${TARGET}"
+ secrets:
+ - source: garagehq_aws_access_key_id
+ target: AWS_ACCESS_KEY_ID
+ - source: garagehq_aws_secret_access_key
+ target: AWS_SECRET_ACCESS_KEY
+ commands:
+ - nix-shell --attr release --run "to_s3_woodpecker"
+
+# - name: docker build and publish
+# image: nixpkgs/nix:nixos-22.05
+# environment:
+# DOCKER_PLATFORM: "linux/${ARCH}"
+# CONTAINER_NAME: "dxflrs/${ARCH}_garage"
+# HOME: "/kaniko"
+# secrets:
+# - docker_auth
+# commands:
+# - mkdir -p /kaniko/.docker
+# - echo $DOCKER_AUTH > /kaniko/.docker/config.json
+# - sha512sum /kaniko/.docker/config.json
+# - export CONTAINER_TAG=${CI_COMMIT_TAG:-$CI_COMMIT_SHA}
+# - nix-shell --attr release --run "to_docker"