aboutsummaryrefslogtreecommitdiff
path: root/gen/test/gleam@result_test.erl
diff options
context:
space:
mode:
authorLouis Pilfold <louis@lpil.uk>2019-06-25 22:48:07 +0100
committerLouis Pilfold <louis@lpil.uk>2019-06-25 22:48:07 +0100
commit2c2541750ca4b7b604070c75c18d84be833c97d5 (patch)
treef5e63d941a1c7e2c2d4dff1d81c43fa2766308ae /gen/test/gleam@result_test.erl
parent96c20b8ebf8420fbba75c97fa08eaeb34e8dc394 (diff)
downloadgleam_stdlib-2c2541750ca4b7b604070c75c18d84be833c97d5.tar.gz
gleam_stdlib-2c2541750ca4b7b604070c75c18d84be833c97d5.zip
stdlib namespace std -> gleam
Diffstat (limited to 'gen/test/gleam@result_test.erl')
-rw-r--r--gen/test/gleam@result_test.erl47
1 files changed, 47 insertions, 0 deletions
diff --git a/gen/test/gleam@result_test.erl b/gen/test/gleam@result_test.erl
new file mode 100644
index 0000000..e246694
--- /dev/null
+++ b/gen/test/gleam@result_test.erl
@@ -0,0 +1,47 @@
+-module(gleam@result_test).
+-compile(no_auto_import).
+
+-export([is_ok_test/0, is_error_test/0, map_test/0, map_error_test/0, flatten_test/0, then_test/0, unwrap_test/0]).
+
+is_ok_test() ->
+ gleam@expect:true(gleam@result:is_ok({ok, 1})),
+ gleam@expect:false(gleam@result:is_ok({error, 1})).
+
+is_error_test() ->
+ gleam@expect:false(gleam@result:is_error({ok, 1})),
+ gleam@expect:true(gleam@result:is_error({error, 1})).
+
+map_test() ->
+ gleam@expect:equal(gleam@result:map({ok, 1}, fun(X) -> X + 1 end), {ok, 2}),
+ gleam@expect:equal(gleam@result:map({ok, 1}, fun(_) -> <<"2">> end),
+ {ok, <<"2">>}),
+ gleam@expect:equal(gleam@result:map({error, 1}, fun(X) -> X + 1 end),
+ {error, 1}).
+
+map_error_test() ->
+ gleam@expect:equal(gleam@result:map_error({ok, 1}, fun(X) -> X + 1 end),
+ {ok, 1}),
+ gleam@expect:equal(gleam@result:map_error({error, 1}, fun(X) -> X + 1 end),
+ {error, 2}).
+
+flatten_test() ->
+ gleam@expect:equal(gleam@result:flatten({ok, {ok, 1}}), {ok, 1}),
+ gleam@expect:equal(gleam@result:flatten({ok, {error, 1}}), {error, 1}),
+ gleam@expect:equal(gleam@result:flatten({error, 1}), {error, 1}),
+ gleam@expect:equal(gleam@result:flatten({error, {error, 1}}),
+ {error, {error, 1}}).
+
+then_test() ->
+ gleam@expect:equal(gleam@result:then({error, 1}, fun(X) -> {ok, X + 1} end),
+ {error, 1}),
+ gleam@expect:equal(gleam@result:then({ok, 1}, fun(X) -> {ok, X + 1} end),
+ {ok, 2}),
+ gleam@expect:equal(gleam@result:then({ok, 1},
+ fun(_) -> {ok, <<"type change">>} end),
+ {ok, <<"type change">>}),
+ gleam@expect:equal(gleam@result:then({ok, 1}, fun(_) -> {error, 1} end),
+ {error, 1}).
+
+unwrap_test() ->
+ gleam@expect:equal(gleam@result:unwrap({ok, 1}, 50), 1),
+ gleam@expect:equal(gleam@result:unwrap({error, <<"nope">>}, 50), 50).