aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoel Challis <git@zvecr.com>2019-10-14 17:57:53 +0100
committerGitHub <noreply@github.com>2019-10-14 17:57:53 +0100
commite1de0d74a6f6c4bdc762b32fb78e449aed0fcecb (patch)
tree677c27ec4e19b5a2c398ce66fa7885765377f957
parent6560dffc05131c05655f8e0d74cc65c5918894fa (diff)
downloadqmk_firmware-e1de0d74a6f6c4bdc762b32fb78e449aed0fcecb.tar.gz
qmk_firmware-e1de0d74a6f6c4bdc762b32fb78e449aed0fcecb.zip
Move running pytest to travis_test (#7005)
-rwxr-xr-xutil/travis_build.sh10
-rw-r--r--util/travis_test.sh36
2 files changed, 27 insertions, 19 deletions
diff --git a/util/travis_build.sh b/util/travis_build.sh
index 2bc1ccd62..225c8548f 100755
--- a/util/travis_build.sh
+++ b/util/travis_build.sh
@@ -1,6 +1,6 @@
1#!/bin/bash 1#!/bin/bash
2 2
3# if docker is installed - call make within the qmk docker image 3# if docker is installed - patch calls to within the qmk docker image
4if command -v docker >/dev/null; then 4if command -v docker >/dev/null; then
5 function make() { 5 function make() {
6 docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@" 6 docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@"
@@ -52,14 +52,6 @@ if [[ "$TRAVIS_COMMIT_MESSAGE" != *"[skip build]"* ]] ; then
52 fi 52 fi
53 done 53 done
54 fi 54 fi
55 # Check and run python tests if necessary
56 PFM=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -E -e '^(lib/python/)' -e '^(bin/qmk)' | wc -l)
57 if [ $PFM -gt 0 -o "$BRANCH" = "master" ]; then
58 echo
59 echo "Running python tests."
60 docker run --rm -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container 'bin/qmk pytest'
61 : $((exit_code = $exit_code + $?))
62 fi
63 fi 55 fi
64 exit $exit_code 56 exit $exit_code
65fi 57fi
diff --git a/util/travis_test.sh b/util/travis_test.sh
index e6a50ac16..9b7402c28 100644
--- a/util/travis_test.sh
+++ b/util/travis_test.sh
@@ -1,29 +1,45 @@
1#!/bin/bash 1#!/bin/bash
2 2
3# if docker is installed - patch calls to within the qmk docker image
4if command -v docker >/dev/null; then
5 function make() {
6 docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@"
7 }
8 function qmk() {
9 docker run --rm -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container bin/qmk "$@"
10 }
11fi
12
3TRAVIS_COMMIT_MESSAGE="${TRAVIS_COMMIT_MESSAGE:-none}" 13TRAVIS_COMMIT_MESSAGE="${TRAVIS_COMMIT_MESSAGE:-none}"
4TRAVIS_COMMIT_RANGE="${TRAVIS_COMMIT_RANGE:-HEAD~1..HEAD}" 14TRAVIS_COMMIT_RANGE="${TRAVIS_COMMIT_RANGE:-HEAD~1..HEAD}"
5 15
6# test force push 16# test force push
7#TRAVIS_COMMIT_RANGE="c287f1bfc5c8...81f62atc4c1d" 17#TRAVIS_COMMIT_RANGE="c287f1bfc5c8...81f62atc4c1d"
8 18
9NUM_IMPACTING_CHANGES=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -Ecv '^(docs/)')
10BRANCH=$(git rev-parse --abbrev-ref HEAD) 19BRANCH=$(git rev-parse --abbrev-ref HEAD)
20CHANGES=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE})
21
22NUM_CORE_CHANGES=$(echo "$CHANGES" | grep -Ecv -e '^(docs/)' -e '^(keyboards/)' -e '^(layouts/)')
23NUM_PY_CHANGES=$(echo "$CHANGES" | grep -Ec -e '^(lib/python/)' -e '^(bin/qmk)')
11 24
12if [[ "$TRAVIS_COMMIT_MESSAGE" == *"[skip test]"* ]]; then 25if [[ "$TRAVIS_COMMIT_MESSAGE" == *"[skip test]"* ]]; then
13 echo "Skipping due to commit message" 26 echo "Skipping due to commit message"
14 exit 0 27 exit 0
15fi 28fi
16 29
17if [ "$BRANCH" != "master" ] && [ "$NUM_IMPACTING_CHANGES" == "0" ]; then 30exit_code=0
18 echo "Skipping due to changes not impacting tests" 31
19 exit 0 32if [ "$BRANCH" == "master" ] || [ "$NUM_CORE_CHANGES" != "0" ]; then
33 echo "Running tests."
34 make test:all
35 : $((exit_code = $exit_code + $?))
36
20fi 37fi
21 38
22# if docker is installed - call make within the qmk docker image 39if [ "$BRANCH" == "master" ] || [ "$NUM_PY_CHANGES" != "0" ]; then
23if command -v docker >/dev/null; then 40 echo "Running python tests."
24 function make() { 41 qmk pytest
25 docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@" 42 : $((exit_code = $exit_code + $?))
26 }
27fi 43fi
28 44
29make test:all 45exit $exit_code