forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#127523 - Oneirical:treasure-test, r=jieyouxu
Migrate `dump-ice-to-disk` and `panic-abort-eh_frame` `run-make` tests to rmake Part of rust-lang#121876 and the associated [Google Summer of Code project](https://blog.rust-lang.org/2024/05/01/gsoc-2024-selected-projects.html). Please try: try-job: x86_64-msvc
- Loading branch information
Showing
7 changed files
with
101 additions
and
86 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
// This test checks if internal compilation error (ICE) log files work as expected. | ||
// - Get the number of lines from the log files without any configuration options, | ||
// then check that the line count doesn't change if the backtrace gets configured to be short | ||
// or full. | ||
// - Check that disabling ICE logging results in zero files created. | ||
// - Check that the ICE files contain some of the expected strings. | ||
// See https://github.com/rust-lang/rust/pull/108714 | ||
|
||
use run_make_support::{cwd, has_extension, has_prefix, rfs, rustc, shallow_find_files}; | ||
|
||
fn main() { | ||
rustc().input("lib.rs").arg("-Ztreat-err-as-bug=1").run_fail(); | ||
let default = get_text_from_ice(".").lines().count(); | ||
clear_ice_files(); | ||
|
||
rustc().env("RUSTC_ICE", cwd()).input("lib.rs").arg("-Ztreat-err-as-bug=1").run_fail(); | ||
let ice_text = get_text_from_ice(cwd()); | ||
let default_set = ice_text.lines().count(); | ||
let content = ice_text; | ||
let ice_files = shallow_find_files(cwd(), |path| { | ||
has_prefix(path, "rustc-ice") && has_extension(path, "txt") | ||
}); | ||
assert_eq!(ice_files.len(), 1); // There should only be 1 ICE file. | ||
let ice_file_name = | ||
ice_files.first().and_then(|f| f.file_name()).and_then(|n| n.to_str()).unwrap(); | ||
// Ensure that the ICE dump path doesn't contain `:`, because they cause problems on Windows. | ||
assert!(!ice_file_name.contains(":"), "{ice_file_name}"); | ||
|
||
clear_ice_files(); | ||
rustc() | ||
.env("RUSTC_ICE", cwd()) | ||
.input("lib.rs") | ||
.env("RUST_BACKTRACE", "short") | ||
.arg("-Ztreat-err-as-bug=1") | ||
.run_fail(); | ||
let short = get_text_from_ice(cwd()).lines().count(); | ||
clear_ice_files(); | ||
rustc() | ||
.env("RUSTC_ICE", cwd()) | ||
.input("lib.rs") | ||
.env("RUST_BACKTRACE", "full") | ||
.arg("-Ztreat-err-as-bug=1") | ||
.run_fail(); | ||
let full = get_text_from_ice(cwd()).lines().count(); | ||
clear_ice_files(); | ||
|
||
// The ICE dump is explicitly disabled. Therefore, this should produce no files. | ||
rustc().env("RUSTC_ICE", "0").input("lib.rs").arg("-Ztreat-err-as-bug=1").run_fail(); | ||
let ice_files = shallow_find_files(cwd(), |path| { | ||
has_prefix(path, "rustc-ice") && has_extension(path, "txt") | ||
}); | ||
assert!(ice_files.is_empty()); // There should be 0 ICE files. | ||
|
||
// The line count should not change. | ||
assert_eq!(short, default_set); | ||
assert_eq!(short, default); | ||
assert_eq!(full, default_set); | ||
assert!(default > 0); | ||
// Some of the expected strings in an ICE file should appear. | ||
assert!(content.contains("thread 'rustc' panicked at")); | ||
assert!(content.contains("stack backtrace:")); | ||
} | ||
|
||
fn clear_ice_files() { | ||
let ice_files = shallow_find_files(cwd(), |path| { | ||
has_prefix(path, "rustc-ice") && has_extension(path, "txt") | ||
}); | ||
for file in ice_files { | ||
rfs::remove_file(file); | ||
} | ||
} | ||
|
||
#[track_caller] | ||
fn get_text_from_ice(dir: impl AsRef<std::path::Path>) -> String { | ||
let ice_files = | ||
shallow_find_files(dir, |path| has_prefix(path, "rustc-ice") && has_extension(path, "txt")); | ||
assert_eq!(ice_files.len(), 1); // There should only be 1 ICE file. | ||
let ice_file = ice_files.get(0).unwrap(); | ||
let output = rfs::read_to_string(ice_file); | ||
output | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
// An `.eh_frame` section in an object file is a symptom of an UnwindAction::Terminate | ||
// being inserted, useful for determining whether or not unwinding is necessary. | ||
// This is useless when panics would NEVER unwind due to -C panic=abort. This section should | ||
// therefore never appear in the emit file of a -C panic=abort compilation, and this test | ||
// checks that this is respected. | ||
// See https://github.com/rust-lang/rust/pull/112403 | ||
|
||
use run_make_support::{llvm_objdump, rustc}; | ||
|
||
fn main() { | ||
rustc() | ||
.input("foo.rs") | ||
.crate_type("lib") | ||
.emit("obj=foo.o") | ||
.panic("abort") | ||
.edition("2021") | ||
.arg("-Zvalidate-mir") | ||
.run(); | ||
llvm_objdump().arg("--dwarf=frames").input("foo.o").run().assert_stdout_not_contains("DW_CFA"); | ||
} |