summaryrefslogtreecommitdiffhomepage
path: root/src/mintage/parser_test.go
blob: 76e0f01dfb2a36ae8755a2f347549178e8e93595 (plain) (blame)
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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
package mintage

import (
	"bytes"
	"errors"
	"testing"
)

func TestParserComplete(t *testing.T) {
	data, err := Parse(bytes.NewBuffer([]byte(`
		2020
			 1000 1001  1002 1003 1004 1005 1006 1007
			 1100 1101  1102 1103 1104 1105 1106 1107
			 1200 1201  1202 1203 1204 1205 1206 1207
		2021-KNM
			2.000    ?  2002 2003 2004 2005 2006 2007
			2.100    ?  2102 2103 2104 2105 2106 2107
			2.200    ?  2202 2203 2204 2205 2206 2207
		2021-MdP
			 3000 3001  3002 3003 3004 3005 3006 3007
			 3100 3101  3102 3103 3104 3105 3106 3107
			 3200 3201  3202 3203 3204 3205 3206 3207
		2022
			4000 4001 4.002 4003 4004 4005 4006 4007
			4100 4101 4.102 4103 4104 4105 4106 4107
			4200 4201 4.202 4203 4204 4205 4206 4207

		2009 "10th Anniversary of Economic and Monetary Union"
			1000 2000 3000
		2022-⋆ "35th Anniversary of the Erasmus Programme"
			1001    ? 3001
	`)), "-")

	if err != nil {
		t.Fatalf(`Expected err=nil; got "%s"`, err)
	}

	for i, row := range data.Standard {
		for k := TypeCirc; k <= TypeProof; k++ {
			for j, col := range row.Mintages[k] {
				n := 1000*(i+1) + 100*k + j
				if i == 1 && j == 1 {
					n = Unknown
				}
				if col != n {
					t.Fatalf("Expected data.Standard[%d].Mintages[%d][%d]=%d; got %d",
						i, k, j, col, n)
				}
			}
		}
	}

	for i, row := range data.Commemorative {
		for k := TypeCirc; k <= TypeProof; k++ {
			n := 1000*(k+1) + i
			if i == 1 && k == 1 {
				n = Unknown
			}
			if row.Mintage[k] != n {
				t.Fatalf("Expected row.Mintage[%d]=%d; got %d",
					k, n, row.Mintage[k])
			}
		}
	}

	if len(data.Standard) != 4 {
		t.Fatalf("Expected len(data.Standard)=2; got %d", len(data.Standard))
	}
	if len(data.Commemorative) != 2 {
		t.Fatalf("Expected len(data.Commemorative)=2; got %d", len(data.Commemorative))
	}

	for i, x := range [...]struct {
		year           int
		mintmark, name string
	}{
		{2009, "", "10th Anniversary of Economic and Monetary Union"},
		{2022, "⋆", "35th Anniversary of the Erasmus Programme"},
	} {
		if data.Commemorative[i].Year != x.year {
			t.Fatalf("Expected data.Commemorative[%d].Year=%d; got %d",
				i, x.year, data.Commemorative[i].Year)
		}
		if data.Commemorative[i].Mintmark != x.mintmark {
			t.Fatalf(`Expected data.Commemorative[%d].Mintmark="%s"; got "%s"`,
				i, x.mintmark, data.Commemorative[i].Mintmark)
		}
		if data.Commemorative[i].Name != x.name {
			t.Fatalf(`Expected data.Commemorative[%d].Name="%s"; got "%s"`,
				i, x.name, data.Commemorative[i].Name)
		}
	}
}

func TestParserMintmarks(t *testing.T) {
	data, err := Parse(bytes.NewBuffer([]byte(`
		2020
			 1000 1001  1002 1003 1004 1005 1006 1007
			 1100 1101  1102 1103 1104 1105 1106 1107
			 1200 1201  1202 1203 1204 1205 1206 1207
		2021-KNM
			2.000    ?  2002 2003 2004 2005 2006 2007
			2.100    ?  2102 2103 2104 2105 2106 2107
			2.200    ?  2202 2203 2204 2205 2206 2207
		2021-MdP
			 3000 3001  3002 3003 3004 3005 3006 3007
			 3100 3101  3102 3103 3104 3105 3106 3107
			 3200 3201  3202 3203 3204 3205 3206 3207
		2022
			 4000 4001 4.002 4003 4004 4005 4006 4007
			 4100 4101 4.102 4103 4104 4105 4106 4107
			 4200 4201 4.202 4203 4204 4205 4206 4207
	`)), "-")

	if err != nil {
		t.Fatalf(`Expected err=nil; got "%s"`, err)
	}

	for i, row := range data.Standard {
		for j, col := range row.Mintages[TypeCirc] {
			n := 1000*(i+1) + j
			if i == 1 && j == 1 {
				n = Unknown
			}
			if col != n {
				t.Fatalf("Expected data.Standard[%d].Mintages[TypeCirc][%d]=%d; got %d",
					i, j, col, n)
			}
		}
	}

	for i, y := range [...]int{2020, 2021, 2021, 2022} {
		if data.Standard[i].Year != y {
			t.Fatalf("Expected data.Standard[%d].Year=%d; got %d",
				i, y, data.Standard[i].Year)
		}
	}

	for i, m := range [...]string{"", "KNM", "MdP", ""} {
		if data.Standard[i].Mintmark != m {
			t.Fatalf(`Expected data.Standard[%d].Mintmark="%s"; got "%s"`,
				i, m, data.Standard[i].Mintmark)
		}
	}
}

func TestParserNoYear(t *testing.T) {
	_, err := Parse(bytes.NewBuffer([]byte(`
			1.000 1001 1002 1003 1004 1005 1006 1007
			1.100 1101 1102 1103 1104 1105 1106 1107
			1.200 1201 1202 1203 1204 1205 1206 1207
		2021
			 2000    ? 2002 2003 2004 2005 2006 2007
			 2100    ? 2102 2103 2104 2105 2106 2107
			 2200    ? 2202 2203 2204 2205 2206 2207
	`)), "-")

	var sErr SyntaxError
	if !errors.As(err, &sErr) {
		t.Fatalf("Expected err=SyntaxError; got %s", err)
	}
}

func TestParserBadToken(t *testing.T) {
	_, err := Parse(bytes.NewBuffer([]byte(`
		2020
			1.000 1001 1002 1003 1004 1005 1006 1007
			1.100 1101 1102 1103 1104 1105 1106 1107
			1.200 1201 1202 1203 1204 1205 1206 1207
		2021 Naughty!
			 2000    ? 2002 2003 2004 2005 2006 2007
			 2100    ? 2102 2103 2104 2105 2106 2107
			 2200    ? 2202 2203 2204 2205 2206 2207
	`)), "-")

	var sErr SyntaxError
	if !errors.As(err, &sErr) {
		t.Fatalf("Expected err=SyntaxError; got %s", err)
	}
}

func TestParserShortRow(t *testing.T) {
	_, err := Parse(bytes.NewBuffer([]byte(`
		2020
			1.000 1001 1002 1003 1004 1005 1006 1007
			1.100 1101 1102 1103 1104 1105 1106 1107
			1.200 1201 1202 1203 1204 1205 1206 1207
		2021
			 2000    ? 2002 2003 2004 2005 2006 2007
			 2100    ? 2102 2103 2104 2105 2106
			 2200    ? 2202 2203 2204 2205 2206 2207
	`)), "-")

	var sErr SyntaxError
	if !errors.As(err, &sErr) {
		t.Fatalf("Expected err=SyntaxError; got %s", err)
	}
}

func TestParserLongRow(t *testing.T) {
	_, err := Parse(bytes.NewBuffer([]byte(`
		2020
			1.000 1001 1002 1003 1004 1005 1006 1007
			1.100 1101 1102 1103 1104 1105 1106 1107
			1.200 1201 1202 1203 1204 1205 1206 1207
		2021
			 2000    ? 2002 2003 2004 2005 2006 2007
			 2100    ? 2102 2103 2104 2105 2106 2107 2108
			 2200    ? 2202 2203 2204 2205 2206 2207
	`)), "-")

	var sErr SyntaxError
	if !errors.As(err, &sErr) {
		t.Fatalf("Expected err=SyntaxError; got %s", err)
	}
}

func TestParserMissingRow(t *testing.T) {
	_, err := Parse(bytes.NewBuffer([]byte(`
		2020
			1.000 1001 1002 1003 1004 1005 1006 1007
			1.100 1101 1102 1103 1104 1105 1106 1107
			1.200 1201 1202 1203 1204 1205 1206 1207
		2021
			 2000    ? 2002 2003 2004 2005 2006 2007
			 2200    ? 2202 2203 2204 2205 2206 2207
	`)), "-")

	var sErr SyntaxError
	if !errors.As(err, &sErr) {
		t.Fatalf("Expected err=SyntaxError; got %s", err)
	}
}