forked from astropy/quantity-2.0
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_api.py
58 lines (41 loc) · 1.82 KB
/
test_api.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# Licensed under a 3-clause BSD style license - see LICENSE.rst
"""Test the Quantity class Array API compatibility."""
import astropy.units as u
import numpy as np
import pytest
from quantity import Quantity, api
from .conftest import ARRAY_NAMESPACES
def test_issubclass_api():
"""Test that Quantity is a subclass of api.Quantity and api.QuantityArray."""
assert issubclass(Quantity, api.Quantity)
assert issubclass(Quantity, api.QuantityArray)
def test_ndarray():
"""Test that ndarray does not satisfy the Quantity API."""
assert not issubclass(np.ndarray, api.Quantity)
assert not isinstance(np.array([1, 2, 3]), api.Quantity)
def test_astropy_quantity():
"""Test that astropy.units.Quantity works with the Quantity API."""
assert issubclass(u.Quantity, api.Quantity)
assert isinstance(u.Quantity(np.array([1, 2, 3]), u.m), api.Quantity)
# ------------------------------
@pytest.fixture
def array_and_quantity(request):
xp = request.param.xp
value = xp.asarray([1.0, 2.0, 3.0])
q = Quantity(value, u.m)
return value, q
@pytest.mark.parametrize("array_and_quantity", ARRAY_NAMESPACES, indirect=True)
class TestIsinstanceAPI:
"""Check Quantities are properly recognized independent of the array type."""
def test_issubclass_api(self, array_and_quantity):
v, q = array_and_quantity
assert not issubclass(type(v), api.Quantity)
assert not issubclass(type(v), api.QuantityArray)
assert issubclass(type(q), api.Quantity)
assert issubclass(type(q), api.QuantityArray)
def test_isinstance_api(self, array_and_quantity):
v, q = array_and_quantity
assert not isinstance(v, api.Quantity)
assert not isinstance(v, api.QuantityArray)
assert isinstance(q, api.Quantity)
assert isinstance(q, api.QuantityArray)