-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpyarr_to_v_test.py
48 lines (38 loc) · 1.43 KB
/
pyarr_to_v_test.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
import pdb, numpy
import libpyarr_to_v
def test_pyarr_to_vector_tensor_double():
x = numpy.random.random((3,5))
vvd = libpyarr_to_v.pyarr_to_2d_vec_double(x)
for a in range(x.shape[0]):
for b in range(x.shape[1]):
assert(vvd[a][b] == x[a, b])
x2 = numpy.random.random((3,5, 3))
vvvd = libpyarr_to_v.pyarr_to_3d_vec_double(x2)
for a in range(x2.shape[0]):
for b in range(x2.shape[1]):
for c in range(x2.shape[2]):
assert(vvvd[a][b][c] == x2[a, b, c])
expect_error(libpyarr_to_v.pyarr_to_3d_vec_double,
RuntimeError,
numpy.zeros((3,5)))
expect_error(libpyarr_to_v.pyarr_to_3d_vec_double,
RuntimeError,
numpy.zeros((1,)))
expect_error(libpyarr_to_v.pyarr_to_3d_vec_double,
RuntimeError,
numpy.zeros((1,2,3,5)))
expect_error(libpyarr_to_v.pyarr_to_2d_vec_double,
RuntimeError,
numpy.zeros((1,)))
expect_error(libpyarr_to_v.pyarr_to_2d_vec_double,
RuntimeError,
numpy.zeros((1,2,3)))
def expect_error(func, err, *args, **kwargs):
try:
func(*args, **kwargs)
except err:
pass
except Exception as e:
raise AssertionError("got unexpected exception: {}: {}".format(type(e), e))
else:
raise AssertionError("didn't get expected exception")