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
|
#!/usr/bin/env escript
%% -*- erlang -*-
main(_) ->
code:add_pathz("src/couchdb"),
application:start(crypto),
etap:plan(11),
case (catch test()) of
ok ->
etap:end_tests();
Other ->
etap:diag(io_lib:format("Test died abnormally: ~p", [Other])),
etap:bail(Other)
end,
ok.
test() ->
% to_existing_atom
etap:is(true, couch_util:to_existing_atom(true), "An atom is an atom."),
etap:is(foo, couch_util:to_existing_atom(<<"foo">>),
"A binary foo is the atom foo."),
etap:is(foobarbaz, couch_util:to_existing_atom("foobarbaz"),
"A list of atoms is one munged atom."),
% terminate_linked
Self = self(),
spawn(fun() ->
ChildPid = spawn_link(fun() -> receive shutdown -> ok end end),
couch_util:terminate_linked(normal),
Self ! {pid, ChildPid}
end),
receive
{pid, Pid} ->
etap:ok(not is_process_alive(Pid), "why wont this work?")
end,
% new_uuid
etap:isnt(couch_util:new_uuid(), couch_util:new_uuid(),
"A guid ought to be unique."),
% implode
etap:is([1, 38, 2, 38, 3], couch_util:implode([1,2,3],"&"),
"use & as separator in list."),
% trim
Strings = [" foo", "foo ", "\tfoo", " foo ", "foo\t", "foo\n", "\nfoo"],
etap:ok(lists:all(fun(S) -> couch_util:trim(S) == "foo" end, Strings),
"everything here trimmed should be foo."),
% abs_pathname
{ok, Cwd} = file:get_cwd(),
etap:is(Cwd ++ "/foo", couch_util:abs_pathname("./foo"),
"foo is in this directory."),
% should_flush
etap:ok(not couch_util:should_flush(),
"Not using enough memory to flush."),
AcquireMem = fun() ->
IntsToAGazillion = lists:seq(1, 200000),
LotsOfData = lists:map(
fun(Int) -> {Int, <<"foobar">>} end,
lists:seq(1, 200000)),
etap:ok(couch_util:should_flush(),
"Allocation 200K tuples puts us above the memory threshold.")
end,
AcquireMem(),
etap:ok(not couch_util:should_flush(),
"Checking to flush invokes GC."),
ok.
|