-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tracking Issue for porting run-make
tests to use Rust
#121876
Labels
A-run-make
Area: port run-make Makefiles to rmake.rs
A-testsuite
Area: The testsuite used to check the correctness of rustc
C-tracking-issue
Category: An issue tracking the progress of sth. like the implementation of an RFC
T-compiler
Relevant to the compiler team, which will review and decide on the PR/issue.
Comments
jieyouxu
added
A-testsuite
Area: The testsuite used to check the correctness of rustc
T-compiler
Relevant to the compiler team, which will review and decide on the PR/issue.
E-help-wanted
Call for participation: Help is requested to fix this issue.
C-tracking-issue
Category: An issue tracking the progress of sth. like the implementation of an RFC
labels
Mar 1, 2024
4 tasks
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
workingjubilee
added
the
E-mentor
Call for participation: This issue has a mentor. Use #t-compiler/help on Zulip for discussion.
label
Mar 22, 2024
5 tasks
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
workingjubilee
added a commit
to workingjubilee/rustc
that referenced
this issue
Mar 31, 2024
Rewrite `core-no-fp-fmt-parse` test in Rust Claiming the simple "core-no-fp-fmt-parse" test from rust-lang#121876. `run_make_support` was altered with `arg_path` written in rust-lang#121918 by `@abhay-51,` with additional doc comment. Preliminary GSoC contribution for the project proposal mentored by `@jieyouxu.`
rust-timer
added a commit
to rust-lang-ci/rust
that referenced
this issue
Mar 31, 2024
Rollup merge of rust-lang#123180 - Oneirical:master, r=Mark-Simulacrum Rewrite `core-no-fp-fmt-parse` test in Rust Claiming the simple "core-no-fp-fmt-parse" test from rust-lang#121876. `run_make_support` was altered with `arg_path` written in rust-lang#121918 by `@abhay-51,` with additional doc comment. Preliminary GSoC contribution for the project proposal mentored by `@jieyouxu.`
matthiaskrgr
added a commit
to matthiaskrgr/rust
that referenced
this issue
Apr 4, 2024
Port hir-tree run-make test to ui test As part of rust-lang#121876 cc `@jieyouxu`
rust-timer
added a commit
to rust-lang-ci/rust
that referenced
this issue
Apr 4, 2024
Rollup merge of rust-lang#122448 - high-cloud:move-hir-tree, r=oli-obk Port hir-tree run-make test to ui test As part of rust-lang#121876 cc `@jieyouxu`
GuillaumeGomez
added a commit
to GuillaumeGomez/rust
that referenced
this issue
Apr 5, 2024
…e-enum, r=Mark-Simulacrum Port argument-non-c-like-enum to Rust Part of rust-lang#121876.
GuillaumeGomez
added a commit
to GuillaumeGomez/rust
that referenced
this issue
Apr 5, 2024
…imulacrum Port `run-make/issue-7349` to a codegen test The test does not need to be a run-make test, it can use the codegen test infrastructure. Also took the opportunity to rename the test to `no-redundant-item-monomorphization` so it's not just some opaque issue number. Part of rust-lang#121876.
rust-timer
added a commit
to rust-lang-ci/rust
that referenced
this issue
Apr 5, 2024
Rollup merge of rust-lang#123474 - jieyouxu:issue-7349-port, r=Mark-Simulacrum Port `run-make/issue-7349` to a codegen test The test does not need to be a run-make test, it can use the codegen test infrastructure. Also took the opportunity to rename the test to `no-redundant-item-monomorphization` so it's not just some opaque issue number. Part of rust-lang#121876.
rust-timer
added a commit
to rust-lang-ci/rust
that referenced
this issue
Apr 5, 2024
Rollup merge of rust-lang#123149 - jieyouxu:rmake-arguments-non-c-like-enum, r=Mark-Simulacrum Port argument-non-c-like-enum to Rust Part of rust-lang#121876.
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 16, 2025
…<try> tests: Port `split-debuginfo` to rmake.rs Part of rust-lang#121876. ## Changes This PR ports `tests/run-make/split-debuginfo` to rmake.rs. This is an **initial** port, and certainly could be cleaned up and/or enhanced. The original Makefile version had several functional problems. I made 1. The linux/non-linux final branch had a conditional interpolation of `UNSTABLE_OPTIONS := -Zunstable-options`. However, one of the use sites was `-C $(UNSTABLE_OPTIONS) split-debuginfo`. This indicates to me that this run-make test is not run in CI under a non-linux + non-windows + non-darwin environment, because that would've failed as this would expand to `-C -Zunstable-options split-debuginfo`. I fixed this in the rmake.rs version, but I'm not sure if this distinction is worth keeping at all if it's not tested in CI. 2. There are several comments that were discovered to be wrong. I tried to fix them in the rmake.rs version as well. 3. The check for path remapping / lack of path remapping through ```make objdump -Wi $(TMPDIR)/foo | grep DW_AT_GNU_dwo_name | (! grep $(TMPDIR)) || exit 1 ``` are incorrect, because that looks at the single line of that contains `DW_AT_GNU_dwo_name`. This is unfortunately wrong because empirical evidence shows that with `objdump`[^objdump], the check actually needs to look at the attribute value of `DW_AT_comp_dir` on the previous line not `DW_AT_GNU_dwo_name`[^gnu-ext]. Example output of `objdump`: ```text <10> DW_AT_comp_dir : (indirect string, offset: 0xafb48): /home/joe/repos/rust <14> DW_AT_GNU_dwo_name: (indirect string, offset: 0x5d1b0): foo.foo.fc848df41df7a00d-cgu.0.rcgu.dwo ``` In the rmake.rs version 4. I included a bunch of FIXMEs and ENHANCEMENTs I noticed regarding the test because I didn't want to do them in this initial port[^enhancement]. 5. The Makefile version didn't test *anything* on Windows (both windows-msvc and windows-gnu). I added some *very* basic and *very* sparse checks for windows-msvc, but I am not willing to spend the effort to expand test coverage to windows-gnu in this initial port. 6. This run-make test is way too big. But I didn't want to expend the effort of breaking this up in this initial port. [^objdump]: the output format differs between `objdump` and `llvm-objdump`, but the same is true for `llvm-objdump` that this is looking at the wrong line. [^gnu-ext]: AFAICT that is a GNU DWARF attribute extension, since it isn't mentioned in DWARFv5 spec [^enhancement]: For instance, the previous path remapping check could in theory be precisely inspected by inspecting `.debug_info` section to look for attribute value of `DW_AT_comp_dir`. But that involves resolving the value of the indirect string, which means you have to: (1) look for offset into string offset table and (2) use *that* offset to find the string itself in the string table. The split part of "split-debuginfo" makes this murky for me, so I wasn't able to replace `llvm-objdump` textual output substring matches with more precise `object` + `gimli` inspections. ## Review advice - I'm sorry for how long the rmake.rs test ended up, but a lot of it is comments and just vertical space due to formatting. - This PR *intentionally* introduces several intermediate commits for the `Makefile`, mostly to illustrate the problems I discovered when looking at the original `Makefile` version. This is intended to highlight the existing problems in the `Makefile` version for the reviewer[^squash]. - There are several intentional non-functional commits: 1. Reindent the `Makefile` to make the platform conditional gating more obvious. 2. Collapse nested if-else branches into an else if construct, which is not supported by GNU Make 3.80. 3. Remove all redundant `-C debuginfo=2` when `-g` is already specified. - This PR is best reviewed commit-by-commit. [^squash]: I intend to squash these intermediate commits away after the reviewer concludes that the current form of the rmake.rs test is acceptable for merge. Before then, I'll keep them to help with review. --- This PR supersedes rust-lang#128754 and is co-authored with `@Oneirical.` r? `@ghost` --- try-job: x86_64-msvc try-job: i686-msvc try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 16, 2025
…<try> tests: Port `split-debuginfo` to rmake.rs Part of rust-lang#121876. ## Changes This PR ports `tests/run-make/split-debuginfo` to rmake.rs. This is an **initial** port, and certainly could be cleaned up and/or enhanced. The original Makefile version had several functional problems. I made 1. The linux/non-linux final branch had a conditional interpolation of `UNSTABLE_OPTIONS := -Zunstable-options`. However, one of the use sites was `-C $(UNSTABLE_OPTIONS) split-debuginfo`. This indicates to me that this run-make test is not run in CI under a non-linux + non-windows + non-darwin environment, because that would've failed as this would expand to `-C -Zunstable-options split-debuginfo`. I fixed this in the rmake.rs version, but I'm not sure if this distinction is worth keeping at all if it's not tested in CI. 2. There are several comments that were discovered to be wrong. I tried to fix them in the rmake.rs version as well. 3. The check for path remapping / lack of path remapping through ```make objdump -Wi $(TMPDIR)/foo | grep DW_AT_GNU_dwo_name | (! grep $(TMPDIR)) || exit 1 ``` are incorrect, because that looks at the single line of that contains `DW_AT_GNU_dwo_name`. This is unfortunately wrong because empirical evidence shows that with `objdump`[^objdump], the check actually needs to look at the attribute value of `DW_AT_comp_dir` on the previous line not `DW_AT_GNU_dwo_name`[^gnu-ext]. Example output of `objdump`: ```text <10> DW_AT_comp_dir : (indirect string, offset: 0xafb48): /home/joe/repos/rust <14> DW_AT_GNU_dwo_name: (indirect string, offset: 0x5d1b0): foo.foo.fc848df41df7a00d-cgu.0.rcgu.dwo ``` In the rmake.rs version 4. I included a bunch of FIXMEs and ENHANCEMENTs I noticed regarding the test because I didn't want to do them in this initial port[^enhancement]. 5. The Makefile version didn't test *anything* on Windows (both windows-msvc and windows-gnu). I added some *very* basic and *very* sparse checks for windows-msvc, but I am not willing to spend the effort to expand test coverage to windows-gnu in this initial port. 6. This run-make test is way too big. But I didn't want to expend the effort of breaking this up in this initial port. [^objdump]: the output format differs between `objdump` and `llvm-objdump`, but the same is true for `llvm-objdump` that this is looking at the wrong line. [^gnu-ext]: AFAICT that is a GNU DWARF attribute extension, since it isn't mentioned in DWARFv5 spec [^enhancement]: For instance, the previous path remapping check could in theory be precisely inspected by inspecting `.debug_info` section to look for attribute value of `DW_AT_comp_dir`. But that involves resolving the value of the indirect string, which means you have to: (1) look for offset into string offset table and (2) use *that* offset to find the string itself in the string table. The split part of "split-debuginfo" makes this murky for me, so I wasn't able to replace `llvm-objdump` textual output substring matches with more precise `object` + `gimli` inspections. ## Review advice - I'm sorry for how long the rmake.rs test ended up, but a lot of it is comments and just vertical space due to formatting. - This PR *intentionally* introduces several intermediate commits for the `Makefile`, mostly to illustrate the problems I discovered when looking at the original `Makefile` version. This is intended to highlight the existing problems in the `Makefile` version for the reviewer[^squash]. - There are several intentional non-functional commits: 1. Reindent the `Makefile` to make the platform conditional gating more obvious. 2. Collapse nested if-else branches into an else if construct, which is not supported by GNU Make 3.80. 3. Remove all redundant `-C debuginfo=2` when `-g` is already specified. - This PR is best reviewed commit-by-commit. [^squash]: I intend to squash these intermediate commits away after the reviewer concludes that the current form of the rmake.rs test is acceptable for merge. Before then, I'll keep them to help with review. --- This PR supersedes rust-lang#128754 and is co-authored with `@Oneirical.` r? `@ghost` --- try-job: x86_64-msvc try-job: i686-msvc try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
Re-triage (2025-01-23):
Also need to:
|
This was referenced Jan 16, 2025
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 20, 2025
…hed, r=<try> tests: Port `symbol-mangling-hashed` to rmake.rs Part of rust-lang#121876. This PR supersedes rust-lang#128567 and is co-authored with `@lolbinarycat.` ### Summary This PR ports `tests/run-make/symbol-mangling-hashed` to rmake.rs. Notable differences when compared to the Makefile version includes: - It's no longer limited to linux + x86_64 only. In particular, this now is exercised on darwin and windows (esp. msvc) too. - The test uses `object` crate to be more precise in the filtering, and avoids relying on parsing the human-readable `nm` output for *some* `nm` in the given environment (which isn't really a thing on msvc anyway, and `llvm-nm` doesn't handle msvc dylibs AFAICT). - Dump the symbols satisfying various criteria on test failure to make it hopefully less of a pain to debug if it ever fails in CI. ### Review advice - Best reviewed commit-by-commit. - I'm not *super* sure about the msvc logic, would benefit from a MSVC (PE/COFF) expert taking a look. --- try-job: x86_64-msvc try-job: i686-msvc try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 20, 2025
…hed, r=<try> tests: Port `symbol-mangling-hashed` to rmake.rs Part of rust-lang#121876. This PR supersedes rust-lang#128567 and is co-authored with `@lolbinarycat.` ### Summary This PR ports `tests/run-make/symbol-mangling-hashed` to rmake.rs. Notable differences when compared to the Makefile version includes: - It's no longer limited to linux + x86_64 only. In particular, this now is exercised on darwin and windows (esp. msvc) too. - The test uses `object` crate to be more precise in the filtering, and avoids relying on parsing the human-readable `nm` output for *some* `nm` in the given environment (which isn't really a thing on msvc anyway, and `llvm-nm` doesn't handle msvc dylibs AFAICT). - Dump the symbols satisfying various criteria on test failure to make it hopefully less of a pain to debug if it ever fails in CI. ### Review advice - Best reviewed commit-by-commit. - I'm not *super* sure about the msvc logic, would benefit from a MSVC (PE/COFF) expert taking a look. --- try-job: x86_64-msvc try-job: i686-msvc-1 try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 20, 2025
…hed, r=<try> tests: Port `symbol-mangling-hashed` to rmake.rs Part of rust-lang#121876. This PR supersedes rust-lang#128567 and is co-authored with `@lolbinarycat.` ### Summary This PR ports `tests/run-make/symbol-mangling-hashed` to rmake.rs. Notable differences when compared to the Makefile version includes: - It's no longer limited to linux + x86_64 only. In particular, this now is exercised on darwin and windows (esp. msvc) too. - The test uses `object` crate to be more precise in the filtering, and avoids relying on parsing the human-readable `nm` output for *some* `nm` in the given environment (which isn't really a thing on msvc anyway, and `llvm-nm` doesn't handle msvc dylibs AFAICT). - Dump the symbols satisfying various criteria on test failure to make it hopefully less of a pain to debug if it ever fails in CI. ### Review advice - Best reviewed commit-by-commit. - I'm not *super* sure about the msvc logic, would benefit from a MSVC (PE/COFF) expert taking a look. --- try-job: x86_64-msvc try-job: i686-msvc-1 try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 21, 2025
…hed, r=<try> tests: Port `symbol-mangling-hashed` to rmake.rs Part of rust-lang#121876. This PR supersedes rust-lang#128567 and is co-authored with `@lolbinarycat.` ### Summary This PR ports `tests/run-make/symbol-mangling-hashed` to rmake.rs. Notable differences when compared to the Makefile version includes: - It's no longer limited to linux + x86_64 only. In particular, this now is exercised on darwin and windows (esp. msvc) too. - The test uses `object` crate to be more precise in the filtering, and avoids relying on parsing the human-readable `nm` output for *some* `nm` in the given environment (which isn't really a thing on msvc anyway, and `llvm-nm` doesn't handle msvc dylibs AFAICT). - Dump the symbols satisfying various criteria on test failure to make it hopefully less of a pain to debug if it ever fails in CI. ### Review advice - Best reviewed commit-by-commit. - I'm not *super* sure about the msvc logic, would benefit from a MSVC (PE/COFF) expert taking a look. --- try-job: x86_64-msvc try-job: i686-msvc-1 try-job: i686-mingw try-job: x86_64-mingw-1 try-job: x86_64-apple-1 try-job: aarch64-apple try-job: test-various
This was referenced Jan 21, 2025
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 21, 2025
…=Noratrieb tests: Port `jobserver-error` to rmake.rs Part of rust-lang#121876. This PR ports `tests/run-make/jobserver-error` to rmake.rs, and is basically rust-lang#128789 slightly adjusted. Namely, `set_aux_fd` is made `unsafe`, alongside some doc updates. The complexity involved here is mostly how to get `/dev/null/` piping to fd 3 working with std `Command`, whereas with a shell this is much easier (as is evident with the `Makefile` version). Supersedes rust-lang#128789. This PR is co-authored with `@Oneirical` and `@coolreader18.` try-job: aarch64-gnu try-job: i686-gnu-1 try-job: x86_64-gnu-debug try-job: x86_64-gnu-llvm-18-1
matthiaskrgr
added a commit
to matthiaskrgr/rust
that referenced
this issue
Jan 21, 2025
…Noratrieb tests: delete `cat-and-grep-sanity-check` Part of rust-lang#121876. All remaining `Makefile`s have open PRs that do not rely on platform `cat` or `grep` or the `cat-and-grep` script.
rust-timer
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 22, 2025
Rollup merge of rust-lang#135824 - jieyouxu:delete-bintools-check, r=Noratrieb tests: delete `cat-and-grep-sanity-check` Part of rust-lang#121876. All remaining `Makefile`s have open PRs that do not rely on platform `cat` or `grep` or the `cat-and-grep` script.
jieyouxu
added a commit
to jieyouxu/rust
that referenced
this issue
Jan 22, 2025
…mpiler-errors tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with `@Oneirical.` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 23, 2025
…=Noratrieb tests: Port `jobserver-error` to rmake.rs Part of rust-lang#121876. This PR ports `tests/run-make/jobserver-error` to rmake.rs, and is basically rust-lang#128789 slightly adjusted. The complexity involved here is mostly how to get `/dev/null/` piping to fd 3 working with std `Command`, whereas with a shell this is much easier (as is evident with the `Makefile` version). Supersedes rust-lang#128789. This PR is co-authored with `@Oneirical` and `@coolreader18.` try-job: aarch64-gnu try-job: i686-gnu-1 try-job: x86_64-gnu-debug try-job: x86_64-gnu-llvm-18-1
matthiaskrgr
added a commit
to matthiaskrgr/rust
that referenced
this issue
Jan 25, 2025
…mpiler-errors tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with `@Oneirical.` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler
matthiaskrgr
added a commit
to matthiaskrgr/rust
that referenced
this issue
Jan 25, 2025
…mpiler-errors tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with ``@Oneirical.`` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler
matthiaskrgr
added a commit
to matthiaskrgr/rust
that referenced
this issue
Jan 25, 2025
…mpiler-errors tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with ```@Oneirical.``` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 25, 2025
tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with `@Oneirical.` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler try-job: aarch64-apple
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 25, 2025
tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with `@Oneirical.` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it ICEs with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler try-job: aarch64-apple
bors
added a commit
to rust-lang-ci/rust
that referenced
this issue
Jan 26, 2025
…iler-errors tests: Port `translation` to rmake.rs Part of rust-lang#121876. This PR partially supersedes rust-lang#129011 and is co-authored with `@Oneirical.` ## Summary This PR ports `tests/run-make/translation` to rmake.rs. Notable changes from the Makefile version include: - We now actually fail if the rustc invocations fail... The Makefile did not have `SHELL=/bin/bash -o pipefail`, so all the piped rustc invocations to grep vacuously succeeded, even if the broken ftl test case actually regressed over time and ICEs on current master. - That test case is converted to assert it fails with a FIXME backlinking to rust-lang#135817. - The test coverage is expanded to not ignore windows. Instead, the test now uses symlink capability detection to gate test execution. - Added some backlinks to relevant tracking issues and the initial translation infra implementation PR. ## Review advice Best reviewed commit-by-commit. r? compiler try-job: aarch64-apple
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
A-run-make
Area: port run-make Makefiles to rmake.rs
A-testsuite
Area: The testsuite used to check the correctness of rustc
C-tracking-issue
Category: An issue tracking the progress of sth. like the implementation of an RFC
T-compiler
Relevant to the compiler team, which will review and decide on the PR/issue.
We want to stop
run-make
tests from relying onmake
, and improve therun-make
tests so thatthey are more accessible to rustc contributors by allowing the tests to be written in Rust (see
#40713 for context). PR #113026 was merged to address this, and now we are able to write
run-make
tests in Rust recipes. We would like your help to port over existing
run-make
tests still usingMakefiles to use Rust recipes instead.
If you would like to work on porting one of the
run-make
tests, please link to this issue in yourPR and leave a comment to claim the test (or multiple tests). If you are stuck, please don't hesitate to open a thread
on Rust's Zulip.
run-make
is the most flexible fallback test kind, but somerun-make
tests could be migrated to become e.g. ui tests instead. Please check if you can convert therun-make
test into other test kinds before porting!When you try to port a test, also consider:
Context: Rust recipes?
PR #113026 adds basic infrastructure support to write
run-make
tests using small Rust programs,called recipes.
We aim to eliminate the dependency on make and Makefiles for building
run-make
-style tests.Makefiles are replaced by recipes (
rmake.rs
). The PR implements runningrun-make
recipes in3 steps:
run_make_support
which thermake.rs
recipes depend on as a toollib.
rmake.rs
and link in the support library.rmake.rs
is basically a replacement forMakefile
, and allows running arbitrary Rust code. Thesupport library is built using cargo, and so can depend on external crates if desired.
The infrastructure implemented by the PR is very barebones, and is the minimally required
infrastructure needed to build, run and pass the two example run-make tests ported over to the new
infrastructure:
You likely will find that you would need to improve the API of the support library, and extend
the functionality of the support library.
Common traps and pitfalls, and tips and tricks
$PATH
uses;
on Windows and:
for *nixes. Usestd::env::{join,split}_paths
to properlyhandle
$PATH
.Be careful of path separator platform differences. Always prefer
PathBuf
operations not stringpaths if possible.
tests/
are not (currently) formatted by rustfmt.Consult https://github.com/rust-lang/rust/blob/master/tests/run-make/tools.mk for which flags
and envs are passed to various executables or libraries. May have to triple check on those.
You can always request your reviewer to run try jobs to test out your PR on environments you don't locally have access to. Good candidate CI jobs include:
Tests that need porting
run-make
alloc tests to rmake #125024)run-make/allow-non-lint-warnings-cmdline
tormake.rs
#126386)run-make/allow-warnings-cmdline-stability
tormake.rs
#125573)atomic-lock-free
tormake
#127787)branch-protection-check-IBT
run-make test #126720, run-make: Deletecat-and-grep-sanity-check
and restrictbranch-protection-check-IBT
to stable #129156, Migratebranch-protection-check-IBT
to rmake.rs #134760)run-make/c-link-to-rust-dylib
tormake.rs
#125808)run-make/c-link-to-rust-staticlib
tormake
#125027)run-make/c-link-to-rust-va-list-fn
tormake
#125026)c-unwind-abi-catch-lib-panic
,foreign-rust-exceptions
andexport-executable-symbols
run-make
tests to rmake #128065)cat-and-grep-sanity-check
and restrictbranch-protection-check-IBT
to stable #129156, tests: deletecat-and-grep-sanity-check
#135824)cdylib-dylib-linkage
run-make
test to rmake #128245)run-make/codegen-options-parsing
tormake.rs
#126478)run-make/comment-section
tormake.rs
#126534)run-make/compile-stdin
tormake.rs
#125607)compiler-lookup-paths
,dump-mono-stats
andprune-link-args
run-make
tests tormake
orui
format #126208)run-make/compressed-debuginfo
tormake.rs
#126629)run-make/const-prop-lint
tormake.rs
#125653)core-no-fp-fmt-parse
test in Rust #123180)run-make/crate-data-smoke
tormake.rs
#125723)crate-hash-rustc-version
tormake
#127693)cross-lang-lto
run-make
test to rmake #128352)cross-lang-lto-clang
andcross-lang-lto-pgo-smoketest
run-make
tests to rmake #128356)cross-lang-lto-upstream-rlibs
,long-linker-command-lines
andlong-linker-command-lines-cmd-exe
run-make
tests to rmake #128196)run-make/dep-graph
tormake.rs
#126517)dep-info
,dep-info-spaces
anddep-info-doesnt-run-much
run-make
tests intodep-info
rmake.rs #128787)run-make/doctests-keep-binaries
to new rmake.rs format #124658)run-make/doctests-runtool
to rmake #124711)dump-ice-to-disk
andpanic-abort-eh_frame
run-make
tests to rmake #127523)run-make/duplicate-output-flavors
tormake.rs
#126542)dylib-chain
,rlib-chain
,issue-47384
,msvc-opt-minsize
andtest-harness
run-make
tests to ui/rmake #127044)run-make/emit-named-files
tormake.rs
#125849)emit-shared-files
andemit-path-unhashed
run-make
tests to rmake #127335)emit-to-stdout
run-make
test to rmake #128460, Add tests for some old fixed issues #131355)error-found-staticlib-instead-crate
,output-filename-conflicts-with-directory
,output-filename-overwrites-input
,native-link-modifier-verbatim-rustc
andnative-link-verbatim-linker
run-make
tests tormake.rs
format #126500)extern-diff-internal-name
,extern-multiple-copies
andextern-multiple-copies2
run-make
tests to rmake #128102)extern-flag-fun
,incremental-debugger-visualiser
andincremental-session-fail
run-make
tests tormake.rs
#126490)extern-flag-pathless
,silly-file-names
,metadata-dep-info
,cdylib-fewer-symbols
andsymbols-include-type-name
run-make
tests to rmake #127006)extern-fn-reachable
to rmake.rs #135458)extra-filename-with-temp-outputs
andissue-85019-moved-src-dir
run-make
tests to rmake #127338)foreign-double-unwind
,issue-36710
andforeign-exceptions
run-make
tests to rmake #127926run-make/glibc-staticlib-args
tormake.rs
#126684)inaccessible-temp-dir
,output-with-hyphens
andissue-10971-temps-dir
run-make
tests tormake
#126279)incr-add-rust-src-component
andissue-84395-lto-embed-bitcode
run-make
tests to rmake #128562, Migrateincr-add-rust-src-component
to rmake #134656)run-make
test suite inx86_64-gnu-debug
#131917)run-make/inline-always-many-cgu
tormake.rs
#126823)interdependent-c-libraries
,compiler-rt-works-on-mingw
andincr-foreign-head-span
run-make
tests to rmake #127989)intrinsic-unreachable
,sepcomp-cci-copies
,sepcomp-inlining
andsepcomp-separate
run-make
tests to rmake.rs #126427)run-make/invalid-library
tormake.rs
#126861)run-make/issue-7349
to a codegen test #123474)run-make/issue-11908
to newrmake.rs
format #125031)run-make/issue-14500
to newrmake.rs
format #125047)issue-14698
.issue-33329
andissue-107094
run-make
tests to rmake or ui #127820)issue-22131
andissue-26006
run-make
tests to rmake #127621)run-make
tests to rmake #127491)run-make/issue-28766
tormake
#125221)run-make/issue-30063
tormake
#125227)issue-37839
,track-path-dep-info
andtrack-pgo-dep-info
run-make
tests to rmake #127378)run-make/issue-46239
tormake
#125222)issue-47551
,issue-35164
andissue-69368
run-make
tests to rmake #127624)bin-emit-no-symbols
run-make
test tormake
#125787)run-make/issue-53964
tormake
#125224)issue-64153
,invalid-staticlib
andno-builtins-lto
run-make
tests tormake
#126437)issue-83045
,rustc-macro-dep-files
andenv-dep-info
run-make
tests to rmake #127381)issue-83112-incr-test-moved-file
,type-mismatch-same-crate-name
andissue-109934-lto-debuginfo
run-make
tests to rmake or ui #127538)issue-85401-static-mir
,missing-crate-dependency
andunstable-flag-required
run-make
tests to rmake #127822)run-make/issue64319
tormake
and rename #125215)jobserver-error
run-make
test to rmake #128789, tests: Portjobserver-error
to rmake.rs #135461)libs-through-symlinks
andtranslation
run-make tests to rmake #129011, Migratelibs-through-symlink
to rmake.rs #134829)libs-through-symlinks
andtranslation
run-make tests to rmake #129011, tests: Porttranslation
to rmake.rs #135818)tests/run-make/libtest-json
totests/ui
#126773, Portrun-make/libtest-json
andrun-make/libtest-junit
to rmake #129037)link-args-order
,ls-metadata
andlto-readonly-lib
run-make
tests tormake
#126095)link-cfg
andrustdoc-default-output
run-make
tests to rmake #128361)run-make/link-framework
tormake.rs
#126898)run-make/llvm-ident
tormake.rs
#126941)lto-empty
,invalid-so
andissue-20626
run-make
tests to rmake.rs #126964)lto-linkage-used-attr
,no-duplicate-libs
andpgo-gen-no-imp-symbols
run-make
tests to rmake #127990)lto-smoke-c
andlink-path-order
run-make
tests to rmake #127928)libtest-thread-limit
run-make
test to rmake #128507)macos-fat-archive
,manual-link
andarchive-duplicate-names
run-make
tests to rmake #127825)run-make/manual-crate-name
tormake.rs
#126064)min-global-align
andno-alloc-shim
run-make
tests to rmake #128407)run-make/multiple-emits
tormake.rs
#126186)run-make/no-cdylib-as-rdylib
tormake
#125104)no-input-file.stderr
test in Rust and support diff #124257)run-make/no-intermediate-extras
to newrmake.rs
#125218)output-type-permutations
run-make
test to rmake #127098)run-make/override-aliased-flags
tormake.rs
#127041)run-make/panic-impl-transitive
tormake
#125146)pass-linker-flags-flavor
,pass-linker-flags-from-dep
andpass-linker-flags
run-make
tests to rmake #127328)pdb-buildinfo-cl-cmd
andpgo-indirect-call-promotion
run-make
tests to rmake #128363)pdb-alt-path
,mismatching-target-triples
andmingw-export-call-convention
run-make
tests to rmake #126805)run-make/pgo-branch-weights
tormake
#125165)pgo-gen
,pgo-use
andprofile
run-make
tests to rmake.rs #126957)pgo-gen-lto
run-make
test to rmake #128757)pointer-auth-link-with-c
,c-dynamic-rlib
andc-dynamic-dylib
run-make
tests to rmake #127872)tests/run-make/prefer-dylib
tormake.rs
#126174)pretty-print-with-dep-file
,pretty-print-to-file
andlibtest-padding
run-make
tests to rmake #126995)print-target-list
tormake
andprint-calling-convention
to ui-test #127877)print-cfg
run-make test to Rust-based rmake.rs #124473)--print=native-static-libs
to rmake.rs #124383)raw-dylib-alt-calling-convention
,raw-dylib-c
andredundant-libs
run-make
tests to rmake #128107)raw-dylib-inline-cross-dylib
andraw-dylib-custom-dlltool
run-make
tests to rmake #127390)remap-path-prefix
,debug-assertions
andemit-stack-sizes
run-make
tests to rmake #126801)remap-path-prefix-dwarf
run-make
test to rmake #128410)reproducible-build
run-make
test to rmake #128456)reproducible-build-2
andstable-symbol-names
run-make
tests to rmake #127095)run-make/return-non-c-like-enum
tormake.rs
#127116)run-make
tests to rmake #127663)rlib-format-packed-bundled-libs
andnative-link-modifier-bundle
run-make
tests to rmake #129018)rlib-format-packed-bundled-libs-2
,native-link-modifier-whole-archive
andno-builtins-attribute
run-make
tests to rmake #128075)rust-lld
run-make tests tormake
#123975)rustdoc-determinism
test in Rust #124698)run-make/rustdoc-error-lines
to newrmake.rs
#124753)run-make/rustdoc-io-error
tormake.rs
#124807)run-make/rustdoc-map-file
to rmake #124837)run-make/rustdoc-output-path
to rmake #124888)run-make/rustdoc-scrape-examples-invalid-expr
tormake.rs
#125248)run-make/rustdoc-scrape-examples-macros
tormake.rs
#125401)run-make/rustdoc-scrape-examples-multiple
tormake.rs
#125357)run-make/rustdoc-scrape-examples-remap
tormake.rs
#125207)run-make/rustdoc-scrape-examples-test
to newrmake.rs
#125275)run-make/rustdoc-scrape-examples-whitespace
tormake.rs
#125318)run-make/rustdoc-shared-flags
to rmake #124963)run-make/rustdoc-themes
to new rmake.rs #125142)run-make/rustdoc-with-out-dir-option
to newrmake.rs
#125178)run-make/rustdoc-with-output-dir-option
tormake.rs
#125485)run-make/rustdoc-with-short-out-dir-option
tormake.rs
#125445)share-generics-dylib
,raw-dylib-import-name-type
,raw-dylib-link-ordinal
andraw-dylib-stdcall-ordinal
run-make
tests to rmake #128112)run-make/short-ice
tormake
#126036)simd-ffi
run-make
test to rmake #128700)split-debuginfo
run-make
test to rmake #128754, tests: Portsplit-debuginfo
to rmake.rs #135572)static-dylib-by-default
,sanitizer-dylib-link
,sanitizer-cdylib-link
andsanitizer-staticlib-link
run-make
tests to rmake #128079)run-make/static-unwinding
tormake
#125213)staticlib-blank-lib
,rlib-format-packed-bundled-libs-3
andissue-97463-abi-param-passing
run-make
tests to rmake #127778)staticlib-dylib-linkage
run-make
test to rmake #128696)std-core-cycle
,obey-crate-type-flag
,mixing-libs
andissue-18943
run-make
tests tormake.rs
#126484)symbol-mangling-hashed
to rmake.rs #128567, tests: Portsymbol-mangling-hashed
to rmake.rs #135768)symbol-visibility
run-make
test to rmake #127060)tests/run-make/sysroot-crates-are-unstable
from Python to rmake #126231, Portrun-make/sysroot-crates-are-unstable
to rmake #129071)target-cpu-native
,target-specs
andtarget-without-atomic-cas
run-make
tests to rmake #127325)test-benches
,c-unwind-abi-catch-panic
andcompiler-lookup-paths-2
run-make
tests to rmake #127985)thumb-none-cortex-m
to rmake #128636)thumb-none-qemu
to rmake #128639)tools.mk(should be removed)use-suggestions-rust-2018
,overwrite-input
,lto-dylib-dep
andmany-crates-but-no-match
run-make
tests to rmake #127000)run-make/used
tormake.rs
#125988)--print
request #124333)version
test run-make as an UI test #123563)volatile-intrinsics
,weird-output-filenames
,wasm-override-linker
,wasm-exceptions-nostd
tormake
#126880)x86_64-fortanix-unknown-sgx-lvi
run-make
test to rmake #129055)emit
,mixing-formats
andbare-outfile
run-make
tests inrmake.rs
format #125383)core-no-oom-handling
,issue-24445
andissue-38237
run-make
tests to newrmake.rs
format #125421)rmake
forwindows-
run-make tests #125613)lto-smoke
,simple-rlib
andmixing-deps
run-make
tests inrmake.rs
format #125638)fpic
,simple-dylib
andissue-37893
run-make
tests inrmake.rs
or ui test format #125662)suspicious-library
,resolve-rename
andincr-prev-body-beyond-eof
run-make
tests inrmake.rs
format #125683)link-arg
,link-dedup
andissue-26092
run-make
tests tormake
format #125500)symlinked-extern
,symlinked-rlib
andsymlinked-libraries
run-make
tests inrmake.rs
format #125674)separate-link
,separate-link-fail
andallocator-shim-circular-deps
run-make
tests toui
orrmake
#126607)extern-flag-rename-transitive
.debugger-visualizer-dep-info
,metadata-flag-frobs-symbols
,extern-overrides-distribution
andforced-unwind-terminate-pof
run-make
tests to rmake #126644)unknown-mod-stdin
,issue-68794-textrel-on-minimal-lib
,raw-dylib-cross-compilation
andused-cdylib-macos
run-make
tests to rmake #126698)include_bytes_deps
,optimization-remarks-dir-pgo
,optimization-remarks-dir
,issue-40535
andrmeta-preferred
run-make
tests to rmake #126709)relocation-model
,error-writing-dependencies
andcrate-name-priority
run-make
tests to rmake #126712)relro-levels
,static-pie
tormake
#126715)The text was updated successfully, but these errors were encountered: