cargo/tests/testsuite/cargo_add/git_rev/mod.rs
Ed Page cbd4edb266 refactor(test): Clarify asserts are for UI
In writing the contrib documentation for functional vs ui tests, I
realized that as we work to make snapbox work for the functional tests,
we'll need distinct `Assert` objects since we'll want to elide a lot
more content in functional tests.  I'm making room for this by
qualifying the existing asserts as being for "ui".
2022-06-21 14:59:54 -05:00

37 lines
1.2 KiB
Rust

use cargo_test_support::compare::assert_ui;
use cargo_test_support::prelude::*;
use cargo_test_support::Project;
use crate::cargo_add::init_registry;
use cargo_test_support::curr_dir;
#[cargo_test]
fn git_rev() {
init_registry();
let project = Project::from_template(curr_dir!().join("in"));
let project_root = project.root();
let cwd = &project_root;
let (git_dep, git_repo) = cargo_test_support::git::new_repo("git-package", |project| {
project
.file(
"Cargo.toml",
&cargo_test_support::basic_manifest("git-package", "0.3.0+git-package"),
)
.file("src/lib.rs", "")
});
let find_head = || (git_repo.head().unwrap().peel_to_commit().unwrap());
let head = find_head().id().to_string();
let git_url = git_dep.url().to_string();
snapbox::cmd::Command::cargo_ui()
.arg("add")
.args(["git-package", "--git", &git_url, "--rev", &head])
.current_dir(cwd)
.assert()
.success()
.stdout_matches_path(curr_dir!().join("stdout.log"))
.stderr_matches_path(curr_dir!().join("stderr.log"));
assert_ui().subset_matches(curr_dir!().join("out"), &project_root);
}