mirror of
https://github.com/rust-lang/cargo
synced 2024-09-13 04:51:31 +00:00
Warning when using features in patch
Signed-off-by: hi-rustin <rustin.liu@gmail.com>
This commit is contained in:
parent
cc80b40f1c
commit
8d2103f212
|
@ -292,6 +292,14 @@ impl<'cfg> PackageRegistry<'cfg> {
|
|||
dep.package_name()
|
||||
);
|
||||
|
||||
if dep.features().len() != 0 || !dep.uses_default_features() {
|
||||
self.source_config.config().shell().warn(format!(
|
||||
"patch for `{}` uses the features mechanism. \
|
||||
default-features and features will not take effect because the patch dependency does not support this mechanism",
|
||||
dep.package_name()
|
||||
))?;
|
||||
}
|
||||
|
||||
// Go straight to the source for resolving `dep`. Load it as we
|
||||
// normally would and then ask it directly for the list of summaries
|
||||
// corresponding to this `dep`.
|
||||
|
|
|
@ -787,6 +787,154 @@ fn add_ignored_patch() {
|
|||
.run();
|
||||
}
|
||||
|
||||
#[cargo_test]
|
||||
fn add_patch_with_features() {
|
||||
Package::new("bar", "0.1.0").publish();
|
||||
|
||||
let p = project()
|
||||
.file(
|
||||
"Cargo.toml",
|
||||
r#"
|
||||
[package]
|
||||
name = "foo"
|
||||
version = "0.0.1"
|
||||
authors = []
|
||||
|
||||
[dependencies]
|
||||
bar = "0.1.0"
|
||||
"#,
|
||||
)
|
||||
.file("src/lib.rs", "")
|
||||
.file("bar/Cargo.toml", &basic_manifest("bar", "0.1.0"))
|
||||
.file("bar/src/lib.rs", r#""#)
|
||||
.build();
|
||||
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[UPDATING] `[ROOT][..]` index
|
||||
[DOWNLOADING] crates ...
|
||||
[DOWNLOADED] bar v0.1.0 [..]
|
||||
[COMPILING] bar v0.1.0
|
||||
[COMPILING] foo v0.0.1 ([CWD])
|
||||
[FINISHED] dev [unoptimized + debuginfo] target(s) in [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
p.cargo("build").with_stderr("[FINISHED] [..]").run();
|
||||
|
||||
p.change_file(
|
||||
"Cargo.toml",
|
||||
r#"
|
||||
[package]
|
||||
name = "foo"
|
||||
version = "0.0.1"
|
||||
authors = []
|
||||
|
||||
[dependencies]
|
||||
bar = "0.1.0"
|
||||
|
||||
[patch.crates-io]
|
||||
bar = { path = 'bar', features = ["some_feature"] }
|
||||
"#,
|
||||
);
|
||||
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[WARNING] patch for `bar` uses the features mechanism. \
|
||||
default-features and features will not take effect because the patch dependency does not support this mechanism
|
||||
[COMPILING] bar v0.1.0 ([CWD]/bar)
|
||||
[COMPILING] foo v0.0.1 ([CWD])
|
||||
[FINISHED] dev [unoptimized + debuginfo] target(s) in [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[WARNING] patch for `bar` uses the features mechanism. \
|
||||
default-features and features will not take effect because the patch dependency does not support this mechanism
|
||||
[FINISHED] [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
}
|
||||
|
||||
#[cargo_test]
|
||||
fn add_patch_with_setting_default_features() {
|
||||
Package::new("bar", "0.1.0").publish();
|
||||
|
||||
let p = project()
|
||||
.file(
|
||||
"Cargo.toml",
|
||||
r#"
|
||||
[package]
|
||||
name = "foo"
|
||||
version = "0.0.1"
|
||||
authors = []
|
||||
|
||||
[dependencies]
|
||||
bar = "0.1.0"
|
||||
"#,
|
||||
)
|
||||
.file("src/lib.rs", "")
|
||||
.file("bar/Cargo.toml", &basic_manifest("bar", "0.1.0"))
|
||||
.file("bar/src/lib.rs", r#""#)
|
||||
.build();
|
||||
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[UPDATING] `[ROOT][..]` index
|
||||
[DOWNLOADING] crates ...
|
||||
[DOWNLOADED] bar v0.1.0 [..]
|
||||
[COMPILING] bar v0.1.0
|
||||
[COMPILING] foo v0.0.1 ([CWD])
|
||||
[FINISHED] dev [unoptimized + debuginfo] target(s) in [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
p.cargo("build").with_stderr("[FINISHED] [..]").run();
|
||||
|
||||
p.change_file(
|
||||
"Cargo.toml",
|
||||
r#"
|
||||
[package]
|
||||
name = "foo"
|
||||
version = "0.0.1"
|
||||
authors = []
|
||||
|
||||
[dependencies]
|
||||
bar = "0.1.0"
|
||||
|
||||
[patch.crates-io]
|
||||
bar = { path = 'bar', default-features = false, features = ["none_default_feature"] }
|
||||
"#,
|
||||
);
|
||||
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[WARNING] patch for `bar` uses the features mechanism. \
|
||||
default-features and features will not take effect because the patch dependency does not support this mechanism
|
||||
[COMPILING] bar v0.1.0 ([CWD]/bar)
|
||||
[COMPILING] foo v0.0.1 ([CWD])
|
||||
[FINISHED] dev [unoptimized + debuginfo] target(s) in [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
p.cargo("build")
|
||||
.with_stderr(
|
||||
"\
|
||||
[WARNING] patch for `bar` uses the features mechanism. \
|
||||
default-features and features will not take effect because the patch dependency does not support this mechanism
|
||||
[FINISHED] [..]
|
||||
",
|
||||
)
|
||||
.run();
|
||||
}
|
||||
|
||||
#[cargo_test]
|
||||
fn no_warn_ws_patch() {
|
||||
Package::new("c", "0.1.0").publish();
|
||||
|
|
Loading…
Reference in a new issue