diff options
Diffstat (limited to 'tests/Test.hs')
-rw-r--r-- | tests/Test.hs | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/tests/Test.hs b/tests/Test.hs new file mode 100644 index 0000000..51ced1f --- /dev/null +++ b/tests/Test.hs @@ -0,0 +1,104 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Main + ( main + ) where + +import Prelude hiding (lookup) + +import qualified Data.HashMap.Strict as M + +import Test.Framework +import Test.Framework.Providers.HUnit +import Test.HUnit hiding (Test) + +import Data.ConfigManager +import Data.ConfigManager.Config +import qualified Data.Text as T + +import Helper (forceGetConfig, getConfig) + +main :: IO () +main = defaultMain tests + +tests :: [Test] +tests = + [ testCase "binding" bindingAssertion + , testCase "name" nameAssertion + , testCase "value" valueAssertion + , testCase "skip" skipAssertion + ] + +bindingAssertion :: Assertion +bindingAssertion = do + empty <- forceGetConfig "" + 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 count" 1 (M.size . hashMap $ oneBinding) + + multipleBindings <- forceGetConfig $ T.unlines + [ "x = \"foo\"" + , "y = \"bar\"" + , "z = \"baz\"" + ] + assertEqual "multiple bindings count" 3 (M.size . hashMap $ multipleBindings) + assertEqual "multiple bindings last" (Just "baz") (lookup "z" multipleBindings :: Maybe String) + + overlappingBindings <- forceGetConfig $ T.unlines + [ "x = \"foo\"" + , "y = \"bar\"" + , "x = \"baz\"" + ] + assertEqual "overlapping bindings count" 2 (M.size . hashMap $ overlappingBindings) + assertEqual "overlapping bindings redefinition" (Just "baz") (lookup "x" overlappingBindings :: Maybe String) + +nameAssertion :: Assertion +nameAssertion = do + validNames <- forceGetConfig $ T.unlines + [ "validIdent = \"foo\" " + , "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) + + invalid1 <- getConfig "-invalid_ident = \"foo\"" + assertEqual "-invalid" Nothing invalid1 + + invalid2 <- getConfig "_invalid = \"foo\"" + assertEqual "_invalid" Nothing invalid2 + +valueAssertion :: Assertion +valueAssertion = do + config <- forceGetConfig $ T.unlines + [ "a = \"lorem ipsum sir dolor emet\"" + , "b = 4 " + , "c = 5.0 " + , " " + ] + 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) + return () + +skipAssertion :: Assertion +skipAssertion = do + config <- forceGetConfig $ T.unlines + [ " " + , " # Comment " + , " x = \"foo\" " + , " " + , " #### " + , " " + , " y = \"bar\" # Other comment" + , " " + ] + 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) |