| | import os |
| | import pytest |
| | import textwrap |
| | import numpy as np |
| | from . import util |
| |
|
| |
|
| | class TestString(util.F2PyTest): |
| | sources = [util.getpath("tests", "src", "string", "char.f90")] |
| |
|
| | @pytest.mark.slow |
| | def test_char(self): |
| | strings = np.array(["ab", "cd", "ef"], dtype="c").T |
| | inp, out = self.module.char_test.change_strings( |
| | strings, strings.shape[1]) |
| | assert inp == pytest.approx(strings) |
| | expected = strings.copy() |
| | expected[1, :] = "AAA" |
| | assert out == pytest.approx(expected) |
| |
|
| |
|
| | class TestDocStringArguments(util.F2PyTest): |
| | sources = [util.getpath("tests", "src", "string", "string.f")] |
| |
|
| | def test_example(self): |
| | a = np.array(b"123\0\0") |
| | b = np.array(b"123\0\0") |
| | c = np.array(b"123") |
| | d = np.array(b"123") |
| |
|
| | self.module.foo(a, b, c, d) |
| |
|
| | assert a.tobytes() == b"123\0\0" |
| | assert b.tobytes() == b"B23\0\0" |
| | assert c.tobytes() == b"123" |
| | assert d.tobytes() == b"D23" |
| |
|
| |
|
| | class TestFixedString(util.F2PyTest): |
| | sources = [util.getpath("tests", "src", "string", "fixed_string.f90")] |
| |
|
| | @staticmethod |
| | def _sint(s, start=0, end=None): |
| | """Return the content of a string buffer as integer value. |
| | |
| | For example: |
| | _sint('1234') -> 4321 |
| | _sint('123A') -> 17321 |
| | """ |
| | if isinstance(s, np.ndarray): |
| | s = s.tobytes() |
| | elif isinstance(s, str): |
| | s = s.encode() |
| | assert isinstance(s, bytes) |
| | if end is None: |
| | end = len(s) |
| | i = 0 |
| | for j in range(start, min(end, len(s))): |
| | i += s[j] * 10**j |
| | return i |
| |
|
| | def _get_input(self, intent="in"): |
| | if intent in ["in"]: |
| | yield "" |
| | yield "1" |
| | yield "1234" |
| | yield "12345" |
| | yield b"" |
| | yield b"\0" |
| | yield b"1" |
| | yield b"\01" |
| | yield b"1\0" |
| | yield b"1234" |
| | yield b"12345" |
| | yield np.ndarray((), np.bytes_, buffer=b"") |
| | yield np.array(b"") |
| | yield np.array(b"\0") |
| | yield np.array(b"1") |
| | yield np.array(b"1\0") |
| | yield np.array(b"\01") |
| | yield np.array(b"1234") |
| | yield np.array(b"123\0") |
| | yield np.array(b"12345") |
| |
|
| | def test_intent_in(self): |
| | for s in self._get_input(): |
| | r = self.module.test_in_bytes4(s) |
| | |
| | expected = self._sint(s, end=4) |
| | assert r == expected, s |
| |
|
| | def test_intent_inout(self): |
| | for s in self._get_input(intent="inout"): |
| | rest = self._sint(s, start=4) |
| | r = self.module.test_inout_bytes4(s) |
| | expected = self._sint(s, end=4) |
| | assert r == expected |
| |
|
| | |
| | assert rest == self._sint(s, start=4) |
| |
|