Commit graph

14755 commits

Author SHA1 Message Date
Arlo Siemsen 627936bdf6 cargo-credential-gnome-secret: dynamically load libsecret 2023-08-17 00:18:00 -05:00
bors 3a34fca9ee Auto merge of #12517 - weihanglo:bump-cargo-util-0.2.6, r=epage
chore(cargo-util): bump version to 0.2.6
2023-08-16 19:25:54 +00:00
Weihang Lo 5691da2b79
chore(cargo-util): bump version to 0.2.6 2023-08-16 20:06:40 +01:00
bors b6254cae48 Auto merge of #12512 - arlosi:rename-basic-cred-provider, r=epage
credential: rename cargo:basic to cargo:token-from-stdout

Multiple people have said that the name of the `cargo:basic` credential provider is confusing, since it's not doing HTTP Basic authentication.

Rename `cargo:basic` to `cargo:token-from-stdout`, which more accurately describes what it does.
2023-08-16 16:29:48 +00:00
bors 11870e3a16 Auto merge of #12513 - weihanglo:fix-bump-check, r=epage
fix(xtask-bump-check): query by package name to detect changes
2023-08-16 14:58:44 +00:00
Weihang Lo 1ee9db3123
fix(xtask-bump-check): query by package name to detect changes
versions and paths of a workspace members between the original and
a checked-out workspace are different, and shouldn't be included in
hash keys when querying packages.
2023-08-16 15:46:43 +01:00
Arlo Siemsen 1065f213e3 credential: rename cargo:basic to cargo:token-from-stdout 2023-08-15 23:56:11 -05:00
bors 93e1aa2ea1 Auto merge of #12508 - weihanglo:ci-github-sha, r=ehuss
ci: use pull request head commit whenever possible
2023-08-16 02:01:29 +00:00
Weihang Lo 4360d9d2ad
ci: use pull request head commit whenever possible
The `github.sha` is a merge commit with the parents of latest master
and the head of the pr. Trying to diff the changes from that merge
SHA to base will show all changes that have been made in-between.

And that doesn't seem about right.

We switch to `github.event.pull_request.head.sha` if there is a pr.

See: https://rust-lang.zulipchat.com/#narrow/stream/246057-t-cargo/topic/version-bump.20CI.20failing
2023-08-16 00:11:23 +01:00
bors bc1842686f Auto merge of #12504 - ehuss:hermit-abi, r=epage
Update hermit-abi

This updates hermit-abi from 0.3.1 to 0.3.2. 0.3.1 was yanked, and I keep getting warnings about it.

Changes: https://github.com/hermitcore/rusty-hermit/compare/hermit-abi-0.3.1...hermit-abi-0.3.2
2023-08-15 21:50:00 +00:00
bors a11f624c97 Auto merge of #11447 - arlosi:exact, r=weihanglo
Crate checksum lookup query should match on semver build metadata

Since crates.io allows crate versions to differ only by build metadata, a query using `OptVersionReq::exact` + `next()` can return nondeterministic results.

This change fixes the issue by adding an additional `filter` that ensures the version is equal (including build metadata).

It still feels somewhat wrong that a query using `exact` can match multiple crates, so an alternative fix would be to add a new variant of `OptVersionReq` that also matched on build metadata.

Fixes #11412
2023-08-15 20:44:15 +00:00
Eric Huss a008741136 Update hermit-abi 2023-08-15 13:29:54 -07:00
bors 7c3904d6c3 Auto merge of #12501 - epage:rustdoc, r=weihanglo
fix(lints): Doctest extraction should respect `[lints]`

Note the first commit shows the bug and the second commit fixes it

Fixes #12497
2023-08-14 20:11:43 +00:00
bors fdd0d273e4 Auto merge of #12500 - weihanglo:relax-panic-msg, r=epage
test: relax assertions of panic message (again)
2023-08-14 19:25:49 +00:00
Ed Page 9984855904 fix(lints): Doctest extraction should respect [lints]
Fixes #12497
2023-08-14 14:23:59 -05:00
Ed Page a80dfae761 test(lints): Demo doctest bug 2023-08-14 14:21:25 -05:00
Weihang Lo 689defd4ba
test: relax assertions of panic message (again) 2023-08-14 19:32:39 +01:00
bors 3b4dd4b255 Auto merge of #12492 - weihanglo:keep-going-doc, r=epage
doc(unstable): `cargo test` does not provide `--keep-going`
2023-08-14 17:45:41 +00:00
bors f13759445f Auto merge of #12488 - weihanglo:ansi-color-log, r=epage
fix(log): enable ansi color only in terminal
2023-08-14 17:03:39 +00:00
Weihang Lo c07043b7cf
fix(log): enable ansi color only in terminal 2023-08-14 15:45:25 +01:00
bors 0067476575 Auto merge of #12490 - amosbird:cargo-yank-doc-fix1, r=weihanglo
Update cargo-yank.md

Fix version typo in cargo-yank.md
2023-08-14 14:42:05 +00:00
Weihang Lo b45ffa9283
doc(unstable): cargo test does not provide --keep-going 2023-08-14 15:26:38 +01:00
bors 18f2b46f28 Auto merge of #12491 - weihanglo:fix-future-incompat, r=ehuss
test: bypass `rustc --test` impl details for `-Zfuture-incompat-test`

Switch to an empty `lib.rs` from `main.rs`.

See https://github.com/rust-lang/rust/issues/114804#issuecomment-1677233355

Closes https://github.com/rust-lang/rust/issues/114804
2023-08-14 13:49:14 +00:00
Weihang Lo b567a67d5c
test: bypass rustc --test impl details for -Zfuture-incompat-test
Switch to an empty `lib.rs` from `main.rs`.

See https://github.com/rust-lang/rust/issues/114804#issuecomment-1677233355
2023-08-14 13:40:47 +01:00
Amos Bird 09215930e6
Update cargo-yank.md
Fix version typo in cargo-yank.md
2023-08-14 16:03:31 +08:00
bors 7e9de3f4ec Auto merge of #12478 - weihanglo:keep-going, r=epage
feat: remove `--keep-going` from `cargo test/bench`
2023-08-13 00:47:32 +00:00
bors 42f17989f7 Auto merge of #12483 - weihanglo:platform-dep, r=ehuss
chore: window-sys should be a platform-specific dependency

r? `@arlosi`
2023-08-12 23:46:34 +00:00
Weihang Lo 862226fc60
chore: window-sys should be a platform-specific dependency 2023-08-12 09:17:18 +01:00
bors 65cee64656 Auto merge of #12482 - rukai:rerun-if-changed-docs, r=weihanglo
docs: make the env var source of rerun-if-env-changed clearer

closes https://github.com/rust-lang/cargo/issues/12403

### What does this PR try to resolve?

The wording of the documentation on [rerun-if-env-changed](https://doc.rust-lang.org/cargo/reference/build-scripts.html#cargorerun-if-env-changedname) was misleading which led me to be confused by the behavior of cargo and then raise https://github.com/rust-lang/cargo/issues/12403
These changes should avoid users being confused by this in the future.
2023-08-12 00:42:04 +00:00
Lucas Kent 24ad2bc24c docs: make the env var source of rerun-if-env-changed clearer 2023-08-12 10:27:21 +10:00
Arlo Siemsen fb98f3fcba Add test differ_only_by_metadata 2023-08-11 18:42:40 -05:00
Arlo Siemsen 8d6464000e Crate checksum lookup includes build metadata 2023-08-11 18:32:46 -05:00
bors 3a73377919 Auto merge of #12479 - weihanglo:credential, r=epage
doc: note the backward compatible `.cargo/credential` file exists
2023-08-11 16:35:27 +00:00
Weihang Lo 94a1217789
doc: note the backward compatible .cargo/credential file exists 2023-08-11 17:25:58 +01:00
Weihang Lo de8b9139ba
feat: remove completions of --keep-going for bench/test
To test, simply run:

zsh

```zsh
fpath+=$PWD/src/etc
autoload -Uz compinit
compinit

cargo t <tab>
```

bash:

```bash

. ./src/etc/cargo.bashcomp.sh

cargo t <tab>
```
2023-08-11 15:42:20 +01:00
Weihang Lo 5ae529b24e
feat: remove --keep-going from cargo test/bench
It confuses people that both `--no-fail-fast` and `--keep-going` exist
on `cargo test` and `cargo bench` but with slightly different behavior.
The intended use cases for `--keep-going` involve build commands like
`build`/`check`/`clippy` but never `test`/`bench`.

Hence, this commit removes `--keep-going` from `test`/`bench` and
provides guidance of `--no-fail-fast` instead.

If people really want to build as many tests as possible, they can also
do it in two steps:

    cargo build --tests --keep-going
    cargo test --test --no-fail-fast
2023-08-11 14:29:02 +01:00
bors 3705df02e3 Auto merge of #12475 - compiler-errors:unelided-lifetime, r=epage
Fix elided lifetime in associated const

Fix an unelided lifetime in an associated const.

The old code was equivalent to:

```rust
impl<'a> RegistryConfig {
    /// File name of [`RegistryConfig`].
    const NAME: &'a str = "config.json";
}
```

and not `&'static str`, as it might be in a regular `const` item.

This "regressed" in rust-lang/rust#97313, which started allowing this behavior (inadvertently, as far as I can tell). It's not necessarily clear to me that this is sound (or at least, it's not something we intended to be able to express), but it's also preventing me from doing crater runs to investigate fallout of this issue (rust-lang/rust#114713 and rust-lang/rust#114716).
2023-08-11 02:28:46 +00:00
Michael Goulet b4a26b0f4c Fix elided lifetime in associated const 2023-08-11 01:10:32 +00:00
bors 7da103076e Auto merge of #12463 - stupendoussuperpowers:nocapture_test_msg, r=epage
prompt the use of `--nocapture` flag if `cargo test` process is terminated via a signal.

Fixes #10855

As per the discussion on this issue, we want to prompt the user to use `--nocapture` if a test is terminated abnormally. The motivation for this change is described in the issue.

We check for 3 things before we display this flag. -
- `!is_simple` (if the test ended with a non 101 status code)
- `harness` (if the standard test harness was used), and
- `!nocapture` (whether or not the `--nocapture` flag was already passed to the test)

There's further tests added to `test::nonzero_exit_status` that check that the `stderr` is correct for the various combinations possible when a test ends with a non-101 status code.

The new expected behavior is -
- Display `--nocapture` note for only non-zero exit statuses, when the `--nocapture` flag is not passed.
- Only display the note if we use a standard test harness since custom test harnesses do not implement the `--nocapture` flag.

To implement the check for the `--nocapture` flag, the function definition for `report_test_errors` was changed to add the `test_args: &[&str]` parameter. This parameter is passed from the immediate calling function. This private function is only called twice change and is not causing regression after making the appropriate changes to both the places it's called in.
2023-08-10 21:20:25 +00:00
bors 54550ef7a3 Auto merge of #12469 - arlosi:cred-stdio, r=weihanglo
cargo-credential: reset stdin & stdout to the Console

Credential providers run with stdin and stdout piped to Cargo to communicate. This makes it more difficult for providers to do anything interactive. The current workaround is for a provider to use the `cargo_credential::tty()` function when reading from the console by re-opening stdin using `/dev/tty` or `CONIN$`.

This PR makes the credential provider to re-attach itself to the current console so that reading from stdin and writing to stdout "just works" when inside the `perform` method of the provider. stderr is unaffected since it's not redirected by Cargo.

Only the `cargo-credential` crate is changed. No changes are needed to Cargo.

cc #8933
2023-08-10 20:20:00 +00:00
Arlo Siemsen 5ade1ad1eb cargo-credential: reset stdin & stdout to the Console 2023-08-10 13:33:33 -05:00
bors af431e1bb7 Auto merge of #12454 - alcolmenar:alcolmenar/fix-invalid-rm, r=epage
Fix cargo remove incorrectly removing used patches

### What does this PR try to resolve?

Fixes an issue where patches are being removed when member dependencies don't explicitly contain the patched crate.

Fixes #12419

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

- Created a test for the failing use case
- Verify passing test

<!--
### Additional information

Other information you want to mention in this PR, such as prior arts,
future extensions, an unresolved problem, or a TODO list.

-->
2023-08-10 18:00:32 +00:00
alcolmenar 72e66fb645
fix: add quiet verbosity around resolve and fix tests 2023-08-10 09:51:36 -07:00
alcolmenar a64ed3976f
fix: add gc unused patches logic and fix tests 2023-08-10 07:27:36 -07:00
alcolmenar 7ad774a3ff
chore: add passing test 2023-08-10 07:27:24 -07:00
bors 7ed917f2fc Auto merge of #12466 - epage:renovate, r=arlosi
chore(gh): Expand update window

I've been having some repos not updated lately.  RenovateBot project's theory is that its because RenovateBot is scheduled to run once every 3 hours and checks the schedule at that point while the schedules I use only offers an exact 3 hour window, making this a race condition.  The schedule originally came from RenovateBot but they changed their polling schedule.

See https://github.com/renovatebot/renovate/discussions/23642#discussioncomment-6618560
2023-08-09 22:40:04 +00:00
alcolmenar dde256fb93
fix: ensure patches are different dependencies to enable unused 2023-08-09 13:09:41 -07:00
sanchit dd8cd9c9a9 add nocapture message to report_test_err 2023-08-10 01:16:27 +05:30
sanchit dde17cf0cf add --nocapture tests 2023-08-10 01:16:00 +05:30
bors 1d43be107b Auto merge of #12468 - arlosi:http-debug-crash, r=weihanglo
Fix panic when enabling http.debug for certain strings

Fixes an issue where enabling HTTP debugging may attempt to slice a string across a character boundary resulting in a panic. This likely occurs when binary HTTP data happens to be valid UTF-8.

By interpreting the strings as `&[u8]` before slicing, (which is what `eq_ignore_ascii_case` did internally anyway), the panic is no longer possible.

Closes #12459

r? `@weihanglo`
2023-08-09 17:31:03 +00:00