diff options
author | Juan J. Martinez <jjm@usebox.net> | 2022-08-20 22:07:57 +0100 |
---|---|---|
committer | Juan J. Martinez <jjm@usebox.net> | 2022-08-20 22:07:57 +0100 |
commit | 0961ef6728abea4f3926fbf34539f4a98583d0c7 (patch) | |
tree | 91b6f2cade39f06d9ec8568c5de0dfe1156c55b6 | |
parent | a398ec460b923d0ade71565e09b8c89b022746a6 (diff) | |
download | micro-lang-hs-0961ef6728abea4f3926fbf34539f4a98583d0c7.tar.gz micro-lang-hs-0961ef6728abea4f3926fbf34539f4a98583d0c7.zip |
Refactor expectError
We expect a specific error in a list of errors.
Added case for call on non callable symbol.
-rw-r--r-- | src/Error.hs | 3 | ||||
-rw-r--r-- | test/Language.hs | 91 |
2 files changed, 45 insertions, 49 deletions
diff --git a/src/Error.hs b/src/Error.hs index 93c5bd4..724f57c 100644 --- a/src/Error.hs +++ b/src/Error.hs @@ -4,13 +4,14 @@ import Data.List (sort) import Text.Parsec (SourcePos, errorPos) import Text.Parsec.Error (ParseError, errorMessages, showErrorMessages) -data ErrorType = GenericError | TypeError | UnexpectedReturn | AlreadyDefined +data ErrorType = GenericError | TypeError | UnexpectedReturn | AlreadyDefined | NonCallable deriving (Show) instance Enum ErrorType where fromEnum GenericError = 0 fromEnum TypeError = 1 fromEnum UnexpectedReturn = 2 fromEnum AlreadyDefined = 3 + fromEnum NonCallable = 4 toEnum _ = error "toEnum is undefined for Error" data Error = Error ErrorType String SourcePos diff --git a/test/Language.hs b/test/Language.hs index 247318f..7d814a7 100644 --- a/test/Language.hs +++ b/test/Language.hs @@ -3,6 +3,7 @@ module Language where import qualified Ast as A import Compiler import Control.Monad.State (evalState) +import Data.Foldable (find) import qualified Error as E import Lexer (scan) import Parser (parse) @@ -17,16 +18,18 @@ assertAst input expected = do Left e -> assertFailure $ show e Right ast -> assertEqual "" expected ast -expectError :: String -> IO (Maybe E.Error) -expectError input = do +expectError :: String -> E.ErrorType -> Assertion +expectError input etyp = do r <- return $ runParser (scan parse) () "test" input case r of Left e -> assertFailure $ show e Right ast -> do res <- return $ evalState (compileAll ast) startState case res of - Left (e : _) -> return $ Just e - Right _ -> return $ Nothing + Left e -> case (find (\(E.Error t _ _) -> t == etyp) e) of + Just _ -> return () + Nothing -> assertFailure $ "expected " ++ show etyp ++ " didn't happen" + Right _ -> assertFailure "expected error, didn't happen" testCase1 = TestLabel "parse module" $ @@ -176,61 +179,52 @@ testCase11 = testCase12 = TestLabel "invalid return value (empty return)" $ - TestCase $ do - e <- - expectError - "module main\n\ - \def fn(): u8 { return; }" - case e of - Nothing -> assertFailure "expected error, didn't happen" - Just (E.Error E.TypeError _ _) -> return $ () + TestCase $ + expectError + "module main\n\ + \def fn(): u8 { return; }" + E.TypeError testCase13 = TestLabel "invalid return value" $ - TestCase $ do - e <- - expectError - "module main\n\ - \def fn(): u16 { return 1; }" - case e of - Nothing -> assertFailure "expected error, didn't happen" - Just (E.Error E.TypeError _ _) -> return $ () + TestCase $ + expectError + "module main\n\ + \def fn(): u16 { return 1; }" + E.TypeError testCase14 = TestLabel "return without function" $ - TestCase $ do - e <- - expectError - "module main\n\ - \return;" - case e of - Nothing -> assertFailure "expected error, didn't happen" - Just (E.Error E.UnexpectedReturn _ _) -> return $ () + TestCase $ + expectError + "module main\n\ + \return;" + E.UnexpectedReturn testCase15 = TestLabel "symbol already defined" $ - TestCase $ do - e <- - expectError - "module main\n\ - \def fn() { }\n\ - \def fn() { }" - case e of - Nothing -> assertFailure "expected error, didn't happen" - Just (E.Error E.AlreadyDefined _ pos) -> - if pos /= (newPos "test" 3 1) then assertFailure ("error position didn't match: " ++ show pos) else return $ () + TestCase $ + expectError + "module main\n\ + \def fn() { }\n\ + \def fn() { }" + E.AlreadyDefined testCase16 = TestLabel "parameter already defined" $ - TestCase $ do - e <- - expectError - "module main\n\ - \def fn(a: u8, a: u8) { }\n" - case e of - Nothing -> assertFailure "expected error, didn't happen" - Just (E.Error E.AlreadyDefined _ pos) -> - if pos /= (newPos "test" 2 15) then assertFailure ("error position didn't match: " ++ show pos) else return $ () + TestCase $ + expectError + "module main\n\ + \def fn(a: u8, a: u8) { }\n" + E.AlreadyDefined + +testCase17 = + TestLabel "call on non callable" $ + TestCase $ + expectError + "module main\n\ + \def fn(a: u8): u8 { return a(); }\n" + E.NonCallable language = [ testCase1, @@ -248,5 +242,6 @@ language = testCase13, testCase14, testCase15, - testCase16 + testCase16, + testCase17 ] |