summaryrefslogtreecommitdiff
path: root/numpy/array_api/tests/test_validation.py
diff options
context:
space:
mode:
authorCharles Harris <charlesr.harris@gmail.com>2022-02-09 14:36:58 -0700
committerGitHub <noreply@github.com>2022-02-09 14:36:58 -0700
commit69cce4014fd16c5182e9d133a273ef29a5a70adc (patch)
tree292f7570467bb979d52d9a8a3fc53010d716b6bf /numpy/array_api/tests/test_validation.py
parent1cacb2ffb1113167a4995f4f4c183f9a8356c2f0 (diff)
parent995f5464b6c5d8569e159a96c6af106721a4e6d5 (diff)
downloadnumpy-69cce4014fd16c5182e9d133a273ef29a5a70adc.tar.gz
Merge pull request #20883 from honno/xp-can-cast
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.py27
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)