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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
|
-module(list_test).
-compile(no_auto_import).
-export([length_test/0, reverse_test/0, is_empty_test/0, contains_test/0, head_test/0, tail_test/0, filter_test/0, map_test/0, traverse_test/0, drop_test/0, take_test/0, new_test/0, append_test/0, flatten_test/0, fold_test/0, fold_right_test/0, find_test/0, all_test/0, any_test/0, zip_test/0, intersperse_test/0, at_test/0, unique_test/0, sort_test/0]).
length_test() ->
expect:equal(list:length([]), 0),
expect:equal(list:length([1]), 1),
expect:equal(list:length([1, 1]), 2),
expect:equal(list:length([1, 1, 1]), 3).
reverse_test() ->
expect:equal(list:reverse([]), []),
expect:equal(list:reverse([1, 2, 3, 4, 5]), [5, 4, 3, 2, 1]).
is_empty_test() ->
expect:true(list:is_empty([])),
expect:false(list:is_empty([1])).
contains_test() ->
expect:true(list:contains([0, 4, 5, 1], 1)),
expect:false(list:contains([0, 4, 5, 7], 1)),
expect:false(list:contains([], 1)).
head_test() ->
expect:equal(list:head([0, 4, 5, 7]), {ok, 0}),
expect:is_error(list:head([])).
tail_test() ->
expect:equal(list:tail([0, 4, 5, 7]), {ok, [4, 5, 7]}),
expect:equal(list:tail([0]), {ok, []}),
expect:is_error(list:tail([])).
filter_test() ->
expect:equal(list:filter([], fun(_) -> true end), []),
expect:equal(list:filter([0, 4, 5, 7, 3], fun(_) -> true end),
[0, 4, 5, 7, 3]),
expect:equal(list:filter([0, 4, 5, 7, 3], fun(X) -> X > 4 end), [5, 7]),
expect:equal(list:filter([0, 4, 5, 7, 3], fun(X) -> X < 4 end), [0, 3]).
map_test() ->
expect:equal(list:map([], fun(X) -> X * 2 end), []),
expect:equal(list:map([0, 4, 5, 7, 3], fun(X) -> X * 2 end),
[0, 8, 10, 14, 6]).
traverse_test() ->
Fun = fun(X) -> case X =:= 6 orelse X =:= 5 orelse X =:= 4 of
true ->
{ok, X * 2};
false ->
{error, X}
end end,
expect:equal(list:traverse([5, 6, 5, 6], Fun), {ok, [10, 12, 10, 12]}),
expect:equal(list:traverse([4, 6, 5, 7, 3], Fun), {error, 7}).
drop_test() ->
expect:equal(list:drop([], 5), []),
expect:equal(list:drop([1, 2, 3, 4, 5, 6, 7, 8], 5), [6, 7, 8]).
take_test() ->
expect:equal(list:take([], 5), []),
expect:equal(list:take([1, 2, 3, 4, 5, 6, 7, 8], 5), [1, 2, 3, 4, 5]).
new_test() ->
expect:equal(list:new(), []).
append_test() ->
expect:equal(list:append([1], [2, 3]), [1, 2, 3]).
flatten_test() ->
expect:equal(list:flatten([]), []),
expect:equal(list:flatten([[]]), []),
expect:equal(list:flatten([[], [], []]), []),
expect:equal(list:flatten([[1, 2], [], [3, 4]]), [1, 2, 3, 4]).
fold_test() ->
expect:equal(list:fold([1, 2, 3], [], fun(X, Acc) -> [X | Acc] end),
[3, 2, 1]).
fold_right_test() ->
expect:equal(list:fold_right([1, 2, 3], [], fun(X, Acc) -> [X | Acc] end),
[1, 2, 3]).
find_test() ->
F = fun(X) -> case X of
2 ->
{ok, 4};
_ ->
{error, 0}
end end,
expect:equal(list:find([1, 2, 3], F), {ok, 4}),
expect:equal(list:find([1, 3, 2], F), {ok, 4}),
expect:is_error(list:find([1, 3], F)).
all_test() ->
expect:equal(list:all([1, 2, 3, 4, 5], fun(X) -> X > 0 end), true),
expect:equal(list:all([1, 2, 3, 4, 5], fun(X) -> X < 0 end), false),
expect:equal(list:all([], fun(_) -> false end), true).
any_test() ->
expect:equal(list:any([1, 2, 3, 4, 5], fun(X) -> X =:= 2 end), true),
expect:equal(list:any([1, 2, 3, 4, 5], fun(X) -> X < 0 end), false),
expect:equal(list:any([], fun(_) -> false end), false).
zip_test() ->
expect:equal(list:zip([], [1, 2, 3]), []),
expect:equal(list:zip([1, 2], []), []),
expect:equal(list:zip([1, 2, 3], [4, 5, 6]), [{1, 4}, {2, 5}, {3, 6}]),
expect:equal(list:zip([5, 6], [1, 2, 3]), [{5, 1}, {6, 2}]),
expect:equal(list:zip([5, 6, 7], [1, 2]), [{5, 1}, {6, 2}]).
intersperse_test() ->
expect:equal(list:intersperse([1, 2, 3], 4), [1, 4, 2, 4, 3]),
expect:equal(list:intersperse([], 2), []).
at_test() ->
expect:equal(list:at([1, 2, 3], 2), {ok, 3}),
expect:is_error(list:at([1, 2, 3], 5)),
expect:is_error(list:at([], 0)),
expect:is_error(list:at([1, 2, 3, 4, 5, 6], -1)).
unique_test() ->
expect:equal(list:unique([1, 1, 2, 3, 4, 4, 4, 5, 6]), [1, 2, 3, 4, 5, 6]),
expect:equal(list:unique([7, 1, 45, 6, 2, 47, 2, 7, 5]),
[7, 1, 45, 6, 2, 47, 5]),
expect:equal(list:unique([3, 4, 5]), [3, 4, 5]),
expect:equal(list:unique([]), []).
sort_test() ->
expect:equal(list:sort([4, 3, 6, 5, 4]), [3, 4, 4, 5, 6]),
expect:equal(list:sort([]), []),
expect:equal(list:sort([{1, 2}, {4, 5}, {3, 2}]), [{1, 2}, {3, 2}, {4, 5}]).
|