Skip to content

Commit

Permalink
Tests.
Browse files Browse the repository at this point in the history
Namely, a regression test for issue #69798 (export added), and the inverse of
that test (export removd).
  • Loading branch information
pnkfelix committed Apr 14, 2020
1 parent e542f4f commit 12207f6
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 0 deletions.
26 changes: 26 additions & 0 deletions src/test/incremental/thinlto/cgu_invalidated_when_export_added.rs
@@ -0,0 +1,26 @@
// revisions: cfail1 cfail2
// build-pass

// rust-lang/rust#69798:
//
// This is analgous to cgu_invalidated_when_import_added, but it covers a
// problem uncovered where a change to the *export* set caused a link failure
// when reusing post-LTO optimized object code.

pub struct Foo {}
impl Drop for Foo {
fn drop(&mut self) {
println!("Dropping Foo");
}
}
#[no_mangle]
pub extern "C" fn run() {
thread_local! { pub static FOO : Foo = Foo { } ; }

#[cfg(cfail2)]
{
FOO.with(|_f| ())
}
}

pub fn main() { run() }
@@ -0,0 +1,26 @@
// revisions: cfail1 cfail2
// build-pass

// rust-lang/rust#69798:
//
// This is analgous to cgu_invalidated_when_export_added, but it covers the
// other direction. This is analogous to cgu_invalidated_when_import_added: we
// include it, because it may uncover bugs in variant implementation strategies.

pub struct Foo {}
impl Drop for Foo {
fn drop(&mut self) {
println!("Dropping Foo");
}
}
#[no_mangle]
pub extern "C" fn run() {
thread_local! { pub static FOO : Foo = Foo { } ; }

#[cfg(cfail1)]
{
FOO.with(|_f| ())
}
}

pub fn main() { run() }

0 comments on commit 12207f6

Please sign in to comment.