From 7b5a2d5445c945b7c5fb1e5214175021d6bdb175 Mon Sep 17 00:00:00 2001 From: Nathan Weinberg Date: Tue, 16 Jul 2024 09:45:50 -0500 Subject: [PATCH] Modify existing E2E job to run unit tests Signed-off-by: Nathan Weinberg --- .github/workflows/e2e.yml | 102 ------------------------------------- .github/workflows/test.yml | 58 +++++++++++++++++++++ README.md | 1 + 3 files changed, 59 insertions(+), 102 deletions(-) delete mode 100644 .github/workflows/e2e.yml create mode 100644 .github/workflows/test.yml diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml deleted file mode 100644 index 323066a..0000000 --- a/.github/workflows/e2e.yml +++ /dev/null @@ -1,102 +0,0 @@ -# SPDX-License-Identifier: Apache-2.0 - -name: E2E test - -on: - push: - branches: - - "main" - - "release-**" - paths: - - '**.py' - - 'pyproject.toml' - - 'requirements*.txt' - - '.github/workflows/e2e.yml' - pull_request: - branches: - - "main" - - "release-**" - paths: - - '**.py' - - 'pyproject.toml' - - 'requirements*.txt' - - '.github/workflows/e2e.yml' - -concurrency: - group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} - cancel-in-progress: true - -jobs: - e2e: - runs-on: ubuntu-gpu - - permissions: - pull-requests: write - - steps: - # No step-security/harden-runner since this is a self-hosted runner - - name: Checkout instructlab/eval - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 - with: - # https://github.com/actions/checkout/issues/249 - fetch-depth: 0 - - - name: Checkout instructlab/instructlab - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 - with: - repository: "instructlab/instructlab" - path: "instructlab" - fetch-depth: 0 - - - name: Install Packages - run: | - sudo apt-get install -y cuda-toolkit git cmake build-essential virtualenv - nvidia-smi - sudo ls -l /dev/nvidia* - - - name: Setup Python 3.11 - uses: actions/setup-python@82c7e631bb3cdc910f68e0081d67478d79c6982d # v5.1.0 - with: - python-version: 3.11 - cache: pip - cache-dependency-path: | - **/pyproject.toml - **/requirements*.txt - - - name: Remove llama-cpp-python from cache - run: | - pip cache remove llama_cpp_python - - - name: Cache huggingface - uses: actions/cache@0c45773b623bea8c8e75f6c82b208c3cf94ea4f9 # v4.0.2 - with: - path: ~/.cache/huggingface - # config contains DEFAULT_MODEL - key: huggingface-${{ hashFiles('src/instructlab/configuration.py') }} - - - name: Install instructlab and instructlab-eval - run: | - export PATH="/home/runner/.local/bin:/usr/local/cuda/bin:$PATH" - python3 -m venv venv - . venv/bin/activate - cd instructlab - sed 's/\[.*\]//' requirements.txt > constraints.txt - python3 -m pip cache remove llama_cpp_python - CMAKE_ARGS="-DLLAMA_CUBLAS=on" python3 -m pip install --no-binary llama_cpp_python -c constraints.txt llama_cpp_python - # needed for --4-bit-quant option to ilab train - python3 -m pip install bitsandbytes - # install instructlab - python3 -m pip install . - cd .. - # Install instructlab-eval - python3 -m pip install . - - - name: Run e2e test - run: | - . venv/bin/activate - ./instructlab/scripts/basic-workflow-tests.sh -cm - - - name: Remove llama-cpp-python from cache - if: always() - run: | - pip cache remove llama_cpp_python diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..e1c0fa3 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,58 @@ +# SPDX-License-Identifier: Apache-2.0 + +name: Test + +on: + push: + branches: + - "main" + - "release-**" + paths: + - '**.py' + - 'pyproject.toml' + - 'requirements*.txt' + - '.github/workflows/e2e.yml' + pull_request: + branches: + - "main" + - "release-**" + paths: + - '**.py' + - 'pyproject.toml' + - 'requirements*.txt' + - '.github/workflows/e2e.yml' + +concurrency: + group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} + cancel-in-progress: true + +jobs: + unit: + runs-on: ubuntu-gpu + steps: + # No step-security/harden-runner since this is a self-hosted runner + - name: Checkout instructlab/eval + uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 + with: + # https://github.com/actions/checkout/issues/249 + fetch-depth: 0 + + - name: Setup Python 3.11 + uses: actions/setup-python@82c7e631bb3cdc910f68e0081d67478d79c6982d # v5.1.0 + with: + python-version: 3.11 + cache: pip + cache-dependency-path: | + **/pyproject.toml + **/requirements*.txt + + - name: Install dependencies + run: | + python3.11 -m venv venv + . venv/bin/activate + python3.11 -m pip install . + + - name: Run unit tests + run: | + . venv/bin/activate + python3 -m pytest diff --git a/README.md b/README.md index 7c8d667..25f17a8 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,7 @@ # eval ![Lint](https://github.com/instructlab/eval/actions/workflows/lint.yml/badge.svg?branch=main) +![Test](https://github.com/instructlab/eval/actions/workflows/test.yml/badge.svg?branch=main) ![Build](https://github.com/instructlab/eval/actions/workflows/pypi.yaml/badge.svg?branch=main) ![Release](https://img.shields.io/github/v/release/instructlab/eval) ![License](https://img.shields.io/github/license/instructlab/eval)