Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adds TRANSFORMERS_TEST_BACKEND #25655

Merged
merged 3 commits into from
Aug 22, 2023

Conversation

vvvm23
Copy link
Contributor

@vvvm23 vvvm23 commented Aug 22, 2023

What does this PR do?

Allows specifying arbitrary additional import following first import torch. This is useful for some custom backends, that will require additional imports to trigger backend registration with upstream torch. See pytorch/benchmark#1805 for a similar change in torchbench.

If the specified backend does not exist, we throw a helpful error. I have updated the docs to include this new variable.

Before submitting

  • This PR fixes a typo or improves the docs (you can dismiss the other checks if that's the case).
  • Did you read the contributor guideline,
    Pull Request section?
  • Was this discussed/approved via a Github issue or the forum? Please add a link
    to it if that's the case.
  • Did you make sure to update the documentation with your changes? Here are the
    documentation guidelines, and
    here are tips on formatting docstrings.
  • Did you write any new necessary tests?

Who can review?

@sgugger would you mind taking a look at this? It relates to my previous PR.

Allows specifying arbitrary additional import following first `import torch`.
This is useful for some custom backends, that will require additional imports to trigger backend registration with upstream torch.
See pytorch/benchmark#1805 for a similar change in `torchbench`.
@sgugger
Copy link
Collaborator

sgugger commented Aug 22, 2023

cc @ydshieh

docs/source/en/testing.md Outdated Show resolved Hide resolved
Copy link
Collaborator

@ydshieh ydshieh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi! Thank you for the PR.

I would like to see a real example of usage, please.

I am also wondering if it's always only one backend needed. What happens if we need multiple ones?

@vvvm23
Copy link
Contributor Author

vvvm23 commented Aug 22, 2023

I would like to see a real example of usage, please.

I have now provided example usage with the torch_npu backend. This is actually already in upstream so wouldn't be needed, but usage would be the same for backends not in upstream.

I am also wondering if it's always only one backend needed. What happens if we need multiple ones?

I feel just having one is fine for now, I am struggling to imagine a use-case for multiple, unless a single worker somehow had CPU, GPU, and other backends all on one physical machine.

```bash
TRANSFORMERS_TEST_DEVICE="cpu" pytest tests/test_logging.py
```

This variable is useful for testing custom or less common PyTorch backends such as `mps`. It can also be used to achieve the same effect as `CUDA_VISIBLE_DEVICES` by targeting specific GPUs or testing in CPU-only mode.

Certain devices will require an additional import after importing `torch` for the first time. This can be specified using the environment variable `TRANSFORMERS_TEST_BACKEND`:
```bash
TRANSFORMERS_TEST_BACKEND="torch_npu" pytest tests/test_logging.py
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tests/test_logging.py doesn't exist in transformers.

It would be nice if the example test against a test file (or even a single test device) that could use the npu device with the necessary backends. But I guess such a test doesn't exist yet and will wait your work on #25654.

Let keep this in mind (to update later)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tests/test_logging.py doesn't exist in transformers.

Interesting, it is referenced numerous times in the docs/source/en/testing.md file!

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

well, probably we move the test files. Will check but thanks pointing out this ❤️

Copy link
Collaborator

@ydshieh ydshieh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thansk! Looking forward seeing a real example running!

@ydshieh ydshieh merged commit 5eeaef9 into huggingface:main Aug 22, 2023
@HuggingFaceDocBuilderDev

The docs for this PR live here. All of your documentation changes will be reflected on that endpoint.

@vvvm23 vvvm23 deleted the add-testing-device-backend branch August 24, 2023 13:19
parambharat pushed a commit to parambharat/transformers that referenced this pull request Sep 26, 2023
* Adds `TRANSFORMERS_TEST_BACKEND`
Allows specifying arbitrary additional import following first `import torch`.
This is useful for some custom backends, that will require additional imports to trigger backend registration with upstream torch.
See pytorch/benchmark#1805 for a similar change in `torchbench`.

* Update src/transformers/testing_utils.py

Co-authored-by: Yih-Dar <[email protected]>

* Adds real backend example to documentation

---------

Co-authored-by: Yih-Dar <[email protected]>
blbadger pushed a commit to blbadger/transformers that referenced this pull request Nov 8, 2023
* Adds `TRANSFORMERS_TEST_BACKEND`
Allows specifying arbitrary additional import following first `import torch`.
This is useful for some custom backends, that will require additional imports to trigger backend registration with upstream torch.
See pytorch/benchmark#1805 for a similar change in `torchbench`.

* Update src/transformers/testing_utils.py

Co-authored-by: Yih-Dar <[email protected]>

* Adds real backend example to documentation

---------

Co-authored-by: Yih-Dar <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants