diff options
author | Matti Picus <matti.picus@gmail.com> | 2018-10-16 06:02:13 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-16 06:02:13 +0300 |
commit | a1fd9da3c929d647522446c549c06f6cc60af0c0 (patch) | |
tree | 0f73195d4387b5d3a0901a3a0f06ce746f57eeef /numpy/lib/tests/test_utils.py | |
parent | a5e10f8b2903892c1c0771de3ff6516709cbb739 (diff) | |
parent | 946781fbf04b9781f263da894cc2dfc9465e65ce (diff) | |
download | numpy-a1fd9da3c929d647522446c549c06f6cc60af0c0.tar.gz |
Merge pull request #12151 from tylerjereddy/test_byte_bounds_contiguity
TST: byte_bounds contiguity handling
Diffstat (limited to 'numpy/lib/tests/test_utils.py')
-rw-r--r-- | numpy/lib/tests/test_utils.py | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/numpy/lib/tests/test_utils.py b/numpy/lib/tests/test_utils.py index c27c3cbf5..2723f3440 100644 --- a/numpy/lib/tests/test_utils.py +++ b/numpy/lib/tests/test_utils.py @@ -56,10 +56,34 @@ def test_safe_eval_nameconstant(): utils.safe_eval('None') -def test_byte_bounds(): - a = arange(12).reshape(3, 4) - low, high = utils.byte_bounds(a) - assert_equal(high - low, a.size * a.itemsize) +class TestByteBounds(object): + + def test_byte_bounds(self): + # pointer difference matches size * itemsize + # due to contiguity + a = arange(12).reshape(3, 4) + low, high = utils.byte_bounds(a) + assert_equal(high - low, a.size * a.itemsize) + + def test_unusual_order_positive_stride(self): + a = arange(12).reshape(3, 4) + b = a.T + low, high = utils.byte_bounds(b) + assert_equal(high - low, b.size * b.itemsize) + + def test_unusual_order_negative_stride(self): + a = arange(12).reshape(3, 4) + b = a.T[::-1] + low, high = utils.byte_bounds(b) + assert_equal(high - low, b.size * b.itemsize) + + def test_strided(self): + a = arange(12) + b = a[::2] + low, high = utils.byte_bounds(b) + # the largest pointer address is lost (even numbers only in the + # stride), and compensate addresses for striding by 2 + assert_equal(high - low, b.size * 2 * b.itemsize - b.itemsize) def test_assert_raises_regex_context_manager(): |