Skip to content

fix clean state

fix clean state #34

name: Test and Release
# Run this job on all pushes and pull requests
# as well as tags with a semantic version
on:
push:
branches:
- 'master'
tags:
# normal versions
- 'v[0-9]+.[0-9]+.[0-9]+'
# pre-releases
- 'v[0-9]+.[0-9]+.[0-9]+-**'
pull_request: {}
# Cancel previous PR/branch runs when a new commit is pushed
concurrency:
group: ${{ github.ref }}
cancel-in-progress: true
jobs:
# Performs quick checks before the expensive test runs
check-and-lint:
if: contains(github.event.head_commit.message, '[skip ci]') == false
runs-on: ubuntu-latest
steps:
- uses: ioBroker/testing-action-check@v1
with:
node-version: '18.x'
# Uncomment the following line if your adapter cannot be installed using 'npm ci'
# install-command: 'npm install'
lint: true
# Runs adapter tests on all supported node versions and OSes
adapter-tests:
if: contains(github.event.head_commit.message, '[skip ci]') == false
runs-on: ${{ matrix.os }}
strategy:
matrix:
node-version: [16.x, 18.x, 20.x]
os: [ubuntu-latest, windows-latest, macos-latest]
steps:
- uses: ioBroker/testing-action-adapter@v1
with:
node-version: ${{ matrix.node-version }}
os: ${{ matrix.os }}
# TODO: To enable automatic npm releases, create a token on npmjs.org
# Enter this token as a GitHub secret (with name NPM_TOKEN) in the repository options
# Then uncomment the following block:
# # Deploys the final package to NPM
# deploy:
# needs: [adapter-tests]
#
# # Trigger this step only when a commit on any branch is tagged with a version number
# if: |
# contains(github.event.head_commit.message, '[skip ci]') == false &&
# github.event_name == 'push' &&
# startsWith(github.ref, 'refs/tags/v')
#
# runs-on: ubuntu-latest
# strategy:
# matrix:
# node-version: [14.x]
#
# steps:
# - name: Checkout code
# uses: actions/checkout@v2
#
# - name: Use Node.js ${{ matrix.node-version }}
# uses: actions/setup-node@v1
# with:
# node-version: ${{ matrix.node-version }}
#
# - name: Extract the version and commit body from the tag
# id: extract_release
# # The body may be multiline, therefore newlines and % need to be escaped
# run: |
# VERSION="${{ github.ref }}"
# VERSION=${VERSION##*/v}
# echo "::set-output name=VERSION::$VERSION"
# BODY=$(git show -s --format=%b)
# BODY="${BODY//'%'/'%25'}"
# BODY="${BODY//$'\n'/'%0A'}"
# BODY="${BODY//$'\r'/'%0D'}"
# echo "::set-output name=BODY::$BODY"
#
# - name: Publish package to npm
# run: |
# npm config set //registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}
# npm whoami
# npm publish
#
# - name: Create Github Release
# uses: actions/create-release@v1
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# with:
# tag_name: ${{ github.ref }}
# release_name: Release v${{ steps.extract_release.outputs.VERSION }}
# draft: false
# # Prerelease versions create prereleases on Github
# prerelease: ${{ contains(steps.extract_release.outputs.VERSION, '-') }}
# body: ${{ steps.extract_release.outputs.BODY }}
#
# # When using Sentry for error reporting, Sentry could be informed about new releases
# # To enable create a API-Token in Sentry (User settings, API keys)
# # Enter this token as a GitHub secret (with name SENTRY_AUTH_TOKEN) in the repository options
# # Then uncomment and customize the following block:
# #- name: Notify Sentry.io about the release
# # run: |
# # npm i -g @sentry/cli
# # export SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}
# # export SENTRY_URL=https://sentry.iobroker.net
# # export SENTRY_ORG=iobroker
# # export SENTRY_PROJECT=iobroker-ford
# # export SENTRY_VERSION=iobroker.ford@${{ steps.extract_release.outputs.VERSION }}
# # sentry-cli releases new $SENTRY_VERSION
# # sentry-cli releases finalize $SENTRY_VERSION
# # # Add the following line BEFORE finalize if repositories are connected in Sentry
# # #sentry-cli releases set-commits $SENTRY_VERSION --auto
# # # Add the following line BEFORE finalize if sourcemap uploads are needed
# # #sentry-cli releases files $SENTRY_VERSION upload-sourcemaps build/