2023-04-07 19:49:24 +03:00
name : 'Nightly jobs'
on :
schedule :
- cron : '30 1 * * *'
workflow_dispatch :
2023-08-23 19:21:43 +03:00
2023-04-07 19:49:24 +03:00
permissions : read-all
# Here we are running two tests:
# 1. run zot with local storage and dedupe disabled, push images, restart zot with dedupe enabled
# task scheduler will start a dedupe all blobs process at zot startup and it shouldn't interfere with clients.
# 2. run zot with s3 storage and dynamodb and dedupe enabled, push images, restart zot with dedupe false and no cache
# task scheduler will start a restore all blobs process at zot startup, after it finishes all blobs should be restored to their original state (have content)
jobs :
2023-05-31 20:26:23 +03:00
dedupe :
2023-04-07 19:49:24 +03:00
name : Dedupe/restore blobs
runs-on : ubuntu-latest
steps :
2023-09-05 12:30:49 -07:00
- uses : actions/checkout@v4
2023-07-06 16:50:12 +03:00
- uses : ./.github/actions/clean-runner
2023-04-07 19:49:24 +03:00
- uses : actions/setup-go@v3
with :
2023-04-27 00:09:46 -07:00
go-version : 1.20 .x
2023-04-07 19:49:24 +03:00
- name : Install dependencies
run : |
cd $GITHUB_WORKSPACE
2023-06-01 16:53:50 -07:00
go install github.com/swaggo/swag/cmd/swag@v1.8.12
2023-04-07 19:49:24 +03:00
go mod download
sudo apt-get update
sudo apt-get install libgpgme-dev libassuan-dev libbtrfs-dev libdevmapper-dev pkg-config rpm uidmap
# install skopeo
2023-06-16 00:28:43 -07:00
git clone -b v1.12.0 https://github.com/containers/skopeo.git
2023-04-07 19:49:24 +03:00
cd skopeo
make bin/skopeo
sudo cp bin/skopeo /usr/bin
skopeo -v
- name : Install localstack
run : |
pip install --upgrade pyopenssl
pip install localstack awscli-local[ver1] # install LocalStack cli and awslocal
docker pull localstack/localstack # Make sure to pull the latest version of the image
localstack start -d # Start LocalStack in the background
2023-08-23 19:21:43 +03:00
2023-04-07 19:49:24 +03:00
echo "Waiting for LocalStack startup..." # Wait 30 seconds for the LocalStack container
2023-08-23 19:21:43 +03:00
localstack wait -t 30 # to become ready before timing out
echo "Startup complete"
2023-09-07 21:06:21 +03:00
- name : Run blackbox nightly dedupe tests
2023-04-07 19:49:24 +03:00
run : |
2023-09-07 21:06:21 +03:00
# test restoring s3 blobs after cache is deleted
# test deduping filesystem blobs after switching dedupe to enable
make run-blackbox-dedupe-nightly
2023-04-07 19:49:24 +03:00
env :
AWS_ACCESS_KEY_ID : fake
AWS_SECRET_ACCESS_KEY : fake
2023-05-31 20:26:23 +03:00
sync :
name : Sync harness
runs-on : ubuntu-latest
steps :
2023-07-06 16:50:12 +03:00
- name : Check out source code
2023-09-05 12:30:49 -07:00
uses : actions/checkout@v4
2023-07-06 16:50:12 +03:00
- uses : ./.github/actions/clean-runner
2023-05-31 20:26:23 +03:00
- uses : actions/setup-go@v3
with :
go-version : 1.20 .x
- name : Install dependencies
run : |
cd $GITHUB_WORKSPACE
2023-06-01 16:53:50 -07:00
go install github.com/swaggo/swag/cmd/swag@v1.8.12
2023-05-31 20:26:23 +03:00
go mod download
- name : Run sync harness
run : |
2023-09-07 21:06:21 +03:00
make run-blackbox-sync-nightly
2023-09-01 20:54:39 +03:00
gc-referrers-stress-s3 :
name : GC(with referrers) on S3 with short interval
runs-on : ubuntu-latest
steps :
2023-09-05 12:30:49 -07:00
- uses : actions/checkout@v4
2023-09-01 20:54:39 +03:00
- uses : ./.github/actions/clean-runner
- uses : actions/setup-go@v4
with :
cache : false
go-version : 1.20 .x
- name : Setup localstack service
run : |
pip install localstack # Install LocalStack cli
docker pull localstack/localstack:1.3 # Make sure to pull the latest version of the image
localstack start -d # Start LocalStack in the background
echo "Waiting for LocalStack startup..." # Wait 30 seconds for the LocalStack container
localstack wait -t 30 # to become ready before timing out
echo "Startup complete"
aws --endpoint-url=http://localhost:4566 s3api create-bucket --bucket zot-storage --region us-east-2 --create-bucket-configuration="{\"LocationConstraint\": \"us-east-2\"}"
aws dynamodb --endpoint-url http://localhost:4566 --region "us-east-2" create-table --table-name BlobTable --attribute-definitions AttributeName=Digest,AttributeType=S --key-schema AttributeName=Digest,KeyType=HASH --provisioned-throughput ReadCapacityUnits=10,WriteCapacityUnits=5
env :
AWS_ACCESS_KEY_ID : fake
AWS_SECRET_ACCESS_KEY : fake
- name : Run zb
run : |
make binary
make bench
./bin/zot-linux-amd64 serve test/gc-stress/config-gc-referrers-bench-s3.json &
sleep 10
bin/zb-linux-amd64 -c 10 -n 100 -o ci-cd http://localhost:8080
killall -r zot-*
# clean zot storage
sudo rm -rf /tmp/zot
env :
AWS_ACCESS_KEY_ID : fake
AWS_SECRET_ACCESS_KEY : fake
gc-stress-s3 :
name : GC(without referrers) on S3 with short interval
runs-on : ubuntu-latest
steps :
2023-09-05 12:30:49 -07:00
- uses : actions/checkout@v4
2023-09-01 20:54:39 +03:00
- uses : ./.github/actions/clean-runner
- uses : actions/setup-go@v4
with :
cache : false
go-version : 1.20 .x
- name : Setup localstack service
run : |
pip install localstack # Install LocalStack cli
docker pull localstack/localstack:1.3 # Make sure to pull the latest version of the image
localstack start -d # Start LocalStack in the background
echo "Waiting for LocalStack startup..." # Wait 30 seconds for the LocalStack container
localstack wait -t 30 # to become ready before timing out
echo "Startup complete"
aws --endpoint-url=http://localhost:4566 s3api create-bucket --bucket zot-storage --region us-east-2 --create-bucket-configuration="{\"LocationConstraint\": \"us-east-2\"}"
aws dynamodb --endpoint-url http://localhost:4566 --region "us-east-2" create-table --table-name BlobTable --attribute-definitions AttributeName=Digest,AttributeType=S --key-schema AttributeName=Digest,KeyType=HASH --provisioned-throughput ReadCapacityUnits=10,WriteCapacityUnits=5
env :
AWS_ACCESS_KEY_ID : fake
AWS_SECRET_ACCESS_KEY : fake
- name : Run zb
run : |
make binary
make bench
./bin/zot-linux-amd64 serve test/gc-stress/config-gc-bench-s3.json &
sleep 10
bin/zb-linux-amd64 -c 10 -n 100 -o ci-cd http://localhost:8080
killall -r zot-*
# clean zot storage
sudo rm -rf /tmp/zot
env :
AWS_ACCESS_KEY_ID : fake
AWS_SECRET_ACCESS_KEY : fake