5458: Use expect in some ra_hir_ty tests r=flodiebold a=lnicola



Co-authored-by: Laurențiu Nicola <lnicola@dend.ro>
This commit is contained in:
bors[bot] 2020-07-21 07:11:55 +00:00 committed by GitHub
commit 57664369af
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 882 additions and 835 deletions

View file

@ -10,6 +10,7 @@ mod display_source_code;
use std::sync::Arc; use std::sync::Arc;
use expect::Expect;
use hir_def::{ use hir_def::{
body::{BodySourceMap, SyntheticSyntax}, body::{BodySourceMap, SyntheticSyntax},
child_by_source::ChildBySource, child_by_source::ChildBySource,
@ -344,3 +345,15 @@ fn typing_whitespace_inside_a_function_should_not_invalidate_types() {
assert!(!format!("{:?}", events).contains("infer"), "{:#?}", events) assert!(!format!("{:?}", events).contains("infer"), "{:#?}", events)
} }
} }
fn check_infer(ra_fixture: &str, expect: Expect) {
let mut actual = infer(ra_fixture);
actual.push('\n');
expect.assert_eq(&actual);
}
fn check_infer_with_mismatches(ra_fixture: &str, expect: Expect) {
let mut actual = infer_with_mismatches(ra_fixture, true);
actual.push('\n');
expect.assert_eq(&actual);
}

File diff suppressed because it is too large Load diff

View file

@ -1,6 +1,6 @@
use insta::assert_snapshot; use expect::expect;
use super::{check_types, infer_with_mismatches}; use super::{check_infer_with_mismatches, check_types};
#[test] #[test]
fn infer_never1() { fn infer_never1() {
@ -240,173 +240,170 @@ fn test(a: i32) {
#[test] #[test]
fn diverging_expression_1() { fn diverging_expression_1() {
let t = infer_with_mismatches( check_infer_with_mismatches(
r#" r"
//- /main.rs //- /main.rs
fn test1() { fn test1() {
let x: u32 = return; let x: u32 = return;
} }
fn test2() { fn test2() {
let x: u32 = { return; }; let x: u32 = { return; };
} }
fn test3() { fn test3() {
let x: u32 = loop {}; let x: u32 = loop {};
} }
fn test4() { fn test4() {
let x: u32 = { loop {} }; let x: u32 = { loop {} };
} }
fn test5() { fn test5() {
let x: u32 = { if true { loop {}; } else { loop {}; } }; let x: u32 = { if true { loop {}; } else { loop {}; } };
} }
fn test6() { fn test6() {
let x: u32 = { let y: u32 = { loop {}; }; }; let x: u32 = { let y: u32 = { loop {}; }; };
} }
"#, ",
true, expect![[r"
11..39 '{ ...urn; }': ()
21..22 'x': u32
30..36 'return': !
51..84 '{ ...; }; }': ()
61..62 'x': u32
70..81 '{ return; }': u32
72..78 'return': !
96..125 '{ ... {}; }': ()
106..107 'x': u32
115..122 'loop {}': !
120..122 '{}': ()
137..170 '{ ...} }; }': ()
147..148 'x': u32
156..167 '{ loop {} }': u32
158..165 'loop {}': !
163..165 '{}': ()
182..246 '{ ...} }; }': ()
192..193 'x': u32
201..243 '{ if t...}; } }': u32
203..241 'if tru... {}; }': u32
206..210 'true': bool
211..223 '{ loop {}; }': u32
213..220 'loop {}': !
218..220 '{}': ()
229..241 '{ loop {}; }': u32
231..238 'loop {}': !
236..238 '{}': ()
258..310 '{ ...; }; }': ()
268..269 'x': u32
277..307 '{ let ...; }; }': u32
283..284 'y': u32
292..304 '{ loop {}; }': u32
294..301 'loop {}': !
299..301 '{}': ()
"]],
); );
assert_snapshot!(t, @r###"
11..39 '{ ...urn; }': ()
21..22 'x': u32
30..36 'return': !
51..84 '{ ...; }; }': ()
61..62 'x': u32
70..81 '{ return; }': u32
72..78 'return': !
96..125 '{ ... {}; }': ()
106..107 'x': u32
115..122 'loop {}': !
120..122 '{}': ()
137..170 '{ ...} }; }': ()
147..148 'x': u32
156..167 '{ loop {} }': u32
158..165 'loop {}': !
163..165 '{}': ()
182..246 '{ ...} }; }': ()
192..193 'x': u32
201..243 '{ if t...}; } }': u32
203..241 'if tru... {}; }': u32
206..210 'true': bool
211..223 '{ loop {}; }': u32
213..220 'loop {}': !
218..220 '{}': ()
229..241 '{ loop {}; }': u32
231..238 'loop {}': !
236..238 '{}': ()
258..310 '{ ...; }; }': ()
268..269 'x': u32
277..307 '{ let ...; }; }': u32
283..284 'y': u32
292..304 '{ loop {}; }': u32
294..301 'loop {}': !
299..301 '{}': ()
"###);
} }
#[test] #[test]
fn diverging_expression_2() { fn diverging_expression_2() {
let t = infer_with_mismatches( check_infer_with_mismatches(
r#" r#"
//- /main.rs //- /main.rs
fn test1() { fn test1() {
// should give type mismatch // should give type mismatch
let x: u32 = { loop {}; "foo" }; let x: u32 = { loop {}; "foo" };
} }
"#, "#,
true, expect![[r#"
11..84 '{ ..." }; }': ()
54..55 'x': u32
63..81 '{ loop...foo" }': &str
65..72 'loop {}': !
70..72 '{}': ()
74..79 '"foo"': &str
63..81: expected u32, got &str
74..79: expected u32, got &str
"#]],
); );
assert_snapshot!(t, @r###"
11..84 '{ ..." }; }': ()
54..55 'x': u32
63..81 '{ loop...foo" }': &str
65..72 'loop {}': !
70..72 '{}': ()
74..79 '"foo"': &str
63..81: expected u32, got &str
74..79: expected u32, got &str
"###);
} }
#[test] #[test]
fn diverging_expression_3_break() { fn diverging_expression_3_break() {
let t = infer_with_mismatches( check_infer_with_mismatches(
r#" r"
//- /main.rs //- /main.rs
fn test1() { fn test1() {
// should give type mismatch // should give type mismatch
let x: u32 = { loop { break; } }; let x: u32 = { loop { break; } };
} }
fn test2() { fn test2() {
// should give type mismatch // should give type mismatch
let x: u32 = { for a in b { break; }; }; let x: u32 = { for a in b { break; }; };
// should give type mismatch as well // should give type mismatch as well
let x: u32 = { for a in b {}; }; let x: u32 = { for a in b {}; };
// should give type mismatch as well // should give type mismatch as well
let x: u32 = { for a in b { return; }; }; let x: u32 = { for a in b { return; }; };
} }
fn test3() { fn test3() {
// should give type mismatch // should give type mismatch
let x: u32 = { while true { break; }; }; let x: u32 = { while true { break; }; };
// should give type mismatch as well -- there's an implicit break, even if it's never hit // should give type mismatch as well -- there's an implicit break, even if it's never hit
let x: u32 = { while true {}; }; let x: u32 = { while true {}; };
// should give type mismatch as well // should give type mismatch as well
let x: u32 = { while true { return; }; }; let x: u32 = { while true { return; }; };
} }
"#, ",
true, expect![[r"
11..85 '{ ...} }; }': ()
54..55 'x': u32
63..82 '{ loop...k; } }': ()
65..80 'loop { break; }': ()
70..80 '{ break; }': ()
72..77 'break': !
63..82: expected u32, got ()
65..80: expected u32, got ()
97..343 '{ ...; }; }': ()
140..141 'x': u32
149..175 '{ for ...; }; }': ()
151..172 'for a ...eak; }': ()
155..156 'a': {unknown}
160..161 'b': {unknown}
162..172 '{ break; }': ()
164..169 'break': !
226..227 'x': u32
235..253 '{ for ... {}; }': ()
237..250 'for a in b {}': ()
241..242 'a': {unknown}
246..247 'b': {unknown}
248..250 '{}': ()
304..305 'x': u32
313..340 '{ for ...; }; }': ()
315..337 'for a ...urn; }': ()
319..320 'a': {unknown}
324..325 'b': {unknown}
326..337 '{ return; }': ()
328..334 'return': !
149..175: expected u32, got ()
235..253: expected u32, got ()
313..340: expected u32, got ()
355..654 '{ ...; }; }': ()
398..399 'x': u32
407..433 '{ whil...; }; }': ()
409..430 'while ...eak; }': ()
415..419 'true': bool
420..430 '{ break; }': ()
422..427 'break': !
537..538 'x': u32
546..564 '{ whil... {}; }': ()
548..561 'while true {}': ()
554..558 'true': bool
559..561 '{}': ()
615..616 'x': u32
624..651 '{ whil...; }; }': ()
626..648 'while ...urn; }': ()
632..636 'true': bool
637..648 '{ return; }': ()
639..645 'return': !
407..433: expected u32, got ()
546..564: expected u32, got ()
624..651: expected u32, got ()
"]],
); );
assert_snapshot!(t, @r###"
11..85 '{ ...} }; }': ()
54..55 'x': u32
63..82 '{ loop...k; } }': ()
65..80 'loop { break; }': ()
70..80 '{ break; }': ()
72..77 'break': !
63..82: expected u32, got ()
65..80: expected u32, got ()
97..343 '{ ...; }; }': ()
140..141 'x': u32
149..175 '{ for ...; }; }': ()
151..172 'for a ...eak; }': ()
155..156 'a': {unknown}
160..161 'b': {unknown}
162..172 '{ break; }': ()
164..169 'break': !
226..227 'x': u32
235..253 '{ for ... {}; }': ()
237..250 'for a in b {}': ()
241..242 'a': {unknown}
246..247 'b': {unknown}
248..250 '{}': ()
304..305 'x': u32
313..340 '{ for ...; }; }': ()
315..337 'for a ...urn; }': ()
319..320 'a': {unknown}
324..325 'b': {unknown}
326..337 '{ return; }': ()
328..334 'return': !
149..175: expected u32, got ()
235..253: expected u32, got ()
313..340: expected u32, got ()
355..654 '{ ...; }; }': ()
398..399 'x': u32
407..433 '{ whil...; }; }': ()
409..430 'while ...eak; }': ()
415..419 'true': bool
420..430 '{ break; }': ()
422..427 'break': !
537..538 'x': u32
546..564 '{ whil... {}; }': ()
548..561 'while true {}': ()
554..558 'true': bool
559..561 '{}': ()
615..616 'x': u32
624..651 '{ whil...; }; }': ()
626..648 'while ...urn; }': ()
632..636 'true': bool
637..648 '{ return; }': ()
639..645 'return': !
407..433: expected u32, got ()
546..564: expected u32, got ()
624..651: expected u32, got ()
"###);
} }