2024-05-02 22:33:35 +02:00
module TestParser ( tests ) where
import Test.HUnit
import Parser.Lexer
import Parser.JavaParser
2024-05-03 15:47:41 +02:00
import Ast
2024-05-02 22:33:35 +02:00
2024-05-03 15:47:41 +02:00
testSingleEmptyClass = TestCase $
assertEqual " expect single empty class hello " [ Class " Hello " [] [] ] $
parse [ CLASS , IDENTIFIER " Hello " , LBRACKET , RBRACKET ]
testTwoEmptyClasses = TestCase $
assertEqual " expect two empty classes " [ Class " Class1 " [] [] , Class " Class2 " [] [] ] $
parse [ CLASS , IDENTIFIER " Class1 " , LBRACKET , RBRACKET , CLASS , IDENTIFIER " Class2 " , LBRACKET , RBRACKET ]
2024-05-03 17:47:59 +02:00
testBooleanField = TestCase $
assertEqual " expect class with boolean field " [ Class " WithBool " [] [ VariableDeclaration " boolean " " value " Nothing ] ] $
parse [ CLASS , IDENTIFIER " WithBool " , LBRACKET , BOOLEAN , IDENTIFIER " value " , SEMICOLON , RBRACKET ]
testIntField = TestCase $
assertEqual " expect class with int field " [ Class " WithInt " [] [ VariableDeclaration " int " " value " Nothing ] ] $
parse [ CLASS , IDENTIFIER " WithInt " , LBRACKET , INT , IDENTIFIER " value " , SEMICOLON , RBRACKET ]
2024-05-06 10:16:57 +02:00
testCustomTypeField = TestCase $
assertEqual " expect class with foo field " [ Class " WithFoo " [] [ VariableDeclaration " Foo " " value " Nothing ] ] $
parse [ CLASS , IDENTIFIER " WithFoo " , LBRACKET , IDENTIFIER " Foo " , IDENTIFIER " value " , SEMICOLON , RBRACKET ]
2024-05-06 10:33:37 +02:00
testMultipleDeclarationSameLine = TestCase $
assertEqual " expect class with two int fields " [ Class " TwoInts " [] [ VariableDeclaration " int " " num1 " Nothing , VariableDeclaration " int " " num2 " Nothing ] ] $
parse [ CLASS , IDENTIFIER " TwoInts " , LBRACKET , INT , IDENTIFIER " num1 " , COMMA , IDENTIFIER " num2 " , SEMICOLON , RBRACKET ]
testMultipleDeclarations = TestCase $
assertEqual " expect class with int and char field " [ Class " Multiple " [] [ VariableDeclaration " int " " value " Nothing , VariableDeclaration " char " " letter " Nothing ] ] $
parse [ CLASS , IDENTIFIER " Multiple " , LBRACKET , INT , IDENTIFIER " value " , SEMICOLON , CHAR , IDENTIFIER " letter " , SEMICOLON , RBRACKET ]
2024-05-06 10:09:50 +02:00
testWithModifier = TestCase $
assertEqual " expect class with int field " [ Class " WithInt " [] [ VariableDeclaration " int " " value " Nothing ] ] $
parse [ ABSTRACT , CLASS , IDENTIFIER " WithInt " , LBRACKET , PUBLIC , INT , IDENTIFIER " value " , SEMICOLON , RBRACKET ]
2024-05-06 23:51:33 +02:00
testEmptyMethod = TestCase $
2024-05-06 23:34:03 +02:00
assertEqual " expect class with method " [ Class " WithMethod " [ MethodDeclaration " int " " foo " [] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithMethod " , LBRACKET , INT , IDENTIFIER " foo " , LBRACE , RBRACE , SEMICOLON , RBRACKET ]
2024-05-06 23:51:33 +02:00
testEmptyPrivateMethod = TestCase $
assertEqual " expect class with method " [ Class " WithMethod " [ MethodDeclaration " int " " foo " [] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithMethod " , LBRACKET , PRIVATE , INT , IDENTIFIER " foo " , LBRACE , RBRACE , LBRACKET , RBRACKET , RBRACKET ]
testEmptyVoidMethod = TestCase $
assertEqual " expect class with method " [ Class " WithMethod " [ MethodDeclaration " void " " foo " [] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithMethod " , LBRACKET , VOID , IDENTIFIER " foo " , LBRACE , RBRACE , LBRACKET , RBRACKET , RBRACKET ]
2024-05-07 15:03:04 +02:00
testEmptyMethodWithParam = TestCase $
assertEqual " expect class with method with param " [ Class " WithParam " [ MethodDeclaration " void " " foo " [ ParameterDeclaration " int " " param " ] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithParam " , LBRACKET , VOID , IDENTIFIER " foo " , LBRACE , INT , IDENTIFIER " param " , RBRACE , SEMICOLON , RBRACKET ]
testEmptyMethodWithParams = TestCase $
assertEqual " expect class with multiple params " [ Class " WithParams " [ MethodDeclaration " void " " foo " [ ParameterDeclaration " int " " p1 " , ParameterDeclaration " Custom " " p2 " ] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithParams " , LBRACKET , VOID , IDENTIFIER " foo " , LBRACE , INT , IDENTIFIER " p1 " , COMMA , IDENTIFIER " Custom " , IDENTIFIER " p2 " , RBRACE , SEMICOLON , RBRACKET ]
testClassWithMethodAndField = TestCase $
assertEqual " expect class with method and field " [ Class " WithMethodAndField " [ MethodDeclaration " void " " foo " [] ( Block [] ) , MethodDeclaration " int " " bar " [] ( Block [] ) ] [ VariableDeclaration " int " " value " Nothing ] ] $
parse [ CLASS , IDENTIFIER " WithMethodAndField " , LBRACKET , VOID , IDENTIFIER " foo " , LBRACE , RBRACE , LBRACKET , RBRACKET , INT , IDENTIFIER " value " , SEMICOLON , INT , IDENTIFIER " bar " , LBRACE , RBRACE , SEMICOLON , RBRACKET ]
2024-05-08 00:02:38 +02:00
testClassWithConstructor = TestCase $
2024-05-14 12:33:42 +02:00
assertEqual " expect class with constructor " [ Class " WithConstructor " [ MethodDeclaration " void " " <init> " [] ( Block [] ) ] [] ] $
2024-05-08 00:02:38 +02:00
parse [ CLASS , IDENTIFIER " WithConstructor " , LBRACKET , IDENTIFIER " WithConstructor " , LBRACE , RBRACE , LBRACKET , RBRACKET , RBRACKET ]
2024-05-31 10:34:47 +02:00
testConstructorWithParams = TestCase $
assertEqual " expect constructor with params " [ Class " WithParams " [ MethodDeclaration " void " " <init> " [ ParameterDeclaration " int " " p1 " ] ( Block [] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithParams " , LBRACKET , IDENTIFIER " WithParams " , LBRACE , INT , IDENTIFIER " p1 " , RBRACE , LBRACKET , RBRACKET , RBRACKET ]
testConstructorWithStatements = TestCase $
assertEqual " expect constructor with statement " [ Class " WithConstructor " [ MethodDeclaration " void " " <init> " [] ( Block [ Return Nothing ] ) ] [] ] $
parse [ CLASS , IDENTIFIER " WithConstructor " , LBRACKET , IDENTIFIER " WithConstructor " , LBRACE , RBRACE , LBRACKET , RETURN , SEMICOLON , RBRACKET , RBRACKET ]
2024-05-02 22:33:35 +02:00
2024-05-14 10:16:56 +02:00
testEmptyBlock = TestCase $ assertEqual " expect empty block " [ Block [] ] $ parseStatement [ LBRACKET , RBRACKET ]
2024-05-08 10:20:55 +02:00
testBlockWithLocalVarDecl = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect block with local var delcaration " [ Block [ LocalVariableDeclaration $ VariableDeclaration " int " " localvar " Nothing ] ] $
parseStatement [ LBRACKET , INT , IDENTIFIER " localvar " , SEMICOLON , RBRACKET ]
2024-05-08 10:30:50 +02:00
testBlockWithMultipleLocalVarDecls = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect block with multiple local var declarations " [ Block [ LocalVariableDeclaration $ VariableDeclaration " int " " var1 " Nothing , LocalVariableDeclaration $ VariableDeclaration " boolean " " var2 " Nothing ] ] $
parseStatement [ LBRACKET , INT , IDENTIFIER " var1 " , SEMICOLON , BOOLEAN , IDENTIFIER " var2 " , SEMICOLON , RBRACKET ]
2024-05-08 10:37:40 +02:00
testNestedBlocks = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect block with block inside " [ Block [ Block [] ] ] $
parseStatement [ LBRACKET , LBRACKET , RBRACKET , RBRACKET ]
2024-05-08 11:05:02 +02:00
testBlockWithEmptyStatement = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect empty block " [ Block [] ] $
parseStatement [ LBRACKET , SEMICOLON , SEMICOLON , RBRACKET ]
2024-05-08 10:20:55 +02:00
2024-05-08 13:16:00 +02:00
testExpressionIntLiteral = TestCase $
assertEqual " expect IntLiteral " ( IntegerLiteral 3 ) $
parseExpression [ INTEGERLITERAL 3 ]
testFieldWithInitialization = TestCase $
assertEqual " expect Class with initialized field " [ Class " WithInitField " [] [ VariableDeclaration " int " " number " $ Just $ IntegerLiteral 3 ] ] $
parse [ CLASS , IDENTIFIER " WithInitField " , LBRACKET , INT , IDENTIFIER " number " , ASSIGN , INTEGERLITERAL 3 , SEMICOLON , RBRACKET ]
2024-05-08 13:29:10 +02:00
testLocalBoolWithInitialization = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect block with with initialized local var " [ Block [ LocalVariableDeclaration $ VariableDeclaration " boolean " " b " $ Just $ BooleanLiteral False ] ] $
parseStatement [ LBRACKET , BOOLEAN , IDENTIFIER " b " , ASSIGN , BOOLLITERAL False , SEMICOLON , RBRACKET ]
2024-05-08 13:29:10 +02:00
testFieldNullWithInitialization = TestCase $
assertEqual " expect Class with initialized field " [ Class " WithInitField " [] [ VariableDeclaration " Object " " bar " $ Just NullLiteral ] ] $
parse [ CLASS , IDENTIFIER " WithInitField " , LBRACKET , IDENTIFIER " Object " , IDENTIFIER " bar " , ASSIGN , NULLLITERAL , SEMICOLON , RBRACKET ]
2024-05-08 15:52:44 +02:00
testReturnVoid = TestCase $
2024-05-14 10:16:56 +02:00
assertEqual " expect block with return nothing " [ Block [ Return Nothing ] ] $
parseStatement [ LBRACKET , RETURN , SEMICOLON , RBRACKET ]
2024-05-08 13:16:00 +02:00
2024-05-08 16:59:10 +02:00
testExpressionNot = TestCase $
assertEqual " expect expression not " ( UnaryOperation Not ( Reference " boar " ) ) $
parseExpression [ NOT , IDENTIFIER " boar " ]
testExpressionMinus = TestCase $
assertEqual " expect expression minus " ( UnaryOperation Minus ( Reference " boo " ) ) $
parseExpression [ MINUS , IDENTIFIER " boo " ]
2024-05-08 22:57:21 +02:00
testExpressionMultiplication = TestCase $
assertEqual " expect multiplication " ( BinaryOperation Multiplication ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , TIMES , INTEGERLITERAL 3 ]
testExpressionDivision = TestCase $
assertEqual " expect division " ( BinaryOperation Division ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , DIV , INTEGERLITERAL 3 ]
testExpressionModulo = TestCase $
assertEqual " expect modulo operation " ( BinaryOperation Modulo ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , MODULO , INTEGERLITERAL 3 ]
testExpressionAddition = TestCase $
assertEqual " expect addition " ( BinaryOperation Addition ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , PLUS , INTEGERLITERAL 3 ]
testExpressionSubtraction = TestCase $
assertEqual " expect subtraction " ( BinaryOperation Subtraction ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , MINUS , INTEGERLITERAL 3 ]
testExpressionLessThan = TestCase $
assertEqual " expect comparision less than " ( BinaryOperation CompareLessThan ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , LESS , INTEGERLITERAL 3 ]
testExpressionGreaterThan = TestCase $
assertEqual " expect comparision greater than " ( BinaryOperation CompareGreaterThan ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , GREATER , INTEGERLITERAL 3 ]
testExpressionLessThanEqual = TestCase $
assertEqual " expect comparision less than or equal " ( BinaryOperation CompareLessOrEqual ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , LESSEQUAL , INTEGERLITERAL 3 ]
testExpressionGreaterThanOrEqual = TestCase $
assertEqual " expect comparision greater than or equal " ( BinaryOperation CompareGreaterOrEqual ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , GREATEREQUAL , INTEGERLITERAL 3 ]
testExpressionEqual = TestCase $
assertEqual " expect comparison equal " ( BinaryOperation CompareEqual ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , EQUAL , INTEGERLITERAL 3 ]
testExpressionNotEqual = TestCase $
assertEqual " expect comparison equal " ( BinaryOperation CompareNotEqual ( Reference " bar " ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " bar " , NOTEQUAL , INTEGERLITERAL 3 ]
2024-05-09 00:09:08 +02:00
testExpressionAnd = TestCase $
assertEqual " expect and expression " ( BinaryOperation And ( Reference " bar " ) ( Reference " baz " ) ) $
parseExpression [ IDENTIFIER " bar " , AND , IDENTIFIER " baz " ]
testExpressionXor = TestCase $
assertEqual " expect xor expression " ( BinaryOperation BitwiseXor ( Reference " bar " ) ( Reference " baz " ) ) $
parseExpression [ IDENTIFIER " bar " , XOR , IDENTIFIER " baz " ]
testExpressionOr = TestCase $
assertEqual " expect or expression " ( BinaryOperation Or ( Reference " bar " ) ( Reference " baz " ) ) $
parseExpression [ IDENTIFIER " bar " , OR , IDENTIFIER " baz " ]
2024-05-14 11:34:57 +02:00
testExpressionPostIncrement = TestCase $
2024-05-31 10:34:47 +02:00
assertEqual " expect PostIncrement " ( StatementExpressionExpression $ PostIncrement ( Reference " a " ) ) $
2024-05-14 11:34:57 +02:00
parseExpression [ IDENTIFIER " a " , INCREMENT ]
testExpressionPostDecrement = TestCase $
2024-05-31 10:34:47 +02:00
assertEqual " expect PostDecrement " ( StatementExpressionExpression $ PostDecrement ( Reference " a " ) ) $
2024-05-14 11:34:57 +02:00
parseExpression [ IDENTIFIER " a " , DECREMENT ]
testExpressionPreIncrement = TestCase $
2024-05-31 11:44:10 +02:00
assertEqual " expect PreIncrement " ( StatementExpressionExpression $ PreIncrement ( Reference " a " ) ) $
2024-05-14 11:34:57 +02:00
parseExpression [ INCREMENT , IDENTIFIER " a " ]
testExpressionPreDecrement = TestCase $
2024-05-31 11:44:10 +02:00
assertEqual " expect PreIncrement " ( StatementExpressionExpression $ PreDecrement ( Reference " a " ) ) $
2024-05-14 11:34:57 +02:00
parseExpression [ DECREMENT , IDENTIFIER " a " ]
2024-05-14 23:14:43 +02:00
testExpressionAssign = TestCase $
2024-05-14 23:35:56 +02:00
assertEqual " expect assign 5 to a " ( StatementExpressionExpression ( Assignment ( Reference " a " ) ( IntegerLiteral 5 ) ) ) $
2024-05-14 23:14:43 +02:00
parseExpression [ IDENTIFIER " a " , ASSIGN , INTEGERLITERAL 5 ]
2024-05-14 23:35:56 +02:00
testExpressionTimesEqual = TestCase $
assertEqual " expect assign and multiplication " ( StatementExpressionExpression ( Assignment ( Reference " a " ) ( BinaryOperation Multiplication ( Reference " a " ) ( IntegerLiteral 5 ) ) ) ) $
parseExpression [ IDENTIFIER " a " , TIMESEQUAL , INTEGERLITERAL 5 ]
testExpressionDivideEqual = TestCase $
assertEqual " expect assign and division " ( StatementExpressionExpression ( Assignment ( Reference " a " ) ( BinaryOperation Division ( Reference " a " ) ( IntegerLiteral 5 ) ) ) ) $
parseExpression [ IDENTIFIER " a " , DIVEQUAL , INTEGERLITERAL 5 ]
testExpressionPlusEqual = TestCase $
assertEqual " expect assign and addition " ( StatementExpressionExpression ( Assignment ( Reference " a " ) ( BinaryOperation Addition ( Reference " a " ) ( IntegerLiteral 5 ) ) ) ) $
parseExpression [ IDENTIFIER " a " , PLUSEQUAL , INTEGERLITERAL 5 ]
testExpressionMinusEqual = TestCase $
assertEqual " expect assign and subtraction " ( StatementExpressionExpression ( Assignment ( Reference " a " ) ( BinaryOperation Subtraction ( Reference " a " ) ( IntegerLiteral 5 ) ) ) ) $
parseExpression [ IDENTIFIER " a " , MINUSEQUAL , INTEGERLITERAL 5 ]
2024-05-31 10:34:47 +02:00
testExpressionThis = TestCase $
assertEqual " expect this " ( Reference " this " ) $
parseExpression [ THIS ]
testExpressionBraced = TestCase $
assertEqual " expect braced expresssion " ( BinaryOperation Multiplication ( Reference " b " ) ( BinaryOperation Addition ( Reference " a " ) ( IntegerLiteral 3 ) ) ) $
parseExpression [ IDENTIFIER " b " , TIMES , LBRACE , IDENTIFIER " a " , PLUS , INTEGERLITERAL 3 , RBRACE ]
testExpressionPrecedence = TestCase $
assertEqual " expect times to be inner expression " ( BinaryOperation Addition ( BinaryOperation Multiplication ( Reference " b " ) ( Reference " a " ) ) ( IntegerLiteral 3 ) ) $
parseExpression [ IDENTIFIER " b " , TIMES , IDENTIFIER " a " , PLUS , INTEGERLITERAL 3 ]
testExpressionMethodCallNoParams = TestCase $
assertEqual " expect methodcall no params " ( StatementExpressionExpression ( MethodCall ( Reference " this " ) " foo " [] ) ) $
parseExpression [ IDENTIFIER " foo " , LBRACE , RBRACE ]
testExpressionMethodCallOneParam = TestCase $
assertEqual " expect methodcall one param " ( StatementExpressionExpression ( MethodCall ( Reference " this " ) " foo " [ Reference " a " ] ) ) $
parseExpression [ IDENTIFIER " foo " , LBRACE , IDENTIFIER " a " , RBRACE ]
testExpressionMethodCallTwoParams = TestCase $
assertEqual " expect methocall two params " ( StatementExpressionExpression ( MethodCall ( Reference " this " ) " foo " [ Reference " a " , IntegerLiteral 5 ] ) ) $
parseExpression [ IDENTIFIER " foo " , LBRACE , IDENTIFIER " a " , COMMA , INTEGERLITERAL 5 , RBRACE ]
testExpressionThisMethodCall = TestCase $
assertEqual " expect this methocall " ( StatementExpressionExpression ( MethodCall ( Reference " this " ) " foo " [] ) ) $
parseExpression [ THIS , DOT , IDENTIFIER " foo " , LBRACE , RBRACE ]
testExpressionThisMethodCallParam = TestCase $
assertEqual " expect this methocall " ( StatementExpressionExpression ( MethodCall ( Reference " this " ) " foo " [ Reference " x " ] ) ) $
parseExpression [ THIS , DOT , IDENTIFIER " foo " , LBRACE , IDENTIFIER " x " , RBRACE ]
2024-05-31 11:04:23 +02:00
testExpressionFieldAccess = TestCase $
assertEqual " expect NameResolution " ( BinaryOperation NameResolution ( Reference " this " ) ( Reference " b " ) ) $
parseExpression [ THIS , DOT , IDENTIFIER " b " ]
testExpressionSimpleFieldAccess = TestCase $
assertEqual " expect Reference " ( Reference " a " ) $
parseExpression [ IDENTIFIER " a " ]
2024-05-31 11:07:19 +02:00
testExpressionFieldSubAccess = TestCase $
assertEqual " expect NameResolution without this " ( BinaryOperation NameResolution ( Reference " a " ) ( Reference " b " ) ) $
parseExpression [ IDENTIFIER " a " , DOT , IDENTIFIER " b " ]
2024-05-31 12:02:25 +02:00
testExpressionConstructorCall = TestCase $
assertEqual " expect constructor call " ( StatementExpressionExpression ( ConstructorCall " Foo " [] ) ) $
parseExpression [ NEW , IDENTIFIER " Foo " , LBRACE , RBRACE ]
2024-05-08 22:57:21 +02:00
2024-05-14 13:57:01 +02:00
testStatementIfThen = TestCase $
assertEqual " expect empty ifthen " [ If ( Reference " a " ) ( Block [ Block [] ] ) Nothing ] $
parseStatement [ IF , LBRACE , IDENTIFIER " a " , RBRACE , LBRACKET , RBRACKET ]
testStatementIfThenElse = TestCase $
assertEqual " expect empty ifthen " [ If ( Reference " a " ) ( Block [ Block [] ] ) ( Just ( Block [ Block [] ] ) ) ] $
parseStatement [ IF , LBRACE , IDENTIFIER " a " , RBRACE , LBRACKET , RBRACKET , ELSE , LBRACKET , RBRACKET ]
2024-05-14 16:48:45 +02:00
testStatementWhile = TestCase $
assertEqual " expect while " [ While ( Reference " a " ) ( Block [ Block [] ] ) ] $
parseStatement [ WHILE , LBRACE , IDENTIFIER " a " , RBRACE , LBRACKET , RBRACKET ]
2024-05-31 10:34:47 +02:00
testStatementAssign = TestCase $
assertEqual " expect assign 5 " [ StatementExpressionStatement ( Assignment ( Reference " a " ) ( IntegerLiteral 5 ) ) ] $
parseStatement [ IDENTIFIER " a " , ASSIGN , INTEGERLITERAL 5 , SEMICOLON ]
testStatementMethodCallNoParams = TestCase $
assertEqual " expect methodcall statement no params " [ StatementExpressionStatement ( MethodCall ( Reference " this " ) " foo " [] ) ] $
parseStatement [ IDENTIFIER " foo " , LBRACE , RBRACE , SEMICOLON ]
2024-05-31 12:02:25 +02:00
testStatementConstructorCall = TestCase $
assertEqual " expect constructor call " [ StatementExpressionStatement ( ConstructorCall " Foo " [] ) ] $
parseStatement [ NEW , IDENTIFIER " Foo " , LBRACE , RBRACE , SEMICOLON ]
testStatementConstructorCallWithArgs = TestCase $
assertEqual " expect constructor call " [ StatementExpressionStatement ( ConstructorCall " Foo " [ Reference " b " ] ) ] $
parseStatement [ NEW , IDENTIFIER " Foo " , LBRACE , IDENTIFIER " b " , RBRACE , SEMICOLON ]
2024-05-31 12:10:00 +02:00
testStatementPreIncrement = TestCase $
assertEqual " expect increment " [ StatementExpressionStatement $ PostIncrement $ Reference " a " ] $
parseStatement [ IDENTIFIER " a " , INCREMENT , SEMICOLON ]
2024-05-14 13:57:01 +02:00
2024-05-08 16:59:10 +02:00
2024-05-02 22:33:35 +02:00
tests = TestList [
2024-05-03 15:47:41 +02:00
testSingleEmptyClass ,
2024-05-03 17:47:59 +02:00
testTwoEmptyClasses ,
testBooleanField ,
2024-05-06 10:16:57 +02:00
testIntField ,
2024-05-06 10:33:37 +02:00
testCustomTypeField ,
2024-05-06 10:09:50 +02:00
testMultipleDeclarations ,
2024-05-06 23:34:03 +02:00
testWithModifier ,
2024-05-06 23:51:33 +02:00
testEmptyMethod ,
testEmptyPrivateMethod ,
2024-05-07 15:03:04 +02:00
testEmptyVoidMethod ,
testEmptyMethodWithParam ,
testEmptyMethodWithParams ,
2024-05-08 00:02:38 +02:00
testClassWithMethodAndField ,
2024-05-08 10:20:55 +02:00
testClassWithConstructor ,
2024-05-31 10:34:47 +02:00
testConstructorWithParams ,
testConstructorWithStatements ,
2024-05-08 10:20:55 +02:00
testEmptyBlock ,
2024-05-08 10:30:50 +02:00
testBlockWithLocalVarDecl ,
2024-05-08 10:37:40 +02:00
testBlockWithMultipleLocalVarDecls ,
2024-05-08 11:05:02 +02:00
testNestedBlocks ,
2024-05-08 13:16:00 +02:00
testBlockWithEmptyStatement ,
testExpressionIntLiteral ,
2024-05-08 13:29:10 +02:00
testFieldWithInitialization ,
testLocalBoolWithInitialization ,
2024-05-08 15:52:44 +02:00
testFieldNullWithInitialization ,
2024-05-08 16:59:10 +02:00
testReturnVoid ,
testExpressionNot ,
2024-05-08 22:57:21 +02:00
testExpressionMinus ,
testExpressionLessThan ,
testExpressionGreaterThan ,
testExpressionLessThanEqual ,
testExpressionGreaterThanOrEqual ,
testExpressionEqual ,
2024-05-09 00:09:08 +02:00
testExpressionNotEqual ,
testExpressionAnd ,
testExpressionXor ,
2024-05-14 11:34:57 +02:00
testExpressionOr ,
testExpressionPostIncrement ,
testExpressionPostDecrement ,
testExpressionPreIncrement ,
2024-05-14 13:57:01 +02:00
testExpressionPreDecrement ,
2024-05-14 23:14:43 +02:00
testExpressionAssign ,
2024-05-14 23:35:56 +02:00
testExpressionTimesEqual ,
testExpressionTimesEqual ,
testExpressionDivideEqual ,
testExpressionPlusEqual ,
testExpressionMinusEqual ,
2024-05-31 10:34:47 +02:00
testExpressionBraced ,
testExpressionThis ,
testExpressionPrecedence ,
testExpressionMethodCallNoParams ,
testExpressionMethodCallOneParam ,
testExpressionMethodCallTwoParams ,
testExpressionThisMethodCall ,
testExpressionThisMethodCallParam ,
2024-05-31 11:04:23 +02:00
testExpressionFieldAccess ,
testExpressionSimpleFieldAccess ,
2024-05-31 11:07:19 +02:00
testExpressionFieldSubAccess ,
2024-05-31 12:02:25 +02:00
testExpressionConstructorCall ,
2024-05-14 13:57:01 +02:00
testStatementIfThen ,
2024-05-14 16:48:45 +02:00
testStatementIfThenElse ,
2024-05-31 10:34:47 +02:00
testStatementWhile ,
testStatementAssign ,
2024-05-31 12:02:25 +02:00
testStatementMethodCallNoParams ,
testStatementConstructorCall ,
2024-05-31 12:10:00 +02:00
testStatementConstructorCallWithArgs ,
2024-06-10 17:19:56 +02:00
testStatementPreIncrement
2024-05-02 22:33:35 +02:00
]