|
- name: CI
-
- on:
- push:
- branches:
- - main
- pull_request:
- workflow_dispatch:
-
- env:
- RUST_LOG: INFO
-
- jobs:
- test:
- name: "Test"
- strategy:
- matrix:
- platform: [ubuntu-latest, macos-latest, windows-latest]
- fail-fast: false
- runs-on: ${{ matrix.platform }}
- timeout-minutes: 60
- steps:
- - name: Print available space (Windows only)
- run: Get-PSDrive
- if: runner.os == 'Windows'
- - name: Override cargo target dir (Windows only)
- run: echo "CARGO_TARGET_DIR=C:\cargo-target" >> "$GITHUB_ENV"
- shell: bash
- if: runner.os == 'Windows'
-
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - name: Free Disk Space (Ubuntu)
- uses: jlumbroso/free-disk-space@main
- if: runner.os == 'Linux'
- with:
- # this might remove tools that are actually needed,
- # if set to "true" but frees about 6 GB
- tool-cache: false
-
- # all of these default to true, but feel free to set to
- # "false" if necessary for your workflow
- android: true
- dotnet: true
- haskell: true
- large-packages: false
- docker-images: true
- swap-storage: false
- - name: Free disk Space (Windows)
- if: runner.os == 'Windows'
- run: |
- docker system prune --all -f
- Remove-Item "C:\Android" -Force -Recurse
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
- cache-directories: ${{ env.CARGO_TARGET_DIR }}
-
- - name: "Check"
- run: cargo check --all
- - name: "Build (Without Python node as it is build with maturin)"
- run: cargo build --all --exclude dora-node-api-python
- - name: "Test"
- run: cargo test --all --exclude dora-ros2-bridge-python
-
- # Run examples as separate job because otherwise we will exhaust the disk
- # space of the GitHub action runners.
- examples:
- name: "Examples"
- strategy:
- matrix:
- platform: [ubuntu-latest, macos-latest, windows-latest]
- fail-fast: false
- runs-on: ${{ matrix.platform }}
- timeout-minutes: 60
- steps:
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - name: Free Disk Space (Ubuntu)
- uses: jlumbroso/free-disk-space@main
- if: runner.os == 'Linux'
- with:
- # this might remove tools that are actually needed,
- # if set to "true" but frees about 6 GB
- tool-cache: false
-
- # all of these default to true, but feel free to set to
- # "false" if necessary for your workflow
- android: true
- dotnet: true
- haskell: true
- large-packages: false
- docker-images: true
- swap-storage: false
- - name: Free disk Space (Windows)
- if: runner.os == 'Windows'
- run: |
- docker system prune --all -f
- Remove-Item "C:\Android" -Force -Recurse
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
-
- # general examples
- - run: cargo install just --locked
- - name: "Rust Dataflow example"
- timeout-minutes: 30
- working-directory: examples/rust-dataflow
- run: just run
-
- - name: "Build examples"
- timeout-minutes: 30
- run: cargo build --examples
- - name: "Multiple Daemons example"
- timeout-minutes: 30
- run: cargo run --example multiple-daemons
- - name: "C Dataflow example"
- timeout-minutes: 15
- run: cargo run --example c-dataflow
- - name: "C++ Dataflow example"
- timeout-minutes: 15
- run: cargo run --example cxx-dataflow
- - name: "Cmake example"
- if: runner.os == 'Linux'
- timeout-minutes: 30
- run: cargo run --example cmake-dataflow
-
- # python examples
- - uses: actions/setup-python@v2
- if: runner.os != 'Windows'
- with:
- python-version: "3.8"
- - uses: actions/setup-python@v2
- if: runner.os == 'Windows'
- with:
- python-version: "3.10"
- - name: "Python Dataflow example"
- run: cargo run --example python-dataflow
- - name: "Python Operator Dataflow example"
- run: cargo run --example python-operator-dataflow
-
- # ROS2 bridge examples
- ros2-bridge-examples:
- name: "ROS2 Bridge Examples"
- runs-on: ubuntu-latest
- timeout-minutes: 45
- steps:
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
-
- - uses: ros-tooling/setup-ros@v0.6
- with:
- required-ros-distributions: humble
- - run: 'source /opt/ros/humble/setup.bash && echo AMENT_PREFIX_PATH=${AMENT_PREFIX_PATH} >> "$GITHUB_ENV"'
- - name: "Install pyarrow for testing"
- run: pip install numpy pyarrow
- - name: "Test"
- run: cargo test -p dora-ros2-bridge-python
- - name: "Rust ROS2 Bridge example"
- timeout-minutes: 30
- env:
- QT_QPA_PLATFORM: offscreen
- run: |
- source /opt/ros/humble/setup.bash && ros2 run turtlesim turtlesim_node &
- source /opt/ros/humble/setup.bash && ros2 run examples_rclcpp_minimal_service service_main &
- cargo run --example rust-ros2-dataflow --features="ros2-examples"
- - uses: actions/setup-python@v2
- if: runner.os != 'Windows'
- with:
- python-version: "3.8"
- - uses: actions/setup-python@v2
- if: runner.os == 'Windows'
- with:
- python-version: "3.10"
- - name: "python-ros2-dataflow"
- timeout-minutes: 30
- env:
- QT_QPA_PLATFORM: offscreen
- run: |
- # Reset only the turtlesim instance as it is not destroyed at the end of the previous job
- source /opt/ros/humble/setup.bash && ros2 service call /reset std_srvs/srv/Empty &
- cargo run --example python-ros2-dataflow --features="ros2-examples"
- - name: "c++-ros2-dataflow"
- timeout-minutes: 30
- env:
- QT_QPA_PLATFORM: offscreen
- run: |
- # Reset only the turtlesim instance as it is not destroyed at the end of the previous job
- source /opt/ros/humble/setup.bash && ros2 service call /reset std_srvs/srv/Empty &
- cargo run --example cxx-ros2-dataflow --features="ros2-examples"
-
- bench:
- name: "Bench"
- strategy:
- matrix:
- platform: [ubuntu-latest, macos-latest, windows-latest]
- fail-fast: false
- runs-on: ${{ matrix.platform }}
- timeout-minutes: 60
- steps:
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
-
- - name: "Benchmark example"
- timeout-minutes: 30
- run: cargo run --example benchmark --release
-
- CLI:
- name: "CLI Test"
- strategy:
- matrix:
- platform: [ubuntu-latest, macos-latest, windows-latest]
- fail-fast: false
- runs-on: ${{ matrix.platform }}
- timeout-minutes: 60
- steps:
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
-
- # CLI tests
- - name: "Build cli and binaries"
- timeout-minutes: 45
- # fail-fast by using bash shell explictly
- shell: bash
- run: |
- cargo install --path binaries/cli --locked
- - name: "Test CLI"
- timeout-minutes: 30
- # fail-fast by using bash shell explictly
- shell: bash
- run: |
- dora up
- dora list
-
- # Test Rust template Project
- dora new test_rust_project --internal-create-with-path-dependencies
- cd test_rust_project
- cargo build --all
- dora start dataflow.yml --name ci-rust-test
- sleep 10
- dora stop --name ci-rust-test
- cd ..
-
- # Test Python template Project
- pip3 install maturin
- maturin build -m apis/python/node/Cargo.toml
- pip3 install target/wheels/*
- dora new test_python_project --lang python --internal-create-with-path-dependencies
- cd test_python_project
- dora start dataflow.yml --name ci-python-test
- sleep 10
- dora stop --name ci-python-test
- cd ..
-
- dora destroy
-
- clippy:
- name: "Clippy"
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v3
-
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
-
- - name: "Clippy"
- run: cargo clippy --all
- - name: "Clippy (tracing feature)"
- run: cargo clippy --all --features tracing
- if: false # only the dora-runtime has this feature, but it is currently commented out
- - name: "Clippy (metrics feature)"
- run: cargo clippy --all --features metrics
- if: false # only the dora-runtime has this feature, but it is currently commented out
-
- rustfmt:
- name: "Formatting"
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v3
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - name: "rustfmt"
- run: cargo fmt --all -- --check
-
- check-license:
- name: "License Checks"
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v3
-
- - uses: r7kamura/rust-problem-matchers@v1.1.0
- - run: cargo --version --verbose
- - uses: Swatinem/rust-cache@v2
- with:
- cache-provider: buildjet
- cache-on-failure: true
- # only save caches for `main` branch
- save-if: ${{ github.ref == 'refs/heads/main' }}
-
- - run: cargo install cargo-lichking
- - name: "Check dependency licenses"
- run: cargo lichking check
|