Compare commits

...

2 Commits

Author SHA1 Message Date
addbee053e
ci: add caching mechnism
All checks were successful
ci/woodpecker/push/cd Pipeline was successful
ci/woodpecker/manual/cd Pipeline was successful
2024-05-20 20:56:49 +06:00
1cda00dcd3
ci: improve step run conditions 2024-05-20 20:51:29 +06:00

View File

@ -2,7 +2,6 @@
when: when:
event: [push, manual] event: [push, manual]
branch: main
variables: variables:
secrets: &secrets secrets: &secrets
@ -14,16 +13,60 @@ variables:
steps: steps:
- name: cache/restore
image: meltwater/drone-cache:v1.4.0
environment:
AWS_ACCESS_KEY_ID:
from_secret: CACHE_S3_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY:
from_secret: CACHE_S3_SECRET_ACCESS_KEY
settings:
restore: true
path_style: true
cache_key: '{{ .Commit.Branch }}-{{ checksum "yarn.lock" }}'
archive_format: gzip
bucket:
from_secret: CACHE_S3_BUCKET
endpoint:
from_secret: CACHE_S3_ENDPOINT
region:
from_secret: CACHE_S3_REGION
mount:
- 'node_modules'
- name: build/yarn - name: build/yarn
depends_on: [ cache/restore ]
image: node:18 image: node:18
# when:
# - path:
# exclude: ['_meta/**']
commands: commands:
- yarn install - yarn install
- yarn build - yarn build
- name: cache/rebuild
depends_on: [ build/yarn ]
image: meltwater/drone-cache:v1.4.0
environment:
AWS_ACCESS_KEY_ID:
from_secret: CACHE_S3_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY:
from_secret: CACHE_S3_SECRET_ACCESS_KEY
settings:
rebuild: true
path_style: true
cache_key: '{{ .Commit.Branch }}-{{ checksum "yarn.lock" }}'
archive_format: gzip
bucket:
from_secret: CACHE_S3_BUCKET
endpoint:
from_secret: CACHE_S3_ENDPOINT
region:
from_secret: CACHE_S3_REGION
mount:
- 'node_modules'
- name: publish/s3 - name: publish/s3
depends_on: [ build/yarn ]
when:
- branch: main
image: amazon/aws-cli:2.15.50 image: amazon/aws-cli:2.15.50
commands: commands:
- aws s3 sync --delete ./dist s3://$${S3_BUCKET}/ - aws s3 sync --delete ./dist s3://$${S3_BUCKET}/
@ -31,6 +74,9 @@ steps:
- <<: *secrets - <<: *secrets
- name: publish/cloudfront - name: publish/cloudfront
depends_on: [ publish/s3 ]
when:
- branch: main
image: amazon/aws-cli:2.15.50 image: amazon/aws-cli:2.15.50
commands: commands:
- aws cloudfront create-invalidation --distribution-id $${CLOUDFRONT_DISTRIBUTION} --paths '/*' - aws cloudfront create-invalidation --distribution-id $${CLOUDFRONT_DISTRIBUTION} --paths '/*'