mirror of
https://github.com/rust-lang/cargo
synced 2024-10-14 19:52:45 +00:00
d43ee1dd22
Remove is_build: Cell<bool> from ProjectBuilder and introduce a new type Project. is_build==false <-> ProjectBuilder is_build==true <-> Project Also add #[must_use] to ProjectBuilder to confirm its instances are surely consumed by its build() method to produce Project. The same goes for RepoBuilder. ProjectBuilder::cargo_process() was removed as its design heavily depended on the internal mutability. Signed-off-by: NODA, Kai <nodakai@gmail.com>
97 lines
3 KiB
Rust
97 lines
3 KiB
Rust
extern crate cargotest;
|
|
extern crate hamcrest;
|
|
|
|
use cargotest::support::{project, execs, main_file, basic_bin_manifest};
|
|
use hamcrest::{assert_that};
|
|
|
|
static MANIFEST_OUTPUT: &'static str = r#"
|
|
{
|
|
"name":"foo",
|
|
"version":"0.5.0",
|
|
"id":"foo[..]0.5.0[..](path+file://[..]/foo)",
|
|
"license": null,
|
|
"license_file": null,
|
|
"description": null,
|
|
"source":null,
|
|
"dependencies":[],
|
|
"targets":[{
|
|
"kind":["bin"],
|
|
"crate_types":["bin"],
|
|
"name":"foo",
|
|
"src_path":"[..][/]foo[/]src[/]foo.rs"
|
|
}],
|
|
"features":{},
|
|
"manifest_path":"[..]Cargo.toml"
|
|
}"#;
|
|
|
|
#[test]
|
|
fn cargo_read_manifest_path_to_cargo_toml_relative() {
|
|
let p = project("foo")
|
|
.file("Cargo.toml", &basic_bin_manifest("foo"))
|
|
.file("src/foo.rs", &main_file(r#""i am foo""#, &[]))
|
|
.build();
|
|
|
|
assert_that(p.cargo("read-manifest")
|
|
.arg("--manifest-path").arg("foo/Cargo.toml")
|
|
.cwd(p.root().parent().unwrap()),
|
|
execs().with_status(0)
|
|
.with_json(MANIFEST_OUTPUT));
|
|
}
|
|
|
|
#[test]
|
|
fn cargo_read_manifest_path_to_cargo_toml_absolute() {
|
|
let p = project("foo")
|
|
.file("Cargo.toml", &basic_bin_manifest("foo"))
|
|
.file("src/foo.rs", &main_file(r#""i am foo""#, &[]))
|
|
.build();
|
|
|
|
assert_that(p.cargo("read-manifest")
|
|
.arg("--manifest-path").arg(p.root().join("Cargo.toml"))
|
|
.cwd(p.root().parent().unwrap()),
|
|
execs().with_status(0)
|
|
.with_json(MANIFEST_OUTPUT));
|
|
}
|
|
|
|
#[test]
|
|
fn cargo_read_manifest_path_to_cargo_toml_parent_relative() {
|
|
let p = project("foo")
|
|
.file("Cargo.toml", &basic_bin_manifest("foo"))
|
|
.file("src/foo.rs", &main_file(r#""i am foo""#, &[]))
|
|
.build();
|
|
|
|
assert_that(p.cargo("read-manifest")
|
|
.arg("--manifest-path").arg("foo")
|
|
.cwd(p.root().parent().unwrap()),
|
|
execs().with_status(101)
|
|
.with_stderr("[ERROR] the manifest-path must be \
|
|
a path to a Cargo.toml file"));
|
|
}
|
|
|
|
#[test]
|
|
fn cargo_read_manifest_path_to_cargo_toml_parent_absolute() {
|
|
let p = project("foo")
|
|
.file("Cargo.toml", &basic_bin_manifest("foo"))
|
|
.file("src/foo.rs", &main_file(r#""i am foo""#, &[]))
|
|
.build();
|
|
|
|
assert_that(p.cargo("read-manifest")
|
|
.arg("--manifest-path").arg(p.root())
|
|
.cwd(p.root().parent().unwrap()),
|
|
execs().with_status(101)
|
|
.with_stderr("[ERROR] the manifest-path must be \
|
|
a path to a Cargo.toml file"));
|
|
}
|
|
|
|
#[test]
|
|
fn cargo_read_manifest_cwd() {
|
|
let p = project("foo")
|
|
.file("Cargo.toml", &basic_bin_manifest("foo"))
|
|
.file("src/foo.rs", &main_file(r#""i am foo""#, &[]))
|
|
.build();
|
|
|
|
assert_that(p.cargo("read-manifest")
|
|
.cwd(p.root()),
|
|
execs().with_status(0)
|
|
.with_json(MANIFEST_OUTPUT));
|
|
}
|