|
import sys |
|
import pytest |
|
import platform |
|
|
|
from numpy.f2py.crackfortran import ( |
|
_selected_int_kind_func as selected_int_kind, |
|
_selected_real_kind_func as selected_real_kind, |
|
) |
|
from . import util |
|
|
|
|
|
class TestKind(util.F2PyTest): |
|
sources = [util.getpath("tests", "src", "kind", "foo.f90")] |
|
|
|
@pytest.mark.skipif(sys.maxsize < 2 ** 31 + 1, |
|
reason="Fails for 32 bit machines") |
|
def test_int(self): |
|
"""Test `int` kind_func for integers up to 10**40.""" |
|
selectedintkind = self.module.selectedintkind |
|
|
|
for i in range(40): |
|
assert selectedintkind(i) == selected_int_kind( |
|
i |
|
), f"selectedintkind({i}): expected {selected_int_kind(i)!r} but got {selectedintkind(i)!r}" |
|
|
|
def test_real(self): |
|
""" |
|
Test (processor-dependent) `real` kind_func for real numbers |
|
of up to 31 digits precision (extended/quadruple). |
|
""" |
|
selectedrealkind = self.module.selectedrealkind |
|
|
|
for i in range(32): |
|
assert selectedrealkind(i) == selected_real_kind( |
|
i |
|
), f"selectedrealkind({i}): expected {selected_real_kind(i)!r} but got {selectedrealkind(i)!r}" |
|
|
|
@pytest.mark.xfail(platform.machine().lower().startswith("ppc"), |
|
reason="Some PowerPC may not support full IEEE 754 precision") |
|
def test_quad_precision(self): |
|
""" |
|
Test kind_func for quadruple precision [`real(16)`] of 32+ digits . |
|
""" |
|
selectedrealkind = self.module.selectedrealkind |
|
|
|
for i in range(32, 40): |
|
assert selectedrealkind(i) == selected_real_kind( |
|
i |
|
), f"selectedrealkind({i}): expected {selected_real_kind(i)!r} but got {selectedrealkind(i)!r}" |
|
|