summary refs log tree commit diff
path: root/src/libfmt_macros/tests.rs
blob: 7282d4a5f248b8127b2d8ea2f2eb6b6d37a210f5 (plain)
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
234
235
236
237
238
239
240
241
242
243
use super::*;

fn same(fmt: &'static str, p: &[Piece<'static>]) {
    let parser = Parser::new(fmt, None, vec![], false);
    assert!(parser.collect::<Vec<Piece<'static>>>() == p);
}

fn fmtdflt() -> FormatSpec<'static> {
    return FormatSpec {
        fill: None,
        align: AlignUnknown,
        flags: 0,
        precision: CountImplied,
        width: CountImplied,
        ty: "",
    };
}

fn musterr(s: &str) {
    let mut p = Parser::new(s, None, vec![], false);
    p.next();
    assert!(!p.errors.is_empty());
}

#[test]
fn simple() {
    same("asdf", &[String("asdf")]);
    same("a{{b", &[String("a"), String("{b")]);
    same("a}}b", &[String("a"), String("}b")]);
    same("a}}", &[String("a"), String("}")]);
    same("}}", &[String("}")]);
    same("\\}}", &[String("\\"), String("}")]);
}

#[test]
fn invalid01() {
    musterr("{")
}
#[test]
fn invalid02() {
    musterr("}")
}
#[test]
fn invalid04() {
    musterr("{3a}")
}
#[test]
fn invalid05() {
    musterr("{:|}")
}
#[test]
fn invalid06() {
    musterr("{:>>>}")
}

#[test]
fn format_nothing() {
    same("{}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: fmtdflt(),
           })]);
}
#[test]
fn format_position() {
    same("{3}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: fmtdflt(),
           })]);
}
#[test]
fn format_position_nothing_else() {
    same("{3:}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: fmtdflt(),
           })]);
}
#[test]
fn format_type() {
    same("{3:a}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "a",
               },
           })]);
}
#[test]
fn format_align_fill() {
    same("{3:>}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: FormatSpec {
                   fill: None,
                   align: AlignRight,
                   flags: 0,
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "",
               },
           })]);
    same("{3:0<}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: FormatSpec {
                   fill: Some('0'),
                   align: AlignLeft,
                   flags: 0,
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "",
               },
           })]);
    same("{3:*<abcd}",
         &[NextArgument(Argument {
               position: ArgumentIs(3),
               format: FormatSpec {
                   fill: Some('*'),
                   align: AlignLeft,
                   flags: 0,
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "abcd",
               },
           })]);
}
#[test]
fn format_counts() {
    use syntax_pos::{GLOBALS, Globals, edition};
    GLOBALS.set(&Globals::new(edition::DEFAULT_EDITION), || {
    same("{:10s}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountImplied,
                   width: CountIs(10),
                   ty: "s",
               },
           })]);
    same("{:10$.10s}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountIs(10),
                   width: CountIsParam(10),
                   ty: "s",
               },
           })]);
    same("{:.*s}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(1),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountIsParam(0),
                   width: CountImplied,
                   ty: "s",
               },
           })]);
    same("{:.10$s}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountIsParam(10),
                   width: CountImplied,
                   ty: "s",
               },
           })]);
    same("{:a$.b$s}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountIsName(Symbol::intern("b")),
                   width: CountIsName(Symbol::intern("a")),
                   ty: "s",
               },
           })]);
    });
}
#[test]
fn format_flags() {
    same("{:-}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: (1 << FlagSignMinus as u32),
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "",
               },
           })]);
    same("{:+#}",
         &[NextArgument(Argument {
               position: ArgumentImplicitlyIs(0),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: (1 << FlagSignPlus as u32) | (1 << FlagAlternate as u32),
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "",
               },
           })]);
}
#[test]
fn format_mixture() {
    same("abcd {3:a} efg",
         &[String("abcd "),
           NextArgument(Argument {
               position: ArgumentIs(3),
               format: FormatSpec {
                   fill: None,
                   align: AlignUnknown,
                   flags: 0,
                   precision: CountImplied,
                   width: CountImplied,
                   ty: "a",
               },
           }),
           String(" efg")]);
}