Skip to content
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

Make the test cfg a userspace check-cfg #785

Closed
1 of 3 tasks
Urgau opened this issue Sep 18, 2024 · 8 comments
Closed
1 of 3 tasks

Make the test cfg a userspace check-cfg #785

Urgau opened this issue Sep 18, 2024 · 8 comments
Labels
finished-final-comment-period The FCP has finished, action upon the disposition label needs to be taken major-change A proposal to make a major change to rustc major-change-accepted A major change proposal that was accepted T-compiler Add this label so rfcbot knows to poll the compiler team

Comments

@Urgau
Copy link
Member

Urgau commented Sep 18, 2024

Proposal

The test cfg is special, in that it's the only built-in cfg that is set by rustc and is allowed to be set by users of rustc1.

Cargo for examples sets it when running cargo test with harness = false (i.e. without rustc --test).

This creates a tension with --check-cfg as to who is the "owner" of the cfg, since it is currently always marked as expected.

However, there are cases where the user might not want to have unit test inside a crate and, as such not have the test cfg being marked as expected, which is not currently possible (we don't have a way to opt-out of the well-known list).

This is particularly relevant for the lib.test = false config in Cargo.toml which disables unit-testing for the package.
In those cases, having test as a well-known config is counter-productive, as it won't produce the warning that is being expected (e.g. rust-lang/rust#117778 and https://rust-lang.zulipchat.com/#narrow/stream/131828-t-compiler/topic/check-cfg.20forbid.20rather.20than.20accept).

As an aside, this is relevant for us regarding core/coretests, alloc/alloctests crates.

Given all of the above, I propose that we make users of rustc be owner of the test cfg.

Concretely, that would mean:

  • Removing the test from rustc well known cfgs list
  • Adjusting the documentation (regarding the owner of test cfg)
  • (for Cargo) Adding the test to it's well known cfgs list (and making it conditional on lib.test)

This should make it clear that it's the responsibility of the user/build system to explicitly "mark" a crate as unit-testable, instead of "forcing" every crate.

The unexpected_cfgs lint is warn-by-default but only activated with --check-cfg (opt-in) so this would only affect users of --check-cfg (I'm only aware of Cargo for now).

This proposal is the result of multiple discussions over the issues and Zulip topic, including with @epage (Cargo maintainer and "liaison" for check-cfg).

Alternative/future work: general mechanism to "un-expect" cfgs

An alternative to this proposal would be to have a more general mechanism to "un-expect" any (or maybe just well known) cfgs.
This was explored in https://rust-lang.zulipchat.com/#narrow/stream/131828-t-compiler/topic/check-cfg.20forbid.20rather.20than.20accept.

However, it's unclear who or which cfgs would benefit from this general mechanism apart for the test cfg. It would also introduce many complexities, in particular regarding precedence or scope, and more generally it's usefulness.

Given this, I don't think we should be doing this more general mechanism until we have actual use cases.

It as also be not noted as this alternative is forward-compatible with the proposal above.

Mentors or Reviewers

my-self (I think)

Process

The main points of the Major Change Process are as follows:

  • File an issue describing the proposal.
  • A compiler team member or contributor who is knowledgeable in the area can second by writing @rustbot second.
    • Finding a "second" suffices for internal changes. If however, you are proposing a new public-facing feature, such as a -C flag, then full team check-off is required.
    • Compiler team members can initiate a check-off via @rfcbot fcp merge on either the MCP or the PR.
  • Once an MCP is seconded, the Final Comment Period begins. If no objections are raised after 10 days, the MCP is considered approved.

You can read more about Major Change Proposals on forge.

Comments

This issue is not meant to be used for technical discussion. There is a Zulip stream for that. Use this issue to leave procedural comments, such as volunteering to review, indicating that you second the proposal (or third, etc), or raising a concern that you would like to be addressed.

Footnotes

  1. Per explicit_builtin_cfgs_in_flags lint.

@Urgau Urgau added major-change A proposal to make a major change to rustc T-compiler Add this label so rfcbot knows to poll the compiler team labels Sep 18, 2024
@rustbot
Copy link
Collaborator

rustbot commented Sep 18, 2024

This issue is not meant to be used for technical discussion. There is a Zulip stream for that. Use this issue to leave procedural comments, such as volunteering to review, indicating that you second the proposal (or third, etc), or raising a concern that you would like to be addressed.

Concerns or objections to the proposal should be discussed on Zulip and formally registered here by adding a comment with the following syntax:

@rustbot concern reason-for-concern 
<description of the concern> 

Concerns can be lifted with:

@rustbot resolve reason-for-concern 

See documentation at https://forge.rust-lang.org

cc @rust-lang/compiler @rust-lang/compiler-contributors

@rustbot rustbot added the to-announce Announce this issue on triage meeting label Sep 18, 2024
@apiraino apiraino removed the to-announce Announce this issue on triage meeting label Oct 17, 2024
@petrochenkov
Copy link

@rfcbot fcp merge

@rfcbot
Copy link
Collaborator

rfcbot commented Oct 19, 2024

Team member @petrochenkov has proposed to merge this. The next step is review by the rest of the tagged team members:

No concerns currently listed.

Once a majority of reviewers approve (and at most 2 approvals are outstanding), this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up!

See this document for info about what commands tagged team members can give me.

@petrochenkov
Copy link

Implementation - rust-lang/rust#131729.

@Urgau
Copy link
Member Author

Urgau commented Dec 2, 2024

This FCP is waiting on your feedback @Aaron1011 @cjgillot @estebank @pnkfelix @wesleywiser.

@rfcbot
Copy link
Collaborator

rfcbot commented Dec 15, 2024

🔔 This is now entering its final comment period, as per the review above. 🔔

psst @petrochenkov, I wasn't able to add the final-comment-period label, please do so.

@Urgau Urgau added the final-comment-period The FCP has started, most (if not all) team members are in agreement label Dec 15, 2024
github-merge-queue bot pushed a commit to rust-lang/cargo that referenced this issue Dec 19, 2024
)

### What does this PR try to resolve?

This PR adds the `test` cfg as a well known Cargo cfg as
rust-lang/compiler-team#785 is now in FCP and
before the compiler change.

### How should we test and review this PR?

Look at the new argument passed and the test changes.

### Additional information

Detailed motivation at
rust-lang/compiler-team#785, but summary
`test` is a weird well known cfg for `rustc` as it's mostly a convention
and build system like Cargo may to set it conditionally (`lib.test =
false` for Cargo, not done in this PR).

Pre-require to rust-lang/rust#131729.

r? @epage
@rfcbot rfcbot added finished-final-comment-period The FCP has finished, action upon the disposition label needs to be taken and removed final-comment-period The FCP has started, most (if not all) team members are in agreement labels Dec 25, 2024
@rfcbot
Copy link
Collaborator

rfcbot commented Dec 25, 2024

The final comment period, with a disposition to merge, as per the review above, is now complete.

As the automated representative of the governance process, I would like to thank the author for their work and everyone else who contributed.

This will be merged soon.

@rfcbot rfcbot added the to-announce Announce this issue on triage meeting label Dec 25, 2024
@Urgau
Copy link
Member Author

Urgau commented Dec 25, 2024

@rustbot label -final-comment-period +major-change-accepted

@Urgau Urgau closed this as completed Dec 25, 2024
@rustbot rustbot added the major-change-accepted A major change proposal that was accepted label Dec 25, 2024
@apiraino apiraino removed the to-announce Announce this issue on triage meeting label Dec 26, 2024
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this issue Jan 3, 2025
…petrochenkov

Make the `test` cfg a userspace check-cfg

This PR implements MCP rust-lang/compiler-team#785, which makes the `test` cfg a "userspace" check-cfg, i.e. no longer included in the well known cfg list.

Things to do:

- [x] Accept the MCP (rust-lang/compiler-team#785 (comment))
- [x] Mark `test` in Cargo (rust-lang/cargo#14963)

`@rustbot` labels +S-waiting-on-MCP +F-check_cfg
r? `@petrochenkov`
rust-timer added a commit to rust-lang-ci/rust that referenced this issue Jan 3, 2025
Rollup merge of rust-lang#131729 - Urgau:check-cfg-test-userspace, r=petrochenkov

Make the `test` cfg a userspace check-cfg

This PR implements MCP rust-lang/compiler-team#785, which makes the `test` cfg a "userspace" check-cfg, i.e. no longer included in the well known cfg list.

Things to do:

- [x] Accept the MCP (rust-lang/compiler-team#785 (comment))
- [x] Mark `test` in Cargo (rust-lang/cargo#14963)

`@rustbot` labels +S-waiting-on-MCP +F-check_cfg
r? `@petrochenkov`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
finished-final-comment-period The FCP has finished, action upon the disposition label needs to be taken major-change A proposal to make a major change to rustc major-change-accepted A major change proposal that was accepted T-compiler Add this label so rfcbot knows to poll the compiler team
Projects
None yet
Development

No branches or pull requests

5 participants