feat: add OpenTelemetry attributes to the metrics backend #46
Workflow file for this run
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: | |
pull_request: | |
push: | |
branches: ['**'] | |
tags: [v*] | |
jobs: | |
ci: | |
# run on 1) push, 2) external PRs, 3) softwaremill-ci PRs | |
# do not run on internal, non-steward PRs since those will be run by push to branch | |
if: | | |
github.event_name == 'push' || | |
github.event.pull_request.head.repo.full_name != github.repository || | |
github.event.pull_request.user.login == 'softwaremill-ci' | |
runs-on: ubuntu-20.04 | |
strategy: | |
fail-fast: false | |
matrix: | |
scala-version: [ "2.12", "2.13", "3" ] | |
target-platform: [ "JVM", "JS", "Native" ] | |
java: [ "11", "21" ] | |
exclude: | |
- java: "21" | |
include: # Restricted to build only specific Loom-based modules | |
- scala-version: "3" | |
target-platform: "JVM" | |
java: "21" | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Set up JDK | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'temurin' | |
cache: 'sbt' | |
java-version: ${{ matrix.java }} | |
- name: Cache sbt | |
uses: actions/cache@v2 | |
with: | |
path: | | |
~/.sbt | |
~/.ivy2/cache | |
~/.coursier | |
key: sbt-cache-${{ runner.os }}-${{ matrix.target-platform }}-${{ hashFiles('project/build.properties') }} | |
- name: Install libidn2-dev libcurl3-dev | |
if: matrix.target-platform == 'Native' | |
run: | | |
sudo apt-get update | |
sudo apt-get install libidn2-dev libcurl3-dev | |
echo "STTP_NATIVE=1" >> $GITHUB_ENV | |
- name: Enable Loom-specific modules | |
if: matrix.java == '21' | |
run: echo "ONLY_LOOM=1" >> $GITHUB_ENV | |
- name: Compile | |
run: sbt -v "compileScoped ${{ matrix.scala-version }} ${{ matrix.target-platform }}" | |
- name: Compile documentation | |
if: matrix.target-platform == 'JVM' && matrix.java == '11' | |
run: sbt -v compileDocs | |
- name: Test | |
run: sbt -v "testScoped ${{ matrix.scala-version }} ${{ matrix.target-platform }}" | |
- name: Prepare release notes | |
if: matrix.java == '11' | |
uses: release-drafter/release-drafter@v5 | |
with: | |
config-name: release-drafter.yml | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Cleanup | |
run: | | |
rm -rf "$HOME/.ivy2/local" || true | |
find $HOME/.ivy2/cache -name "ivydata-*.properties" -delete || true | |
find $HOME/.ivy2/cache -name "*-LM-SNAPSHOT*" -delete || true | |
find $HOME/.cache/coursier/v1 -name "ivydata-*.properties" -delete || true | |
find $HOME/.sbt -name "*.lock" -delete || true | |
mima: | |
# run on 1) push, 2) external PRs, 3) softwaremill-ci PRs | |
# do not run on internal, non-steward PRs since those will be run by push to branch | |
if: | | |
github.event_name == 'push' || | |
github.event.pull_request.head.repo.full_name != github.repository || | |
github.event.pull_request.user.login == 'softwaremill-ci' | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
with: | |
fetch-depth: 0 # checkout tags so that dynver works properly (we need the version for MiMa) | |
- name: Set up JDK 11 | |
uses: actions/setup-java@v1 | |
with: | |
java-version: 11 | |
- name: Cache sbt | |
uses: actions/cache@v2 | |
with: | |
path: | | |
~/.sbt | |
~/.ivy2/cache | |
~/.coursier | |
key: sbt-cache-${{ runner.os }}-JVM-${{ hashFiles('project/build.properties') }} | |
- name: Check MiMa # disable for major releases | |
run: sbt -v mimaReportBinaryIssues | |
- name: Cleanup | |
run: | | |
rm -rf "$HOME/.ivy2/local" || true | |
find $HOME/.ivy2/cache -name "ivydata-*.properties" -delete || true | |
find $HOME/.ivy2/cache -name "*-LM-SNAPSHOT*" -delete || true | |
find $HOME/.cache/coursier/v1 -name "ivydata-*.properties" -delete || true | |
find $HOME/.sbt -name "*.lock" -delete || true | |
publish: | |
name: Publish release | |
needs: [ci] | |
if: github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v')) | |
runs-on: ubuntu-22.04 | |
strategy: | |
matrix: | |
java: [ "11", "21" ] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Set up JDK | |
uses: actions/setup-java@v4 | |
with: | |
distribution: 'temurin' | |
java-version: ${{ matrix.java }} | |
cache: 'sbt' | |
- name: Cache sbt | |
uses: actions/cache@v2 | |
with: | |
path: | | |
~/.sbt | |
~/.ivy2/cache | |
~/.coursier | |
key: sbt-cache-release-${{ runner.os }}-${{ hashFiles('project/build.properties') }} | |
- name: Install libidn2-dev libcurl3-dev | |
run: | | |
sudo apt-get update | |
sudo apt-get install libidn2-dev libcurl3-dev | |
- name: Enable Native-specific modules | |
if: matrix.java == '11' | |
run: echo "STTP_NATIVE=1" >> $GITHUB_ENV | |
- name: Enable Loom-specific modules | |
if: matrix.java == '21' | |
run: echo "ONLY_LOOM=1" >> $GITHUB_ENV | |
- name: Compile | |
run: sbt compile | |
- name: Publish artifacts | |
run: sbt ci-release | |
env: | |
PGP_PASSPHRASE: ${{ secrets.PGP_PASSPHRASE }} | |
PGP_SECRET: ${{ secrets.PGP_SECRET }} | |
SONATYPE_USERNAME: ${{ secrets.SONATYPE_USERNAME }} | |
SONATYPE_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }} | |
- name: Extract version from commit message | |
if: matrix.java == '11' | |
run: | | |
version=${GITHUB_REF/refs\/tags\/v/} | |
echo "VERSION=$version" >> $GITHUB_ENV | |
env: | |
COMMIT_MSG: ${{ github.event.head_commit.message }} | |
- name: Publish release notes | |
if: matrix.java == '11' | |
uses: release-drafter/release-drafter@v5 | |
with: | |
config-name: release-drafter.yml | |
publish: true | |
name: "v${{ env.VERSION }}" | |
tag: "v${{ env.VERSION }}" | |
version: "v${{ env.VERSION }}" | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Cleanup | |
run: | | |
rm -rf "$HOME/.ivy2/local" || true | |
find $HOME/.ivy2/cache -name "ivydata-*.properties" -delete || true | |
find $HOME/.ivy2/cache -name "*-LM-SNAPSHOT*" -delete || true | |
find $HOME/.cache/coursier/v1 -name "ivydata-*.properties" -delete || true | |
find $HOME/.sbt -name "*.lock" -delete || true | |
# `automerge` label is attached iff there is exactly one file changed by steward and this file belongs to a | |
# whitelist specified by `labeler.yml` | |
label: | |
name: Attach automerge label | |
# only for PRs by softwaremill-ci | |
if: github.event.pull_request.user.login == 'softwaremill-ci' | |
runs-on: ubuntu-22.04 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 2 | |
# count number of files changed | |
- name: Count number of files changed | |
id: count-changed-files | |
run: | | |
N=$(git diff --name-only -r HEAD^1 HEAD | wc -w) | |
echo "changed_files_num=$N" >> $GITHUB_OUTPUT | |
- name: Launch labeler | |
# skip if more than one file changed | |
if: steps.count-changed-files.outputs.changed_files_num == 1 | |
uses: srvaroa/labeler@master | |
env: | |
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" | |
auto-merge: | |
name: Auto merge | |
# only for PRs by softwaremill-ci | |
if: github.event.pull_request.user.login == 'softwaremill-ci' | |
needs: [ ci, mima, label ] | |
runs-on: ubuntu-22.04 | |
steps: | |
- id: automerge | |
name: automerge | |
uses: "pascalgn/automerge-action@v0.15.6" | |
env: | |
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" | |
MERGE_METHOD: "squash" |