-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathassoc_test.go
140 lines (130 loc) · 3.09 KB
/
assoc_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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
// This file tests operations on associative arrays
package awk
import (
"testing"
)
// TestIntIntArray tests Get/Set operations on an associative array that
// maps integers to integers.
func TestIntIntArray(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
for i := 0; i < 10; i++ {
a.Set(i, i*10)
}
for i := 9; i >= 0; i-- {
got := a.Get(i).Int()
if got != i*10 {
t.Fatalf("Expected %d but received %d", i*10, got)
}
}
}
// TestValueValueArray tests Get/Set operations on an
// associative array that maps Values to Values.
func TestValueValueArray(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
for i := 0; i < 10; i++ {
a.Set(scr.NewValue(i), scr.NewValue(i*10))
}
for i := 9; i >= 0; i-- {
got := a.Get(scr.NewValue(i)).Int()
if got != i*10 {
t.Fatalf("Expected %d but received %d", i*10, got)
}
}
}
// TestStringStringArray tests Get/Set operations on an associative array that
// maps strings to strings.
func TestStringStringArray(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
keys := []string{"The", "tree", "has", "entered", "my", "hands"}
values := []string{"The", "sap", "has", "ascended", "my", "arms"}
for i, k := range keys {
a.Set(k, values[i])
}
for i, k := range keys {
want := values[i]
got := a.Get(k).String()
if got != want {
t.Fatalf("Expected %q but received %q", want, got)
}
}
}
// TestMultiDimArray tests Get/Set operations on a "multidimensional"
// associative array.
func TestMultiDimArray(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
for i := 9; i >= 0; i-- {
for j := 9; j >= 0; j-- {
a.Set(i, j, i*10+j)
}
}
for i := 0; i < 10; i++ {
for j := 9; j >= 0; j-- {
got := a.Get(i, j).Int()
if got != i*10+j {
t.Fatalf("Expected %d but received %d", i*10+j, got)
}
}
}
}
// TestArrayKeys tests the Keys operation on an associative array.
func TestArrayKeys(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
for i := 10; i <= 100; i += 10 {
a.Set(i, i*2)
}
ksum := 0
for _, k := range a.Keys() {
ksum += k.Int()
}
if ksum != 550 {
t.Fatalf("Expected 550 but received %d", ksum)
}
}
// TestArrayValues tests the Values operation on an associative array.
func TestArrayValues(t *testing.T) {
scr := NewScript()
a := scr.NewValueArray()
for i := 10; i <= 100; i += 10 {
a.Set(i, i*2)
}
vsum := 0
for _, v := range a.Values() {
vsum += v.Int()
}
if vsum != 1100 {
t.Fatalf("Expected 1100 but received %d", vsum)
}
}
// TestArrayDelete tests deleting an element from an associative array.
func TestArrayDelete(t *testing.T) {
// Create an array of values, then delete every other element.
scr := NewScript()
a := scr.NewValueArray()
for i := 0; i <= 100; i++ {
a.Set(i, i/2)
}
for i := 1; i <= 100; i += 2 {
a.Delete(i)
}
vsum := 0
for i := 0; i <= 100; i++ {
vsum += a.Get(i).Int()
}
if vsum != 1275 {
t.Fatalf("Expected 1275 but received %d", vsum)
}
// Empty the array and try again.
a.Delete()
vsum = 0
for i := 0; i <= 100; i++ {
vsum += a.Get(i).Int()
}
if vsum != 0 {
t.Fatalf("Expected 0 but received %d", vsum)
}
}