aboutsummaryrefslogtreecommitdiff
path: root/tests/Test.hs
diff options
context:
space:
mode:
authorJoris2016-03-20 22:04:11 +0100
committerJoris2016-03-20 22:04:11 +0100
commit5edfb35f6be596e9d91df6690b9977c783bb147b (patch)
tree537c7f62879884a57957d90cf0f284a1bff51745 /tests/Test.hs
parent28f8f4d52e72953ed8bdf1518a259c8b57ed3596 (diff)
Return Either instead of Maybe for lookup
Diffstat (limited to 'tests/Test.hs')
-rw-r--r--tests/Test.hs46
1 files changed, 24 insertions, 22 deletions
diff --git a/tests/Test.hs b/tests/Test.hs
index 03f9d39..641e1e6 100644
--- a/tests/Test.hs
+++ b/tests/Test.hs
@@ -8,6 +8,8 @@ import Prelude hiding (lookup)
import qualified Data.HashMap.Strict as M
import Data.Maybe (fromJust)
+import Data.Either (isLeft)
+import Data.Text (Text)
import Test.Framework
import Test.Framework.Providers.HUnit
@@ -38,8 +40,8 @@ bindingAssertion = do
assertEqual "empty" (M.fromList []) (hashMap empty)
oneBinding <- forceGetConfig "x = \"foo\""
- assertEqual "one binding present" (Just "foo") (lookup "x" oneBinding :: Maybe String)
- assertEqual "one binding missing" Nothing (lookup "y" oneBinding :: Maybe String)
+ assertEqual "one binding present" (Right "foo") (lookup "x" oneBinding)
+ assertBool "one binding missing" (isLeft $ (lookup "y" oneBinding :: Either Text Int))
assertEqual "one binding count" 1 (M.size . hashMap $ oneBinding)
multipleBindings <- forceGetConfig $ T.unlines
@@ -48,7 +50,7 @@ bindingAssertion = do
, "z = \"baz\""
]
assertEqual "multiple bindings count" 3 (M.size . hashMap $ multipleBindings)
- assertEqual "multiple bindings last" (Just "baz") (lookup "z" multipleBindings :: Maybe String)
+ assertEqual "multiple bindings last" (Right "baz") (lookup "z" multipleBindings)
overlappingBindings <- forceGetConfig $ T.unlines
[ "x = \"foo\""
@@ -56,7 +58,7 @@ bindingAssertion = do
, "x = \"baz\""
]
assertEqual "overlapping bindings count" 2 (M.size . hashMap $ overlappingBindings)
- assertEqual "overlapping bindings redefinition" (Just "baz") (lookup "x" overlappingBindings :: Maybe String)
+ assertEqual "overlapping bindings redefinition" (Right "baz") (lookup "x" overlappingBindings)
lookupDefaultAssertion :: Assertion
lookupDefaultAssertion = do
@@ -71,9 +73,9 @@ nameAssertion = do
, "valid_ident = \"foo\""
, "valid-ident = \"foo\""
]
- assertEqual "validIdent" (Just "foo") (lookup "validIdent" validNames :: Maybe String)
- assertEqual "valid_ident" (Just "foo") (lookup "valid_ident" validNames :: Maybe String)
- assertEqual "valid-ident" (Just "foo") (lookup "valid-ident" validNames :: Maybe String)
+ assertEqual "validIdent" (Right "foo") (lookup "validIdent" validNames)
+ assertEqual "valid_ident" (Right "foo") (lookup "valid_ident" validNames)
+ assertEqual "valid-ident" (Right "foo") (lookup "valid-ident" validNames)
invalid1 <- getConfig "-invalid_ident = \"foo\""
assertEqual "-invalid" Nothing invalid1
@@ -89,12 +91,12 @@ valueAssertion = do
, "c = 5.0 "
, "d = True "
]
- assertEqual "string" (Just "lorem ipsum sir dolor emet") (lookup "a" config :: Maybe String)
- assertEqual "integer" (Just 4) (lookup "b" config :: Maybe Int)
- assertEqual "double 1" (Just 4.0) (lookup "b" config :: Maybe Double)
- assertEqual "double 2" (Just 5.0) (lookup "c" config :: Maybe Double)
- assertEqual "integer fail" Nothing (lookup "c" config :: Maybe Int)
- assertEqual "boolean" (Just True) (lookup "d" config :: Maybe Bool)
+ assertEqual "string" (Right "lorem ipsum sir dolor emet") (lookup "a" config)
+ assertEqual "integer" (Right 4) (lookup "b" config)
+ assertEqual "double 1" (Right 4.0) (lookup "b" config)
+ assertEqual "double 2" (Right 5.0) (lookup "c" config)
+ assertBool "integer fail" (isLeft $ (lookup "c" config :: Either Text Int))
+ assertEqual "boolean" (Right True) (lookup "d" config)
return ()
skipAssertion :: Assertion
@@ -110,18 +112,18 @@ skipAssertion = do
, " "
]
assertEqual "bindings count" 2 (M.size . hashMap $ config)
- assertEqual "bindings x" (Just "foo") (lookup "x" config :: Maybe String)
- assertEqual "bindings y" (Just "bar") (lookup "y" config :: Maybe String)
+ assertEqual "bindings x" (Right "foo") (lookup "x" config)
+ assertEqual "bindings y" (Right "bar") (lookup "y" config)
importAssertion :: Assertion
importAssertion = do
config <- fromJust . eitherToMaybe <$> readConfig "tests/resources/a.conf"
- assertEqual "a" (Just "foo") (lookup "a" config :: Maybe String)
- assertEqual "b" (Just 15) (lookup "b" config :: Maybe Int)
- assertEqual "c" (Just "re baz") (lookup "c" config :: Maybe String)
- assertEqual "d" (Just "zap") (lookup "d" config :: Maybe String)
- assertEqual "e" (Just "re nam") (lookup "e" config :: Maybe String)
- assertEqual "f" (Just 8.5) (lookup "f" config :: Maybe Double)
+ assertEqual "a" (Right "foo") (lookup "a" config)
+ assertEqual "b" (Right 15) (lookup "b" config)
+ assertEqual "c" (Right "re baz") (lookup "c" config)
+ assertEqual "d" (Right "zap") (lookup "d" config)
+ assertEqual "e" (Right "re nam") (lookup "e" config)
+ assertEqual "f" (Right 8.5) (lookup "f" config)
missingConfig <- getConfig "import \"required.conf\""
assertEqual "missing config" Nothing missingConfig
@@ -130,4 +132,4 @@ importAssertion = do
[ "importMaybe \"required.conf\""
, "x = 4"
]
- assertEqual "missing optional config" (Just 4) (lookup "x" missingOptionalConfig :: Maybe Int)
+ assertEqual "missing optional config" (Right 4) (lookup "x" missingOptionalConfig)