Initial take on easier imports
This commit is contained in:
36
test/Spec.hs
36
test/Spec.hs
@ -366,98 +366,98 @@ lambdas = testGroup "Lambda Evaluation Tests"
|
||||
providedLibraries :: TestTree
|
||||
providedLibraries = testGroup "Library Tests"
|
||||
[ testCase "Triage test Leaf" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "test t"
|
||||
env = decodeResult $ result $ evalTricu library (parseTricu input)
|
||||
env @?= "\"Leaf\""
|
||||
|
||||
, testCase "Triage test (Stem Leaf)" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "test (t t)"
|
||||
env = decodeResult $ result $ evalTricu library (parseTricu input)
|
||||
env @?= "\"Stem\""
|
||||
|
||||
, testCase "Triage test (Fork Leaf Leaf)" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "test (t t t)"
|
||||
env = decodeResult $ result $ evalTricu library (parseTricu input)
|
||||
env @?= "\"Fork\""
|
||||
|
||||
, testCase "Boolean NOT: true" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "not? true"
|
||||
env = result $ evalTricu library (parseTricu input)
|
||||
env @?= Leaf
|
||||
|
||||
, testCase "Boolean NOT: false" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "not? false"
|
||||
env = result $ evalTricu library (parseTricu input)
|
||||
env @?= Stem Leaf
|
||||
|
||||
|
||||
, testCase "Boolean AND TF" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "and? (t t) (t)"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Leaf
|
||||
|
||||
, testCase "Boolean AND FT" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "and? (t) (t t)"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Leaf
|
||||
|
||||
, testCase "Boolean AND FF" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "and? (t) (t)"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Leaf
|
||||
|
||||
, testCase "Boolean AND TT" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "and? (t t) (t t)"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Stem Leaf
|
||||
|
||||
, testCase "List head" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "head [(t) (t t) (t t t)]"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Leaf
|
||||
|
||||
, testCase "List tail" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "head (tail (tail [(t) (t t) (t t t)]))"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Fork Leaf Leaf
|
||||
|
||||
, testCase "List map" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "head (tail (map (a : (t t t)) [(t) (t) (t)]))"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Fork Leaf Leaf
|
||||
|
||||
, testCase "Empty list check" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "emptyList? []"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Stem Leaf
|
||||
|
||||
, testCase "Non-empty list check" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "not? (emptyList? [(1) (2) (3)])"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Stem Leaf
|
||||
|
||||
, testCase "Concatenate strings" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "append \"Hello, \" \"world!\""
|
||||
env = decodeResult $ result $ evalTricu library (parseTricu input)
|
||||
env @?= "\"Hello, world!\""
|
||||
|
||||
, testCase "Verifying Equality" $ do
|
||||
library <- evaluateFile "./lib/list.tri"
|
||||
library <- evaluateFile "./lib/List.tri"
|
||||
let input = "equal? (t t t) (t t t)"
|
||||
env = evalTricu library (parseTricu input)
|
||||
result env @?= Stem Leaf
|
||||
@ -474,12 +474,12 @@ fileEval = testGroup "File evaluation tests"
|
||||
res @?= Fork (Stem Leaf) Leaf
|
||||
|
||||
, testCase "Mapping and Equality" $ do
|
||||
library <- liftIO $ evaluateFile "./lib/list.tri"
|
||||
library <- liftIO $ evaluateFile "./lib/List.tri"
|
||||
fEnv <- liftIO $ evaluateFileWithContext library "./test/map.tri"
|
||||
(mainResult fEnv) @?= Stem Leaf
|
||||
|
||||
, testCase "Eval and decoding string" $ do
|
||||
library <- liftIO $ evaluateFile "./lib/list.tri"
|
||||
library <- liftIO $ evaluateFile "./lib/List.tri"
|
||||
res <- liftIO $ evaluateFileWithContext library "./test/string.tri"
|
||||
decodeResult (result res) @?= "\"String test!\""
|
||||
]
|
||||
|
@ -1,5 +1,4 @@
|
||||
|
||||
!import "lib/base.tri"
|
||||
!import "lib/Base.tri"
|
||||
|
||||
!import "test/named-imports/2.tri"
|
||||
!import "test/named-imports/3.tri" ThreeRenamed
|
||||
|
Reference in New Issue
Block a user