Skip to content

Test3, fully parameterized #417

Test3, fully parameterized

Test3, fully parameterized #417

Workflow file for this run

name: Arduino CI
# on which event should we start push, pull request or schedule dispatches
on:
- push
- pull_request
# This template runes multiple workflows
jobs:
#############################################################################
# This action sets common variables for the flow and
# identifies the examples to compile
setup:
# we run this on self hosted runner, use labels to be more specific
# add specific names if there are some, otherwise self-hosted, X64, Linux are the default ones
runs-on:
- self-hosted
- X64
- Linux
steps:
# checkout the latest github action code
- name: Checkout actions
uses: actions/checkout@v4
# checkout the latest arduino-cli compiler
- name: Setup Arduino CLI
uses: arduino/setup-arduino-cli@master
# Update the arduino code. Attention this does not setup XMC packages as this are set inside the self hosted runner
# the arduino board support packages can be updated automatically
# the XMC board support package is only linked inside the self hosted runner, which allows
# to use none official and beta versions
- name: Install/Update Arduino Platform
run: |
arduino-cli core update-index
arduino-cli core install "arduino:avr"
arduino-cli core install "infineon:xmc"
# Fetch variables and move them to the GITHUB_OUTPUT and fetch HIL information
- id: set-matrix
run: |
REPO="$(basename "$GITHUB_REPOSITORY")"
echo "repo=$REPO" >> $GITHUB_OUTPUT
export $(xfp-dev arduino workspace-setup project-name)
echo "project=$PROJECTNAME" >> $GITHUB_OUTPUT
cd $GITHUB_WORKSPACE/src/framework/arduino
declare -a data
for x in examples/*;
do
data+=($x);
done;
export mvar=$(jq --compact-output --null-input '$ARGS.positional' --args -- "${data[@]}")
echo matrix_example="$mvar" >> $GITHUB_OUTPUT
cd $GITHUB_WORKSPACE/.github
mfqbn=$(cat ./fqbn.yml | shyaml get-values fqbn | awk '{printf " --fqbn=%s", $0}')
echo "fqbn_example=$mfqbn" >> $GITHUB_OUTPUT
ep=`cat ./fqbn.yml | shyaml get-value hil.example`
export exp=$(jq --compact-output --null-input '$ARGS.positional' --args -- "${ep}")
echo "matrix_hil=$exp" >> $GITHUB_OUTPUT
fq=`cat ./fqbn.yml | shyaml get-value hil.fqbn`
export fqb=$(jq --compact-output --null-input '$ARGS.positional' --args -- "${fq}")
echo "fqbn_hil=$fqb" >> $GITHUB_OUTPUT
cd /opt/runner_support/
./py_checkusb.py --switch repo --namelist $REPO --onoff on
declare -a typelist
declare -a seriallist
mapfile -t typelist < <(./py_checkusb.py --repo ${REPO} --full --batch)
for TYPE in "${typelist[@]}";
do
declare -a serials
readarray -td, serials <<<"$TYPE"
seriallist+=(${serials[2]})
done;
export mser=$(jq --compact-output --null-input '$ARGS.positional' --args -- "${seriallist[@]}")
echo serials_hil="$mser" >> $GITHUB_OUTPUT
# # Cache python pip downloads if we have one for faster access
# - name: Cache pip
# uses: actions/cache@v4
# with:
# path: ~/.cache/pip
# key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
# restore-keys: ${{ runner.os }}-pip-
# # Ditto, cache PlatformIO downloads for faster acces during compilation
# - name: Cache PlatformIO
# uses: actions/cache@v4
# with:
# path: ~/.platformio
# key: ${{ runner.os }}-${{ hashFiles('**/lockfiles') }}
# Connect the GITHUB_OUTPUT to the variables and the workflow output mechanism
outputs:
repo: ${{ steps.set-matrix.outputs.repo }}
project: ${{ steps.set-matrix.outputs.project }}
matrix_example: ${{ steps.set-matrix.outputs.matrix_example }}
fqbn_example: ${{ steps.set-matrix.outputs.fqbn_example }}
matrix_hil: ${{ steps.set-matrix.outputs.matrix_hil }}
fqbn_hil: ${{ steps.set-matrix.outputs.fqbn_hil }}
serials_hil: ${{ steps.set-matrix.outputs.serials_hil }}
#############################################################################
# The build job compiles the sample code for different boards
build-ard:
# wait on first setup run before starting main function
needs: setup
# we run this on self hosted runner, use labels to be more specific
# add specific names if there are some, otherwise self-hosted, X64, Linux are the default ones
runs-on:
- self-hosted
- X64
- Linux
# which combination of sample code and boards should run
# for this example of 2 sample codes and 3 boards a total of 2x3=6 runners have to work.
# if we have only 4 runner then these 4 are started and the last 2 are waiting until they can start
strategy:
matrix:
# List of all examples in the lib to compile
example: ${{ fromJson(needs.setup.outputs.matrix_example) }}
# These are the steps which should run for each combination of fqbn and example code
steps:
# checkout the latest github action code
- name: Checkout actions
uses: actions/checkout@v4
# checkout the latest arduino-cli compiler
- name: Setup Arduino CLI
uses: arduino/setup-arduino-cli@master
# prepare the runner for the repo data
# setup links inside the self hosted runner for correct directory setup
# REPO is the base name of the library which is linked to the right directory structure
# check wether the .arduino15 packages dir is available
# ln -sf $GITHUB_WORKSPACE/$REPO/build/ $HOME/Arduino/libraries/$REPO
- name: Set and check environment, install repos
run: |
export REPO=${{ needs.setup.outputs.repo }}
ln -sfn /opt/XMC-for-Arduino ~/.arduino15/packages/Infineon
mkdir -p "$HOME/Arduino/libraries"
cd $GITHUB_WORKSPACE/
xfp-dev arduino workspace-setup --path $HOME/Arduino/libraries
# Compile the sample code for the selected board and board support package with the arduino compiler
# ln -sf $GITHUB_WORKSPACE/ $HOME/Arduino/libraries/$REPO
- name: Compile Sketch
run: |
export TMPDIR=$HOME/tmp
mkdir -p $TMPDIR
cd $HOME/Arduino/libraries/${{ needs.setup.outputs.project }}
arduino-cli compile ${{ needs.setup.outputs.fqbn_example }} --libraries="." --libraries="$HOME/Arduino/libraries/." ${{ matrix.example }} --verbose
#############################################################################
# The build job compiles the sample code for different boards
build-plt:
# wait on first setup run before starting main function
needs: setup
# we run this on self hosted runner, use labels to be more specific
# add specific names if there are some, otherwise self-hosted, X64, Linux are the default ones
runs-on:
- self-hosted
- X64
- Linux
# which combination of sample code and boards should run
# for this example of 2 sample codes and 3 boards a total of 2x3=6 runners have to work.
# if we have only 4 runner then these 4 are started and the last 2 are waiting until they can start
strategy:
matrix:
# List of all examples in the lib to compile
example: ${{ fromJson(needs.setup.outputs.matrix_example) }}
steps:
# checkout the latest github action code
- name: Checkout actions
uses: actions/checkout@v4
# checkout the latest arduino-cli compiler
- name: Setup Arduino CLI
uses: arduino/setup-arduino-cli@master
# prepare the runner for the repo data
# setup links inside the self hosted runner for correct directory setup
# REPO is the base name of the library which is linked to the right directory structure
# check wether the .arduino15 packages dir is available
# export REPO=${{ needs.setup.outputs.repo }}
# ln -sf $GITHUB_WORKSPACE/$REPO/build/ $HOME/Arduino/libraries/$REPO
- name: Set and check environment, install repos
run: |
ln -sfn /opt/XMC-for-Arduino ~/.arduino15/packages/Infineon
mkdir -p "$HOME/Arduino/libraries"
cd $GITHUB_WORKSPACE/
xfp-dev arduino workspace-setup --path $HOME/Arduino/libraries
- name: Install PlatformIO
run: |
python -m pip install --upgrade pip
pip install --upgrade platformio
platformio platform install -f infineonxmc
platformio platform install -f atmelavr
# PlatformIO uses python for compiling and it does multiple board compiles
# at once. PlatformIO is used here to check compatibility, but is not needed for the the flash step
- name: Run PlatformIO
run: |
cd $HOME/Arduino/libraries/${{ needs.setup.outputs.project }}
# boards="${{ needs.setup.outputs.fqbn_example }}"
# export board=`echo $boards | perl -pe 's/fqbn\=\w+:\w+:/board /gx'`
# export board=`echo $board | perl -ne 'print lc'`
# pio ci --lib="." ${board} --project-option="lib_deps=Wire"
pio ci --lib="." --board=uno --project-option="lib_deps=Wire"
env:
PLATFORMIO_CI_SRC: ${{ matrix.example }}
#############################################################################
# This step allows HIL (Hardware in the loop), therefore
# is searches for the given board/sensor combination and tries to find the actual port
# on the self hosted runner. (see documentation for the board2port finder)
flash:
# We need a successful build before we can run the deploy
needs: [setup, build-ard]
# we run this on self hosted runner, use labels to be more specific
# add specific names if there are some, otherwise self-hosted, X64, Linux are the default ones
runs-on:
- self-hosted
- X64
- Linux
strategy:
# flashing only one by one
max-parallel: 1
# the code to flash
matrix:
# the code to flash
example: ${{ fromJson(needs.setup.outputs.matrix_hil) }}
# board packages we want to run
# attention the matrix spans over the fqbn not platform so that we can choose different boards
# this example compiles each sample code for Arduino Uno, XMC2Go and XMC4700 boards
fqbn: ${{ fromJson(needs.setup.outputs.fqbn_hil) }}
# the serials of the hardware boards
serials: ${{ fromJson(needs.setup.outputs.serials_hil) }}
# These are the steps which should run for each combination of fqbn and example code
steps:
# Compile the code which we want to flash
# REPO: the name of the repository which is also the link name
# check/set the arduino15 package library
# link the repo to the correct place for compiling under arduino-cli
# compile the code with the arduino-cli and export the binary files for flashing
# ln -sf $GITHUB_WORKSPACE/ $HOME/Arduino/libraries/$REPO
- name: Compile Sketch
run: |
export TMPDIR=$HOME/tmp
mkdir -p $TMPDIR
ln -sfn /opt/XMC-for-Arduino ~/.arduino15/packages/Infineon
mkdir -p "$HOME/Arduino/libraries"
cd $HOME/Arduino/libraries/${{ needs.setup.outputs.project }}
arduino-cli compile --clean --log --warnings all \
--fqbn ${{ matrix.fqbn }} \
--libraries="." \
--libraries="$HOME/Arduino/libraries/." ${{ matrix.example }} \
--export-binaries
# Flashes the compiled HEX file onto the selected MCU
# REPO: the name of the repository which is also the link name
# HEXNAME: the board depended name of the HEX files
# SERIAL_NUM: the unique serial number of the hardware board according the board2port.yaml
# DEVICE: the flashing device according the board2port.yaml
# PORT: real PORT name of the attached hardware based on the SERIAL_NUM
# use the python based XMC flasher
- name: Flash
run: |
cd /opt/runner_support/
export HEXNAME=`tr ':' '.' <<<"${{ matrix.fqbn }}"`
declare -a devicelist
devicelist+=($(./py_checkusb.py --serial ${{ matrix.serials }} --batch))
for line in "${devicelist[@]}"; do
if [[ $line =~ $device[1] ]]; then
echo "Line: " $line
readarray -td, device <<<"$line"
echo "Device: " ${device[@]}
fi
done
echo "fqbn: " ${{ matrix.fqbn }}
echo "serials: " ${{ matrix.serials }}
echo "Build HEX name: " $HEXNAME
# for line in "${devicelist[@]}";
# do
# export SERIAL_NUM=${device[0]}
# export HEXNAME=${device[1]}
# export DEVICE=${device[2]}
# export PORT=`./find_usb.sh $SERIAL_NUM`
# echo "Repo name extracted: " ${{ needs.setup.outputs.repo }}
# echo "Real repo name: " ${{ needs.setup.outputs.project }}
# echo "Build HEX name: " $HEXNAME
# echo "Port Serial Num: " $SERIAL_NUM
# echo "Flash device: " $DEVICE
# echo "Port found: " $PORT
# echo "Board type name: " $TYPE
# cd $HOME
# python $HOME/.arduino15/packages/Infineon/hardware/xmc/3.2.0/tools/xmc-flasher.py upload -d $DEVICE -p $PORT -f $HOME/Arduino/libraries/${{ needs.setup.outputs.project }}/${{ matrix.example }}/build/$HEXNAME/*.hex
# /opt/runner_support/py_console.py --port $PORT
# done
- name: Monitor
run: |
cd /opt/runner_support/
echo "Build HEX name: " $HEXNAME
echo "Port Serial Num: " $SERIAL_NUM
echo "Flash device: " $DEVICE
echo "Port found: " $PORT
echo "Board type name: " $TYPE
#export HEXNAME=`tr ':' '.' <<<"${{ matrix.fqbn }}"`
#export SERIAL_NUM=`cat ./board2port.yaml | shyaml get-value $HEXNAME.${{ needs.setup.outputs.repo }}.${{ matrix.port_name}}`
#export DEVICE=`cat ./board2port.yaml | shyaml get-value $HEXNAME.${{ needs.setup.outputs.repo }}.${{ matrix.device}}`
#export PORT=`./find_usb.sh $SERIAL_NUM`
- name: HIL switch off
run: |
cd /opt/runner_support/
REPO="$(basename "$GITHUB_REPOSITORY")"
python py_checkusb.py --switch repo --namelist ${REPO} --onoff off