Skip to content

Commit e0f6840

Browse files
authored
Rollup merge of #106793 - Mark-Simulacrum:normalize-test, r=compiler-errors
Normalize test output more thoroughly This prevents differences in local environments, which may (for example) end up with a longer backtrace with more digits in the backtrace prefix, as happened to me. While we're at it, clean more of the output up, including the exact location of the error in the compiler. cc #106521 which introduced this test
2 parents 720137b + 95ef76b commit e0f6840

File tree

2 files changed

+55
-28
lines changed

2 files changed

+55
-28
lines changed

tests/ui/chalkify/bugs/async.rs

+13-4
Original file line numberDiff line numberDiff line change
@@ -2,12 +2,21 @@
22
// known-bug
33
// unset-rustc-env:RUST_BACKTRACE
44
// compile-flags:-Z trait-solver=chalk --edition=2021
5-
// error-pattern:stack backtrace:
5+
// error-pattern:internal compiler error
66
// failure-status:101
7-
// normalize-stderr-test "note: .*" -> ""
8-
// normalize-stderr-test "thread 'rustc' .*" -> ""
9-
// normalize-stderr-test " .*\n" -> ""
107
// normalize-stderr-test "DefId([^)]*)" -> "..."
8+
// normalize-stderr-test "\nerror: internal compiler error.*\n\n" -> ""
9+
// normalize-stderr-test "note:.*unexpectedly panicked.*\n\n" -> ""
10+
// normalize-stderr-test "note: we would appreciate a bug report.*\n\n" -> ""
11+
// normalize-stderr-test "note: compiler flags.*\n\n" -> ""
12+
// normalize-stderr-test "note: rustc.*running on.*\n\n" -> ""
13+
// normalize-stderr-test "thread.*panicked.*\n" -> ""
14+
// normalize-stderr-test "stack backtrace:\n" -> ""
15+
// normalize-stderr-test "\s\d{1,}: .*\n" -> ""
16+
// normalize-stderr-test "\s at .*\n" -> ""
17+
// normalize-stderr-test ".*note: Some details.*\n" -> ""
18+
// normalize-stderr-test "\n\n[ ]*\n" -> ""
19+
// normalize-stderr-test "compiler/.*: projection" -> "projection"
1120

1221
fn main() -> () {}
1322

tests/ui/chalkify/bugs/async.stderr

+42-24
Original file line numberDiff line numberDiff line change
@@ -1,29 +1,47 @@
1-
error[E0277]: `[async fn body@$DIR/async.rs:14:29: 16:2]` is not a future
2-
LL |LL | |LL | | }
3-
4-
5-
error[E0277]: the size for values of type `<[async fn body@$DIR/async.rs:14:29: 16:2] as Future>::Output` cannot be known at compilation time
6-
LL |LL | |LL | | }
7-
8-
9-
error[E0277]: `[async fn body@$DIR/async.rs:14:29: 16:2]` is not a future
1+
error[E0277]: `[async fn body@$DIR/async.rs:23:29: 25:2]` is not a future
2+
--> $DIR/async.rs:23:29
3+
|
4+
LL | async fn foo(x: u32) -> u32 {
5+
| _____________________________-
6+
LL | | x
7+
LL | | }
8+
| | ^
9+
| | |
10+
| |_`[async fn body@$DIR/async.rs:23:29: 25:2]` is not a future
11+
| required by a bound introduced by this call
12+
|
13+
= help: the trait `Future` is not implemented for `[async fn body@$DIR/async.rs:23:29: 25:2]`
14+
= note: [async fn body@$DIR/async.rs:23:29: 25:2] must be a future or must implement `IntoFuture` to be awaited
15+
note: required by a bound in `identity_future`
16+
--> $SRC_DIR/core/src/future/mod.rs:LL:COL
17+
18+
error[E0277]: the size for values of type `<[async fn body@$DIR/async.rs:23:29: 25:2] as Future>::Output` cannot be known at compilation time
19+
--> $DIR/async.rs:23:29
20+
|
21+
LL | async fn foo(x: u32) -> u32 {
22+
| _____________________________^
23+
LL | | x
24+
LL | | }
25+
| |_^ doesn't have a size known at compile-time
26+
|
27+
= help: the trait `Sized` is not implemented for `<[async fn body@$DIR/async.rs:23:29: 25:2] as Future>::Output`
28+
note: required by a bound in `identity_future`
29+
--> $SRC_DIR/core/src/future/mod.rs:LL:COL
30+
31+
error[E0277]: `[async fn body@$DIR/async.rs:23:29: 25:2]` is not a future
32+
--> $DIR/async.rs:23:25
33+
|
1034
LL | async fn foo(x: u32) -> u32 {
11-
12-
error: internal compiler error: compiler/rustc_trait_selection/src/traits/error_reporting/mod.rs:1114:25: projection clauses should be implied from elsewhere. obligation: `Obligation(predicate=Binder(ProjectionPredicate(AliasTy { substs: [[async fn body@$DIR/async.rs:14:29: 16:2]], def_id: ...), _use_mk_alias_ty_instead: () }, Term::Ty(u32)), []), depth=0)`
35+
| ^^^ `[async fn body@$DIR/async.rs:23:29: 25:2]` is not a future
36+
|
37+
= help: the trait `Future` is not implemented for `[async fn body@$DIR/async.rs:23:29: 25:2]`
38+
= note: [async fn body@$DIR/async.rs:23:29: 25:2] must be a future or must implement `IntoFuture` to be awaited
39+
40+
error: internal compiler error: projection clauses should be implied from elsewhere. obligation: `Obligation(predicate=Binder(ProjectionPredicate(AliasTy { substs: [[async fn body@$DIR/async.rs:23:29: 25:2]], def_id: ...), _use_mk_alias_ty_instead: () }, Term::Ty(u32)), []), depth=0)`
41+
--> $DIR/async.rs:23:25
42+
|
1343
LL | async fn foo(x: u32) -> u32 {
14-
15-
16-
stack backtrace:
17-
18-
19-
20-
21-
22-
23-
24-
25-
26-
query stack during panic:
44+
| ^^^query stack during panic:
2745
#0 [typeck] type-checking `foo`
2846
#1 [thir_body] building THIR for `foo`
2947
#2 [mir_built] building MIR for `foo`

0 commit comments

Comments
 (0)