# SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved. # SPDX-License-Identifier: Apache-2.0 name: Docker Build and Test on: push: branches: - main - "pull-request/[0-9]+" concurrency: group: ${{ github.workflow }}-build-test-${{ github.ref_name || github.run_id }} cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} jobs: changed-files: runs-on: ubuntu-latest outputs: has_code_changes: ${{ steps.filter.outputs.has_code_changes }} steps: - name: Checkout code uses: actions/checkout@08eba0b27e820071cde6df949e0beb9ba4906955 # v4.3.0 - name: Check for changes uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 id: filter with: filters: .github/filters.yaml backend-status-check: runs-on: ubuntu-latest needs: [vllm, sglang, trtllm] if: always() steps: - name: "Check all dependent jobs" run: | echo '${{ toJson(needs) }}' | jq -e 'to_entries | map(.value.result) | all(. as $result | ["success", "skipped"] | any($result == .))' vllm: runs-on: gpu-l40-amd64 needs: changed-files if: needs.changed-files.outputs.has_code_changes == 'true' steps: - name: Checkout code uses: actions/checkout@08eba0b27e820071cde6df949e0beb9ba4906955 # v4.3.0 - name: Build Container id: build-image uses: ./.github/actions/docker-build with: framework: vllm target: runtime ngc_ci_access_token: ${{ secrets.NGC_CI_ACCESS_TOKEN }} ci_token: ${{ secrets.CI_TOKEN }} aws_default_region: ${{ secrets.AWS_DEFAULT_REGION }} sccache_s3_bucket: ${{ secrets.SCCACHE_S3_BUCKET }} aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} - name: Run tests uses: ./.github/actions/pytest with: image_tag: ${{ steps.build-image.outputs.image_tag }} pytest_marks: "e2e and vllm and gpu_1 and not slow" sglang: runs-on: gpu-l40-amd64 needs: changed-files if: needs.changed-files.outputs.has_code_changes == 'true' steps: - name: Checkout repository uses: actions/checkout@08eba0b27e820071cde6df949e0beb9ba4906955 # v4.3.0 - name: Build Container id: build-image uses: ./.github/actions/docker-build with: framework: sglang target: runtime ngc_ci_access_token: ${{ secrets.NGC_CI_ACCESS_TOKEN }} ci_token: ${{ secrets.CI_TOKEN }} aws_default_region: ${{ secrets.AWS_DEFAULT_REGION }} sccache_s3_bucket: ${{ secrets.SCCACHE_S3_BUCKET }} aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} - name: Run tests uses: ./.github/actions/pytest with: image_tag: ${{ steps.build-image.outputs.image_tag }} pytest_marks: "e2e and sglang and gpu_1" trtllm: runs-on: gpu-l40-amd64 needs: changed-files if: needs.changed-files.outputs.has_code_changes == 'true' steps: - name: Checkout code uses: actions/checkout@08eba0b27e820071cde6df949e0beb9ba4906955 # v4.3.0 - name: Build Container id: build-image uses: ./.github/actions/docker-build with: framework: trtllm target: runtime ngc_ci_access_token: ${{ secrets.NGC_CI_ACCESS_TOKEN }} ci_token: ${{ secrets.CI_TOKEN }} aws_default_region: ${{ secrets.AWS_DEFAULT_REGION }} sccache_s3_bucket: ${{ secrets.SCCACHE_S3_BUCKET }} aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} - name: Run tests uses: ./.github/actions/pytest with: image_tag: ${{ steps.build-image.outputs.image_tag }} pytest_marks: "e2e and trtllm_marker and gpu_1 and not slow"