From 283fc60222a06cbcbd075753df2ed5dd82eff7f1 Mon Sep 17 00:00:00 2001 From: Yuri Astrakhan Date: Mon, 2 Oct 2023 00:06:02 -0400 Subject: [PATCH 1/3] test --- .github/workflows/audit-check.yml | 14 - .github/workflows/bench.yml | 27 - .github/workflows/build-deploy-docs.yml | 30 -- .github/workflows/ci.yml | 652 ------------------------ .github/workflows/dependabot.yml | 27 - .github/workflows/grcov.yml | 78 --- .github/workflows/homebrew.yml | 21 + 7 files changed, 21 insertions(+), 828 deletions(-) delete mode 100644 .github/workflows/audit-check.yml delete mode 100644 .github/workflows/bench.yml delete mode 100644 .github/workflows/build-deploy-docs.yml delete mode 100644 .github/workflows/ci.yml delete mode 100644 .github/workflows/dependabot.yml delete mode 100644 .github/workflows/grcov.yml create mode 100644 .github/workflows/homebrew.yml diff --git a/.github/workflows/audit-check.yml b/.github/workflows/audit-check.yml deleted file mode 100644 index 5c98fae41..000000000 --- a/.github/workflows/audit-check.yml +++ /dev/null @@ -1,14 +0,0 @@ -name: Security audit - -on: - schedule: - - cron: "0 0 * * *" - -jobs: - audit: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions-rs/audit-check@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/bench.yml b/.github/workflows/bench.yml deleted file mode 100644 index 1fad55133..000000000 --- a/.github/workflows/bench.yml +++ /dev/null @@ -1,27 +0,0 @@ -name: Benchmark - -on: -# push: -# branches: [ main ] -# paths-ignore: -# - '**.md' -# - 'demo/**' -# - 'docs/**' -# pull_request: -# types: [ opened, synchronize, reopened ] -# paths-ignore: -# - '**.md' -# - 'demo/**' -# - 'docs/**' - workflow_dispatch: - -jobs: - check_benchmark: - runs-on: ubuntu-latest - - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - - name: Check benchmark - run: cargo bench diff --git a/.github/workflows/build-deploy-docs.yml b/.github/workflows/build-deploy-docs.yml deleted file mode 100644 index c932c99f0..000000000 --- a/.github/workflows/build-deploy-docs.yml +++ /dev/null @@ -1,30 +0,0 @@ -name: Documentation - -on: - push: - branches: [ main ] - pull_request: - -jobs: - build-docs: - name: Build Docs - runs-on: ubuntu-latest - concurrency: - group: ${{ github.workflow }}-${{ github.ref }} - steps: - - uses: actions/checkout@v4 - - uses: Swatinem/rust-cache@v2 - - - name: Setup mdBook - uses: peaceiris/actions-mdbook@v1 - with: - mdbook-version: 'latest' - - - run: mdbook build docs - - - name: Deploy - uses: peaceiris/actions-gh-pages@v3 - if: ${{ github.ref == 'refs/heads/main' }} - with: - github_token: ${{ secrets.GITHUB_TOKEN }} - publish_dir: ./target/book diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml deleted file mode 100644 index fba17aaa2..000000000 --- a/.github/workflows/ci.yml +++ /dev/null @@ -1,652 +0,0 @@ -name: CI - -on: - push: - branches: [ main ] - pull_request: - branches: [ main ] - paths-ignore: - - '**.md' - - 'demo/**' - - 'docs/**' - release: - types: [ published ] - workflow_dispatch: - -defaults: - run: - shell: bash - -jobs: - lint-debug-test: - name: Lint and Unit test - runs-on: ubuntu-latest - env: - PGDATABASE: test - PGHOST: localhost - PGUSER: postgres - PGPASSWORD: postgres - services: - postgres: - image: postgis/postgis:16-3.4 - ports: - # will assign a random free host port - - 5432/tcp - # Sadly there is currently no way to pass arguments to the service image other than this hack - # See also https://stackoverflow.com/a/62720566/177275 - options: >- - -e POSTGRES_DB=test - -e POSTGRES_USER=postgres - -e POSTGRES_PASSWORD=postgres - -e PGDATABASE=test - -e PGUSER=postgres - -e PGPASSWORD=postgres - --health-cmd pg_isready - --health-interval 10s - --health-timeout 5s - --health-retries 5 - --entrypoint sh - postgis/postgis:16-3.4 - -c "exec docker-entrypoint.sh postgres -c ssl=on -c ssl_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem -c ssl_key_file=/etc/ssl/private/ssl-cert-snakeoil.key" - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - name: Rust Versions - run: rustc --version && cargo --version - - uses: Swatinem/rust-cache@v2 - if: github.event_name != 'release' && github.event_name != 'workflow_dispatch' - - run: cargo fmt --all -- --check - - run: cargo clippy --package martin-tile-utils -- -D warnings - - run: cargo clippy --package martin-mbtiles --no-default-features -- -D warnings - - run: cargo clippy --package martin-mbtiles -- -D warnings - - run: cargo clippy --package martin -- -D warnings - - run: cargo clippy --package martin --features bless-tests -- -D warnings - - run: cargo doc --no-deps --workspace - env: - RUSTDOCFLAGS: "-D warnings" - - name: Init database - run: tests/fixtures/initdb.sh - env: - PGPORT: ${{ job.services.postgres.ports[5432] }} - - name: Run cargo test - run: | - set -x - cargo test --package martin-tile-utils - cargo test --package martin-mbtiles --no-default-features - cargo test --package martin-mbtiles - cargo test --package martin - cargo test --doc - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=require - - docker-build-test: - name: Build and test docker images - runs-on: ubuntu-latest - env: - # PG_* variables are used by psql - PGDATABASE: test - PGHOST: localhost - PGUSER: postgres - PGPASSWORD: postgres - TARGETS: "aarch64-unknown-linux-musl x86_64-unknown-linux-musl" - # TODO: aarch64-unknown-linux-gnu - services: - postgres: - image: postgis/postgis:15-3.3 - ports: - - 5432/tcp - options: >- - -e POSTGRES_DB=test - -e POSTGRES_USER=postgres - -e POSTGRES_PASSWORD=postgres - -e PGDATABASE=test - -e PGUSER=postgres - -e PGPASSWORD=postgres - --health-cmd pg_isready - --health-interval 10s - --health-timeout 5s - --health-retries 5 - --entrypoint sh - postgis/postgis:15-3.3 - -c "exec docker-entrypoint.sh postgres -c ssl=on -c ssl_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem -c ssl_key_file=/etc/ssl/private/ssl-cert-snakeoil.key" - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - uses: Swatinem/rust-cache@v2 - if: github.event_name != 'release' && github.event_name != 'workflow_dispatch' - - name: Install cross - run: | - cargo install cross - # Install latest cross version from git (disabled as it is probably less stable) - # cargo install cross --git https://github.com/cross-rs/cross - cross --version - - name: Init database - run: tests/fixtures/initdb.sh - env: - PGPORT: ${{ job.services.postgres.ports[5432] }} - - - name: Set up QEMU - uses: docker/setup-qemu-action@v3 - # https://github.com/docker/setup-qemu-action - with: - platforms: linux/amd64,linux/arm64 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - # https://github.com/docker/setup-buildx-action - with: - install: true - platforms: linux/amd64,linux/arm64 - - - name: Build targets - run: | - for target in $TARGETS; do - echo -e "\n----------------------------------------------" - echo "Building $target" - - export "CARGO_TARGET_$(echo $target | tr 'a-z-' 'A-Z_')_RUSTFLAGS"='-C strip=debuginfo' - cross build --release --target $target --package martin-mbtiles - cross build --release --target $target --package martin - - mkdir -p target_releases/$target - mv target/$target/release/mbtiles target_releases/$target - mv target/$target/release/martin target_releases/$target - done - - - name: Save build artifacts to build-${{ matrix.target }} - uses: actions/upload-artifact@v3 - with: - name: cross-build - path: target_releases/* - - name: Reorganize artifacts for docker build - run: | - mkdir -p target_releases/linux/arm64 - mv target_releases/aarch64-unknown-linux-musl/* target_releases/linux/arm64/ - mkdir -p target_releases/linux/amd64 - mv target_releases/x86_64-unknown-linux-musl/* target_releases/linux/amd64/ - - - name: Build linux/arm64 Docker image - uses: docker/build-push-action@v5 - # https://github.com/docker/build-push-action - with: - context: . - file: multi-platform.Dockerfile - load: true - tags: ${{ github.repository }}:linux-arm64 - platforms: linux/arm64 - - name: Test linux/arm64 Docker image - run: | - PLATFORM=linux/arm64 - TAG=${{ github.repository }}:linux-arm64 - export MBTILES_BUILD=- - export MBTILES_BIN="docker run --rm --net host --platform $PLATFORM -e DATABASE_URL -v $PWD/tests:/tests --entrypoint /usr/local/bin/mbtiles $TAG" - export MARTIN_BUILD=- - export MARTIN_BIN="docker run --rm --net host --platform $PLATFORM -e DATABASE_URL -v $PWD/tests:/tests $TAG" - tests/test.sh - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=require - - - name: Build linux/amd64 Docker image - uses: docker/build-push-action@v5 - # https://github.com/docker/build-push-action - with: - context: . - file: multi-platform.Dockerfile - load: true - tags: ${{ github.repository }}:linux-amd64 - platforms: linux/amd64 - - name: Test linux/amd64 Docker image - run: | - PLATFORM=linux/amd64 - TAG=${{ github.repository }}:linux-amd64 - export MBTILES_BUILD=- - export MBTILES_BIN="docker run --rm --net host --platform $PLATFORM -e DATABASE_URL -v $PWD/tests:/tests --entrypoint /usr/local/bin/mbtiles $TAG" - export MARTIN_BUILD=- - export MARTIN_BIN="docker run --rm --net host --platform $PLATFORM -e DATABASE_URL -v $PWD/tests:/tests $TAG" - tests/test.sh - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=require - - - name: Login to GitHub Docker registry - if: github.event_name != 'pull_request' - uses: docker/login-action@v3 - # https://github.com/docker/login-action - with: - registry: ghcr.io - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Docker meta - id: docker_meta - uses: docker/metadata-action@v5 - # https://github.com/docker/metadata-action - with: - images: ghcr.io/${{ github.repository }} - - name: Push the Docker image - if: github.event_name != 'pull_request' - uses: docker/build-push-action@v5 - with: - context: . - file: multi-platform.Dockerfile - push: true - tags: ${{ steps.docker_meta.outputs.tags }} - labels: ${{ steps.docker_meta.outputs.labels }} - platforms: linux/amd64,linux/arm64 - - build: - name: Build ${{ matrix.target }} - runs-on: ${{ matrix.os }} - strategy: - fail-fast: true - matrix: - include: - - target: aarch64-apple-darwin - os: macOS-latest - cross: 'true' - - target: debian-x86_64 - os: ubuntu-latest - cross: 'true' - - target: x86_64-apple-darwin - os: macOS-latest - - target: x86_64-pc-windows-msvc - os: windows-latest - ext: '.exe' - - target: x86_64-unknown-linux-gnu - os: ubuntu-latest - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - name: Rust Versions - run: rustc --version && cargo --version - - uses: Swatinem/rust-cache@v2 - if: github.event_name != 'release' && github.event_name != 'workflow_dispatch' - - name: Build (.deb) - if: matrix.target == 'debian-x86_64' - run: | - set -x - sudo apt-get install -y dpkg dpkg-dev liblzma-dev - cargo install cargo-deb - cargo deb -v -p martin --output target/debian/debian-x86_64.deb - mkdir -p target_releases - mv target/debian/debian-x86_64.deb target_releases/ - - name: Build - if: matrix.target != 'debian-x86_64' - run: | - set -x - rustup target add "${{ matrix.target }}" - export RUSTFLAGS='-C strip=debuginfo' - cargo build --release --target ${{ matrix.target }} --package martin-mbtiles - cargo build --release --target ${{ matrix.target }} --package martin - mkdir -p target_releases - mv target/${{ matrix.target }}/release/mbtiles${{ matrix.ext }} target_releases/ - mv target/${{ matrix.target }}/release/martin${{ matrix.ext }} target_releases/ - - name: Save build artifacts to build-${{ matrix.target }} - uses: actions/upload-artifact@v3 - with: - name: build-${{ matrix.target }} - path: target_releases/* - - test-multi-os: - name: Test on ${{ matrix.os }} - runs-on: ${{ matrix.os }} - needs: [ build ] - strategy: - fail-fast: true - matrix: - include: - - target: x86_64-apple-darwin - os: macOS-latest - - target: x86_64-pc-windows-msvc - os: windows-latest - ext: '.exe' - - target: x86_64-unknown-linux-gnu - os: ubuntu-latest - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - uses: Swatinem/rust-cache@v2 - if: github.event_name != 'release' && github.event_name != 'workflow_dispatch' - - name: Start postgres - uses: nyurik/action-setup-postgis@v1 - id: pg - with: - username: test - password: test - database: test - rights: --superuser - - name: Init database - run: | - echo "DATABASE_URL=$DATABASE_URL" - echo "Print the same in base64 to bypass Github's obfuscation (uses hardcoded password):" - echo "$DATABASE_URL" | base64 - tests/fixtures/initdb.sh - env: - DATABASE_URL: ${{ steps.pg.outputs.connection-uri }} - - name: Download build artifact build-${{ matrix.target }} - uses: actions/download-artifact@v3 - with: - name: build-${{ matrix.target }} - path: target/ - - name: Integration Tests - run: | - export MARTIN_BUILD=- - export MARTIN_BIN=target/martin${{ matrix.ext }} - export MBTILES_BUILD=- - export MBTILES_BIN=target/mbtiles${{ matrix.ext }} - if [[ "${{ runner.os }}" != "Windows" ]]; then - chmod +x "$MARTIN_BIN" "$MBTILES_BIN" - fi - tests/test.sh - env: - DATABASE_URL: ${{ steps.pg.outputs.connection-uri }} - - name: Compare test output results (Linux) - if: matrix.target == 'x86_64-unknown-linux-gnu' - run: diff --brief --recursive --new-file tests/output tests/expected - - name: Download Debian package (Linux) - if: matrix.target == 'x86_64-unknown-linux-gnu' - uses: actions/download-artifact@v3 - with: - name: build-debian-x86_64 - path: target/ - - name: Tests Debian package (Linux) - if: matrix.target == 'x86_64-unknown-linux-gnu' - run: | - sudo dpkg -i target/debian-x86_64.deb - export MARTIN_BUILD=- - export MARTIN_BIN=/usr/bin/martin${{ matrix.ext }} - export MBTILES_BUILD=- - export MBTILES_BIN=/usr/bin/mbtiles${{ matrix.ext }} - tests/test.sh - env: - DATABASE_URL: ${{ steps.pg.outputs.connection-uri }} - - name: Save test output on failure (Linux) - if: failure() && matrix.target == 'x86_64-unknown-linux-gnu' - uses: actions/upload-artifact@v3 - with: - name: failed-test-output - path: tests/output/* - retention-days: 5 - - test-with-svc: - name: Test postgis:${{ matrix.img_ver }} sslmode=${{ matrix.sslmode }} - runs-on: ubuntu-latest - needs: [ build ] - strategy: - fail-fast: true - matrix: - include: - # These must match the versions of postgres used in the docker-compose.yml - - img_ver: 11-3.0-alpine - args: postgres - sslmode: disable - - img_ver: 14-3.3-alpine - args: postgres - sslmode: disable - # alpine images don't support SSL, so for this we use the debian images - - img_ver: 15-3.3 - args: postgres -c ssl=on -c ssl_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem -c ssl_key_file=/etc/ssl/private/ssl-cert-snakeoil.key - sslmode: require - # - # FIXME! - # DISABLED because Rustls fails to validate name (CN?) with the NotValidForName error - #- img_ver: 15-3.3 - # args: postgres -c ssl=on -c ssl_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem -c ssl_key_file=/etc/ssl/private/ssl-cert-snakeoil.key - # sslmode: verify-ca - #- img_ver: 15-3.3 - # args: postgres -c ssl=on -c ssl_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem -c ssl_key_file=/etc/ssl/private/ssl-cert-snakeoil.key - # sslmode: verify-full - env: - PGDATABASE: test - PGHOST: localhost - PGUSER: postgres - PGPASSWORD: postgres - services: - postgres: - image: postgis/postgis:${{ matrix.img_ver }} - ports: - - 5432/tcp - options: >- - -e POSTGRES_DB=test - -e POSTGRES_USER=postgres - -e POSTGRES_PASSWORD=postgres - -e PGDATABASE=test - -e PGUSER=postgres - -e PGPASSWORD=postgres - --health-cmd pg_isready - --health-interval 10s - --health-timeout 5s - --health-retries 5 - --entrypoint sh - postgis/postgis:${{ matrix.img_ver }} - -c "exec docker-entrypoint.sh ${{ matrix.args }}" - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - uses: Swatinem/rust-cache@v2 - if: github.event_name != 'release' && github.event_name != 'workflow_dispatch' - - name: Init database - run: tests/fixtures/initdb.sh - env: - PGPORT: ${{ job.services.postgres.ports[5432] }} - - name: Get DB SSL cert (sslmode=verify-*) - if: matrix.sslmode == 'verify-ca' || matrix.sslmode == 'verify-full' - run: | - set -x - mkdir -p target/certs - docker cp ${{ job.services.postgres.id }}:/etc/ssl/certs/ssl-cert-snakeoil.pem target/certs/server.crt - docker cp ${{ job.services.postgres.id }}:/etc/ssl/private/ssl-cert-snakeoil.key target/certs/server.key - - name: Download build artifact build-x86_64-unknown-linux-gnu - uses: actions/download-artifact@v3 - with: - name: build-x86_64-unknown-linux-gnu - path: target_releases/ - - name: Integration Tests - run: | - if [[ "${{ matrix.sslmode }}" == "verify-ca" || "${{ matrix.sslmode }}" == "verify-full" ]]; then - export PGSSLROOTCERT=target/certs/server.crt - fi - export MARTIN_BUILD=- - export MARTIN_BIN=target_releases/martin - export MBTILES_BUILD=- - export MBTILES_BIN=target_releases/mbtiles - chmod +x "$MARTIN_BIN" "$MBTILES_BIN" - tests/test.sh - rm -rf target_releases - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=${{ matrix.sslmode }} - - name: Download Debian package - uses: actions/download-artifact@v3 - with: - name: build-debian-x86_64 - path: target_releases/ - - name: Tests Debian package - run: | - sudo dpkg -i target_releases/debian-x86_64.deb - if [[ "${{ matrix.sslmode }}" == "verify-ca" || "${{ matrix.sslmode }}" == "verify-full" ]]; then - export PGSSLROOTCERT=target/certs/server.crt - fi - export MARTIN_BUILD=- - export MARTIN_BIN=/usr/bin/martin - export MBTILES_BUILD=- - export MBTILES_BIN=/usr/bin/mbtiles - tests/test.sh - sudo dpkg -P martin - rm -rf target_releases - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=${{ matrix.sslmode }} - - name: Unit Tests - if: matrix.sslmode != 'verify-ca' && matrix.sslmode != 'verify-full' - run: | - echo "Running unit tests, connecting to DATABASE_URL=$DATABASE_URL" - echo "Same but as base64 to prevent GitHub obfuscation (this is not a secret):" - echo "$DATABASE_URL" | base64 - set -x - cargo test --package martin - cargo clean - env: - DATABASE_URL: postgres://${{ env.PGUSER }}:${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }}?sslmode=${{ matrix.sslmode }} - - name: On error, save test output - if: failure() - uses: actions/upload-artifact@v3 - with: - name: test-output - path: tests/output/* - retention-days: 5 - - package: - name: Package - runs-on: ubuntu-latest - needs: [ lint-debug-test, docker-build-test, test-multi-os, test-with-svc ] - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - name: Download build artifact build-aarch64-apple-darwin - uses: actions/download-artifact@v3 - with: - name: build-aarch64-apple-darwin - path: target/aarch64-apple-darwin - - name: Download build artifact build-x86_64-apple-darwin - uses: actions/download-artifact@v3 - with: - name: build-x86_64-apple-darwin - path: target/x86_64-apple-darwin - - name: Download build artifact build-x86_64-unknown-linux-gnu - uses: actions/download-artifact@v3 - with: - name: build-x86_64-unknown-linux-gnu - path: target/x86_64-unknown-linux-gnu - - - name: Download cross-build artifacts - uses: actions/download-artifact@v3 - with: - name: cross-build - path: target/cross - - - name: Download build artifact build-x86_64-pc-windows-msvc - uses: actions/download-artifact@v3 - with: - name: build-x86_64-pc-windows-msvc - path: target/x86_64-pc-windows-msvc - - name: Download build artifact build-debian-x86_64 - uses: actions/download-artifact@v3 - with: - name: build-debian-x86_64 - path: target/debian-x86_64 - - - name: Package - run: | - set -x - - cd target - mkdir files - mv cross/* . - - cd aarch64-apple-darwin - chmod +x martin mbtiles - tar czvf ../files/martin-Darwin-aarch64.tar.gz martin mbtiles - cd .. - - cd x86_64-apple-darwin - chmod +x martin mbtiles - tar czvf ../files/martin-Darwin-x86_64.tar.gz martin mbtiles - cd .. - - cd x86_64-unknown-linux-gnu - chmod +x martin mbtiles - tar czvf ../files/martin-Linux-x86_64.tar.gz martin mbtiles - cd .. - - cd aarch64-unknown-linux-musl - chmod +x martin mbtiles - tar czvf ../files/martin-Linux-aarch64-musl.tar.gz martin mbtiles - cd .. - - cd x86_64-unknown-linux-musl - chmod +x martin mbtiles - tar czvf ../files/martin-Linux-x86_64-musl.tar.gz martin mbtiles - cd .. - - # - # Special case for Windows - # - cd x86_64-pc-windows-msvc - 7z a ../files/martin-Windows-x86_64.zip martin.exe mbtiles.exe - cd .. - - # - # Special case for Debian .deb package - # - cd debian-x86_64 - mv debian-x86_64.deb ../files/martin-Debian-x86_64.deb - cd .. - - - name: Create Homebrew config - if: startsWith(github.ref, 'refs/tags/v') - run: | - set -x - - # Extract Github release version only without the "v" prefix - MARTIN_VERSION=$(echo "${{ github.ref }}" | sed -e 's/refs\/tags\/v//') - - cd target - mkdir homebrew - - cat << EOF > homebrew_config.yaml - version: "$MARTIN_VERSION" - macos_arm_sha256: "$(shasum -a 256 files/martin-Darwin-aarch64.tar.gz | cut -d' ' -f1)" - macos_intel_sha256: "$(shasum -a 256 files/martin-Darwin-x86_64.tar.gz | cut -d' ' -f1)" - linux_arm_sha256: "$(shasum -a 256 files/martin-Linux-aarch64-musl.tar.gz | cut -d' ' -f1)" - linux_intel_sha256: "$(shasum -a 256 files/martin-Linux-x86_64-musl.tar.gz | cut -d' ' -f1)" - EOF - - - name: Publish - if: startsWith(github.ref, 'refs/tags/') - uses: softprops/action-gh-release@v1 - with: - draft: true - files: 'target/files/*' - body_path: CHANGELOG.md - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - - name: Checkout maplibre/homebrew-martin - if: startsWith(github.ref, 'refs/tags/') - uses: actions/checkout@v4 - with: - repository: maplibre/homebrew-martin - token: ${{ secrets.GH_HOMEBREW_MARTIN_TOKEN }} - path: target/homebrew - - - name: Create Homebrew formula - if: startsWith(github.ref, 'refs/tags/') - uses: cuchi/jinja2-action@v1.2.0 - with: - template: .github/templates/homebrew.martin.rb.j2 - output_file: target/homebrew/martin.rb - data_file: target/homebrew_config.yaml - - - name: Create a PR for maplibre/homebrew-martin - if: startsWith(github.ref, 'refs/tags/') - uses: peter-evans/create-pull-request@v3 - with: - token: ${{ secrets.GH_HOMEBREW_MARTIN_TOKEN }} - commit-message: "Update to ${{ github.ref }}" - title: "Update to ${{ github.ref }}" - body: "Update to ${{ github.ref }}" - branch: "update-to-${{ github.ref }}" - branch-suffix: timestamp - base: "main" - labels: "auto-update" - assignees: "nyurik" - draft: false - delete-branch: true - path: target/homebrew - - # This final step is needed to mark the whole workflow as successful - # Don't change its name - it is used by the merge protection rules - done: - name: CI Finished - runs-on: ubuntu-latest - needs: [ package ] - steps: - - name: Finished - run: echo "CI finished successfully" diff --git a/.github/workflows/dependabot.yml b/.github/workflows/dependabot.yml deleted file mode 100644 index 4e7dfc47f..000000000 --- a/.github/workflows/dependabot.yml +++ /dev/null @@ -1,27 +0,0 @@ -name: Dependabot auto-merge -on: pull_request - -permissions: write-all - -jobs: - dependabot: - runs-on: ubuntu-latest - if: ${{ github.actor == 'dependabot[bot]' }} - steps: - - name: Dependabot metadata - id: metadata - uses: dependabot/fetch-metadata@v1.6.0 - with: - github-token: "${{ secrets.GITHUB_TOKEN }}" - - name: Approve Dependabot PRs - if: ${{steps.metadata.outputs.update-type == 'version-update:semver-patch'}} - run: gh pr review --approve "$PR_URL" - env: - PR_URL: ${{github.event.pull_request.html_url}} - GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} - - name: Enable auto-merge for Dependabot PRs - if: ${{steps.metadata.outputs.update-type == 'version-update:semver-patch'}} - run: gh pr merge --auto --squash "$PR_URL" - env: - PR_URL: ${{github.event.pull_request.html_url}} - GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} diff --git a/.github/workflows/grcov.yml b/.github/workflows/grcov.yml deleted file mode 100644 index a79833858..000000000 --- a/.github/workflows/grcov.yml +++ /dev/null @@ -1,78 +0,0 @@ -name: Code coverage - -on: - push: - branches: [ main ] - paths-ignore: - - '**.md' - - 'demo/**' - - 'docs/**' - pull_request: - branches: [ main ] - paths-ignore: - - '**.md' - - 'demo/**' - - 'docs/**' - workflow_dispatch: - -jobs: - grcov: - runs-on: ubuntu-latest - env: - # PG_* variables are used by psql - PGDATABASE: test - PGHOST: localhost - PGUSER: postgres - services: - postgres: - image: postgis/postgis:14-3.3-alpine - env: - # POSTGRES_* variables are used by the postgis/postgres image - POSTGRES_DB: ${{ env.PGDATABASE }} - POSTGRES_USER: ${{ env.PGUSER }} - POSTGRES_HOST_AUTH_METHOD: trust - ports: - # will assign a random free host port - - 5432/tcp - # needed because the postgres container does not provide a healthcheck - options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 - steps: - - name: Checkout sources - uses: actions/checkout@v4 - - uses: Swatinem/rust-cache@v2 - - - name: Setup database - run: | - sudo apt-get install postgresql-client - tests/fixtures/initdb.sh - env: - PGPORT: ${{ job.services.postgres.ports[5432] }} - - - name: Install nightly toolchain - uses: dtolnay/rust-toolchain@master - with: - toolchain: nightly - override: true - - - name: Run tests - run: cargo test - env: - CARGO_INCREMENTAL: '0' - RUSTFLAGS: '-Zprofile -Ccodegen-units=1 -Cinline-threshold=0 -Clink-dead-code -Coverflow-checks=off -Cpanic=abort -Zpanic_abort_tests' - RUSTDOCFLAGS: '-Zprofile -Ccodegen-units=1 -Cinline-threshold=0 -Clink-dead-code -Coverflow-checks=off -Cpanic=abort -Zpanic_abort_tests' - DATABASE_URL: postgres://${{ env.PGUSER }}@${{ env.PGHOST }}:${{ job.services.postgres.ports[5432] }}/${{ env.PGDATABASE }} - - - name: Gather coverage data - id: coverage - uses: actions-rs/grcov@v0.1 - - - name: Codecov upload - uses: codecov/codecov-action@v3 - with: - file: ${{ steps.coverage.outputs.report }} - - - name: Check conditional cfg values - run: | - cargo +nightly check -Z unstable-options -Z check-cfg=features,names,values,output --workspace - env: - RUSTFLAGS: '-D warnings' diff --git a/.github/workflows/homebrew.yml b/.github/workflows/homebrew.yml new file mode 100644 index 000000000..bf01a900c --- /dev/null +++ b/.github/workflows/homebrew.yml @@ -0,0 +1,21 @@ +name: Homebrew + +on: [pull_request] + +jobs: + test: + runs-on: macos-latest + + steps: + - run: brew version +# - name: Checkout code +# uses: actions/checkout@v2 +# +# - name: Set up Homebrew +# run: | +# brew update +# brew install --build-bottle formula # Replace 'formula' with the name of your formula +# +# - name: Test Formula Installation +# run: | +# brew install --verbose formula # Replace 'formula' with the name of your formula From 268429bb351009a1a8207336aa4222051d90a747 Mon Sep 17 00:00:00 2001 From: Yuri Astrakhan Date: Mon, 2 Oct 2023 00:09:25 -0400 Subject: [PATCH 2/3] wip --- .github/workflows/homebrew.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/homebrew.yml b/.github/workflows/homebrew.yml index bf01a900c..1f2396fe4 100644 --- a/.github/workflows/homebrew.yml +++ b/.github/workflows/homebrew.yml @@ -7,7 +7,10 @@ jobs: runs-on: macos-latest steps: - - run: brew version + - run: brew --version + - run: brew tap maplibre/martin https://github.com/maplibre/martin.git + - run: brew install maplibre/martin/martin + # - name: Checkout code # uses: actions/checkout@v2 # From 0f8951163266ff2860f1eda1272a660b3e5a30c9 Mon Sep 17 00:00:00 2001 From: Yuri Astrakhan Date: Thu, 12 Oct 2023 14:03:23 -0400 Subject: [PATCH 3/3] wip --- .github/workflows/homebrew.yml | 57 ++++++++++++++++++++++++++++++++-- 1 file changed, 55 insertions(+), 2 deletions(-) diff --git a/.github/workflows/homebrew.yml b/.github/workflows/homebrew.yml index 1f2396fe4..e0d430e51 100644 --- a/.github/workflows/homebrew.yml +++ b/.github/workflows/homebrew.yml @@ -8,8 +8,61 @@ jobs: steps: - run: brew --version - - run: brew tap maplibre/martin https://github.com/maplibre/martin.git - - run: brew install maplibre/martin/martin + - run: brew tap maplibre/martin + - run: brew install martin + + - name: Checkout maplibre/homebrew-martin + # if: startsWith(github.ref, 'refs/tags/') + uses: actions/checkout@v4 + with: + repository: maplibre/homebrew-martin + token: ${{ secrets.GH_HOMEBREW_MARTIN_TOKEN }} + path: target/homebrew + + - name: Create Homebrew config + # if: startsWith(github.ref, 'refs/tags/v') + run: | + set -x + + # Extract Github release version only without the "v" prefix + MARTIN_VERSION=$(echo "refs/tags/v0.9.4" | sed -e 's/refs\/tags\/v//') + + mkdir -p target/homebrew + cd target + + cat << EOF > homebrew_config.yaml + version: "$MARTIN_VERSION" + macos_arm_sha256: "TEST_macos_arm_sha256" + macos_intel_sha256: "TEST_macos_intel_sha256" + linux_arm_sha256: "TEST_linux_arm_sha256" + linux_intel_sha256: "TEST_linux_intel_sha256" + EOF + + - name: Create Homebrew formula + # if: startsWith(github.ref, 'refs/tags/') + uses: cuchi/jinja2-action@v1.2.0 + with: + template: .github/templates/homebrew.martin.rb.j2 + output_file: target/homebrew/martin.rb + data_file: target/homebrew_config.yaml + + - name: Create a PR for maplibre/homebrew-martin + # if: startsWith(github.ref, 'refs/tags/') + uses: peter-evans/create-pull-request@v3 + with: + token: ${{ secrets.GH_HOMEBREW_MARTIN_TOKEN }} + commit-message: "Update to ${{ github.ref }}" + title: "Update to ${{ github.ref }}" + body: "Update to ${{ github.ref }}" + branch: "update-to-${{ github.ref }}" + branch-suffix: timestamp + base: "main" + labels: "auto-update" + assignees: "nyurik" + draft: false + delete-branch: true + path: target/homebrew + # - name: Checkout code # uses: actions/checkout@v2