refactor: DRY by using matrix for docker builds
This commit is contained in:
parent
c6e18fbc96
commit
645c1031d4
126
.github/workflows/osrm-backend.yml
vendored
126
.github/workflows/osrm-backend.yml
vendored
@ -116,91 +116,51 @@ jobs:
|
|||||||
npm run docs && ./scripts/error_on_dirty.sh
|
npm run docs && ./scripts/error_on_dirty.sh
|
||||||
npm audit --production
|
npm audit --production
|
||||||
|
|
||||||
docker-image:
|
docker-image-matrix:
|
||||||
needs: format-taginfo-docs
|
strategy:
|
||||||
runs-on: ubuntu-22.04
|
matrix:
|
||||||
continue-on-error: false
|
dockerfile: [Dockerfile, Dockerfile-alpine]
|
||||||
steps:
|
needs: format-taginfo-docs
|
||||||
- name: Check out the repo
|
runs-on: ubuntu-22.04
|
||||||
uses: actions/checkout@v4
|
continue-on-error: false
|
||||||
- name: Enable osm.pbf cache
|
steps:
|
||||||
uses: actions/cache@v4
|
- name: Check out the repo
|
||||||
with:
|
uses: actions/checkout@v4
|
||||||
path: berlin-latest.osm.pbf
|
- name: Enable osm.pbf cache
|
||||||
key: v1-berlin-osm-pbf
|
uses: actions/cache@v4
|
||||||
restore-keys: |
|
with:
|
||||||
v1-berlin-osm-pbf
|
path: berlin-latest.osm.pbf
|
||||||
- name: Docker build
|
key: v1-berlin-osm-pbf
|
||||||
run: |
|
restore-keys: |
|
||||||
docker build -t osrm-backend-local -f docker/Dockerfile .
|
v1-berlin-osm-pbf
|
||||||
- name: Test Docker image
|
- name: Docker build
|
||||||
run: |
|
run: |
|
||||||
if [ ! -f "${PWD}/berlin-latest.osm.pbf" ]; then
|
docker build -t osrm-backend-local -f docker/${{ matrix.dockerfile }} .
|
||||||
wget http://download.geofabrik.de/europe/germany/berlin-latest.osm.pbf
|
- name: Test Docker image
|
||||||
fi
|
run: |
|
||||||
TAG=osrm-backend-local
|
if [ ! -f "${PWD}/berlin-latest.osm.pbf" ]; then
|
||||||
# when `--memory-swap` value equals `--memory` it means container won't use swap
|
wget http://download.geofabrik.de/europe/germany/berlin-latest.osm.pbf
|
||||||
# see https://docs.docker.com/config/containers/resource_constraints/#--memory-swap-details
|
fi
|
||||||
MEMORY_ARGS="--memory=1g --memory-swap=1g"
|
TAG=osrm-backend-local
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-extract --dump-nbg-graph -p /opt/car.lua /data/berlin-latest.osm.pbf
|
# when `--memory-swap` value equals `--memory` it means container won't use swap
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-components /data/berlin-latest.osrm.nbg /data/berlin-latest.geojson
|
# see https://docs.docker.com/config/containers/resource_constraints/#--memory-swap-details
|
||||||
if [ ! -s "${PWD}/berlin-latest.geojson" ]
|
MEMORY_ARGS="--memory=1g --memory-swap=1g"
|
||||||
then
|
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-extract --dump-nbg-graph -p /opt/car.lua /data/berlin-latest.osm.pbf
|
||||||
>&2 echo "No berlin-latest.geojson found"
|
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-components /data/berlin-latest.osrm.nbg /data/berlin-latest.geojson
|
||||||
exit 1
|
if [ ! -s "${PWD}/berlin-latest.geojson" ]
|
||||||
fi
|
then
|
||||||
|
>&2 echo "No berlin-latest.geojson found"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# removing `.osrm.nbg` to check that whole pipeline works without it
|
# removing `.osrm.nbg` to check that whole pipeline works without it
|
||||||
rm -rf "${PWD}/berlin-latest.osrm.nbg"
|
rm -rf "${PWD}/berlin-latest.osrm.nbg"
|
||||||
|
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-partition /data/berlin-latest.osrm
|
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-partition /data/berlin-latest.osrm
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-customize /data/berlin-latest.osrm
|
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-customize /data/berlin-latest.osrm
|
||||||
docker run $MEMORY_ARGS --name=osrm-container -t -p 5000:5000 -v "${PWD}:/data" "${TAG}" osrm-routed --algorithm mld /data/berlin-latest.osrm &
|
docker run $MEMORY_ARGS --name=osrm-container -t -p 5000:5000 -v "${PWD}:/data" "${TAG}" osrm-routed --algorithm mld /data/berlin-latest.osrm &
|
||||||
curl --retry-delay 3 --retry 10 --retry-all-errors "http://127.0.0.1:5000/route/v1/driving/13.388860,52.517037;13.385983,52.496891?steps=true"
|
curl --retry-delay 3 --retry 10 --retry-all-errors "http://127.0.0.1:5000/route/v1/driving/13.388860,52.517037;13.385983,52.496891?steps=true"
|
||||||
docker stop osrm-container
|
docker stop osrm-container
|
||||||
|
|
||||||
docker-alpine-image:
|
|
||||||
needs: format-taginfo-docs
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
continue-on-error: false
|
|
||||||
steps:
|
|
||||||
- name: Check out the repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Enable osm.pbf cache
|
|
||||||
uses: actions/cache@v4
|
|
||||||
with:
|
|
||||||
path: berlin-latest.osm.pbf
|
|
||||||
key: v1-berlin-osm-pbf
|
|
||||||
restore-keys: |
|
|
||||||
v1-berlin-osm-pbf
|
|
||||||
- name: Docker alpine build
|
|
||||||
run: |
|
|
||||||
docker build -t osrm-backend-local -f docker/Dockerfile-alpine .
|
|
||||||
- name: Test Docker alpine image
|
|
||||||
run: |
|
|
||||||
if [ ! -f "${PWD}/berlin-latest.osm.pbf" ]; then
|
|
||||||
wget http://download.geofabrik.de/europe/germany/berlin-latest.osm.pbf
|
|
||||||
fi
|
|
||||||
TAG=osrm-backend-local
|
|
||||||
# when `--memory-swap` value equals `--memory` it means container won't use swap
|
|
||||||
# see https://docs.docker.com/config/containers/resource_constraints/#--memory-swap-details
|
|
||||||
MEMORY_ARGS="--memory=1g --memory-swap=1g"
|
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-extract --dump-nbg-graph -p /opt/car.lua /data/berlin-latest.osm.pbf
|
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-components /data/berlin-latest.osrm.nbg /data/berlin-latest.geojson
|
|
||||||
if [ ! -s "${PWD}/berlin-latest.geojson" ]
|
|
||||||
then
|
|
||||||
>&2 echo "No berlin-latest.geojson found"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# removing `.osrm.nbg` to check that whole pipeline works without it
|
|
||||||
rm -rf "${PWD}/berlin-latest.osrm.nbg"
|
|
||||||
|
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-partition /data/berlin-latest.osrm
|
|
||||||
docker run $MEMORY_ARGS -t -v "${PWD}:/data" "${TAG}" osrm-customize /data/berlin-latest.osrm
|
|
||||||
docker run $MEMORY_ARGS --name=osrm-container -t -p 5000:5000 -v "${PWD}:/data" "${TAG}" osrm-routed --algorithm mld /data/berlin-latest.osrm &
|
|
||||||
curl --retry-delay 3 --retry 10 --retry-all-errors "http://127.0.0.1:5000/route/v1/driving/13.388860,52.517037;13.385983,52.496891?steps=true"
|
|
||||||
docker stop osrm-container
|
|
||||||
|
|
||||||
build-test-publish:
|
build-test-publish:
|
||||||
needs: format-taginfo-docs
|
needs: format-taginfo-docs
|
||||||
|
Loading…
Reference in New Issue
Block a user