From e707ec7a0f8fcee39d756cb5341c6db063312eaa Mon Sep 17 00:00:00 2001 From: Urgau Date: Thu, 25 Apr 2024 20:39:17 +0200 Subject: [PATCH] Port run-make `--print=native-static-libs` to rmake.rs --- .../tidy/src/allowed_run_make_makefiles.txt | 1 - .../print-native-static-libs/Makefile | 19 ------- .../print-native-static-libs/rmake.rs | 56 +++++++++++++++++++ 3 files changed, 56 insertions(+), 20 deletions(-) delete mode 100644 tests/run-make/print-native-static-libs/Makefile create mode 100644 tests/run-make/print-native-static-libs/rmake.rs diff --git a/src/tools/tidy/src/allowed_run_make_makefiles.txt b/src/tools/tidy/src/allowed_run_make_makefiles.txt index 93188b4fbaebd..eb097f3c220f0 100644 --- a/src/tools/tidy/src/allowed_run_make_makefiles.txt +++ b/src/tools/tidy/src/allowed_run_make_makefiles.txt @@ -221,7 +221,6 @@ run-make/pretty-print-to-file/Makefile run-make/pretty-print-with-dep-file/Makefile run-make/print-calling-conventions/Makefile run-make/print-cfg/Makefile -run-make/print-native-static-libs/Makefile run-make/print-target-list/Makefile run-make/profile/Makefile run-make/prune-link-args/Makefile diff --git a/tests/run-make/print-native-static-libs/Makefile b/tests/run-make/print-native-static-libs/Makefile deleted file mode 100644 index a16c8b0f2a405..0000000000000 --- a/tests/run-make/print-native-static-libs/Makefile +++ /dev/null @@ -1,19 +0,0 @@ -include ../tools.mk - -# ignore-cross-compile -# ignore-wasm - -all: - $(RUSTC) --crate-type rlib -lbar_cli bar.rs - $(RUSTC) foo.rs -lfoo_cli -lfoo_cli --crate-type staticlib --print native-static-libs 2>&1 \ - | grep 'note: native-static-libs: ' \ - | sed 's/note: native-static-libs: \(.*\)/\1/' > $(TMPDIR)/libs.txt - - cat $(TMPDIR)/libs.txt | grep -F "glib-2.0" # in bar.rs - cat $(TMPDIR)/libs.txt | grep -F "systemd" # in foo.rs - cat $(TMPDIR)/libs.txt | grep -F "bar_cli" - cat $(TMPDIR)/libs.txt | grep -F "foo_cli" - - # make sure that foo_cli and glib-2.0 are not consecutively present - cat $(TMPDIR)/libs.txt | grep -Fv "foo_cli -lfoo_cli" - cat $(TMPDIR)/libs.txt | grep -Fv "glib-2.0 -lglib-2.0" diff --git a/tests/run-make/print-native-static-libs/rmake.rs b/tests/run-make/print-native-static-libs/rmake.rs new file mode 100644 index 0000000000000..9b3b4bb1a9b6e --- /dev/null +++ b/tests/run-make/print-native-static-libs/rmake.rs @@ -0,0 +1,56 @@ +//! This checks the output of `--print=native-static-libs` + +//@ ignore-cross-compile +//@ ignore-wasm + +extern crate run_make_support; + +use std::io::BufRead; + +use run_make_support::rustc; + +fn main() { + // build supporting crate + rustc() + .input("bar.rs") + .arg("--crate-type") + .arg("rlib") + .arg("-lbar_cli") + .run(); + + // build main crate as staticlib + let output = rustc() + .input("foo.rs") + .arg("--crate-type") + .arg("staticlib") + .arg("-lfoo_cli") + .arg("-lfoo_cli") // 2nd time + .arg("--print=native-static-libs") + .run(); + + let mut found_note = false; + for l in output.stderr.lines() { + let l = l.expect("utf-8 string"); + + let Some(args) = l.strip_prefix("note: native-static-libs:") else { continue; }; + assert!(!found_note); + found_note = true; + + let args: Vec<&str> = args.trim().split_ascii_whitespace().collect(); + + assert!(args.contains(&"-lglib-2.0")); // in bar.rs + assert!(args.contains(&"-lsystemd")); // in foo.rs + assert!(args.contains(&"-lbar_cli")); + assert!(args.contains(&"-lfoo_cli")); + + // make sure that no args are consecutively present + let dedup_args: Vec<&str> = { + let mut args = args.clone(); + args.dedup(); + args + }; + assert_eq!(args, dedup_args); + } + + assert!(found_note); +}