File: test_coordinate.py

package info (click to toggle)
apbs 3.4.1-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 199,188 kB
  • sloc: ansic: 284,988; cpp: 60,416; fortran: 44,896; xml: 13,895; sh: 13,838; python: 8,105; yacc: 2,922; makefile: 1,428; f90: 989; objc: 448; lex: 294; awk: 266; sed: 205; java: 134; csh: 79
file content (106 lines) | stat: -rw-r--r-- 2,742 bytes parent folder | download | duplicates (3)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import numpy as np
from apbs.geometry import Coordinate
import pytest


class TestCoordinate:
    @pytest.mark.parametrize(
        "args,expect",
        [
            ((0, 0, 0), np.array([0, 0, 0], dtype=np.float32)),
            ((1, 2, 3), np.array([1, 2, 3], dtype=np.float32)),
            (tuple(), np.array([0, 0, 0], dtype=np.float32)),
        ],
    )
    def test_ctor(self, args, expect):
        sut = Coordinate(*args)
        assert (sut._data == expect).all()

    @pytest.mark.parametrize("args", [range(1), range(2), range(4), range(5)])
    def test_exceptions(self, args):
        with pytest.raises(RuntimeError):
            sut = Coordinate(*args)

    def test_property_get(self):
        sut = Coordinate(1, 2, 3)
        assert sut.x == 1
        assert sut.y == 2
        assert sut.z == 3

    def test_property_set(self):
        sut = Coordinate(0, 0, 0)
        assert sut.x == 0
        assert sut.y == 0
        assert sut.z == 0
        sut.x = 1
        sut.y = 2
        sut.z = 3
        assert sut.x == 1
        assert sut.y == 2
        assert sut.z == 3

    def test_get_idx(self):
        sut = Coordinate(0, 0, 0)
        sut[0] = 1
        sut[1] = 2
        sut[2] = 3
        assert sut.x == 1
        assert sut.y == 2
        assert sut.z == 3

        with pytest.raises(IndexError):
            sut[3] = 5

    def test_operators(self):
        lo = Coordinate(0, 0, 0)
        hi = Coordinate(1, 1, 1)
        assert hi > lo

        same1 = Coordinate(0, 0, 0)
        same2 = Coordinate(0, 0, 0)
        assert same1 == same2

        lo = Coordinate(0, 0, 0)
        hi = Coordinate(1, 1, 1)
        assert hi != lo

        same1 = Coordinate(0, 0, 0)
        same2 = Coordinate(0, 0, 0)
        assert same1 <= same2
        lo = Coordinate(0, 0, 0)
        hi = Coordinate(1, 1, 1)
        assert lo <= hi

        same1 = Coordinate(0, 0, 0)
        same2 = Coordinate(0, 0, 0)
        assert same1 >= same2
        lo = Coordinate(0, 0, 0)
        hi = Coordinate(1, 1, 1)
        assert lo <= hi

        c = Coordinate(0, 0, 0)
        assert c + 1 == Coordinate(1, 1, 1)

        c = Coordinate(1, 1, 1)
        assert c - 1 == Coordinate(0, 0, 0)

        c = Coordinate(1, 1, 1)
        assert c * 2 == Coordinate(2, 2, 2)

        c = Coordinate(2, 2, 2)
        assert c / 2 == Coordinate(1, 1, 1)

    def test_any(self):
        c = Coordinate(3, 2, 2)
        assert c.any(lambda x: x > 2)

        c = Coordinate(-1, 2, 2)
        assert c.any(lambda x: x < 0)
        assert c.any(lambda x: x == -1)

    def test_all(self):
        c = Coordinate(2, 2, 2)
        assert c.all(lambda x: x == 2)

        c = Coordinate(-1, 2, 2)
        assert c.all(lambda x: x < 3)