Skip to content

Commit

Permalink
ci/transformers: print not implemented xpu backend ops
Browse files Browse the repository at this point in the history
Signed-off-by: Dmitry Rogozhkin <[email protected]>
  • Loading branch information
dvrogozh committed Dec 24, 2024
1 parent 2be4062 commit 4c62151
Showing 1 changed file with 40 additions and 14 deletions.
54 changes: 40 additions & 14 deletions .github/workflows/_linux_transformers.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ jobs:
python: ${{ inputs.python != '' && inputs.python || '3.10' }}
pytorch: ${{ inputs.pytorch != '' && inputs.pytorch || 'nightly' }}
transformers: ${{ inputs.transformers != '' && inputs.transformers || 'v4.47.0' }}
PYTORCH_DEBUG_XPU_FALLBACK: '1'
TRANSFORMERS_TEST_DEVICE_SPEC: 'spec.py'
steps:
- name: Checkout torch-xpu-ops
Expand Down Expand Up @@ -149,19 +150,19 @@ jobs:
(cat reports/$TEST_CASE/stats.txt | grep errors) && failed=1
(cat reports/$TEST_CASE/stats.txt | grep "13 failed") || failed=1
[[ "$failed" = 1 ]] && (echo "FAILED_CASES=$FAILED_CASES,$TEST_CASE" >> $GITHUB_ENV)
- name: Run tests/generation
env:
TEST_CASE: 'tests_generation'
run: |
source activate huggingface_transformers_test
cd transformers
# Excluding tests due to:
# * torch.distributed.* not yet supported by XPU
pattern="not TestFSDPGeneration"
python3 -m pytest -rsf --make-reports=$TEST_CASE tests/generation -k "$pattern" || true
(cat reports/$TEST_CASE/stats.txt | grep errors) && failed=1
(cat reports/$TEST_CASE/stats.txt | grep "17 failed") || failed=1
[[ "$failed" = 1 ]] && (echo "FAILED_CASES=$FAILED_CASES,$TEST_CASE" >> $GITHUB_ENV)
#- name: Run tests/generation
# env:
# TEST_CASE: 'tests_generation'
# run: |
# source activate huggingface_transformers_test
# cd transformers
# # Excluding tests due to:
# # * torch.distributed.* not yet supported by XPU
# pattern="not TestFSDPGeneration"
# python3 -m pytest -rsf --make-reports=$TEST_CASE tests/generation -k "$pattern" || true
# (cat reports/$TEST_CASE/stats.txt | grep errors) && failed=1
# (cat reports/$TEST_CASE/stats.txt | grep "17 failed") || failed=1
# [[ "$failed" = 1 ]] && (echo "FAILED_CASES=$FAILED_CASES,$TEST_CASE" >> $GITHUB_ENV)
- name: Run tests/models
env:
TEST_CASE: 'tests_models'
Expand All @@ -176,7 +177,7 @@ jobs:
not test_model_parallel_equal_results and \
not test_resize_embeddings_untied and \
not test_resize_tokens_embeddings"
python3 -m pytest -rsf --make-reports=$TEST_CASE tests/models -k "$pattern" || true
python3 -m pytest -rsf --make-reports=$TEST_CASE tests/models/albert -k "$pattern" || true
(cat reports/$TEST_CASE/stats.txt | grep errors) && failed=1
# TODO: establish baseline with failed tests after resolving random failures
#(cat reports/$TEST_CASE/stats.txt | grep "10 failed") || failed=1
Expand Down Expand Up @@ -283,6 +284,29 @@ jobs:
echo "| $test_group | $file | $error | $comment |"
done <_failures_uniq.txt
} >> $GITHUB_STEP_SUMMARY
- name: Print not implemented XPU backend ops
run: |
cd transformers
{
echo "### Not implemented ops"
echo "| Test group | Operator | Status |"
echo "| --- | --- | --- |"
rm -rf _ops.txt
for log in $(find reports -name failures_line.txt); do
# Each failure_line.txt is located in: reports/$test_group/failure_line.txt
test_group=$(echo $log | cut -f2 -d/)
op=$(grep NotImplementedError $log | grep "for the XPU device" | sed "s/.*The operator '\(.*\)' is not.*/\1/")
echo "| $test_group | <pre>$op</pre> | not implemented |" >> _ops.txt
done
for log in $(find reports -name warnings.txt); do
# Each warnings.txt is located in: reports/$test_group/warnings.txt
test_group=$(echo $log | cut -f2 -d/)
op=$(grep UserWarning $log | grep "on the XPU backend" | sed "s/.*The operator '\(.*\) on the XPU.*/\1/")
echo "| $test_group | <pre>$op</pre> | fallback to CPU happens |" >> _ops.txt
done
sort _ops.txt | uniq > _ops_uniq.txt
cat _ops_uniq.txt
} >> $GITHUB_STEP_SUMMARY
- name: Print annotations
if: ${{ ! cancelled() }}
run: |
Expand Down Expand Up @@ -329,6 +353,8 @@ jobs:
# printing annotations with key environment variables
echo "| jobs.$GITHUB_JOB.env.ZE_AFFINITY_MASK | $ZE_AFFINITY_MASK |"
echo "| jobs.$GITHUB_JOB.env.NEOReadDebugKeys | $NEOReadDebugKeys |"
echo "| jobs.$GITHUB_JOB.env.PYTORCH_ENABLE_XPU_FALLBACK | $PYTORCH_ENABLE_XPU_FALLBACK |"
echo "| jobs.$GITHUB_JOB.env.PYTORCH_DEBUG_XPU_FALLBACK | $PYTORCH_DEBUG_XPU_FALLBACK |"
} >> $GITHUB_STEP_SUMMARY
- name: Upload Test log
if: ${{ ! cancelled() }}
Expand Down

0 comments on commit 4c62151

Please sign in to comment.