diff options
Diffstat (limited to 'crates/ra_assists/src/tests/generated.rs')
-rw-r--r-- | crates/ra_assists/src/tests/generated.rs | 848 |
1 files changed, 848 insertions, 0 deletions
diff --git a/crates/ra_assists/src/tests/generated.rs b/crates/ra_assists/src/tests/generated.rs new file mode 100644 index 000000000..d17504529 --- /dev/null +++ b/crates/ra_assists/src/tests/generated.rs | |||
@@ -0,0 +1,848 @@ | |||
1 | //! Generated file, do not edit by hand, see `xtask/src/codegen` | ||
2 | |||
3 | use super::check_doc_test; | ||
4 | |||
5 | #[test] | ||
6 | fn doctest_add_custom_impl() { | ||
7 | check_doc_test( | ||
8 | "add_custom_impl", | ||
9 | r#####" | ||
10 | #[derive(Deb<|>ug, Display)] | ||
11 | struct S; | ||
12 | "#####, | ||
13 | r#####" | ||
14 | #[derive(Display)] | ||
15 | struct S; | ||
16 | |||
17 | impl Debug for S { | ||
18 | $0 | ||
19 | } | ||
20 | "#####, | ||
21 | ) | ||
22 | } | ||
23 | |||
24 | #[test] | ||
25 | fn doctest_add_derive() { | ||
26 | check_doc_test( | ||
27 | "add_derive", | ||
28 | r#####" | ||
29 | struct Point { | ||
30 | x: u32, | ||
31 | y: u32,<|> | ||
32 | } | ||
33 | "#####, | ||
34 | r#####" | ||
35 | #[derive($0)] | ||
36 | struct Point { | ||
37 | x: u32, | ||
38 | y: u32, | ||
39 | } | ||
40 | "#####, | ||
41 | ) | ||
42 | } | ||
43 | |||
44 | #[test] | ||
45 | fn doctest_add_explicit_type() { | ||
46 | check_doc_test( | ||
47 | "add_explicit_type", | ||
48 | r#####" | ||
49 | fn main() { | ||
50 | let x<|> = 92; | ||
51 | } | ||
52 | "#####, | ||
53 | r#####" | ||
54 | fn main() { | ||
55 | let x: i32 = 92; | ||
56 | } | ||
57 | "#####, | ||
58 | ) | ||
59 | } | ||
60 | |||
61 | #[test] | ||
62 | fn doctest_add_from_impl_for_enum() { | ||
63 | check_doc_test( | ||
64 | "add_from_impl_for_enum", | ||
65 | r#####" | ||
66 | enum A { <|>One(u32) } | ||
67 | "#####, | ||
68 | r#####" | ||
69 | enum A { One(u32) } | ||
70 | |||
71 | impl From<u32> for A { | ||
72 | fn from(v: u32) -> Self { | ||
73 | A::One(v) | ||
74 | } | ||
75 | } | ||
76 | "#####, | ||
77 | ) | ||
78 | } | ||
79 | |||
80 | #[test] | ||
81 | fn doctest_add_function() { | ||
82 | check_doc_test( | ||
83 | "add_function", | ||
84 | r#####" | ||
85 | struct Baz; | ||
86 | fn baz() -> Baz { Baz } | ||
87 | fn foo() { | ||
88 | bar<|>("", baz()); | ||
89 | } | ||
90 | |||
91 | "#####, | ||
92 | r#####" | ||
93 | struct Baz; | ||
94 | fn baz() -> Baz { Baz } | ||
95 | fn foo() { | ||
96 | bar("", baz()); | ||
97 | } | ||
98 | |||
99 | fn bar(arg: &str, baz: Baz) { | ||
100 | ${0:todo!()} | ||
101 | } | ||
102 | |||
103 | "#####, | ||
104 | ) | ||
105 | } | ||
106 | |||
107 | #[test] | ||
108 | fn doctest_add_hash() { | ||
109 | check_doc_test( | ||
110 | "add_hash", | ||
111 | r#####" | ||
112 | fn main() { | ||
113 | r#"Hello,<|> World!"#; | ||
114 | } | ||
115 | "#####, | ||
116 | r#####" | ||
117 | fn main() { | ||
118 | r##"Hello, World!"##; | ||
119 | } | ||
120 | "#####, | ||
121 | ) | ||
122 | } | ||
123 | |||
124 | #[test] | ||
125 | fn doctest_add_impl() { | ||
126 | check_doc_test( | ||
127 | "add_impl", | ||
128 | r#####" | ||
129 | struct Ctx<T: Clone> { | ||
130 | data: T,<|> | ||
131 | } | ||
132 | "#####, | ||
133 | r#####" | ||
134 | struct Ctx<T: Clone> { | ||
135 | data: T, | ||
136 | } | ||
137 | |||
138 | impl<T: Clone> Ctx<T> { | ||
139 | $0 | ||
140 | } | ||
141 | "#####, | ||
142 | ) | ||
143 | } | ||
144 | |||
145 | #[test] | ||
146 | fn doctest_add_impl_default_members() { | ||
147 | check_doc_test( | ||
148 | "add_impl_default_members", | ||
149 | r#####" | ||
150 | trait Trait { | ||
151 | Type X; | ||
152 | fn foo(&self); | ||
153 | fn bar(&self) {} | ||
154 | } | ||
155 | |||
156 | impl Trait for () { | ||
157 | Type X = (); | ||
158 | fn foo(&self) {}<|> | ||
159 | |||
160 | } | ||
161 | "#####, | ||
162 | r#####" | ||
163 | trait Trait { | ||
164 | Type X; | ||
165 | fn foo(&self); | ||
166 | fn bar(&self) {} | ||
167 | } | ||
168 | |||
169 | impl Trait for () { | ||
170 | Type X = (); | ||
171 | fn foo(&self) {} | ||
172 | $0fn bar(&self) {} | ||
173 | |||
174 | } | ||
175 | "#####, | ||
176 | ) | ||
177 | } | ||
178 | |||
179 | #[test] | ||
180 | fn doctest_add_impl_missing_members() { | ||
181 | check_doc_test( | ||
182 | "add_impl_missing_members", | ||
183 | r#####" | ||
184 | trait Trait<T> { | ||
185 | Type X; | ||
186 | fn foo(&self) -> T; | ||
187 | fn bar(&self) {} | ||
188 | } | ||
189 | |||
190 | impl Trait<u32> for () {<|> | ||
191 | |||
192 | } | ||
193 | "#####, | ||
194 | r#####" | ||
195 | trait Trait<T> { | ||
196 | Type X; | ||
197 | fn foo(&self) -> T; | ||
198 | fn bar(&self) {} | ||
199 | } | ||
200 | |||
201 | impl Trait<u32> for () { | ||
202 | fn foo(&self) -> u32 { | ||
203 | ${0:todo!()} | ||
204 | } | ||
205 | |||
206 | } | ||
207 | "#####, | ||
208 | ) | ||
209 | } | ||
210 | |||
211 | #[test] | ||
212 | fn doctest_add_new() { | ||
213 | check_doc_test( | ||
214 | "add_new", | ||
215 | r#####" | ||
216 | struct Ctx<T: Clone> { | ||
217 | data: T,<|> | ||
218 | } | ||
219 | "#####, | ||
220 | r#####" | ||
221 | struct Ctx<T: Clone> { | ||
222 | data: T, | ||
223 | } | ||
224 | |||
225 | impl<T: Clone> Ctx<T> { | ||
226 | fn $0new(data: T) -> Self { Self { data } } | ||
227 | } | ||
228 | |||
229 | "#####, | ||
230 | ) | ||
231 | } | ||
232 | |||
233 | #[test] | ||
234 | fn doctest_add_turbo_fish() { | ||
235 | check_doc_test( | ||
236 | "add_turbo_fish", | ||
237 | r#####" | ||
238 | fn make<T>() -> T { todo!() } | ||
239 | fn main() { | ||
240 | let x = make<|>(); | ||
241 | } | ||
242 | "#####, | ||
243 | r#####" | ||
244 | fn make<T>() -> T { todo!() } | ||
245 | fn main() { | ||
246 | let x = make::<${0:_}>(); | ||
247 | } | ||
248 | "#####, | ||
249 | ) | ||
250 | } | ||
251 | |||
252 | #[test] | ||
253 | fn doctest_apply_demorgan() { | ||
254 | check_doc_test( | ||
255 | "apply_demorgan", | ||
256 | r#####" | ||
257 | fn main() { | ||
258 | if x != 4 ||<|> !y {} | ||
259 | } | ||
260 | "#####, | ||
261 | r#####" | ||
262 | fn main() { | ||
263 | if !(x == 4 && y) {} | ||
264 | } | ||
265 | "#####, | ||
266 | ) | ||
267 | } | ||
268 | |||
269 | #[test] | ||
270 | fn doctest_auto_import() { | ||
271 | check_doc_test( | ||
272 | "auto_import", | ||
273 | r#####" | ||
274 | fn main() { | ||
275 | let map = HashMap<|>::new(); | ||
276 | } | ||
277 | pub mod std { pub mod collections { pub struct HashMap { } } } | ||
278 | "#####, | ||
279 | r#####" | ||
280 | use std::collections::HashMap; | ||
281 | |||
282 | fn main() { | ||
283 | let map = HashMap::new(); | ||
284 | } | ||
285 | pub mod std { pub mod collections { pub struct HashMap { } } } | ||
286 | "#####, | ||
287 | ) | ||
288 | } | ||
289 | |||
290 | #[test] | ||
291 | fn doctest_change_return_type_to_result() { | ||
292 | check_doc_test( | ||
293 | "change_return_type_to_result", | ||
294 | r#####" | ||
295 | fn foo() -> i32<|> { 42i32 } | ||
296 | "#####, | ||
297 | r#####" | ||
298 | fn foo() -> Result<i32, ${0:_}> { Ok(42i32) } | ||
299 | "#####, | ||
300 | ) | ||
301 | } | ||
302 | |||
303 | #[test] | ||
304 | fn doctest_change_visibility() { | ||
305 | check_doc_test( | ||
306 | "change_visibility", | ||
307 | r#####" | ||
308 | <|>fn frobnicate() {} | ||
309 | "#####, | ||
310 | r#####" | ||
311 | pub(crate) fn frobnicate() {} | ||
312 | "#####, | ||
313 | ) | ||
314 | } | ||
315 | |||
316 | #[test] | ||
317 | fn doctest_convert_to_guarded_return() { | ||
318 | check_doc_test( | ||
319 | "convert_to_guarded_return", | ||
320 | r#####" | ||
321 | fn main() { | ||
322 | <|>if cond { | ||
323 | foo(); | ||
324 | bar(); | ||
325 | } | ||
326 | } | ||
327 | "#####, | ||
328 | r#####" | ||
329 | fn main() { | ||
330 | if !cond { | ||
331 | return; | ||
332 | } | ||
333 | foo(); | ||
334 | bar(); | ||
335 | } | ||
336 | "#####, | ||
337 | ) | ||
338 | } | ||
339 | |||
340 | #[test] | ||
341 | fn doctest_fill_match_arms() { | ||
342 | check_doc_test( | ||
343 | "fill_match_arms", | ||
344 | r#####" | ||
345 | enum Action { Move { distance: u32 }, Stop } | ||
346 | |||
347 | fn handle(action: Action) { | ||
348 | match action { | ||
349 | <|> | ||
350 | } | ||
351 | } | ||
352 | "#####, | ||
353 | r#####" | ||
354 | enum Action { Move { distance: u32 }, Stop } | ||
355 | |||
356 | fn handle(action: Action) { | ||
357 | match action { | ||
358 | $0Action::Move { distance } => {} | ||
359 | Action::Stop => {} | ||
360 | } | ||
361 | } | ||
362 | "#####, | ||
363 | ) | ||
364 | } | ||
365 | |||
366 | #[test] | ||
367 | fn doctest_fix_visibility() { | ||
368 | check_doc_test( | ||
369 | "fix_visibility", | ||
370 | r#####" | ||
371 | mod m { | ||
372 | fn frobnicate() {} | ||
373 | } | ||
374 | fn main() { | ||
375 | m::frobnicate<|>() {} | ||
376 | } | ||
377 | "#####, | ||
378 | r#####" | ||
379 | mod m { | ||
380 | $0pub(crate) fn frobnicate() {} | ||
381 | } | ||
382 | fn main() { | ||
383 | m::frobnicate() {} | ||
384 | } | ||
385 | "#####, | ||
386 | ) | ||
387 | } | ||
388 | |||
389 | #[test] | ||
390 | fn doctest_flip_binexpr() { | ||
391 | check_doc_test( | ||
392 | "flip_binexpr", | ||
393 | r#####" | ||
394 | fn main() { | ||
395 | let _ = 90 +<|> 2; | ||
396 | } | ||
397 | "#####, | ||
398 | r#####" | ||
399 | fn main() { | ||
400 | let _ = 2 + 90; | ||
401 | } | ||
402 | "#####, | ||
403 | ) | ||
404 | } | ||
405 | |||
406 | #[test] | ||
407 | fn doctest_flip_comma() { | ||
408 | check_doc_test( | ||
409 | "flip_comma", | ||
410 | r#####" | ||
411 | fn main() { | ||
412 | ((1, 2),<|> (3, 4)); | ||
413 | } | ||
414 | "#####, | ||
415 | r#####" | ||
416 | fn main() { | ||
417 | ((3, 4), (1, 2)); | ||
418 | } | ||
419 | "#####, | ||
420 | ) | ||
421 | } | ||
422 | |||
423 | #[test] | ||
424 | fn doctest_flip_trait_bound() { | ||
425 | check_doc_test( | ||
426 | "flip_trait_bound", | ||
427 | r#####" | ||
428 | fn foo<T: Clone +<|> Copy>() { } | ||
429 | "#####, | ||
430 | r#####" | ||
431 | fn foo<T: Copy + Clone>() { } | ||
432 | "#####, | ||
433 | ) | ||
434 | } | ||
435 | |||
436 | #[test] | ||
437 | fn doctest_inline_local_variable() { | ||
438 | check_doc_test( | ||
439 | "inline_local_variable", | ||
440 | r#####" | ||
441 | fn main() { | ||
442 | let x<|> = 1 + 2; | ||
443 | x * 4; | ||
444 | } | ||
445 | "#####, | ||
446 | r#####" | ||
447 | fn main() { | ||
448 | (1 + 2) * 4; | ||
449 | } | ||
450 | "#####, | ||
451 | ) | ||
452 | } | ||
453 | |||
454 | #[test] | ||
455 | fn doctest_introduce_named_lifetime() { | ||
456 | check_doc_test( | ||
457 | "introduce_named_lifetime", | ||
458 | r#####" | ||
459 | impl Cursor<'_<|>> { | ||
460 | fn node(self) -> &SyntaxNode { | ||
461 | match self { | ||
462 | Cursor::Replace(node) | Cursor::Before(node) => node, | ||
463 | } | ||
464 | } | ||
465 | } | ||
466 | "#####, | ||
467 | r#####" | ||
468 | impl<'a> Cursor<'a> { | ||
469 | fn node(self) -> &SyntaxNode { | ||
470 | match self { | ||
471 | Cursor::Replace(node) | Cursor::Before(node) => node, | ||
472 | } | ||
473 | } | ||
474 | } | ||
475 | "#####, | ||
476 | ) | ||
477 | } | ||
478 | |||
479 | #[test] | ||
480 | fn doctest_introduce_variable() { | ||
481 | check_doc_test( | ||
482 | "introduce_variable", | ||
483 | r#####" | ||
484 | fn main() { | ||
485 | <|>(1 + 2)<|> * 4; | ||
486 | } | ||
487 | "#####, | ||
488 | r#####" | ||
489 | fn main() { | ||
490 | let $0var_name = (1 + 2); | ||
491 | var_name * 4; | ||
492 | } | ||
493 | "#####, | ||
494 | ) | ||
495 | } | ||
496 | |||
497 | #[test] | ||
498 | fn doctest_invert_if() { | ||
499 | check_doc_test( | ||
500 | "invert_if", | ||
501 | r#####" | ||
502 | fn main() { | ||
503 | if<|> !y { A } else { B } | ||
504 | } | ||
505 | "#####, | ||
506 | r#####" | ||
507 | fn main() { | ||
508 | if y { B } else { A } | ||
509 | } | ||
510 | "#####, | ||
511 | ) | ||
512 | } | ||
513 | |||
514 | #[test] | ||
515 | fn doctest_make_raw_string() { | ||
516 | check_doc_test( | ||
517 | "make_raw_string", | ||
518 | r#####" | ||
519 | fn main() { | ||
520 | "Hello,<|> World!"; | ||
521 | } | ||
522 | "#####, | ||
523 | r#####" | ||
524 | fn main() { | ||
525 | r#"Hello, World!"#; | ||
526 | } | ||
527 | "#####, | ||
528 | ) | ||
529 | } | ||
530 | |||
531 | #[test] | ||
532 | fn doctest_make_usual_string() { | ||
533 | check_doc_test( | ||
534 | "make_usual_string", | ||
535 | r#####" | ||
536 | fn main() { | ||
537 | r#"Hello,<|> "World!""#; | ||
538 | } | ||
539 | "#####, | ||
540 | r#####" | ||
541 | fn main() { | ||
542 | "Hello, \"World!\""; | ||
543 | } | ||
544 | "#####, | ||
545 | ) | ||
546 | } | ||
547 | |||
548 | #[test] | ||
549 | fn doctest_merge_imports() { | ||
550 | check_doc_test( | ||
551 | "merge_imports", | ||
552 | r#####" | ||
553 | use std::<|>fmt::Formatter; | ||
554 | use std::io; | ||
555 | "#####, | ||
556 | r#####" | ||
557 | use std::{fmt::Formatter, io}; | ||
558 | "#####, | ||
559 | ) | ||
560 | } | ||
561 | |||
562 | #[test] | ||
563 | fn doctest_merge_match_arms() { | ||
564 | check_doc_test( | ||
565 | "merge_match_arms", | ||
566 | r#####" | ||
567 | enum Action { Move { distance: u32 }, Stop } | ||
568 | |||
569 | fn handle(action: Action) { | ||
570 | match action { | ||
571 | <|>Action::Move(..) => foo(), | ||
572 | Action::Stop => foo(), | ||
573 | } | ||
574 | } | ||
575 | "#####, | ||
576 | r#####" | ||
577 | enum Action { Move { distance: u32 }, Stop } | ||
578 | |||
579 | fn handle(action: Action) { | ||
580 | match action { | ||
581 | Action::Move(..) | Action::Stop => foo(), | ||
582 | } | ||
583 | } | ||
584 | "#####, | ||
585 | ) | ||
586 | } | ||
587 | |||
588 | #[test] | ||
589 | fn doctest_move_arm_cond_to_match_guard() { | ||
590 | check_doc_test( | ||
591 | "move_arm_cond_to_match_guard", | ||
592 | r#####" | ||
593 | enum Action { Move { distance: u32 }, Stop } | ||
594 | |||
595 | fn handle(action: Action) { | ||
596 | match action { | ||
597 | Action::Move { distance } => <|>if distance > 10 { foo() }, | ||
598 | _ => (), | ||
599 | } | ||
600 | } | ||
601 | "#####, | ||
602 | r#####" | ||
603 | enum Action { Move { distance: u32 }, Stop } | ||
604 | |||
605 | fn handle(action: Action) { | ||
606 | match action { | ||
607 | Action::Move { distance } if distance > 10 => foo(), | ||
608 | _ => (), | ||
609 | } | ||
610 | } | ||
611 | "#####, | ||
612 | ) | ||
613 | } | ||
614 | |||
615 | #[test] | ||
616 | fn doctest_move_bounds_to_where_clause() { | ||
617 | check_doc_test( | ||
618 | "move_bounds_to_where_clause", | ||
619 | r#####" | ||
620 | fn apply<T, U, <|>F: FnOnce(T) -> U>(f: F, x: T) -> U { | ||
621 | f(x) | ||
622 | } | ||
623 | "#####, | ||
624 | r#####" | ||
625 | fn apply<T, U, F>(f: F, x: T) -> U where F: FnOnce(T) -> U { | ||
626 | f(x) | ||
627 | } | ||
628 | "#####, | ||
629 | ) | ||
630 | } | ||
631 | |||
632 | #[test] | ||
633 | fn doctest_move_guard_to_arm_body() { | ||
634 | check_doc_test( | ||
635 | "move_guard_to_arm_body", | ||
636 | r#####" | ||
637 | enum Action { Move { distance: u32 }, Stop } | ||
638 | |||
639 | fn handle(action: Action) { | ||
640 | match action { | ||
641 | Action::Move { distance } <|>if distance > 10 => foo(), | ||
642 | _ => (), | ||
643 | } | ||
644 | } | ||
645 | "#####, | ||
646 | r#####" | ||
647 | enum Action { Move { distance: u32 }, Stop } | ||
648 | |||
649 | fn handle(action: Action) { | ||
650 | match action { | ||
651 | Action::Move { distance } => if distance > 10 { foo() }, | ||
652 | _ => (), | ||
653 | } | ||
654 | } | ||
655 | "#####, | ||
656 | ) | ||
657 | } | ||
658 | |||
659 | #[test] | ||
660 | fn doctest_remove_dbg() { | ||
661 | check_doc_test( | ||
662 | "remove_dbg", | ||
663 | r#####" | ||
664 | fn main() { | ||
665 | <|>dbg!(92); | ||
666 | } | ||
667 | "#####, | ||
668 | r#####" | ||
669 | fn main() { | ||
670 | 92; | ||
671 | } | ||
672 | "#####, | ||
673 | ) | ||
674 | } | ||
675 | |||
676 | #[test] | ||
677 | fn doctest_remove_hash() { | ||
678 | check_doc_test( | ||
679 | "remove_hash", | ||
680 | r#####" | ||
681 | fn main() { | ||
682 | r#"Hello,<|> World!"#; | ||
683 | } | ||
684 | "#####, | ||
685 | r#####" | ||
686 | fn main() { | ||
687 | r"Hello, World!"; | ||
688 | } | ||
689 | "#####, | ||
690 | ) | ||
691 | } | ||
692 | |||
693 | #[test] | ||
694 | fn doctest_remove_mut() { | ||
695 | check_doc_test( | ||
696 | "remove_mut", | ||
697 | r#####" | ||
698 | impl Walrus { | ||
699 | fn feed(&mut<|> self, amount: u32) {} | ||
700 | } | ||
701 | "#####, | ||
702 | r#####" | ||
703 | impl Walrus { | ||
704 | fn feed(&self, amount: u32) {} | ||
705 | } | ||
706 | "#####, | ||
707 | ) | ||
708 | } | ||
709 | |||
710 | #[test] | ||
711 | fn doctest_reorder_fields() { | ||
712 | check_doc_test( | ||
713 | "reorder_fields", | ||
714 | r#####" | ||
715 | struct Foo {foo: i32, bar: i32}; | ||
716 | const test: Foo = <|>Foo {bar: 0, foo: 1} | ||
717 | "#####, | ||
718 | r#####" | ||
719 | struct Foo {foo: i32, bar: i32}; | ||
720 | const test: Foo = Foo {foo: 1, bar: 0} | ||
721 | "#####, | ||
722 | ) | ||
723 | } | ||
724 | |||
725 | #[test] | ||
726 | fn doctest_replace_if_let_with_match() { | ||
727 | check_doc_test( | ||
728 | "replace_if_let_with_match", | ||
729 | r#####" | ||
730 | enum Action { Move { distance: u32 }, Stop } | ||
731 | |||
732 | fn handle(action: Action) { | ||
733 | <|>if let Action::Move { distance } = action { | ||
734 | foo(distance) | ||
735 | } else { | ||
736 | bar() | ||
737 | } | ||
738 | } | ||
739 | "#####, | ||
740 | r#####" | ||
741 | enum Action { Move { distance: u32 }, Stop } | ||
742 | |||
743 | fn handle(action: Action) { | ||
744 | match action { | ||
745 | Action::Move { distance } => foo(distance), | ||
746 | _ => bar(), | ||
747 | } | ||
748 | } | ||
749 | "#####, | ||
750 | ) | ||
751 | } | ||
752 | |||
753 | #[test] | ||
754 | fn doctest_replace_let_with_if_let() { | ||
755 | check_doc_test( | ||
756 | "replace_let_with_if_let", | ||
757 | r#####" | ||
758 | enum Option<T> { Some(T), None } | ||
759 | |||
760 | fn main(action: Action) { | ||
761 | <|>let x = compute(); | ||
762 | } | ||
763 | |||
764 | fn compute() -> Option<i32> { None } | ||
765 | "#####, | ||
766 | r#####" | ||
767 | enum Option<T> { Some(T), None } | ||
768 | |||
769 | fn main(action: Action) { | ||
770 | if let Some(x) = compute() { | ||
771 | } | ||
772 | } | ||
773 | |||
774 | fn compute() -> Option<i32> { None } | ||
775 | "#####, | ||
776 | ) | ||
777 | } | ||
778 | |||
779 | #[test] | ||
780 | fn doctest_replace_qualified_name_with_use() { | ||
781 | check_doc_test( | ||
782 | "replace_qualified_name_with_use", | ||
783 | r#####" | ||
784 | fn process(map: std::collections::<|>HashMap<String, String>) {} | ||
785 | "#####, | ||
786 | r#####" | ||
787 | use std::collections::HashMap; | ||
788 | |||
789 | fn process(map: HashMap<String, String>) {} | ||
790 | "#####, | ||
791 | ) | ||
792 | } | ||
793 | |||
794 | #[test] | ||
795 | fn doctest_replace_unwrap_with_match() { | ||
796 | check_doc_test( | ||
797 | "replace_unwrap_with_match", | ||
798 | r#####" | ||
799 | enum Result<T, E> { Ok(T), Err(E) } | ||
800 | fn main() { | ||
801 | let x: Result<i32, i32> = Result::Ok(92); | ||
802 | let y = x.<|>unwrap(); | ||
803 | } | ||
804 | "#####, | ||
805 | r#####" | ||
806 | enum Result<T, E> { Ok(T), Err(E) } | ||
807 | fn main() { | ||
808 | let x: Result<i32, i32> = Result::Ok(92); | ||
809 | let y = match x { | ||
810 | Ok(a) => a, | ||
811 | $0_ => unreachable!(), | ||
812 | }; | ||
813 | } | ||
814 | "#####, | ||
815 | ) | ||
816 | } | ||
817 | |||
818 | #[test] | ||
819 | fn doctest_split_import() { | ||
820 | check_doc_test( | ||
821 | "split_import", | ||
822 | r#####" | ||
823 | use std::<|>collections::HashMap; | ||
824 | "#####, | ||
825 | r#####" | ||
826 | use std::{collections::HashMap}; | ||
827 | "#####, | ||
828 | ) | ||
829 | } | ||
830 | |||
831 | #[test] | ||
832 | fn doctest_unwrap_block() { | ||
833 | check_doc_test( | ||
834 | "unwrap_block", | ||
835 | r#####" | ||
836 | fn foo() { | ||
837 | if true {<|> | ||
838 | println!("foo"); | ||
839 | } | ||
840 | } | ||
841 | "#####, | ||
842 | r#####" | ||
843 | fn foo() { | ||
844 | println!("foo"); | ||
845 | } | ||
846 | "#####, | ||
847 | ) | ||
848 | } | ||