aboutsummaryrefslogtreecommitdiff
path: root/test/FunTests/Parser.hs
diff options
context:
space:
mode:
Diffstat (limited to 'test/FunTests/Parser.hs')
-rw-r--r--test/FunTests/Parser.hs225
1 files changed, 225 insertions, 0 deletions
diff --git a/test/FunTests/Parser.hs b/test/FunTests/Parser.hs
new file mode 100644
index 0000000..2339a82
--- /dev/null
+++ b/test/FunTests/Parser.hs
@@ -0,0 +1,225 @@
+module FunTests.Parser
+ ( parserTest
+ ) where
+
+import Fun.Parser
+import Test.HUnit
+
+isLeft :: Either a b -> Bool
+isLeft (Left _) = True
+isLeft (Right _) = False
+
+isRight :: Either a b -> Bool
+isRight (Right _) = True
+isRight (Left _) = False
+
+----
+
+testIsDigit :: Test
+testIsDigit = test
+ [ isDigit '0' ~=? True
+ , isDigit '9' ~=? True
+ , isDigit 'A' ~=? False
+ , isDigit 'z' ~=? False
+ ]
+
+testIsAlpha :: Test
+testIsAlpha = test
+ [ isAlpha 'A' ~=? True
+ , isAlpha 'z' ~=? True
+ , isAlpha '0' ~=? False
+ , isAlpha '9' ~=? False
+ ]
+
+testIsLower :: Test
+testIsLower = test
+ [ isLower 'a' ~=? True
+ , isLower 'z' ~=? True
+ , isLower 'A' ~=? False
+ , isLower '9' ~=? False
+ ]
+
+testIsUpper :: Test
+testIsUpper = test
+ [ isUpper 'A' ~=? True
+ , isUpper 'Z' ~=? True
+ , isUpper '9' ~=? False
+ , isUpper 'a' ~=? False
+ ]
+
+testChar :: Test
+testChar = test
+ [ char "abc" ~=? Right ('a', "bc")
+ , char "a" ~=? Right ('a', "")
+ , isLeft (char "") ~=? True
+ ]
+
+testDigit :: Test
+testDigit = test
+ [ digit "123" ~=? Right ('1', "23")
+ , digit "9abc" ~=? Right ('9', "abc")
+ , isLeft (digit "a123") ~=? True
+ ]
+
+testDigits :: Test
+testDigits = test
+ [ digits "123" ~=? Right ("123", "")
+ , digits "98abc" ~=? Right ("98", "abc")
+ , isLeft (digits "a123") ~=? True
+ ]
+
+testNumber :: Test
+testNumber = test
+ [ number "-123" ~=? Right (-123, "")
+ , number "98abc" ~=? Right (98, "abc")
+ , isLeft (number "--123") ~=? True
+ , isLeft (number "a123") ~=? True
+ ]
+
+testSpace :: Test
+testSpace = test
+ [ space " ab" ~=? Right (' ', "ab")
+ , space " a" ~=? Right (' ', " a")
+ , isLeft (space "a b") ~=? True
+ ]
+
+testNotSpace :: Test
+testNotSpace = test
+ [ notSpace "~b" ~=? Right ('~', "b")
+ , notSpace "8b" ~=? Right ('8', "b")
+ , notSpace "ab" ~=? Right ('a', "b")
+ , isLeft (notSpace " b") ~=? True
+ ]
+
+testNewline :: Test
+testNewline = test
+ [ newline "\nab" ~=? Right ('\n', "ab")
+ , newline "\n\na" ~=? Right ('\n', "\na")
+ --, newline "\r\na" ~=? Right ('\r', "\na") -- or sth TODO
+ , isLeft (newline "a\nb") ~=? True
+ ]
+
+testLetter :: Test
+testLetter = test
+ [ letter "abc" ~=? Right ('a', "bc")
+ , letter "a123" ~=? Right ('a', "123")
+ , isLeft (letter "1abc") ~=? True
+ ]
+
+testLetters :: Test
+testLetters = test
+ [ letters "abc" ~=? Right ("abc", "")
+ , letters "ab123" ~=? Right ("ab", "123")
+ , isLeft (letters "1abc") ~=? True
+ ]
+
+testAlphanum :: Test
+testAlphanum = test
+ [ alphanum "abc" ~=? Right ('a', "bc")
+ , alphanum "a123" ~=? Right ('a', "123")
+ , alphanum "1234" ~=? Right ('1', "234")
+ , isLeft (alphanum "_abc") ~=? True
+ , isLeft (alphanum "*123") ~=? True
+ ]
+
+testSpecial :: Test
+testSpecial = test
+ [ special "*123" ~=? Right ('*', "123")
+ , special "#abc" ~=? Right ('#', "abc")
+ , isLeft (special "abc") ~=? True
+ , isLeft (special "123") ~=? True
+ ]
+
+testOneOf :: Test
+testOneOf = test
+ [ oneOf "abcd" "d123" ~=? Right ('d', "123")
+ , oneOf "#(!" "#abc" ~=? Right ('#', "abc")
+ , isLeft (oneOf "abcde" "fu") ~=? True
+ , isLeft (oneOf "123" "a123") ~=? True
+ ]
+
+testString :: Test
+testString = test
+ [ string "\"hallo\"naa" ~=? Right ("hallo", "naa")
+ , string "\"\"ah" ~=? Right ("", "ah")
+ , isLeft (string "\"hallo naa") ~=? True
+ , isLeft (string "na\"hallo\"") ~=? True
+ ]
+
+testLiteral :: Test
+testLiteral = test
+ [ literal 'a' "abc" ~=? Right ('a', "bc")
+ , literal '~' "~12" ~=? Right ('~', "12")
+ , isLeft (literal 'a' "123abc") ~=? True
+ , isLeft (literal '1' " 123") ~=? True
+ ]
+
+testResult :: Test
+testResult = test
+ [result 'a' "abc" ~=? Right ('a', "abc"), result ' ' "" ~=? Right (' ', "")]
+
+testOneOrMore :: Test
+testOneOrMore = test
+ [ oneOrMore (literal 'a') "abc" ~=? Right ("a", "bc")
+ , oneOrMore (literal '1') "111234" ~=? Right ("111", "234")
+ , isLeft (oneOrMore (literal 'a') "1234") ~=? True
+ ]
+
+testIter :: Test
+testIter = test
+ [ iter (literal 'a') "abc" ~=? Right ("a", "bc")
+ , iter (literal '1') "111234" ~=? Right ("111", "234")
+ , iter (literal 'a') "1234" ~=? Right ("", "1234")
+ ]
+
+testIterFull :: Test
+testIterFull = test
+ [ iterFull (literal 'a') "aaa" ~=? Right ("aaa", "")
+ , iterFull (literal '1') "1" ~=? Right ("1", "")
+ , isLeft (iterFull (literal 'a') "abc") ~=? True
+ , isLeft (iterFull (literal 'a') "1234") ~=? True
+ ]
+
+testToken :: Test
+testToken = test
+ [ token (literal 'a') "a b" ~=? Right ('a', "b")
+ , token (literal ' ') " a" ~=? Right (' ', "a")
+ , isLeft (token (literal 'a') "ab") ~=? True
+ , isLeft (token (literal 'a') "ba ") ~=? True
+ ]
+
+testAccept :: Test
+testAccept = test
+ [ accept "abc" "abc 123" ~=? Right ("abc", "123")
+ , accept "1" "1 1 23" ~=? Right ("1", "1 23")
+ , isLeft (accept " " " a") ~=? True
+ , isLeft (accept "abc" "aabc ") ~=? True
+ ]
+
+parserTest :: IO Counts
+parserTest = runTestTT $ TestList
+ [ testIsDigit
+ , testIsAlpha
+ , testIsLower
+ , testIsUpper
+ , testChar
+ , testDigit
+ , testDigits
+ , testNumber
+ , testSpace
+ , testNotSpace
+ , testNewline
+ , testLetter
+ , testLetters
+ , testAlphanum
+ , testSpecial
+ , testOneOf
+ , testString
+ , testLiteral
+ , testResult
+ , testOneOrMore
+ , testIter
+ , testIterFull
+ , testToken
+ , testAccept
+ ]