CI #576
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
pull_request: | |
schedule: | |
# keep request limits in mind before increasing the cron frequency | |
# * is a special character in YAML so you have to quote this string | |
- cron: '0 2 * * *' | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout main | |
uses: actions/checkout@v3 | |
- uses: pnpm/action-setup@v2 | |
name: Set up pnpm | |
with: | |
version: 7 | |
- name: Set up Node.js 18 | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
- name: Install dependencies | |
run: pnpm install | |
- name: Run tests | |
run: pnpm test | |
env: | |
CI: true | |
fetch-and-publish: | |
runs-on: ubuntu-latest | |
needs: test | |
if: github.ref == 'refs/heads/main' | |
steps: | |
- name: Checkout main | |
uses: actions/checkout@v3 | |
- name: Set up Python 3 | |
uses: actions/setup-python@v4 | |
with: | |
python-version: 3 | |
- name: Install awscli | |
run: pip3 install awscli awscli-plugin-endpoint | |
- name: Set up awscli configuration | |
env: | |
DO_SPACES_KEY: ${{ secrets.DO_SPACES_KEY }} | |
DO_SPACES_SECRET: ${{ secrets.DO_SPACES_SECRET }} | |
run: | | |
set -e; | |
mkdir ~/.aws; | |
echo " | |
[default] | |
aws_access_key_id=$DO_SPACES_KEY | |
aws_secret_access_key=$DO_SPACES_SECRET | |
" > ~/.aws/credentials; | |
echo " | |
[plugins] | |
endpoint = awscli_plugin_endpoint | |
[default] | |
region = fr-par | |
s3 = | |
endpoint_url = https://fra1.digitaloceanspaces.com | |
signature_version = s3v4 | |
max_concurrent_requests = 100 | |
max_queue_size = 2000 | |
multipart_threshold = 2000MB | |
# Edit the multipart_chunksize value according to the file sizes that you want to upload. The present configuration allows to upload files up to 10 GB (100 requests * 10MB). For example setting it to 5GB allows you to upload files up to 5TB. | |
multipart_chunksize = 2000MB | |
s3api = | |
endpoint_url = https://fra1.digitaloceanspaces.com | |
" > ~/.aws/config; | |
- name: Ensure that bucket versioning is enabled | |
env: | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: aws s3api put-bucket-versioning --bucket $DO_SPACES_BUCKET_NAME --versioning-configuration 'Status=Enabled' | |
- uses: pnpm/action-setup@v2 | |
name: Set up pnpm | |
with: | |
version: 7 | |
- name: Set up Node.js 18 | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
- name: Install dependencies | |
run: pnpm install | |
- name: "Fetch and upload feed: DE_GTFS" | |
if: ${{ success() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
OPENDATA_OEPNV_EMAIL: ${{ secrets.OPENDATA_OEPNV_EMAIL }} | |
OPENDATA_OEPNV_PASSWORD: ${{ secrets.OPENDATA_OEPNV_PASSWORD }} | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-de-gtfs; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key de/gtfs.zip || echo 'not-yet-existing'); | |
newhash=$(cat de-gtfs.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read de-gtfs.zip s3://"$DO_SPACES_BUCKET_NAME"/de/gtfs.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: DE_NETEX" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
OPENDATA_OEPNV_EMAIL: ${{ secrets.OPENDATA_OEPNV_EMAIL }} | |
OPENDATA_OEPNV_PASSWORD: ${{ secrets.OPENDATA_OEPNV_PASSWORD }} | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-de-netex; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key de/netex.zip || echo 'not-yet-existing'); | |
newhash=$(cat de-netex.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read de-netex.zip s3://"$DO_SPACES_BUCKET_NAME"/de/netex.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: DE_ZHV" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
OPENDATA_OEPNV_EMAIL: ${{ secrets.OPENDATA_OEPNV_EMAIL }} | |
OPENDATA_OEPNV_PASSWORD: ${{ secrets.OPENDATA_OEPNV_PASSWORD }} | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-de-zhv; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key de/zhv.zip || echo 'not-yet-existing'); | |
newhash=$(cat de-zhv.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read de-zhv.zip s3://"$DO_SPACES_BUCKET_NAME"/de/zhv.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: DE_NRW_GTFS" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
OPENDATA_OEPNV_EMAIL: ${{ secrets.OPENDATA_OEPNV_EMAIL }} | |
OPENDATA_OEPNV_PASSWORD: ${{ secrets.OPENDATA_OEPNV_PASSWORD }} | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-de-nrw-gtfs; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key de/nrw-gtfs.zip || echo 'not-yet-existing'); | |
newhash=$(cat de-nrw-gtfs.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read de-nrw-gtfs.zip s3://"$DO_SPACES_BUCKET_NAME"/de/nrw-gtfs.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: DE_HVV_GTFS" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-de-hvv-gtfs; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key de/hvv-gtfs.zip || echo 'not-yet-existing'); | |
newhash=$(cat de-hvv-gtfs.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read de-hvv-gtfs.zip s3://"$DO_SPACES_BUCKET_NAME"/de/hvv-gtfs.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: LU_GTFS" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-lu-gtfs; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key lu/gtfs.zip || echo 'not-yet-existing'); | |
newhash=$(cat lu-gtfs.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read lu-gtfs.zip s3://"$DO_SPACES_BUCKET_NAME"/lu/gtfs.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; | |
- name: "Fetch and upload feed: SE_GTFS" | |
if: ${{ success() || failure() }} # this should allow the other steps to run, but should still mark the workflow as failing | |
env: | |
TRAFIKLAB_API_KEY: ${{ secrets.TRAFIKLAB_API_KEY }} | |
DO_SPACES_BUCKET_NAME: ${{ secrets.DO_SPACES_BUCKET_NAME }} | |
run: | | |
set -e; | |
npm run fetch-se-gtfs; | |
currentobj=$(aws s3api head-object --bucket $DO_SPACES_BUCKET_NAME --key se/gtfs.zip || echo 'not-yet-existing'); | |
newhash=$(cat se-gtfs.zip | md5sum); | |
if [ $(echo $currentobj | grep $newhash | wc -l) -ne 1 ] | |
then | |
aws s3 cp --acl public-read se-gtfs.zip s3://"$DO_SPACES_BUCKET_NAME"/se/gtfs.zip | |
else | |
echo 'file unchanged, skipping.' | |
fi; |