aboutsummaryrefslogtreecommitdiff
path: root/stdlib
diff options
context:
space:
mode:
Diffstat (limited to 'stdlib')
-rw-r--r--stdlib/source/lux/test.lux85
1 files changed, 43 insertions, 42 deletions
diff --git a/stdlib/source/lux/test.lux b/stdlib/source/lux/test.lux
index 647ae8895..928e90506 100644
--- a/stdlib/source/lux/test.lux
+++ b/stdlib/source/lux/test.lux
@@ -36,14 +36,14 @@
[world
["." program]]])
-(type: #export Counters
+(type: #export Tally
{#successes Nat
#failures Nat
#expected_coverage (Set Name)
#actual_coverage (Set Name)})
-(def: (add_counters parameter subject)
- (-> Counters Counters Counters)
+(def: (add_tally parameter subject)
+ (-> Tally Tally Tally)
{#successes (n.+ (get@ #successes parameter) (get@ #successes subject))
#failures (n.+ (get@ #failures parameter) (get@ #failures subject))
#expected_coverage (set.union (get@ #expected_coverage parameter)
@@ -52,21 +52,21 @@
(get@ #actual_coverage subject))})
(def: start
- Counters
+ Tally
{#successes 0
#failures 0
#expected_coverage (set.new name.hash)
#actual_coverage (set.new name.hash)})
(template [<name> <category>]
- [(def: <name> Counters (update@ <category> .inc start))]
+ [(def: <name> Tally (update@ <category> .inc start))]
[success #successes]
[failure #failures]
)
(type: #export Assertion
- (Promise [Counters Text]))
+ (Promise [Tally Text]))
(type: #export Test
(Random Assertion))
@@ -77,9 +77,9 @@
{#.doc "Sequencing combinator."}
(-> Assertion Assertion Assertion)
(do promise.monad
- [[l_counter l_documentation] left
- [r_counter r_documentation] right]
- (wrap [(add_counters l_counter r_counter)
+ [[l_tally l_documentation] left
+ [r_tally r_documentation] right]
+ (wrap [(add_tally l_tally r_tally)
(format l_documentation ..separator r_documentation)])))
(def: #export (and left right)
@@ -94,12 +94,12 @@
(def: #export (context description)
(-> Text Test Test)
- (random\map (promise\map (function (_ [counters documentation])
- [counters (|> documentation
- (text.split_all_with ..separator)
- (list\map (|>> (format context_prefix)))
- (text.join_with ..separator)
- (format description ..separator))]))))
+ (random\map (promise\map (function (_ [tally documentation])
+ [tally (|> documentation
+ (text.split_all_with ..separator)
+ (list\map (|>> (format context_prefix)))
+ (text.join_with ..separator)
+ (format description ..separator))]))))
(def: failure_prefix "[Failure] ")
(def: success_prefix "[Success] ")
@@ -144,7 +144,7 @@
[prng result])))
(def: failed?
- (-> Counters Bit)
+ (-> Tally Bit)
(|>> (get@ #failures) (n.> 0)))
(def: (times_failure seed documentation)
@@ -158,33 +158,34 @@
(-> Nat Test Test)
(case amount
0 (..fail (exception.construct ..must_try_test_at_least_once []))
- 1 test
_ (do random.monad
[seed random.nat]
(function (_ prng)
(let [[prng' instance] (random.run (random.pcg32 [..pcg32_magic_inc seed]) test)]
[prng' (do promise.monad
- [[counters documentation] instance]
- (if (failed? counters)
- (wrap [counters (times_failure seed documentation)])
- (|> test (times (dec amount)) (random.run prng') product.right)))])))))
-
-(def: (tally duration counters)
- (-> Duration Counters Text)
- (let [successes (get@ #successes counters)
- failures (get@ #failures counters)
- missing (set.difference (get@ #actual_coverage counters)
- (get@ #expected_coverage counters))
- unexpected (set.difference (get@ #expected_coverage counters)
- (get@ #actual_coverage counters))
+ [[tally documentation] instance]
+ (if (failed? tally)
+ (wrap [tally (times_failure seed documentation)])
+ (case amount
+ 1 instance
+ _ (|> test (times (dec amount)) (random.run prng') product.right))))])))))
+
+(def: (description duration tally)
+ (-> Duration Tally Text)
+ (let [successes (get@ #successes tally)
+ failures (get@ #failures tally)
+ missing (set.difference (get@ #actual_coverage tally)
+ (get@ #expected_coverage tally))
+ unexpected (set.difference (get@ #expected_coverage tally)
+ (get@ #actual_coverage tally))
report (: (-> (Set Name) Text)
(|>> set.to_list
(list.sort (\ name.order <))
(exception.enumerate %.name)))
- expected_definitions_to_cover (set.size (get@ #expected_coverage counters))
+ expected_definitions_to_cover (set.size (get@ #expected_coverage tally))
unexpected_definitions_covered (set.size unexpected)
actual_definitions_covered (n.- unexpected_definitions_covered
- (set.size (get@ #actual_coverage counters)))
+ (set.size (get@ #actual_coverage tally)))
coverage (case expected_definitions_to_cover
0 "N/A"
expected (let [missing_ratio (f./ (n.frac expected)
@@ -228,14 +229,14 @@
[pre (promise.future instant.now)
#let [seed (instant.to_millis pre)
prng (random.pcg32 [..pcg32_magic_inc seed])]
- [counters documentation] (|> test (random.run prng) product.right)
+ [tally documentation] (|> test (random.run prng) product.right)
post (promise.future instant.now)
#let [duration (instant.span pre post)
_ (debug.log! (format documentation text.new_line text.new_line
- (tally duration counters)
+ (..description duration tally)
text.new_line))]]
(promise.future (\ program.default exit
- (case (get@ #failures counters)
+ (case (get@ #failures tally)
0 ..success_exit_code
_ ..failure_exit_code)))))
@@ -246,8 +247,8 @@
(text.join_with " & "))
coverage (set.from_list name.hash coverage)]
(|> (..assert message condition)
- (promise\map (function (_ [counters documentation])
- [(update@ #actual_coverage (set.union coverage) counters)
+ (promise\map (function (_ [tally documentation])
+ [(update@ #actual_coverage (set.union coverage) tally)
documentation])))))
(def: (|cover| coverage condition)
@@ -261,8 +262,8 @@
(list\map %.name)
(text.join_with " & "))
coverage (set.from_list name.hash coverage)]
- (random\map (promise\map (function (_ [counters documentation])
- [(update@ #actual_coverage (set.union coverage) counters)
+ (random\map (promise\map (function (_ [tally documentation])
+ [(update@ #actual_coverage (set.union coverage) tally)
documentation]))
(..context context test))))
@@ -328,8 +329,8 @@
(-> Text Text Test Test)
(let [coverage (..decode_coverage module coverage)]
(|> (..context module test)
- (random\map (promise\map (function (_ [counters documentation])
- [(update@ #expected_coverage (set.union coverage) counters)
+ (random\map (promise\map (function (_ [tally documentation])
+ [(update@ #expected_coverage (set.union coverage) tally)
documentation]))))))
(syntax: #export (covering {module <c>.identifier}
@@ -375,7 +376,7 @@
[assertions (monad.seq ! (list\map run! tests))]
(wrap [(|> assertions
(list\map product.left)
- (list\fold ..add_counters ..start))
+ (list\fold ..add_tally ..start))
(|> assertions
(list\map product.right)
(text.join_with ..separator))])))))