diff options
author | Matthew Barber <quitesimplymatt@gmail.com> | 2022-01-24 10:20:20 +0000 |
---|---|---|
committer | Matthew Barber <quitesimplymatt@gmail.com> | 2022-02-09 08:36:14 +0000 |
commit | 8eac9a4bb5b497ca29ebb852f21169ecfd0191e1 (patch) | |
tree | beae66ff1a5a88fe62085b2d335a6ef5c1c22b10 /numpy/array_api/tests/test_validation.py | |
parent | a6f55fe293502dd94eccb3799efdbaaa1d5ff1df (diff) | |
download | numpy-8eac9a4bb5b497ca29ebb852f21169ecfd0191e1.tar.gz |
BUG: Fix `np.array_api.can_cast()` by not relying on `np.can_cast()`
Diffstat (limited to 'numpy/array_api/tests/test_validation.py')
-rw-r--r-- | numpy/array_api/tests/test_validation.py | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/numpy/array_api/tests/test_validation.py b/numpy/array_api/tests/test_validation.py new file mode 100644 index 000000000..0dd100d15 --- /dev/null +++ b/numpy/array_api/tests/test_validation.py @@ -0,0 +1,27 @@ +from typing import Callable + +import pytest + +from numpy import array_api as xp + + +def p(func: Callable, *args, **kwargs): + f_sig = ", ".join( + [str(a) for a in args] + [f"{k}={v}" for k, v in kwargs.items()] + ) + id_ = f"{func.__name__}({f_sig})" + return pytest.param(func, args, kwargs, id=id_) + + +@pytest.mark.parametrize( + "func, args, kwargs", + [ + p(xp.can_cast, 42, xp.int8), + p(xp.can_cast, xp.int8, 42), + p(xp.result_type, 42), + ], +) +def test_raises_on_invalid_types(func, args, kwargs): + """Function raises TypeError when passed invalidly-typed inputs""" + with pytest.raises(TypeError): + func(*args, **kwargs) |