mirror of
https://github.com/unisonweb/unison.git
synced 2024-11-14 16:28:34 +03:00
7a2a8fb28b
This adds a _base transcript which will be run as a prelude before the other transcripts (not sure how yet). The goal is to cut down on the boilerplate which has been creeping into the tests. We also rename a few more of the builtin IO functions which return Either Failure a
4.7 KiB
4.7 KiB
Unit tests for builtin functions
This transcript defines unit tests for builtin functions. There's a single .> test
execution at the end that will fail the transcript with a nice report if any of the tests fail.
Int
functions
use Int
-- Note: you can make the tests more fine-grained if you
-- want to be able to tell which one is failing
test> Int.tests.arithmetic =
checks [
+1 + +1 `eq` +2,
+10 - +4 == +6,
+11 * +6 `eq` +66,
+11 * +6 `eq` +66,
+10 / +3 == +3,
+10 / +5 == +2,
+10 `mod` +3 == +1,
+10 `mod` +2 == +0,
-13 `mod` +3 == +2,
-13 `mod` -3 == -1,
-13 `mod` -5 == -3,
-13 `mod` +5 == +2,
negate +99 == -99,
increment +99 == +100,
not (isEven +99),
isEven +100,
isOdd +105,
not (isOdd +108),
signum +99 == +1,
signum -3949 == -1,
signum +0 == +0,
+42 `gt` -1,
+42 `lt` +1000,
+43 `lteq` +43,
+43 `lteq` +44,
+43 `gteq` +43,
+43 `gteq` +41
]
test> Int.tests.bitTwiddling =
checks [
+5 `and` +4 == +4,
+5 `and` +1 == +1,
+4 `or` +1 == +5,
+5 `xor` +1 == +4,
complement -1 == +0,
popCount +1 == 1,
popCount +2 == 1,
popCount +4 == 1,
popCount +5 == 2,
popCount -1 == 64,
leadingZeros +1 == 63,
trailingZeros +1 == 0,
leadingZeros +2 == 62,
trailingZeros +2 == 1,
pow +2 6 == +64,
shiftLeft +1 6 == +64,
shiftRight +64 6 == +1
]
test> Int.tests.conversions =
checks [
truncate0 -2438344 == 0,
truncate0 +999 == 999,
toText +0 == "0",
toText +10 == "10",
toText -1039 == "-1039",
fromText "+0" == Some +0,
fromText "a8f9djasdlfkj" == None,
fromText "3940" == Some +3940,
toFloat +9394 == 9394.0,
toFloat -20349 == -20349.0
]
Nat
functions
use Nat
test> Nat.tests.arithmetic =
checks [
1 + 1 `eq` 2,
10 `drop` 4 == 6,
10 `sub` 12 == -2,
11 * 6 `eq` 66,
10 / 3 == 3,
10 / 5 == 2,
10 `mod` 3 == 1,
10 `mod` 2 == 0,
increment 99 == 100,
not (isEven 99),
isEven 100,
isOdd 105,
not (isOdd 108),
42 `gt` 1,
42 `lt` 1000,
43 `lteq` 43,
43 `lteq` 44,
43 `gteq` 43,
43 `gteq` 41
]
test> Nat.tests.bitTwiddling =
checks [
5 `and` 4 == 4,
5 `and` 1 == 1,
4 `or` 1 == 5,
5 `xor` 1 == 4,
complement (complement 0) == 0,
popCount 1 == 1,
popCount 2 == 1,
popCount 4 == 1,
popCount 5 == 2,
popCount (complement 0) == 64,
leadingZeros 1 == 63,
trailingZeros 1 == 0,
leadingZeros 2 == 62,
trailingZeros 2 == 1,
pow 2 6 == 64,
shiftLeft 1 6 == 64,
shiftRight 64 6 == 1
]
test> Nat.tests.conversions =
checks [
toFloat 2438344 == 2438344.0,
toFloat 0 == 0.0,
toText 0 == "0",
toText 32939 == "32939",
toText 10 == "10",
fromText "ooga" == None,
fromText "90" == Some 90
]
Any
functions
> [Any "hi", Any (41 + 1)]
test> Any.test1 = checks [(Any "hi" == Any "hi")]
test> Any.test2 = checks [(not (Any "hi" == Any 42))]
I found and typechecked these definitions in scratch.u. If you
do an `add` or `update`, here's how your codebase would
change:
⍟ These new definitions are ok to `add`:
Any.test1 : [Result]
Any.test2 : [Result]
Now evaluating any watch expressions (lines starting with
`>`)... Ctrl+C cancels.
1 | > [Any "hi", Any (41 + 1)]
⧩
[Any "hi", Any 42]
3 | test> Any.test1 = checks [(Any "hi" == Any "hi")]
✅ Passed Passed
4 | test> Any.test2 = checks [(not (Any "hi" == Any 42))]
✅ Passed Passed
Run the tests
Now that all the tests have been added to the codebase, let's view the test report. This will fail the transcript (with a nice message) if any of the tests are failing.
.> test
Cached test results (`help testcache` to learn more)
◉ Any.test1 Passed
◉ Any.test2 Passed
◉ Int.tests.arithmetic Passed
◉ Int.tests.bitTwiddling Passed
◉ Int.tests.conversions Passed
◉ Nat.tests.arithmetic Passed
◉ Nat.tests.bitTwiddling Passed
◉ Nat.tests.conversions Passed
✅ 8 test(s) passing
Tip: Use view Any.test1 to view the source of a test.