mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
19102: gh-actions: report release-tests result to Matrix r=maribu a=miri64 19128: boards: common: stdio_cdc_acm: let tests wait a bit for serial port r=miri64 a=miri64 19133: makefiles/utils/strings.mk: Fix version_is_greater_or_equal r=maribu a=maribu ### Contribution description The Makefile function `version_is_greater_or_equal` is used to check if a version of GNU Make is at least the required one. However, it has the built-in assumption the version numbers have to format x.y.z, but Alpine Linux currently ships GNU Make 4.4. This results in `$(call _pad_number,3,)` which runs `printf '$03d' ''` in the shell, which is not valid. This fixes the issue by making `_pad_number` more robust by fall back to printing `0` with the given padding, if the number given to print is empty. ### Testing procedure Append ```Makefile $(info A=$(call version_is_greater_or_equal,4.2.0,4.2.0)) $(info B=$(call version_is_greater_or_equal,4.2,4.2.0)) $(info C=$(call version_is_greater_or_equal,4.1,4.2.0)) $(info D=$(call version_is_greater_or_equal,4.1.9,4.2.0)) $(info E=$(call version_is_greater_or_equal,5.1.9,4.2.0)) $(info F=$(call version_is_greater_or_equal,5.0.0,4.2.0)) $(info G=$(call version_is_greater_or_equal,4.2.1,4.2.0)) $(info H=$(call version_is_greater_or_equal,4.3.1,4.2.0)) ``` e.g. to `makefiles/utils/strings.mk`, build something and observe the info output. This yields ``` A=1 B=1 C= D= E=1 F=1 G=1 H=1 ``` for me and does not complain about invalid `printf` invocations. ### Issues/PRs references None Co-authored-by: Martine Lenders <m.lenders@fu-berlin.de> Co-authored-by: Marian Buschsieweke <marian.buschsieweke@ovgu.de>
This commit is contained in:
commit
1dcccdc99a
22
.github/workflows/release-test.yml
vendored
22
.github/workflows/release-test.yml
vendored
@ -123,6 +123,7 @@ jobs:
|
|||||||
sudo apt-get install lib32asan6
|
sudo apt-get install lib32asan6
|
||||||
- name: Run release tests
|
- name: Run release tests
|
||||||
timeout-minutes: 350
|
timeout-minutes: 350
|
||||||
|
id: tests
|
||||||
run: |
|
run: |
|
||||||
RIOTBASE="$GITHUB_WORKSPACE/RIOT"
|
RIOTBASE="$GITHUB_WORKSPACE/RIOT"
|
||||||
TOX_ARGS=""
|
TOX_ARGS=""
|
||||||
@ -173,6 +174,27 @@ jobs:
|
|||||||
mkdir test-reports/
|
mkdir test-reports/
|
||||||
junit2html ${REPORT_XML} ${REPORT_NAME}.html
|
junit2html ${REPORT_XML} ${REPORT_NAME}.html
|
||||||
cp ${REPORT_XML} ${REPORT_NAME}.xml
|
cp ${REPORT_XML} ${REPORT_NAME}.xml
|
||||||
|
- name: Generate result message
|
||||||
|
if: always()
|
||||||
|
id: generate_results
|
||||||
|
run: |
|
||||||
|
if [ "${{ steps.tests.conclusion }}" == "success" ]; then
|
||||||
|
nice_str=echo "✅ **PASSED**"
|
||||||
|
elif [ "${{ steps.tests.conclusion }}" == "failure" ]; then
|
||||||
|
nice_str="❌ **FAILED**"
|
||||||
|
fi
|
||||||
|
echo "nice_str=${nice_str}" >> ${GITHUB_OUTPUT}
|
||||||
|
- name: Report to Matrix channel
|
||||||
|
if: ${{ always() && steps.generate_results.outputs.nice_str != '' }}
|
||||||
|
uses: fadenb/matrix-chat-message@v0.0.6
|
||||||
|
with:
|
||||||
|
homeserver: matrix.org
|
||||||
|
token: ${{ secrets.RIOT_CI_MATRIX_TOKEN }}
|
||||||
|
channel: '!UXNJuMzHTSAnwntbbN:utwente.io'
|
||||||
|
message: |
|
||||||
|
${{ steps.generate_results.outputs.nice_str}}: Release tests
|
||||||
|
[${{ matrix.pytest_mark }}, ${{ matrix.sudo }}] on "*${{ github.event_name }}*":
|
||||||
|
${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}
|
||||||
- uses: actions/upload-artifact@v2
|
- uses: actions/upload-artifact@v2
|
||||||
if: always()
|
if: always()
|
||||||
with:
|
with:
|
||||||
|
@ -8,4 +8,9 @@ ifeq (,$(filter-out stdio_cdc_acm,$(filter stdio_% slipdev_stdio,$(USEMODULE))))
|
|||||||
USEMODULE += stdio_cdc_acm
|
USEMODULE += stdio_cdc_acm
|
||||||
endif
|
endif
|
||||||
FEATURES_REQUIRED += highlevel_stdio
|
FEATURES_REQUIRED += highlevel_stdio
|
||||||
|
|
||||||
|
# Enforce tests to wait a bit for the serial port after reset
|
||||||
|
TERM_DELAY ?= 2
|
||||||
|
TESTRUNNER_CONNECT_DELAY ?= $(TERM_DELAY)
|
||||||
|
$(call target-export-variables,test,TESTRUNNER_CONNECT_DELAY)
|
||||||
endif
|
endif
|
||||||
|
@ -7,8 +7,8 @@ lowercase = $(subst A,a,$(subst B,b,$(subst C,c,$(subst D,d,$(subst E,e,$(subst
|
|||||||
uppercase = $(subst a,A,$(subst b,B,$(subst c,C,$(subst d,D,$(subst e,E,$(subst f,F,$(subst g,G,$(subst h,H,$(subst i,I,$(subst j,J,$(subst k,K,$(subst l,L,$(subst m,M,$(subst n,N,$(subst o,O,$(subst p,P,$(subst q,Q,$(subst r,R,$(subst s,S,$(subst t,T,$(subst u,U,$(subst v,V,$(subst w,W,$(subst x,X,$(subst y,Y,$(subst z,Z,$1))))))))))))))))))))))))))
|
uppercase = $(subst a,A,$(subst b,B,$(subst c,C,$(subst d,D,$(subst e,E,$(subst f,F,$(subst g,G,$(subst h,H,$(subst i,I,$(subst j,J,$(subst k,K,$(subst l,L,$(subst m,M,$(subst n,N,$(subst o,O,$(subst p,P,$(subst q,Q,$(subst r,R,$(subst s,S,$(subst t,T,$(subst u,U,$(subst v,V,$(subst w,W,$(subst x,X,$(subst y,Y,$(subst z,Z,$1))))))))))))))))))))))))))
|
||||||
uppercase_and_underscore = $(call uppercase,$(subst -,_,$1))
|
uppercase_and_underscore = $(call uppercase,$(subst -,_,$1))
|
||||||
|
|
||||||
# Padds $2 number to $1 digits
|
# Padds number $2 to $1 digits. If $2 is empty, zero will be printed instead.
|
||||||
_pad_number = $(shell printf '%0$1d' $2)
|
_pad_number = $(shell printf '%0$1d' $(if $2,$2,0))
|
||||||
|
|
||||||
# Gets major, minor, patch from 'major.minor.patch', e.g.: 4.2.1 by index
|
# Gets major, minor, patch from 'major.minor.patch', e.g.: 4.2.1 by index
|
||||||
# $1: index
|
# $1: index
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from riotctrl.ctrl import RIOTCtrl
|
from riotctrl.ctrl import RIOTCtrl
|
||||||
@ -15,6 +16,8 @@ from riotctrl.shell.json import RapidJSONShellInteractionParser, rapidjson
|
|||||||
|
|
||||||
from riotctrl_shell.congure_test import CongureTest
|
from riotctrl_shell.congure_test import CongureTest
|
||||||
|
|
||||||
|
from testrunner.spawn import MAKE_TERM_CONNECT_DELAY
|
||||||
|
|
||||||
|
|
||||||
class TestCongUREBase(unittest.TestCase):
|
class TestCongUREBase(unittest.TestCase):
|
||||||
# pylint: disable=too-many-public-methods
|
# pylint: disable=too-many-public-methods
|
||||||
@ -25,6 +28,7 @@ class TestCongUREBase(unittest.TestCase):
|
|||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
cls.ctrl = RIOTCtrl()
|
cls.ctrl = RIOTCtrl()
|
||||||
cls.ctrl.reset()
|
cls.ctrl.reset()
|
||||||
|
time.sleep(MAKE_TERM_CONNECT_DELAY)
|
||||||
cls.ctrl.start_term()
|
cls.ctrl.start_term()
|
||||||
if cls.DEBUG:
|
if cls.DEBUG:
|
||||||
cls.ctrl.term.logfile = sys.stdout
|
cls.ctrl.term.logfile = sys.stdout
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from riotctrl.ctrl import RIOTCtrl
|
from riotctrl.ctrl import RIOTCtrl
|
||||||
@ -15,6 +16,8 @@ from riotctrl.shell.json import RapidJSONShellInteractionParser, rapidjson
|
|||||||
|
|
||||||
from riotctrl_shell.congure_test import CongureTest
|
from riotctrl_shell.congure_test import CongureTest
|
||||||
|
|
||||||
|
from testrunner.spawn import MAKE_TERM_CONNECT_DELAY
|
||||||
|
|
||||||
|
|
||||||
class TestCongUREBase(unittest.TestCase):
|
class TestCongUREBase(unittest.TestCase):
|
||||||
DEBUG = False
|
DEBUG = False
|
||||||
@ -25,6 +28,7 @@ class TestCongUREBase(unittest.TestCase):
|
|||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
cls.ctrl = RIOTCtrl()
|
cls.ctrl = RIOTCtrl()
|
||||||
cls.ctrl.reset()
|
cls.ctrl.reset()
|
||||||
|
time.sleep(MAKE_TERM_CONNECT_DELAY)
|
||||||
cls.ctrl.start_term()
|
cls.ctrl.start_term()
|
||||||
if cls.DEBUG:
|
if cls.DEBUG:
|
||||||
cls.ctrl.term.logfile = sys.stdout
|
cls.ctrl.term.logfile = sys.stdout
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from riotctrl.ctrl import RIOTCtrl
|
from riotctrl.ctrl import RIOTCtrl
|
||||||
@ -15,6 +16,8 @@ from riotctrl.shell.json import RapidJSONShellInteractionParser, rapidjson
|
|||||||
|
|
||||||
from riotctrl_shell.congure_test import CongureTest
|
from riotctrl_shell.congure_test import CongureTest
|
||||||
|
|
||||||
|
from testrunner.spawn import MAKE_TERM_CONNECT_DELAY
|
||||||
|
|
||||||
|
|
||||||
class TestCongUREBase(unittest.TestCase):
|
class TestCongUREBase(unittest.TestCase):
|
||||||
# pylint: disable=too-many-public-methods
|
# pylint: disable=too-many-public-methods
|
||||||
@ -25,6 +28,7 @@ class TestCongUREBase(unittest.TestCase):
|
|||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
cls.ctrl = RIOTCtrl()
|
cls.ctrl = RIOTCtrl()
|
||||||
cls.ctrl.reset()
|
cls.ctrl.reset()
|
||||||
|
time.sleep(MAKE_TERM_CONNECT_DELAY)
|
||||||
cls.ctrl.start_term()
|
cls.ctrl.start_term()
|
||||||
if cls.DEBUG:
|
if cls.DEBUG:
|
||||||
cls.ctrl.term.logfile = sys.stdout
|
cls.ctrl.term.logfile = sys.stdout
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from riotctrl.ctrl import RIOTCtrl
|
from riotctrl.ctrl import RIOTCtrl
|
||||||
@ -17,6 +18,8 @@ from riotctrl.shell.json import RapidJSONShellInteractionParser, rapidjson
|
|||||||
|
|
||||||
from riotctrl_shell.congure_test import CongureTest
|
from riotctrl_shell.congure_test import CongureTest
|
||||||
|
|
||||||
|
from testrunner.spawn import MAKE_TERM_CONNECT_DELAY
|
||||||
|
|
||||||
|
|
||||||
class TestCongUREBase(unittest.TestCase):
|
class TestCongUREBase(unittest.TestCase):
|
||||||
DEBUG = False
|
DEBUG = False
|
||||||
@ -25,6 +28,7 @@ class TestCongUREBase(unittest.TestCase):
|
|||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
cls.ctrl = RIOTCtrl()
|
cls.ctrl = RIOTCtrl()
|
||||||
cls.ctrl.reset()
|
cls.ctrl.reset()
|
||||||
|
time.sleep(MAKE_TERM_CONNECT_DELAY)
|
||||||
cls.ctrl.start_term()
|
cls.ctrl.start_term()
|
||||||
if cls.DEBUG:
|
if cls.DEBUG:
|
||||||
cls.ctrl.term.logfile = sys.stdout
|
cls.ctrl.term.logfile = sys.stdout
|
||||||
|
Loading…
Reference in New Issue
Block a user