package parser import ( "monkey/ast" "monkey/lexer" "testing" ) func TestLetStatements(t *testing.T) { input := ` return 5; return 10; return 993322; ` l := lexer.New(input) p := New(l) program := p.ParseProgram() checkParserErrors(t, p) if len(program.Statements) != 3 { t.Fatalf("program.Statements does not contain 3 statements. got=%d", len(program.Statements)) } for _, stmt := range program.Statements { returnStmt, ok := stmt.(*ast.ReturnStatement) if !ok { t.Errorf("stmt not *ast.ReturnStatement. got=%T", stmt) continue } if returnStmt.TokenLiteral() != "return" { t.Errorf("returnStmt.TokenLiteral not 'return', got %q", returnStmt.TokenLiteral()) } } } func checkParserErrors(t *testing.T, p *Parser) { errors := p.Errors() if len(errors) == 0 { return } t.Errorf("parser has %d errors", len(errors)) for _, msg := range errors { t.Errorf("parser error %q", msg) } t.FailNow() } func testLetStatements(t *testing.T, s ast.Statement, name string) bool { if s.TokenLiteral() != "let" { t.Errorf("s.TokenLiteral not 'let'. got=%q", s.TokenLiteral()) return false } letStmt, ok := s.(*ast.LetStatement) if !ok { t.Errorf("s not *ast.LetStatement. got=%T", s) return false } if letStmt.Name.Value != name { t.Errorf("letStmt.Name.Value not '%s'. got=%s", name, letStmt.Name.Value) return false } if letStmt.Name.TokenLiteral() != name { t.Errorf("letStmt.Name.TokenLiteral not '%s'. got=%s", name, letStmt.Name.TokenLiteral()) return false } return true }