diff options
| author | bors <bors@rust-lang.org> | 2017-02-06 14:10:13 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-02-06 14:10:13 +0000 |
| commit | 324b175174c19b8be4592df11e65e0c4b6fee9d3 (patch) | |
| tree | c898b6e95844adbf2e1df8794f1f1da3c34fce23 /src/test | |
| parent | 4711ac314c3380f992e218879b7c94b26ba4102b (diff) | |
| parent | ab3c8269f4d73d4760e99aca82411f954a11e571 (diff) | |
| download | rust-324b175174c19b8be4592df11e65e0c4b6fee9d3.tar.gz rust-324b175174c19b8be4592df11e65e0c4b6fee9d3.zip | |
Auto merge of #39500 - michaelwoerister:fix-ich-testing, r=nikomatsakis
Let the dep-tracking test framework check that all #[rustc_dirty] attrs have been actually checked r? @nikomatsakis
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/incremental/hashes/inherent_impls.rs | 67 | ||||
| -rw-r--r-- | src/test/incremental/hashes/trait_defs.rs | 4 | ||||
| -rw-r--r-- | src/test/incremental/hashes/trait_impls.rs | 50 | ||||
| -rw-r--r-- | src/test/incremental/unchecked_dirty_clean.rs | 44 | ||||
| -rw-r--r-- | src/test/incremental/unchecked_dirty_clean_metadata.rs | 45 |
5 files changed, 183 insertions, 27 deletions
diff --git a/src/test/incremental/hashes/inherent_impls.rs b/src/test/incremental/hashes/inherent_impls.rs index 5c37bc13359..fd9ac61046e 100644 --- a/src/test/incremental/hashes/inherent_impls.rs +++ b/src/test/incremental/hashes/inherent_impls.rs @@ -39,9 +39,7 @@ impl Foo { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn method_name2() { } } @@ -60,16 +58,47 @@ impl Foo { #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] + #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn method_body() { println!("Hello, world!"); } } -// Change Method Privacy ----------------------------------------------------------- + +// Change Method Body (inlined) ------------------------------------------------ +// +// This should affect the method itself, but not the impl. +#[cfg(cfail1)] +impl Foo { + #[inline] + pub fn method_body_inlined() { } +} + +#[cfg(not(cfail1))] +#[rustc_clean(label="Hir", cfg="cfail2")] +#[rustc_clean(label="Hir", cfg="cfail3")] +#[rustc_metadata_clean(cfg="cfail2")] +#[rustc_metadata_clean(cfg="cfail3")] +impl Foo { + #[rustc_clean(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail3")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] + #[rustc_metadata_dirty(cfg="cfail2")] + #[rustc_metadata_clean(cfg="cfail3")] + #[inline] + pub fn method_body_inlined() { + println!("Hello, world!"); + } +} + + +// Change Method Privacy ------------------------------------------------------- #[cfg(cfail1)] impl Foo { pub fn method_privacy() { } @@ -142,13 +171,11 @@ impl Foo { impl Foo { #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_clean(cfg="cfail2")] + #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn add_method_to_impl1(&self) { } - #[rustc_dirty(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn add_method_to_impl2(&self) { } } @@ -188,9 +215,13 @@ impl Foo { #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] + // At the moment we explicitly ignore argument names in metadata, since they + // are not used in downstream crates (except in rustdoc) + #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn change_method_parameter_name(&self, b: i64) { } } @@ -252,9 +283,13 @@ impl Foo { #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] + // At the moment we explicitly ignore argument names in metadata, since they + // are not used in downstream crates (except in rustdoc) + #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub fn change_method_parameter_order(&self, b: i64, a: i64) { } } @@ -465,7 +500,7 @@ impl Bar<u32> { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl<T> Bar<T> { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] @@ -486,7 +521,7 @@ impl Bar<u32> { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl Bar<u64> { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] @@ -507,7 +542,7 @@ impl<T> Bar<T> { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl<T: 'static> Bar<T> { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] @@ -528,7 +563,7 @@ impl<T> Bar<T> { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl<T: Clone> Bar<T> { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] diff --git a/src/test/incremental/hashes/trait_defs.rs b/src/test/incremental/hashes/trait_defs.rs index bc401ae9340..94698506ec5 100644 --- a/src/test/incremental/hashes/trait_defs.rs +++ b/src/test/incremental/hashes/trait_defs.rs @@ -316,8 +316,10 @@ trait TraitChangeModeSelfOwnToMut: Sized { #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] trait TraitChangeModeSelfOwnToMut: Sized { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] fn method(mut self) {} diff --git a/src/test/incremental/hashes/trait_impls.rs b/src/test/incremental/hashes/trait_impls.rs index 15094492248..30e376f04fb 100644 --- a/src/test/incremental/hashes/trait_impls.rs +++ b/src/test/incremental/hashes/trait_impls.rs @@ -46,9 +46,7 @@ impl ChangeMethodNameTrait for Foo { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] pub trait ChangeMethodNameTrait { - #[rustc_dirty(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] fn method_name2(); } @@ -59,16 +57,14 @@ pub trait ChangeMethodNameTrait { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl ChangeMethodNameTrait for Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] - #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] fn method_name2() { } } // Change Method Body ----------------------------------------------------------- // -// This should affect the method itself, but not the trait. +// This should affect the method itself, but not the impl. pub trait ChangeMethodBodyTrait { fn method_name(); @@ -85,16 +81,50 @@ impl ChangeMethodBodyTrait for Foo { #[rustc_metadata_clean(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl ChangeMethodBodyTrait for Foo { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail3")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] + #[rustc_metadata_clean(cfg="cfail2")] + #[rustc_metadata_clean(cfg="cfail3")] + fn method_name() { + () + } +} + +// Change Method Body (inlined fn) --------------------------------------------- +// +// This should affect the method itself, but not the impl. + +pub trait ChangeMethodBodyTraitInlined { + fn method_name(); +} + +#[cfg(cfail1)] +impl ChangeMethodBodyTraitInlined for Foo { + #[inline] + fn method_name() { } +} + +#[cfg(not(cfail1))] +#[rustc_clean(label="Hir", cfg="cfail2")] +#[rustc_clean(label="Hir", cfg="cfail3")] +#[rustc_metadata_clean(cfg="cfail2")] +#[rustc_metadata_clean(cfg="cfail3")] +impl ChangeMethodBodyTraitInlined for Foo { + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] + #[rustc_dirty(label="HirBody", cfg="cfail2")] + #[rustc_clean(label="HirBody", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] + #[inline] fn method_name() { () } } -// Change Method Selfness ----------------------------------------------------------- +// Change Method Selfness ------------------------------------------------------ #[cfg(cfail1)] pub trait ChangeMethodSelfnessTrait { @@ -447,7 +477,7 @@ impl ChangeSelfTypeOfImpl for u32 { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl ChangeSelfTypeOfImpl for u64 { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] @@ -472,7 +502,7 @@ impl<T> AddLifetimeBoundToImplParameter for T { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl<T: 'static> AddLifetimeBoundToImplParameter for T { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] @@ -497,7 +527,7 @@ impl<T> AddTraitBoundToImplParameter for T { #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] impl<T: Clone> AddTraitBoundToImplParameter for T { - #[rustc_dirty(label="Hir", cfg="cfail2")] + #[rustc_clean(label="Hir", cfg="cfail2")] #[rustc_clean(label="Hir", cfg="cfail3")] #[rustc_metadata_dirty(cfg="cfail2")] #[rustc_metadata_clean(cfg="cfail3")] diff --git a/src/test/incremental/unchecked_dirty_clean.rs b/src/test/incremental/unchecked_dirty_clean.rs new file mode 100644 index 00000000000..a81e884f39e --- /dev/null +++ b/src/test/incremental/unchecked_dirty_clean.rs @@ -0,0 +1,44 @@ +// Copyright 2017 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// revisions: rpass1 cfail2 +// compile-flags: -Z query-dep-graph + +#![allow(warnings)] +#![feature(rustc_attrs)] + +// Sanity check for the dirty-clean system. We add #[rustc_dirty]/#[rustc_clean] +// attributes in places that are not checked and make sure that this causes an +// error. + +fn main() { + + #[rustc_dirty(label="Hir", cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + { + // empty block + } + + #[rustc_clean(label="Hir", cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + { + // empty block + } +} + +struct _Struct { + #[rustc_dirty(label="Hir", cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + _field1: i32, + + #[rustc_clean(label="Hir", cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + _field2: i32, +} diff --git a/src/test/incremental/unchecked_dirty_clean_metadata.rs b/src/test/incremental/unchecked_dirty_clean_metadata.rs new file mode 100644 index 00000000000..4017b4d4ba9 --- /dev/null +++ b/src/test/incremental/unchecked_dirty_clean_metadata.rs @@ -0,0 +1,45 @@ +// Copyright 2017 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// revisions: rpass1 cfail2 +// compile-flags: -Z query-dep-graph + +#![allow(warnings)] +#![feature(rustc_attrs)] + +// Sanity check for the dirty-clean system. We add +// #[rustc_metadata_dirty]/#[rustc_metadata_clean] attributes in places that +// are not checked and make sure that this causes an error. + +fn main() { + + #[rustc_metadata_dirty(cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + { + // empty block + } + + #[rustc_metadata_clean(cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + { + // empty block + } +} + +struct _Struct { + #[rustc_metadata_dirty(cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + _field1: i32, + + #[rustc_metadata_clean(cfg="cfail2")] + //[cfail2]~^ ERROR found unchecked #[rustc_dirty]/#[rustc_clean] attribute + _field2: i32, +} + |
