-
Notifications
You must be signed in to change notification settings - Fork 44
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
Incomplete tests #301
Comments
The TODO is
The spec does not seem to fix the behavior for unsigned ints: https://data-apis.org/array-api/latest/API_specification/generated/array_api.negative.html So maybe a first action item is to clarify the spec? |
That sounds right. I thought I remember this already being addressed in the standard, but I guess it never was. At any rate, it's pretty clear to me that this behavior should be undefined in the standard, because we generally don't require wraparound behavior for integers to be defined. Maybe there is (or should be) something in the standard that just states that generally. |
This is a tracking issue for tests that are currently incomplete. These are mostly notated in the code by TODO comments, but it's useful to note them all here too. I haven't checked everything throughly so if there is something missing that isn't noted in a comment it might not be listed here.
Note there are also some functions that aren't yet tested at all, but those are covered in separate issues (e.g., #248 #299). I also am not including tests that are currently skipped entirely as flaky (#300).
test_array_object.py
test_getitem_masking.py
(key.ndim < x.ndim not tested)test_creation_functions.py
The
device
keyword is never tested (see below)test_data_type_functions.py
test_astype
(no complex types, no values testing, no test forcopy
) -- ENH: test astype with complex inputs #311test_broadcast_arrays
(no values testing)test_broadcast_to
(no values testing)test_can_cast
(no complex types) -- ENH: add a test for can_cast(complex dtypes) #320test_finfo
(no values testing)test_iinfo
(no values testing)test_fft.py
test_irfftn
(no shape tests) -- fixed in switch back testing of irfftn shapes #309test_has_names.py
test_indexing.py
test_take
(negative axis, negative indices, different dtypes for indices, axis=None Testaxis=None
intest_take
#191)test_inspection_functions.py
Basically none of the inspection APIs are currently tested, beyond the basic signature tests. Note that for many of these functions, we may not even need to use hypothesis. Just a basic test that the function outputs the right thing and a smoke test that the data outputted is correct.
test_linalg.py
(note: values testing here might be hard. Values testing isn't as high priority for functions that already generally work)
test_det
(no values testing)test_eigh
(no values testing)test_eigvalsh
(no values testing)test_inv
(no values testing)test_matmul
(the@
__matmul__
operator methods are not tested)test_matrix_norm
(no values testing)test_qr
(no test that Q is orthonormal)test_slogdet
(no values testing)test_svdvals
(no values testing; no test that it agrees withsvd()
)test_trace
(need to update dtype assertion, this should matchtest_sum
)test_vector_norm
(no values testing)Additionally, there are some limitations in the hypothesis strategies used by some of the functions. These should be made more general so that the functions are actually tested on a full gamut of possible inputs:
symmetric_matrices
(does not generate complex Hermitian matricespositive_definite_matrices
(only generates stacks of identity matricesinvertable_matrices
(only generates stacks of diagonal matrices)test_manipulation_functions.py
test_tile
(no shapes or values testing)test_operators_and_elementwise_functions.py
test_divide
(no complex numbers testing) -- fixed in stop skipping test_divide for complex inputs #306test_negative
(there is a TODO about uints)test_signatures.py
Several issues tracked in other issues: #256, #171
test_sorting_functions.py
test_argsort
(no testing of signed zeros or nans)test_sort
(no testing of signed zeros or nans)test_special_cases.py
Many special cases are not tested. This is tracked at #284
test_statistical_functions.py
See also #167
test_mean
(no values testing)test_std
(no values testing)test_var
(no values testing)OTHER
The text was updated successfully, but these errors were encountered: