mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-11 06:24:24 +00:00
rewrite output-type-permutations to rmake
This commit is contained in:
parent
11dd90f761
commit
3cdce7ee10
@ -100,7 +100,6 @@ run-make/no-alloc-shim/Makefile
|
||||
run-make/no-builtins-attribute/Makefile
|
||||
run-make/no-duplicate-libs/Makefile
|
||||
run-make/obey-crate-type-flag/Makefile
|
||||
run-make/output-type-permutations/Makefile
|
||||
run-make/panic-abort-eh_frame/Makefile
|
||||
run-make/pass-linker-flags-flavor/Makefile
|
||||
run-make/pass-linker-flags-from-dep/Makefile
|
||||
|
@ -1,147 +0,0 @@
|
||||
# ignore-cross-compile
|
||||
include ../tools.mk
|
||||
|
||||
all:
|
||||
$(RUSTC) foo.rs --crate-type=rlib,dylib,staticlib
|
||||
$(call REMOVE_RLIBS,bar)
|
||||
$(call REMOVE_DYLIBS,bar)
|
||||
rm $(call STATICLIB,bar)
|
||||
rm -f $(TMPDIR)/{lib,}bar.{dll.exp,dll.lib,pdb,dll.a}
|
||||
# Check that $(TMPDIR) is empty.
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --crate-type=bin
|
||||
rm $(TMPDIR)/$(call BIN,bar)
|
||||
rm -f $(TMPDIR)/bar.pdb
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit=asm,llvm-ir,llvm-bc,obj,link
|
||||
rm $(TMPDIR)/bar.ll
|
||||
rm $(TMPDIR)/bar.bc
|
||||
rm $(TMPDIR)/bar.s
|
||||
rm $(TMPDIR)/bar.o
|
||||
rm $(TMPDIR)/$(call BIN,bar)
|
||||
rm -f $(TMPDIR)/bar.pdb
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit asm -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit asm=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit=asm=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit llvm-bc -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit llvm-bc=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit=llvm-bc=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit llvm-ir -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit llvm-ir=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit=llvm-ir=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit obj -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit obj=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --emit=obj=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit link -o $(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --emit link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --emit=link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
rm -f $(TMPDIR)/foo.pdb
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --crate-type=rlib -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --crate-type=rlib --emit link=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --crate-type=rlib --emit=link=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --crate-type=dylib -o $(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --crate-type=dylib --emit link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --crate-type=dylib --emit=link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
rm -f $(TMPDIR)/{lib,}foo.{dll.exp,dll.lib,pdb,dll.a,exe.a}
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ] || (ls -1 $(TMPDIR) && exit 1)
|
||||
|
||||
$(RUSTC) foo.rs --crate-type=staticlib -o $(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --crate-type=staticlib --emit link=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
$(RUSTC) foo.rs --crate-type=staticlib --emit=link=$(TMPDIR)/foo
|
||||
rm $(TMPDIR)/foo
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --crate-type=bin -o $(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --crate-type=bin --emit link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
$(RUSTC) foo.rs --crate-type=bin --emit=link=$(TMPDIR)/$(call BIN,foo)
|
||||
rm $(TMPDIR)/$(call BIN,foo)
|
||||
rm -f $(TMPDIR)/foo.pdb
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit llvm-ir=$(TMPDIR)/ir \
|
||||
--emit link \
|
||||
--crate-type=rlib
|
||||
rm $(TMPDIR)/ir
|
||||
rm $(TMPDIR)/libbar.rlib
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit asm=$(TMPDIR)/asm \
|
||||
--emit llvm-ir=$(TMPDIR)/ir \
|
||||
--emit llvm-bc=$(TMPDIR)/bc \
|
||||
--emit obj=$(TMPDIR)/obj \
|
||||
--emit link=$(TMPDIR)/link \
|
||||
--crate-type=staticlib
|
||||
rm $(TMPDIR)/asm
|
||||
rm $(TMPDIR)/ir
|
||||
rm $(TMPDIR)/bc
|
||||
rm $(TMPDIR)/obj
|
||||
rm $(TMPDIR)/link
|
||||
$(RUSTC) foo.rs --emit=asm=$(TMPDIR)/asm \
|
||||
--emit llvm-ir=$(TMPDIR)/ir \
|
||||
--emit=llvm-bc=$(TMPDIR)/bc \
|
||||
--emit obj=$(TMPDIR)/obj \
|
||||
--emit=link=$(TMPDIR)/link \
|
||||
--crate-type=staticlib
|
||||
rm $(TMPDIR)/asm
|
||||
rm $(TMPDIR)/ir
|
||||
rm $(TMPDIR)/bc
|
||||
rm $(TMPDIR)/obj
|
||||
rm $(TMPDIR)/link
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
||||
|
||||
$(RUSTC) foo.rs --emit=asm,llvm-ir,llvm-bc,obj,link --crate-type=staticlib
|
||||
rm $(TMPDIR)/bar.ll
|
||||
rm $(TMPDIR)/bar.s
|
||||
rm $(TMPDIR)/bar.o
|
||||
rm $(call STATICLIB,bar)
|
||||
mv $(TMPDIR)/bar.bc $(TMPDIR)/foo.bc
|
||||
# Don't check that the $(TMPDIR) is empty - we left `foo.bc` for later
|
||||
# comparison.
|
||||
|
||||
$(RUSTC) foo.rs --emit=llvm-bc,link --crate-type=rlib
|
||||
cmp $(TMPDIR)/foo.bc $(TMPDIR)/bar.bc
|
||||
rm $(TMPDIR)/bar.bc
|
||||
rm $(TMPDIR)/foo.bc
|
||||
$(call REMOVE_RLIBS,bar)
|
||||
[ "$$(ls -1 $(TMPDIR) | wc -l)" -eq "0" ]
|
178
tests/run-make/output-type-permutations/rmake.rs
Normal file
178
tests/run-make/output-type-permutations/rmake.rs
Normal file
@ -0,0 +1,178 @@
|
||||
// In 2014, rustc's output flags were reworked to be a lot more modular.
|
||||
// This test uses these output flags in an expansive variety of combinations
|
||||
// and syntax styles, checking that compilation is successful and that no unexpected
|
||||
// files are created.
|
||||
// The assert_eq! checks that "1 file remains" at the end of each part of the test,
|
||||
// because foo.rs counts as a file, and should be the only remaining one.
|
||||
// See https://github.com/rust-lang/rust/pull/12020
|
||||
|
||||
use run_make_support::{
|
||||
bin_name, cwd, dynamic_lib_name, fs_wrapper, rust_lib_name, rustc, static_lib_name,
|
||||
};
|
||||
|
||||
fn remove_artifacts() {
|
||||
std::fs::remove_file("libbar.ddl.exp").unwrap_or_default();
|
||||
std::fs::remove_file("libbar.dll.lib").unwrap_or_default();
|
||||
std::fs::remove_file("libbar.pdb").unwrap_or_default();
|
||||
std::fs::remove_file("libbar.dll.a").unwrap_or_default();
|
||||
std::fs::remove_file("libbar.exe.a").unwrap_or_default();
|
||||
std::fs::remove_file("bar.ddl.exp").unwrap_or_default();
|
||||
std::fs::remove_file("bar.dll.lib").unwrap_or_default();
|
||||
std::fs::remove_file("bar.pdb").unwrap_or_default();
|
||||
std::fs::remove_file("bar.dll.a").unwrap_or_default();
|
||||
std::fs::remove_file("bar.exe.a").unwrap_or_default();
|
||||
}
|
||||
|
||||
fn main() {
|
||||
rustc().input("foo.rs").crate_type("rlib,dylib,staticlib").run();
|
||||
fs_wrapper::remove_file(rust_lib_name("bar"));
|
||||
fs_wrapper::remove_file(dynamic_lib_name("bar"));
|
||||
fs_wrapper::remove_file(static_lib_name("bar"));
|
||||
remove_artifacts();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").crate_type("bin").run();
|
||||
fs_wrapper::remove_file(bin_name("bar"));
|
||||
std::fs::remove_file("bar.pdb").unwrap_or_default();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("asm,llvm-ir,llvm-bc,obj,link").run();
|
||||
fs_wrapper::remove_file("bar.ll");
|
||||
fs_wrapper::remove_file("bar.bc");
|
||||
fs_wrapper::remove_file("bar.s");
|
||||
fs_wrapper::remove_file("bar.o");
|
||||
fs_wrapper::remove_file(bin_name("bar"));
|
||||
std::fs::remove_file("bar.pdb").unwrap_or_default();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("asm").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").emit("asm=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").arg("--emit=asm=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("llvm-bc").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").emit("llvm-bc=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").arg("--emit=llvm-bc=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("llvm-ir").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").emit("llvm-ir=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").arg("--emit=llvm-ir=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("obj").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").emit("obj=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").arg("--emit=obj=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
let bin_foo = bin_name("foo");
|
||||
rustc().input("foo.rs").emit("link").output(&bin_foo).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").emit(&format!("link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").arg(&format!("--emit=link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
std::fs::remove_file("foo.pdb").unwrap_or_default();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").crate_type("rlib").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").crate_type("rlib").emit("link=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").crate_type("rlib").arg("--emit=link=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").crate_type("dylib").output(&bin_foo).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").crate_type("dylib").emit(&format!("link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").crate_type("dylib").arg(&format!("--emit=link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
remove_artifacts();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").crate_type("staticlib").emit("link").output("foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").crate_type("staticlib").emit("link=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
rustc().input("foo.rs").crate_type("staticlib").arg("--emit=link=foo").run();
|
||||
fs_wrapper::remove_file("foo");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").crate_type("bin").output(&bin_foo).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").crate_type("bin").emit(&format!("link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
rustc().input("foo.rs").crate_type("bin").arg(&format!("--emit=link={bin_foo}")).run();
|
||||
fs_wrapper::remove_file(&bin_foo);
|
||||
std::fs::remove_file("foo.pdb").unwrap_or_default();
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("llvm-ir=ir").emit("link").crate_type("rlib").run();
|
||||
fs_wrapper::remove_file("ir");
|
||||
fs_wrapper::remove_file(rust_lib_name("bar"));
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc()
|
||||
.input("foo.rs")
|
||||
.emit("asm=asm")
|
||||
.emit("llvm-ir=ir")
|
||||
.emit("llvm-bc=bc")
|
||||
.emit("obj=obj")
|
||||
.emit("link=link")
|
||||
.crate_type("staticlib")
|
||||
.run();
|
||||
fs_wrapper::remove_file("asm");
|
||||
fs_wrapper::remove_file("ir");
|
||||
fs_wrapper::remove_file("bc");
|
||||
fs_wrapper::remove_file("obj");
|
||||
fs_wrapper::remove_file("link");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc()
|
||||
.input("foo.rs")
|
||||
.arg("--emit=asm=asm")
|
||||
.arg("--emit")
|
||||
.arg("llvm-ir=ir")
|
||||
.arg("--emit=llvm-bc=bc")
|
||||
.arg("--emit")
|
||||
.arg("obj=obj")
|
||||
.arg("--emit=link=link")
|
||||
.crate_type("staticlib")
|
||||
.run();
|
||||
fs_wrapper::remove_file("asm");
|
||||
fs_wrapper::remove_file("ir");
|
||||
fs_wrapper::remove_file("bc");
|
||||
fs_wrapper::remove_file("obj");
|
||||
fs_wrapper::remove_file("link");
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
|
||||
rustc().input("foo.rs").emit("asm,llvm-ir,llvm-bc,obj,link").crate_type("staticlib").run();
|
||||
fs_wrapper::remove_file("bar.ll");
|
||||
fs_wrapper::remove_file("bar.s");
|
||||
fs_wrapper::remove_file("bar.o");
|
||||
fs_wrapper::remove_file(static_lib_name("bar"));
|
||||
fs_wrapper::rename("bar.bc", "foo.bc");
|
||||
// Don't check that no files except foo.rs remain - we left `foo.bc` for later
|
||||
// comparison.
|
||||
|
||||
rustc().input("foo.rs").emit("llvm-bc,link").crate_type("rlib").run();
|
||||
assert_eq!(fs_wrapper::read("foo.bc"), fs_wrapper::read("bar.bc"));
|
||||
fs_wrapper::remove_file("bar.bc");
|
||||
fs_wrapper::remove_file("foo.bc");
|
||||
fs_wrapper::remove_file(rust_lib_name("bar"));
|
||||
assert_eq!(fs_wrapper::read_dir(cwd()).count(), 1);
|
||||
}
|
Loading…
Reference in New Issue
Block a user