forked from PierreSenellart/matrix_tutorial
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_matrix.c
More file actions
59 lines (48 loc) · 1.15 KB
/
test_matrix.c
File metadata and controls
59 lines (48 loc) · 1.15 KB
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
#include "utest.h"
#include "matrix.h"
UTEST(matrix_create, simple) {
matrix m = matrix_create(3, 5, 0.);
ASSERT_TRUE(m.ok && m.n1==3 && m.n2==5);
}
UTEST(matrix_create, too_large) {
matrix m = matrix_create((unsigned)-1, (unsigned)-1, 0.);
ASSERT_FALSE(m.ok);
}
UTEST(matrix_create, zero) {
matrix m = matrix_create(0, 0, 0.);
ASSERT_TRUE(m.ok && m.n1==0 && m.n2==0);
}
UTEST(matrix_identity, simple) {
matrix m = matrix_identity(42);
ASSERT_TRUE(m.ok && m.n1==42 && m.n2==42);
}
UTEST(matrix_identity, too_large) {
matrix m = matrix_identity((unsigned) -1);
ASSERT_TRUE(!m.ok);
}
UTEST(matrix_identity, zero) {
matrix m = matrix_identity(0);
ASSERT_TRUE(m.ok && m.n1==0 && m.n2==0);
}
UTEST(matrix_destroy, simple) {
matrix m = matrix_create(2, 5, 0.);
matrix_destroy(m);
ASSERT_TRUE(1);
}
UTEST(matrix_destroy, wrong) {
matrix m;
m.ok=false;
m.data=(scalar*)0xdeadbeef;
matrix_destroy(m);
ASSERT_TRUE(1);
}
UTEST(matrix_get, simple) {
matrix m = matrix_identity(12);
ASSERT_TRUE(*matrix_get(m,3,3)==1.);
}
UTEST(matrix_get, wrong) {
matrix m;
m.ok=false;
ASSERT_TRUE(matrix_get(m, 0, 0)==NULL);
}
UTEST_MAIN()