summaryrefslogtreecommitdiff
path: root/numpy/array_api/tests/test_validation.py
diff options
context:
space:
mode:
authorCharles Harris <charlesr.harris@gmail.com>2022-06-09 11:55:32 -0600
committerGitHub <noreply@github.com>2022-06-09 11:55:32 -0600
commit5ea81775e0d2d13a4fec6bab882002e050bd3da1 (patch)
treed2dc068c7c06c22393841ddc0dd7ee011996249f /numpy/array_api/tests/test_validation.py
parent9d6b102617a92ad41964a5611c8dec87d3053a9f (diff)
parent5447192c8dc5d43d837b93ed5c5d47457e367669 (diff)
downloadnumpy-5ea81775e0d2d13a4fec6bab882002e050bd3da1.tar.gz
Merge branch 'main' into bugfix_16492_segfault_on_pyfragments
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)