use std::fs; use gitbutler::virtual_branches::{branch, branch::BranchOwnershipClaims}; use crate::suite::virtual_branches::Test; #[tokio::test] async fn should_unapply_with_commits() { let Test { project_id, controller, repository, .. } = &Test::default(); controller .set_base_branch(project_id, &"refs/remotes/origin/master".parse().unwrap()) .await .unwrap(); let branch_id = controller .create_virtual_branch(project_id, &branch::BranchCreateRequest::default()) .await .unwrap(); fs::write( repository.path().join("file.txt"), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n", ) .unwrap(); controller .create_commit(project_id, &branch_id, "test", None, false) .await .unwrap(); // change in the committed hunks leads to hunk locking fs::write( repository.path().join("file.txt"), "_\n2\n3\n4\n5\n6\n7\n8\n9\n_\n", ) .unwrap(); controller .unapply_ownership( project_id, &"file.txt:1-5,7-11" .parse::() .unwrap(), ) .await .unwrap(); let branch = controller .list_virtual_branches(project_id) .await .unwrap() .0 .into_iter() .find(|b| b.id == branch_id) .unwrap(); assert!(branch.files.is_empty()); }