From 363f2638685130618bacd65315f0aa5fbb08e100 Mon Sep 17 00:00:00 2001 From: Richard Cheng Date: Mon, 23 Sep 2024 08:40:43 -0700 Subject: [PATCH] workflow-2612 - Update / cleanup interface input/output between build job and reusable workflow. --- .github/workflows/baremetal_ci_teensy.yml | 34 +++++------- .github/workflows/reusable_fit_ci.yml | 63 +++++++++++------------ 2 files changed, 43 insertions(+), 54 deletions(-) diff --git a/.github/workflows/baremetal_ci_teensy.yml b/.github/workflows/baremetal_ci_teensy.yml index db0d6299..f55488cc 100644 --- a/.github/workflows/baremetal_ci_teensy.yml +++ b/.github/workflows/baremetal_ci_teensy.yml @@ -3,13 +3,12 @@ run-name: ${{ github.actor }} running Baremetal CI actions on: [push] env: - platform_setup: "fsw-gds" - baremetal_bin: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/bin/BaremetalReference.hex + run_job_select: "fsw-gds" + build_binary: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/bin/BaremetalReference.hex gds_args: --comm-adapter uart --uart-device /dev/ttyACM0 dict_path: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/dict/BaremetalReferenceTopologyAppDictionary.xml test_path: BaremetalReference/test/int/baremetal_ref_integration_test.py - workspace_path: ${{ github.workspace }} - new_baremetal_bin: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/bin/build_binary + new_build_binary: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/bin/build_binary new_dict_path: ${{ github.workspace }}/build-artifacts/teensy41/BaremetalReference/dict/dictionary.xml jobs: @@ -17,12 +16,10 @@ jobs: build: runs-on: ubuntu-latest outputs: - platform_setup: ${{ env.platform_setup }} + run_job_select: ${{ env.run_job_select }} start_cmd: /home/odroid/teensy_loader_cli/teensy_loader_cli --mcu=TEENSY41 -v -s ./build_binary gds_args: ${{ env.gds_args }} - dict_path: ${{ env.dict_path }} test_path: ${{ env.test_path }} - workspace_path: ${{ env.workspace_path }} steps: - uses: actions/checkout@v4 - name: "Checkout F' Repository" @@ -30,13 +27,13 @@ jobs: with: submodules: true path: ${{ inputs.fprime_location }} - - name: "Build" + - name: "Fprime Venv and Requirements Install" run: | python3 -m venv ./fprime-venv . ./fprime-venv/bin/activate - pip3 install -U setuptools wheel pip pip3 install -r ${{ inputs.fprime_location }}./fprime/requirements.txt - + - name: "Platform Specific Requirements Install" + run: | mkdir -p ~/.local/bin curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | BINDIR=~/.local/bin sh cd ~/.local/bin @@ -50,38 +47,33 @@ jobs: arduino-cli config add board_manager.additional_urls https://www.pjrc.com/teensy/package_teensy_index.json arduino-cli core update-index arduino-cli core install teensy:avr - + - name: "Build" + run: | . ./fprime-venv/bin/activate fprime-util generate fprime-util build - name: "Rename build files" run: | - mv ${{ env.baremetal_bin }} ${{ env.new_baremetal_bin }} + mv ${{ env.build_binary }} ${{ env.new_build_binary }} mv ${{ env.dict_path}} ${{ env.new_dict_path}} - name: "Upload build binary" uses: actions/upload-artifact@v4 with: name: build_binary - path: ${{ env.new_baremetal_bin }} + path: ${{ env.new_build_binary }} - name: "Upload dictionary" uses: actions/upload-artifact@v4 with: name: dictionary.xml path: ${{ env.new_dict_path }} - #- name: "Temp step, file renaming" - # run: | - # mv ${{ github.workspace }}/lib/arduino/fprime-arduino/ATmega/vendor/libraries/TimerOne/examples/FanSpeed/FanSpeed.pde ${{ github.workspace }}/lib/arduino/fprime-arduino/ATmega/vendor/libraries/TimerOne/examples/FanSpeed/FanSpeed.ino - # mv ${{ github.workspace }}/lib/arduino/fprime-arduino/ATmega/vendor/libraries/TimerOne/examples/Interrupt/Interrupt.pde ${{ github.workspace }}/lib/arduino/fprime-arduino/ATmega/vendor/libraries/TimerOne/examples/Interrupt/Interrupt.ino - run: echo "Expose env vars for reusable workflow." fit: needs: build uses: ./.github/workflows/reusable_fit_ci.yml with: + test_path: ${{ needs.build.outputs.test_path }} runs_on: self-hosted - platform_setup: ${{ needs.build.outputs.platform_setup }} + run_job_select: ${{ needs.build.outputs.run_job_select }} start_cmd: ${{ needs.build.outputs.start_cmd }} gds_args: ${{ needs.build.outputs.gds_args }} - dict_path: ${{ needs.build.outputs.dict_path }} - test_path: ${{ needs.build.outputs.test_path }} - workspace_path: ${{ needs.build.outputs.workspace_path }} diff --git a/.github/workflows/reusable_fit_ci.yml b/.github/workflows/reusable_fit_ci.yml index cdea6248..24733c41 100644 --- a/.github/workflows/reusable_fit_ci.yml +++ b/.github/workflows/reusable_fit_ci.yml @@ -3,12 +3,15 @@ name: resuable-fit on: workflow_call: inputs: + test_path: + required: true + type: string runs_on: required: false type: string default: "ubuntu-latest" - platform_setup: - required: true + run_job_select: + required: false type: string default: "non-embedded" start_cmd: @@ -18,25 +21,20 @@ on: gds_args: required: false type: string - dict_path: - required: false - type: string - test_path: - required: false - type: string - workspace_path: - required: true - type: string + default: "" jobs: -# Following jobs are on a switch, only one will run based on platform_setup string. -# Each job has a different method of starting FSW, FIT is run at the end of each job. -# If adding a new setup make sure it does not collide with an existing job. -# After one of these jobs is run, the upload FIT artifact job will then run. +# Setup job will run first by creating the virtual environment and then downloading the +# FSW binary and dictionary created in the build job step of the caller workflow to this +# workflow. After that the following run jobs are on a switch, only one will run based +# on run_job_select string. Each run job has a different method of starting FSW, FIT is +# run at the end of each job. If adding a new run job make sure it does not collide with +# an existing job. After one of these jobs is run, the upload FIT artifact job will then +# run. # -# / non-embedded \ -# build --->| fsw-gds |---> upload-fit-artifacts -# \ gds-fsw / +# / run-non-embedded \ +# setup --->| run-fsw-gds |---> upload-fit-artifacts +# \ run-gds-fsw / setup: runs-on: ${{ inputs.runs_on }} @@ -47,23 +45,23 @@ jobs: with: submodules: true path: ${{ inputs.fprime_location }} - - name: "Build" + - name: "Install and activate Virtual Environment" run: | python3 -m venv ./fprime-venv . ./fprime-venv/bin/activate pip3 install -U setuptools wheel pip pip3 install -r ${{ inputs.fprime_location }}./fprime/requirements.txt - - name: "Download Binary" + - name: "Download FSW Binary" uses: actions/download-artifact@v4 with: name: build_binary - - name: "Download dictionary" + - name: "Download Dictionary" uses: actions/download-artifact@v4 with: name: dictionary.xml - non-embedded: - if: ${{ inputs.platform_setup == 'non-embedded' }} + run-non-embedded: + if: ${{ inputs.run_job_select == 'non-embedded' }} runs-on: ${{ inputs.runs_on }} needs: setup steps: @@ -75,10 +73,10 @@ jobs: run: | . ./fprime-venv/bin/activate sleep 12 - pytest ${{ inputs.test_path }} --dictionary ${{ inputs.dict_path }} -rP + pytest ${{ inputs.test_path }} --dictionary ./dictionary.xml -rP - fsw-gds: - if: ${{ inputs.platform_setup == 'fsw-gds' }} + run-fsw-gds: + if: ${{ inputs.run_job_select == 'fsw-gds' }} needs: setup runs-on: ${{ inputs.runs_on }} steps: @@ -94,15 +92,15 @@ jobs: . ./fprime-venv/bin/activate pytest ${{ inputs.test_path }} -rP --dictionary ./dictionary.xml --logs ./ - gds-fsw: - if: ${{ inputs.platform_setup == 'gds-fsw' }} + run-gds-fsw: + if: ${{ inputs.run_job_select == 'gds-fsw' }} needs: setup runs-on: ${{ inputs.runs_on }} steps: - name: "Start GDS" run: | . ./fprime-venv/bin/activate - fprime-gds -n --dictionary ${{ inputs.dict_path }} --gui none ${{ inputs.gds_args }} & + fprime-gds -n --dictionary ./dictionary.xml --gui none ${{ inputs.gds_args }} & - name: "Start FSW" run: | ${{ inputs.start_cmd }} @@ -110,18 +108,17 @@ jobs: - name: "Run Integration tests" run: | . ./fprime-venv/bin/activate - pytest ${{ inputs.test_path }} --dictionary ${{ inputs.dict_path }} -rP + pytest ${{ inputs.test_path }} --dictionary ./dictionary.xml -rP upload-fit-artifact: runs-on: ${{ inputs.runs_on }} if: ${{ always() }} #as long as one of the above jobs run, this job will run - needs: [non-embedded, fsw-gds, gds-fsw] + needs: [run-non-embedded, run-fsw-gds, run-gds-fsw] steps: - name: "Upload Integration Test Results" - #Navigate to workspace path. nagigate into newest directory, which is for test logs. + #Navigate into newest directory, which is for test logs. #Rename test log because it contains date time and time is separated by colons that upload-artifact cannot handle. #Store full path to test log xlsx in a variable for upload-artifact to use. - # cd ${{ inputs.workspace_path }} run: | cd "$(ls -td -- */ | head -n 1)" mv TestLog*.xlsx TestLog.xlsx