Skip to content

Merge pull request #175 from BlueAndi/dependabot/github_actions/dot-g… #435

Merge pull request #175 from BlueAndi/dependabot/github_actions/dot-g…

Merge pull request #175 from BlueAndi/dependabot/github_actions/dot-g… #435

Workflow file for this run

name: master
# Controls when the action will run.
on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
release:
# A release, pre-release, or draft of a release is published.
types: [ published ]
# Allows you to run this workflow manually from the Actions tab.
workflow_dispatch:
# A workflow run is made up of one or more jobs that can run sequentially or in parallel.
jobs:
# The introduction just shows some useful informations.
intro:
# The type of runner that the job will run on.
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job.
steps:
- run: echo "The job was automatically triggered by a ${{ github.event_name }} event."
- run: echo "The name of the branch is ${{ github.ref }} and the repository is ${{ github.repository }}."
# Build all targets
build:
# The type of runner that the job will run on.
runs-on: ubuntu-latest
needs: intro
strategy:
matrix:
environment: ["adafruit_feather_esp32_v2", "az-delivery-devkit-v4", "esp32doit-devkit-v1", "esp32-nodemcu", "lilygo-ttgo-t-display", "lilygo-t-display-s3", "m5stack_core", "ulanzi-tc001", "wemos_lolin_s2_mini"]
# Steps represent a sequence of tasks that will be executed as part of the job.
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Cache pip
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Cache PlatformIO
uses: actions/cache@v3
with:
path: ~/.platformio
key: ${{ runner.os }}-${{ hashFiles('**/lockfiles') }}
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.9'
- name: Install PlatformIO
run: |
python -m pip install --upgrade pip
pip install --upgrade platformio
- name: Create release artifcats folder
if: startsWith(github.ref_type, 'refs/tags/v')
run: |
mkdir ${{ github.workspace }}/artifacts
- name: Compile ${{ matrix.environment }} firmware
run: platformio run --environment ${{ matrix.environment }}
- name: Build ${{ matrix.environment }} filesystem image
run: platformio run --environment ${{ matrix.environment }} --target buildfs
- name: Deploy ${{ matrix.environment }}
if: startsWith(github.ref_type, 'refs/tags/v')
uses: actions/upload-artifact@v2
with:
name: ${{ matrix.environment }}
path: |
${{ github.workspace }}/.pio/build/${{ matrix.environment }}/firmware.bin
${{ github.workspace }}/.pio/build/${{ matrix.environment }}/spiffs.bin
${{ github.workspace }}/.pio/build/${{ matrix.environment }}/littlefs.bin
retention-days: 5
# Perform static checks
check:
# The type of runner that the job will run on.
runs-on: ubuntu-latest
needs: intro
strategy:
matrix:
environment: ["adafruit_feather_esp32_v2", "az-delivery-devkit-v4", "esp32doit-devkit-v1", "esp32-nodemcu", "lilygo-ttgo-t-display", "lilygo-t-display-s3", "m5stack_core", "ulanzi-tc001", "wemos_lolin_s2_mini"]
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Cache pip
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Cache PlatformIO
uses: actions/cache@v3
with:
path: ~/.platformio
key: ${{ runner.os }}-${{ hashFiles('**/lockfiles') }}
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.9'
- name: Install PlatformIO
run: |
python -m pip install --upgrade pip
pip install --upgrade platformio
- name: Perform static checks on ${{ matrix.environment }}
run: platformio check --environment ${{ matrix.environment }} --fail-on-defect=medium --fail-on-defect=high
# Perform tests
test:
# The type of runner that the job will run on.
runs-on: ubuntu-latest
needs: intro
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Cache pip
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Cache PlatformIO
uses: actions/cache@v3
with:
path: ~/.platformio
key: ${{ runner.os }}-${{ hashFiles('**/lockfiles') }}
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.9'
- name: Install PlatformIO
run: |
python -m pip install --upgrade pip
pip install --upgrade platformio
- name: Run tests on native environment
run: platformio test --environment test
# Build documentation
doc:
# The type of runner that the job will run on.
runs-on: ubuntu-latest
needs: intro
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Cache pip
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Cache PlatformIO
uses: actions/cache@v3
with:
path: ~/.platformio
key: ${{ runner.os }}-${{ hashFiles('**/lockfiles') }}
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.9'
- name: Install PlatformIO
run: |
python -m pip install --upgrade pip
pip install --upgrade platformio
- name: Set up graphviz
uses: ts-graphviz/setup-graphviz@v1.2.0
- name: Set up doxygen and generate documentation
uses: mattnotmitt/doxygen-action@v1.9.5
with:
working-directory: './doc/doxygen'
doxyfile-path: './Doxyfile'
# Deploy release artifacts
deploy:
if: startsWith(github.ref_type, 'refs/tags/v')
# The type of runner that the job will run on.
runs-on: ubuntu-latest
needs: [build, check, doc]
steps:
- name: Deploy release artifacts
uses: actions/download-artifact@v4.1.7
with:
path: ${{ github.workspace }}/artifacts
- name: Display structure of release artifacts
run: ls -R
working-directory: ${{ github.workspace }}/artifacts
- name: Zip release artifacts folder
run: zip -rj ${{ github.event.repository.name }}-${{ github.event.release.tag_name }}.zip .
working-directory: ${{ github.workspace }}/artifacts
- name: Release
uses: softprops/action-gh-release@v1
with:
files: ${{ github.workspace }}/artifacts/${{ github.event.repository.name }}-${{ github.event.release.tag_name }}.zip
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}