diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index d79ef849c0..1f65f390ee 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -6,18 +6,17 @@ on: pull_request: env: - RUN: docker run --shm-size 1G --rm tmppilot /bin/sh -c - PERSIST_WITH_CACHE: docker run --shm-size 1G -v /tmp/comma_download_cache:/tmp/comma_download_cache --name tmppilot tmppilot /bin/sh -c - PERSIST: docker run --shm-size 1G --name tmppilot tmppilot /bin/sh -c - CI_RUN: docker run -e GITHUB_ACTION -e GITHUB_REF -e GITHUB_HEAD_REF -e GITHUB_SHA -e GITHUB_REPOSITORY -e GITHUB_RUN_ID --rm tmppilotci /bin/bash -c - UNIT_TEST: coverage run --append -m unittest discover + BASE_IMAGE: openpilot-base + DOCKER_REGISTRY: ghcr.io/commaai + + DOCKER_LOGIN: docker login ghcr.io -u adeebshihadeh -p ${{ secrets.CONTAINER_TOKEN }} BUILD: | - docker pull $(grep -ioP '(?<=^from)\s+\S+' Dockerfile.openpilot_base) || true - docker pull docker.io/commaai/openpilot-base:latest || true - docker build --cache-from docker.io/commaai/openpilot-base:latest -t commaai/openpilot-base:latest -f Dockerfile.openpilot_base . + docker pull $(grep -iohP '(?<=^from)\s+\S+' Dockerfile.openpilot_base) || true + docker pull $DOCKER_REGISTRY/$BASE_IMAGE:latest || true + docker build --cache-from $DOCKER_REGISTRY/$BASE_IMAGE:latest -t $DOCKER_REGISTRY/$BASE_IMAGE:latest -t $BASE_IMAGE:latest -f Dockerfile.openpilot_base . - docker pull docker.io/commaai/openpilotci:latest || true - docker build --cache-from docker.io/commaai/openpilotci:latest -t tmppilot -f Dockerfile.openpilotci . + RUN: docker run --shm-size 1G -v $PWD:/tmp/openpilot -e PYTHONPATH=/tmp/openpilot -e GITHUB_ACTION -e GITHUB_REF -e GITHUB_HEAD_REF -e GITHUB_SHA -e GITHUB_REPOSITORY -e GITHUB_RUN_ID -v /tmp/comma_download_cache:/tmp/comma_download_cache $BASE_IMAGE /bin/sh -c + UNIT_TEST: coverage run --append -m unittest discover jobs: build_release: @@ -25,32 +24,27 @@ jobs: runs-on: ubuntu-20.04 timeout-minutes: 50 env: - TEST_DIR: tmppilot + STRIPPED_DIR: tmppilot steps: - uses: actions/checkout@v2 with: submodules: true - name: Strip non-release files run: | - mkdir $TEST_DIR - cp -pR --parents $(cat release/files_common) $TEST_DIR - cp Dockerfile.openpilot_base Dockerfile.openpilotci $TEST_DIR + mkdir $STRIPPED_DIR + cp -pR --parents $(cat release/files_common) $STRIPPED_DIR + cp Dockerfile.openpilot_base $STRIPPED_DIR # need this to build on x86 - cp -pR --parents phonelibs/libyuv phonelibs/snpe \ - external/bin selfdrive/modeld/runners $TEST_DIR - - # need these so docker copy won't fail - cp Pipfile Pipfile.lock .pylintrc .pre-commit-config.yaml $TEST_DIR - cd $TEST_DIR - mkdir laika laika_repo tools + cp -pR --parents phonelibs/libyuv phonelibs/snpe selfdrive/modeld/runners $STRIPPED_DIR - name: Build Docker image - run: cd $TEST_DIR && eval "$BUILD" - - name: Build openpilot and run quick check + run: eval "$BUILD" + - name: Build openpilot and run checks run: | - $RUN "cd /tmp/openpilot && \ - scons -j$(nproc) && \ - $UNIT_TEST selfdrive/car" + cd $STRIPPED_DIR + ${{ env.RUN }} "cd /tmp/openpilot && \ + scons -j$(nproc) && \ + python -m unittest discover selfdrive/car" build_mac: name: build macos @@ -81,22 +75,24 @@ jobs: name: build webcam runs-on: ubuntu-20.04 timeout-minutes: 90 + env: + IMAGE_NAME: openpilotwebcamci steps: - uses: actions/checkout@v2 with: submodules: true - name: Build Docker image run: | - docker pull docker.io/commaai/openpilotwebcamci:latest - docker build --cache-from docker.io/commaai/openpilotwebcamci:latest -t tmppilotwebcam -f tools/webcam/Dockerfile . + eval "$BUILD" + docker pull $DOCKER_REGISTRY/$IMAGE_NAME:latest || true + docker build --cache-from $DOCKER_REGISTRY/$IMAGE_NAME:latest -t $DOCKER_REGISTRY/$IMAGE_NAME:latest -f tools/webcam/Dockerfile . - name: Build openpilot - run: docker run --shm-size 1G --rm tmppilotwebcam /bin/sh -c "cd /tmp/openpilot && USE_WEBCAM=1 scons -j$(nproc)" - - name: Push to dockerhub + run: docker run --shm-size 1G --rm $DOCKER_REGISTRY/$IMAGE_NAME /bin/sh -c "cd /tmp/openpilot && USE_WEBCAM=1 scons -j$(nproc)" + - name: Push to container registry if: github.ref == 'refs/heads/master' && github.event_name != 'pull_request' && github.repository == 'commaai/openpilot' run: | - docker login -u wmelching -p ${{ secrets.COMMA_DOCKERHUB_TOKEN}} - docker tag tmppilotwebcam docker.io/commaai/openpilotwebcamci:latest - docker push docker.io/commaai/openpilotwebcamci:latest + $DOCKER_LOGIN + docker push $DOCKER_REGISTRY/$IMAGE_NAME:latest docker_push: name: docker push @@ -105,18 +101,15 @@ jobs: if: github.ref == 'refs/heads/master' && github.event_name != 'pull_request' && github.repository == 'commaai/openpilot' needs: static_analysis # hack to ensure slow tests run first since this and static_analysis are fast steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Build Docker image - run: eval "$BUILD" - - name: Push to dockerhub - run: | - docker login -u wmelching -p ${{ secrets.COMMA_DOCKERHUB_TOKEN}} - docker tag commaai/openpilot-base:latest docker.io/commaai/openpilot-base:latest - docker push docker.io/commaai/openpilot-base:latest - docker tag tmppilot docker.io/commaai/openpilotci:latest - docker push docker.io/commaai/openpilotci:latest + - uses: actions/checkout@v2 + with: + submodules: true + - name: Build Docker image + run: eval "$BUILD" + - name: Push to container registry + run: | + $DOCKER_LOGIN + docker push $DOCKER_REGISTRY/$BASE_IMAGE:latest docker_push_prebuilt: name: docker push prebuilt @@ -124,188 +117,168 @@ jobs: timeout-minutes: 50 if: github.event_name == 'status' && github.repository == 'commaai/openpilot' needs: [static_analysis, unit_tests, process_replay, test_longitudinal, test_car_models] + env: + IMAGE_NAME: openpilot-prebuilt steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Build Docker image - run: echo "RUN cd /tmp/openpilot && scons -c && scons -j\$(nproc)" >> Dockerfile.openpilotci && eval "$BUILD" - - name: Push to dockerhub - run: | - docker login -u wmelching -p ${{ secrets.COMMA_DOCKERHUB_TOKEN}} - docker tag tmppilot docker.io/commaai/openpilot:latest - docker push docker.io/commaai/openpilot:latest + - uses: actions/checkout@v2 + with: + submodules: true + - name: Build Docker image + run: | + eval "$BUILD" + docker pull $DOCKER_REGISTRY/$IMAGE_NAME:latest || true + docker build --cache-from $DOCKER_REGISTRY/$IMAGE_NAME:latest -t $DOCKER_REGISTRY/$IMAGE_NAME:latest -f Dockerfile.openpilot . + - name: Push to container registry + run: | + $DOCKER_LOGIN + docker push $DOCKER_REGISTRY/$IMAGE_NAME:latest static_analysis: name: static analysis runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Build Docker image - run: eval "$BUILD" - - name: pre-commit - run: $RUN "cd /tmp/openpilot/ && git init && git add -A && pre-commit run --all" + - uses: actions/checkout@v2 + with: + submodules: true + - name: Build Docker image + run: eval "$BUILD" + - name: pre-commit + run: ${{ env.RUN }} "cd /tmp/openpilot/ && git init && git add -A && pre-commit run --all" valgrind: name: valgrind runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Cache dependencies - id: dependency-cache - uses: actions/cache@v2 - with: - path: | - /tmp/comma_download_cache - key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/test_valgrind_replay.py') }} - - name: Build Docker image - run: eval "$BUILD" - - name: Run valgrind - run: | - $PERSIST_WITH_CACHE "cd /tmp/openpilot && \ - scons -j$(nproc) && \ - FILEREADER_CACHE=1 python selfdrive/test/test_valgrind_replay.py" - - name: Print logs - if: always() - run: | - docker cp tmppilot:/tmp/openpilot/selfdrive/test/valgrind_logs.txt valgrind_logs.txt - cat valgrind_logs.txt - - uses: actions/upload-artifact@v2 - if: always() - continue-on-error: true - with: - name: valgrind_logs.txt - path: valgrind_logs.txt + - uses: actions/checkout@v2 + with: + submodules: true + - name: Cache dependencies + id: dependency-cache + uses: actions/cache@v2 + with: + path: /tmp/comma_download_cache + key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/test_valgrind_replay.py') }} + - name: Build Docker image + run: eval "$BUILD" + - name: Run valgrind + run: | + ${{ env.RUN }} "cd /tmp/openpilot && \ + scons -j$(nproc) && \ + FILEREADER_CACHE=1 python selfdrive/test/test_valgrind_replay.py" + - name: Print logs + if: always() + run: cat selfdrive/test/valgrind_logs.txt unit_tests: name: unit tests runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Build Docker image - run: eval "$BUILD" - - name: Run unit tests - run: | - $PERSIST "cd /tmp/openpilot && \ - scons -j$(nproc) && \ - coverage run selfdrive/test/test_fingerprints.py && \ - $UNIT_TEST common && \ - $UNIT_TEST opendbc/can && \ - $UNIT_TEST selfdrive/boardd && \ - $UNIT_TEST selfdrive/controls && \ - $UNIT_TEST selfdrive/monitoring && \ - $UNIT_TEST selfdrive/loggerd && \ - $UNIT_TEST selfdrive/car && \ - $UNIT_TEST selfdrive/locationd && \ - $UNIT_TEST selfdrive/athena && \ - $UNIT_TEST selfdrive/thermald && \ - $UNIT_TEST tools/lib/tests" - - name: Upload coverage to Codecov - run: | - docker commit tmppilot tmppilotci - $CI_RUN "cd /tmp/openpilot && bash <(curl -s https://codecov.io/bash) -v -F unit_tests" + - uses: actions/checkout@v2 + with: + submodules: true + - name: Build Docker image + run: eval "$BUILD" + - name: Run unit tests + run: | + ${{ env.RUN }} "cd /tmp/openpilot && \ + scons -j$(nproc) && \ + coverage run selfdrive/test/test_fingerprints.py && \ + $UNIT_TEST common && \ + $UNIT_TEST opendbc/can && \ + $UNIT_TEST selfdrive/boardd && \ + $UNIT_TEST selfdrive/controls && \ + $UNIT_TEST selfdrive/monitoring && \ + $UNIT_TEST selfdrive/loggerd && \ + $UNIT_TEST selfdrive/car && \ + $UNIT_TEST selfdrive/locationd && \ + $UNIT_TEST selfdrive/athena && \ + $UNIT_TEST selfdrive/thermald && \ + $UNIT_TEST tools/lib/tests" + - name: Upload coverage to Codecov + run: bash <(curl -s https://codecov.io/bash) -v -F unit_tests process_replay: name: process replay runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Cache dependencies - id: dependency-cache - uses: actions/cache@v2 - with: - path: | - /tmp/comma_download_cache - key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/process_replay/test_processes.py') }} - - name: Build Docker image - run: eval "$BUILD" - - name: Run replay - run: | - $PERSIST_WITH_CACHE "cd /tmp/openpilot && \ - scons -j$(nproc) && \ - FILEREADER_CACHE=1 CI=1 coverage run selfdrive/test/process_replay/test_processes.py" - - name: Upload coverage to Codecov - run: | - docker commit tmppilot tmppilotci - $CI_RUN "cd /tmp/openpilot && bash <(curl -s https://codecov.io/bash) -v -F process_replay" - - name: Print diff - if: always() - run: | - docker cp tmppilot:/tmp/openpilot/selfdrive/test/process_replay/diff.txt diff.txt - cat diff.txt - - uses: actions/upload-artifact@v2 - if: always() - continue-on-error: true - with: - name: process_replay_diff.txt - path: diff.txt + - uses: actions/checkout@v2 + with: + submodules: true + - name: Cache dependencies + id: dependency-cache + uses: actions/cache@v2 + with: + path: /tmp/comma_download_cache + key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/process_replay/test_processes.py') }} + - name: Build Docker image + run: eval "$BUILD" + - name: Run replay + run: | + ${{ env.RUN }} "cd /tmp/openpilot && \ + scons -j$(nproc) && \ + FILEREADER_CACHE=1 CI=1 coverage run selfdrive/test/process_replay/test_processes.py" + - name: Upload coverage to Codecov + run: bash <(curl -s https://codecov.io/bash) -v -F process_replay + - name: Print diff + if: always() + run: cat selfdrive/test/process_replay/diff.txt + - uses: actions/upload-artifact@v2 + if: always() + continue-on-error: true + with: + name: process_replay_diff.txt + path: selfdrive/test/process_replay/diff.txt test_longitudinal: name: longitudinal runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Build Docker image - run: eval "$BUILD" - - name: Test longitudinal - run: | - $PERSIST "mkdir -p /tmp/openpilot/selfdrive/test/out && \ - cd /tmp/openpilot/ && \ - scons -j$(nproc) && \ - cd selfdrive/test/longitudinal_maneuvers && \ - OPTEST=1 ./test_longitudinal.py" - - name: Copy artifacts - if: always() - run: | - mkdir out - docker cp tmppilot:/tmp/openpilot/selfdrive/test/longitudinal_maneuvers/out/longitudinal/ out/ - - uses: actions/upload-artifact@v2 - if: always() - continue-on-error: true - with: - name: longitudinal - path: out + - uses: actions/checkout@v2 + with: + submodules: true + - name: Build Docker image + run: eval "$BUILD" + - name: Test longitudinal + run: | + ${{ env.RUN }} "mkdir -p /tmp/openpilot/selfdrive/test/out && \ + cd /tmp/openpilot/ && \ + scons -j$(nproc) && \ + cd selfdrive/test/longitudinal_maneuvers && \ + ./test_longitudinal.py" + - uses: actions/upload-artifact@v2 + if: always() + continue-on-error: true + with: + name: longitudinal + path: selfdrive/test/longitudinal_maneuvers/out/longitudinal/ test_car_models: - name: test car models + name: car models runs-on: ubuntu-20.04 timeout-minutes: 50 steps: - - uses: actions/checkout@v2 - with: - submodules: true - - name: Cache dependencies - id: dependency-cache - uses: actions/cache@v2 - with: - path: | - /tmp/comma_download_cache - key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/test_car_models.py') }} - - name: Build Docker image - run: eval "$BUILD" - - name: Test car models - run: | - $PERSIST_WITH_CACHE "cd /tmp/openpilot && \ - scons -j$(nproc) && \ - FILEREADER_CACHE=1 coverage run --parallel-mode -m nose --processes=4 --process-timeout=60 \ - selfdrive/test/test_models.py && \ - coverage combine" - - name: Upload coverage to Codecov - run: | - docker commit tmppilot tmppilotci - $CI_RUN "cd /tmp/openpilot && bash <(curl -s https://codecov.io/bash) -v -F test_car_models" + - uses: actions/checkout@v2 + with: + submodules: true + - name: Cache dependencies + id: dependency-cache + uses: actions/cache@v2 + with: + path: /tmp/comma_download_cache + key: ${{ hashFiles('.github/workflows/test.yaml', 'selfdrive/test/test_car_models.py') }} + - name: Build Docker image + run: eval "$BUILD" + - name: Test car models + run: | + ${{ env.RUN }} "cd /tmp/openpilot && \ + scons -j$(nproc) && \ + FILEREADER_CACHE=1 coverage run --parallel-mode -m nose --processes=4 --process-timeout=60 \ + selfdrive/test/test_models.py && \ + coverage combine" + - name: Upload coverage to Codecov + run: bash <(curl -s https://codecov.io/bash) -v -F test_car_models diff --git a/Dockerfile.openpilotci b/Dockerfile.openpilot similarity index 94% rename from Dockerfile.openpilotci rename to Dockerfile.openpilot index ce60d3c26e..8363a06fdd 100644 --- a/Dockerfile.openpilotci +++ b/Dockerfile.openpilot @@ -23,3 +23,6 @@ COPY ./opendbc /tmp/openpilot/opendbc COPY ./cereal /tmp/openpilot/cereal COPY ./panda /tmp/openpilot/panda COPY ./selfdrive /tmp/openpilot/selfdrive + +WORKDIR /tmp/openpilot +RUN scons -j$(nproc) diff --git a/Dockerfile.openpilot_base b/Dockerfile.openpilot_base index 6667809e40..7b1a65a568 100644 --- a/Dockerfile.openpilot_base +++ b/Dockerfile.openpilot_base @@ -60,4 +60,5 @@ RUN pyenv install 3.8.2 && \ pip install --no-cache-dir pipenv==2020.8.13 && \ cd /tmp && \ pipenv install --system --deploy --dev --clear && \ + pip uninstall torch tensorflow -y && \ pip uninstall -y pipenv diff --git a/selfdrive/loggerd/tests/loggerd_tests_common.py b/selfdrive/loggerd/tests/loggerd_tests_common.py index b05057fdf6..acd62ec915 100644 --- a/selfdrive/loggerd/tests/loggerd_tests_common.py +++ b/selfdrive/loggerd/tests/loggerd_tests_common.py @@ -76,6 +76,7 @@ class UploaderTestCase(unittest.TestCase): uploader.Params = MockParams uploader.fake_upload = True uploader.force_wifi = True + uploader.allow_sleep = False self.seg_num = random.randint(1, 300) self.seg_format = "2019-04-18--12-52-54--{}" self.seg_format2 = "2019-05-18--11-22-33--{}" diff --git a/selfdrive/loggerd/uploader.py b/selfdrive/loggerd/uploader.py index 0c45e02e91..3874fbf0ea 100644 --- a/selfdrive/loggerd/uploader.py +++ b/selfdrive/loggerd/uploader.py @@ -19,6 +19,7 @@ NetworkType = log.ThermalData.NetworkType UPLOAD_ATTR_NAME = 'user.upload' UPLOAD_ATTR_VALUE = b'1' +allow_sleep = bool(os.getenv("UPLOADER_SLEEP", "1")) force_wifi = os.getenv("FORCEWIFI") is not None fake_upload = os.getenv("FAKEUPLOAD") is not None @@ -208,7 +209,8 @@ def uploader_fn(exit_event): d = uploader.next_file_to_upload(with_raw=allow_raw_upload and on_wifi and offroad) if d is None: # Nothing to upload - time.sleep(60 if offroad else 5) + if allow_sleep: + time.sleep(60 if offroad else 5) continue key, fn = d @@ -218,7 +220,7 @@ def uploader_fn(exit_event): success = uploader.upload(key, fn) if success: backoff = 0.1 - else: + elif allow_sleep: cloudlog.info("backoff %r", backoff) time.sleep(backoff + random.uniform(0, backoff)) backoff = min(backoff*2, 120) diff --git a/selfdrive/test/longitudinal_maneuvers/test_longitudinal.py b/selfdrive/test/longitudinal_maneuvers/test_longitudinal.py index c469a328a3..60f886e307 100755 --- a/selfdrive/test/longitudinal_maneuvers/test_longitudinal.py +++ b/selfdrive/test/longitudinal_maneuvers/test_longitudinal.py @@ -1,6 +1,5 @@ #!/usr/bin/env python3 import os -os.environ['OLD_CAN'] = '1' os.environ['NOCRASH'] = '1' import unittest @@ -11,16 +10,10 @@ from selfdrive.config import Conversions as CV from selfdrive.car.honda.values import CruiseButtons as CB from selfdrive.test.longitudinal_maneuvers.maneuver import Maneuver import selfdrive.manager as manager +from common.file_helpers import mkdirs_exists_ok from common.params import Params -def create_dir(path): - try: - os.makedirs(path) - except OSError: - pass - - def check_no_collision(log): return min(log['d_rel']) > 0 @@ -317,7 +310,7 @@ def setup_output(): view_html += "