-
Notifications
You must be signed in to change notification settings - Fork 0
/
interpreter_test.go
108 lines (90 loc) · 2.15 KB
/
interpreter_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package minimalisp_test
import (
"testing"
. "bakku.dev/minimalisp"
)
func TestInterpret_ShouldCorrectlyInterpretCode1(t *testing.T) {
expressions := []Expression{
&DefvarExpr{Token{Identifier, "name", 1, nil}, &LiteralExpr{"Steven"}},
&VarExpr{Token{Identifier, "name", 2, nil}},
}
interpreter := NewInterpreter()
ret, err := interpreter.Interpret(expressions)
if err != nil {
t.Fatalf("Expected no error, got %v", err)
}
if ret != "Steven" {
t.Fatalf("Expected 'Steven' as result, got '%v'", ret)
}
}
func TestInterpret_ShouldCorrectlyInterpretCode2(t *testing.T) {
expressions := []Expression{
&IfExpr{
&LiteralExpr{nil},
&LiteralExpr{"yes"},
&LiteralExpr{"no"},
},
}
interpreter := NewInterpreter()
ret, err := interpreter.Interpret(expressions)
if err != nil {
t.Fatalf("Expected no error, got %v", err)
}
if ret != "no" {
t.Fatalf("Expected 'no' as result, got '%v'", ret)
}
}
func TestInterpret_ShouldCorrectlyInterpretCode3(t *testing.T) {
expressions := []Expression{
&DefvarExpr{
Token{Identifier, "outer-name", 1, nil},
&LiteralExpr{"Steven"},
},
&DefunExpr{
Token{Identifier, "give-outer", 2, nil},
[]Token{},
&VarExpr{Token{Identifier, "outer-name", 2, nil}},
},
&FuncCallExpr{
Token{Identifier, "give-outer", 3, nil},
[]Expression{},
},
}
interpreter := NewInterpreter()
ret, err := interpreter.Interpret(expressions)
if err != nil {
t.Fatalf("Expected no error, got %v", err)
}
if ret != "Steven" {
t.Fatalf("Expected 'no' as result, got '%v'", ret)
}
}
func TestInterpret_ShouldCorrectlyInterpretCode4(t *testing.T) {
expressions := []Expression{
&FuncCallExpr{
Token{Identifier, "first", 1, nil},
[]Expression{
&FuncCallExpr{
Token{Identifier, "rest", 1, nil},
[]Expression{
&ListExpr{
[]Expression{
&LiteralExpr{1},
&LiteralExpr{2},
&LiteralExpr{3},
},
},
},
},
},
},
}
interpreter := NewInterpreter()
ret, err := interpreter.Interpret(expressions)
if err != nil {
t.Fatalf("Expected no error, got %v", err)
}
if ret != 2 {
t.Fatalf("Expected '2' as result, got '%v'", ret)
}
}