-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtests.py
More file actions
63 lines (54 loc) · 1.58 KB
/
Copy pathtests.py
File metadata and controls
63 lines (54 loc) · 1.58 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
60
61
62
from sparse_recommender import Sparse
def test_setMatrix():
matrix = Sparse()
matrix.set(0, 0, 4)
matrix.set(0, 1, 3)
matrix.set(1, 0, 6)
matrix.set(1, 1, 2)
assert matrix.get(1, 0) == 6
assert matrix.get(0, 3) == 0
def test_getMatrix():
matrix = Sparse()
matrix.set(0, 0, 9)
matrix.set(0, 1, 8)
matrix.set(1, 0, 7)
matrix.set(1, 1, 6)
assert matrix.get(0, 0) == 9
assert matrix.get(3, 1) == 0 #testing edge case that is not set
def test_recommendMatrix():
matrix = Sparse()
matrix.set(0, 0, 4)
matrix.set(0, 1, 3)
matrix.set(1, 0, 6)
matrix.set(1, 1, 2)
assert matrix.recommend([0,6]) == {0: 18, 1: 12}
assert matrix.recommend([2,3]) == {0: 17, 1: 18}
assert matrix.recommend([4,8,5]) == {0: 40, 1: 40}
def test_to_dense():
matrix = Sparse()
matrix.set(0, 0, 4)
matrix.set(0, 1, 3)
matrix.set(1, 0, 6)
matrix.set(1, 1, 2)
matrix.set(1, 5, 5) #testing edge case here
assert matrix.to_dense() == [[4, 3, 0], [6, 2, 5]]
def test_add_movie():
matrix = Sparse()
matrix.set(0, 0, 4)
matrix.set(0, 1, 3)
matrix.set(1, 0, 6)
matrix.set(1, 1, 2)
matrixNew = Sparse()
matrixNew.set(0, 2, 4)
matrixNew.set(0, 3, 9)
result = matrix.add_movie(matrixNew)
assert result.get(0, 1) == 3
assert result.get(0, 2) == 4
assert result.get(0, 3) == 9
def test_add_movie():
matrix1 = Sparse()
matrix1.set(1, 1, 3)
matrix2 = Sparse()
matrix2.set(1, 1, 2)
result_matrix = matrix1.add_movie(matrix2)
assert result_matrix.get(1, 1) == 5