From 354a5143ed475f3ce1f0aa43aed436448efad09c Mon Sep 17 00:00:00 2001 From: Zhong Ruijie <109201212+RUIJIEZHONG66166@users.noreply.github.com> Date: Thu, 19 Dec 2024 14:45:03 +0800 Subject: [PATCH] [Test] Add transformers test (#1175) For validating the upstream of transformers, we plan to add regular test for tracking the status of transformers. --------- Signed-off-by: Dmitry Rogozhkin Co-authored-by: Dmitry Rogozhkin --- .github/scripts/spec.py | 7 ++ .github/workflows/_linux_transformers.yml | 135 +++++++++++++++++++++ .github/workflows/nightly_ondemand_whl.yml | 2 +- 3 files changed, 143 insertions(+), 1 deletion(-) create mode 100644 .github/scripts/spec.py create mode 100644 .github/workflows/_linux_transformers.yml diff --git a/.github/scripts/spec.py b/.github/scripts/spec.py new file mode 100644 index 000000000..b8bf6d59a --- /dev/null +++ b/.github/scripts/spec.py @@ -0,0 +1,7 @@ +import torch + +DEVICE_NAME = 'xpu' + +MANUAL_SEED_FN = torch.xpu.manual_seed +EMPTY_CACHE_FN = torch.xpu.empty_cache +DEVICE_COUNT_FN = torch.xpu.device_count diff --git a/.github/workflows/_linux_transformers.yml b/.github/workflows/_linux_transformers.yml new file mode 100644 index 000000000..fd099fcb6 --- /dev/null +++ b/.github/workflows/_linux_transformers.yml @@ -0,0 +1,135 @@ +name: Linux Transformers Test + +on: + pull_request: + branches: + - main + paths: + - '.github/scripts/spec.py' + - '.github/workflows/_linux_transformers.yml' + workflow_dispatch: + inputs: + pytorch: + required: false + type: string + default: 'nightly' + description: Pytorch branch/commit + python: + required: false + type: string + default: '3.10' + description: Python version + runner: + required: true + type: string + default: 'linux.idc.xpu' + description: Runner label + driver: + required: false + type: string + default: 'lts' + description: Driver lts/rolling + nightly_whl: + required: false + type: string + default: '' + description: Pytorch nightly wheel version + transformers: + required: false + type: string + default: 'v4.47.0' + description: Transformers version + +permissions: read-all + +jobs: + Torch-XPU-Transformers-Tests: + runs-on: ${{ inputs.runner != '' && inputs.runner || 'linux.idc.xpu' }} + env: + NEOReadDebugKeys: ${{ inputs.driver == 'rolling' && '1' || '0' }} + DisableScratchPages: ${{ inputs.driver == 'rolling' && '1' || '0' }} + python: ${{ inputs.python != '' && inputs.python || '3.10' }} + pytorch: ${{ inputs.pytorch != '' && inputs.pytorch || 'nightly' }} + TRANSFORMERS_TEST_DEVICE_SPEC: 'spec.py' + steps: + - name: Checkout torch-xpu-ops + uses: actions/checkout@v4 + with: + path: torch-xpu-ops + - name: Checkout Transformers + uses: actions/checkout@v4 + with: + repository: huggingface/transformers + ref: ${{ inputs.transformers != '' && inputs.transformers || 'v4.47.0' }} + path: transformers + - name: Prepare OS environment + run: | + sudo apt-get update + sudo apt-get install -y \ + espeak-ng \ + git-lfs \ + pkg-config \ + libavcodec-dev \ + libavdevice-dev \ + libavfilter-dev \ + libavformat-dev \ + libavutil-dev \ + libswresample-dev \ + libswscale-dev + git lfs install + - name: Prepare Conda ENV + run: | + which conda && conda clean -ay + conda remove --all -y -n huggingface_transformers_test || rm -rf $(dirname ${CONDA_EXE})/../envs/huggingface_transformers_test + conda create -y -n huggingface_transformers_test python=${{ env.python }} + source activate huggingface_transformers_test + - name: Prepare Stock XPU Pytorch + run: | + pwd + source activate huggingface_transformers_test + if [ -z "${{ inputs.nightly_whl }}" ]; then + pip install torch torchvision torchaudio --pre --index-url https://download.pytorch.org/whl/nightly/xpu + else + pip install torch==$(echo ${{ inputs.nightly_whl }}) torchvision torchaudio --pre --index-url https://download.pytorch.org/whl/nightly/xpu + fi + - name: Prepare Transformers + run: | + pwd + source activate huggingface_transformers_test + cd transformers + pip install -e . + pip install -e ".[dev-torch,testing,video]" + rm -rf tests_log && mkdir -p tests_log + rm -rf reports + cp ${{ github.workspace }}/torch-xpu-ops/.github/scripts/spec.py ./ + - name: Report installed versions + id: installed + run: | + source activate huggingface_transformers_test + echo "TORCH_BRANCH_ID=$(python -c 'import torch; print(torch.__version__)')" |tee -a "${GITHUB_OUTPUT}" >> "${GITHUB_ENV}" + echo "TORCH_COMMIT_ID=$(python -c 'import torch; print(torch.version.git_version)')" |tee -a "${GITHUB_OUTPUT}" >> "${GITHUB_ENV}" + echo "pip installed packages:" + pip list | tee ${{ github.workspace }}/transformers/tests_log/pip_list.txt + echo "GPU render nodes:" + cat /sys/class/drm/render*/device/device | tee ${{ github.workspace }}/transformers/tests_log/device_IDs.txt + - name: Sanitry check installed packages + run: | + source activate huggingface_transformers_test + # These checks are to exit earlier if for any reason Transformers + # reinstalled torch packages back to CUDA versions (not expected). + pip show torch | grep Version | grep xpu + pip show torchaudio | grep Version | grep xpu + pip show torchvision | grep Version | grep xpu + - name: Run XPU backbone + run: | + source activate huggingface_transformers_test + cd transformers + python3 -m pytest -rsf --make-reports=tests_benchmark -k backbone tests + - name: Upload Test log + if: ${{ ! cancelled() }} + uses: actions/upload-artifact@v4 + with: + name: Torch-XPU-Transformers-Log-${{ github.event.pull_request.number || github.sha }} + path: | + ${{ github.workspace }}/transformers/reports + ${{ github.workspace }}/transformers/tests_log diff --git a/.github/workflows/nightly_ondemand_whl.yml b/.github/workflows/nightly_ondemand_whl.yml index 5de5f8caa..5dc776bbb 100644 --- a/.github/workflows/nightly_ondemand_whl.yml +++ b/.github/workflows/nightly_ondemand_whl.yml @@ -57,7 +57,7 @@ concurrency: jobs: Linux-Nightly-Ondemand-UT-WHL-Tests: - if: github.event_name == 'schedule' || ${{ inputs.ut_suite }} + if: github.event_name == 'schedule' || ${{ inputs.ut }} uses: ./.github/workflows/_linux_ut.yml with: ut: ${{ github.event_name == 'schedule' && 'op_regression,op_regression_dev1,op_extended,op_ut,torch_xpu' || inputs.ut }}