2022-11-26 23:57:50 +00:00
|
|
|
// Copyright 2020 The Jujutsu Authors
|
2020-12-12 08:00:42 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2023-06-28 14:12:40 +00:00
|
|
|
use jj_lib::matchers::{EverythingMatcher, FilesMatcher};
|
2023-08-27 16:57:48 +00:00
|
|
|
use jj_lib::merged_tree::{DiffSummary, MergedTree};
|
2023-06-28 14:12:40 +00:00
|
|
|
use jj_lib::repo_path::RepoPath;
|
2020-12-12 08:00:42 +00:00
|
|
|
use test_case::test_case;
|
2022-11-08 12:35:16 +00:00
|
|
|
use testutils::TestRepo;
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-09-12 06:52:38 +00:00
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
#[test_case(true ; "git backend")]
|
2020-12-12 08:00:42 +00:00
|
|
|
fn test_types(use_git: bool) {
|
2022-05-21 18:20:51 +00:00
|
|
|
let test_repo = TestRepo::init(use_git);
|
2022-02-05 23:29:05 +00:00
|
|
|
let repo = &test_repo.repo;
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-05-17 05:47:31 +00:00
|
|
|
let clean_path = RepoPath::from_internal_string("clean");
|
|
|
|
let modified_path = RepoPath::from_internal_string("modified");
|
|
|
|
let added_path = RepoPath::from_internal_string("added");
|
|
|
|
let removed_path = RepoPath::from_internal_string("removed");
|
2020-12-12 08:00:42 +00:00
|
|
|
|
|
|
|
let tree1 = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&clean_path, "clean"),
|
|
|
|
(&modified_path, "contents before"),
|
|
|
|
(&removed_path, "removed contents"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
|
|
|
let tree2 = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&clean_path, "clean"),
|
|
|
|
(&modified_path, "contents after"),
|
|
|
|
(&added_path, "added contents"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1).diff_summary(&MergedTree::Legacy(tree2), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![modified_path],
|
|
|
|
added: vec![added_path],
|
|
|
|
removed: vec![removed_path]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-09-12 06:52:38 +00:00
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
#[test_case(true ; "git backend")]
|
2020-12-12 08:00:42 +00:00
|
|
|
fn test_tree_file_transition(use_git: bool) {
|
2022-05-21 18:20:51 +00:00
|
|
|
let test_repo = TestRepo::init(use_git);
|
2022-02-05 23:29:05 +00:00
|
|
|
let repo = &test_repo.repo;
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-05-17 05:47:31 +00:00
|
|
|
let dir_file_path = RepoPath::from_internal_string("dir/file");
|
|
|
|
let dir_path = RepoPath::from_internal_string("dir");
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-11-21 07:46:54 +00:00
|
|
|
let tree1 = testutils::create_tree(repo, &[(&dir_file_path, "contents")]);
|
|
|
|
let tree2 = testutils::create_tree(repo, &[(&dir_path, "contents")]);
|
2020-12-12 08:00:42 +00:00
|
|
|
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![dir_path.clone()],
|
|
|
|
removed: vec![dir_file_path.clone()]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2).diff_summary(&MergedTree::Legacy(tree1), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![dir_file_path],
|
|
|
|
removed: vec![dir_path]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-09-12 06:52:38 +00:00
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
#[test_case(true ; "git backend")]
|
2020-12-12 08:00:42 +00:00
|
|
|
fn test_sorting(use_git: bool) {
|
2022-05-21 18:20:51 +00:00
|
|
|
let test_repo = TestRepo::init(use_git);
|
2022-02-05 23:29:05 +00:00
|
|
|
let repo = &test_repo.repo;
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-05-17 05:47:31 +00:00
|
|
|
let a_path = RepoPath::from_internal_string("a");
|
|
|
|
let b_path = RepoPath::from_internal_string("b");
|
|
|
|
let f_a_path = RepoPath::from_internal_string("f/a");
|
|
|
|
let f_b_path = RepoPath::from_internal_string("f/b");
|
|
|
|
let f_f_a_path = RepoPath::from_internal_string("f/f/a");
|
|
|
|
let f_f_b_path = RepoPath::from_internal_string("f/f/b");
|
|
|
|
let n_path = RepoPath::from_internal_string("n");
|
|
|
|
let s_b_path = RepoPath::from_internal_string("s/b");
|
|
|
|
let z_path = RepoPath::from_internal_string("z");
|
2020-12-12 08:00:42 +00:00
|
|
|
|
|
|
|
let tree1 = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&a_path, "before"),
|
|
|
|
(&f_a_path, "before"),
|
|
|
|
(&f_f_a_path, "before"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
|
|
|
let tree2 = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&a_path, "after"),
|
|
|
|
(&b_path, "after"),
|
|
|
|
(&f_a_path, "after"),
|
|
|
|
(&f_b_path, "after"),
|
|
|
|
(&f_f_a_path, "after"),
|
|
|
|
(&f_f_b_path, "after"),
|
|
|
|
(&n_path, "after"),
|
|
|
|
(&s_b_path, "after"),
|
|
|
|
(&z_path, "after"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![a_path.clone(), f_a_path.clone(), f_f_a_path.clone()],
|
|
|
|
added: vec![
|
|
|
|
b_path.clone(),
|
|
|
|
f_b_path.clone(),
|
|
|
|
f_f_b_path.clone(),
|
2021-05-17 06:40:39 +00:00
|
|
|
n_path.clone(),
|
2020-12-12 08:00:42 +00:00
|
|
|
s_b_path.clone(),
|
2021-05-17 06:40:39 +00:00
|
|
|
z_path.clone(),
|
2020-12-12 08:00:42 +00:00
|
|
|
],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2).diff_summary(&MergedTree::Legacy(tree1), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![a_path, f_a_path, f_f_a_path],
|
|
|
|
added: vec![],
|
2021-05-17 06:40:39 +00:00
|
|
|
removed: vec![b_path, f_b_path, f_f_b_path, n_path, s_b_path, z_path]
|
2020-12-12 08:00:42 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
2021-06-05 21:29:40 +00:00
|
|
|
|
2021-09-12 06:52:38 +00:00
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
#[test_case(true ; "git backend")]
|
2021-06-05 21:29:40 +00:00
|
|
|
fn test_matcher_dir_file_transition(use_git: bool) {
|
2022-05-21 18:20:51 +00:00
|
|
|
let test_repo = TestRepo::init(use_git);
|
2022-02-05 23:29:05 +00:00
|
|
|
let repo = &test_repo.repo;
|
2021-06-05 21:29:40 +00:00
|
|
|
|
|
|
|
let a_path = RepoPath::from_internal_string("a");
|
|
|
|
let a_a_path = RepoPath::from_internal_string("a/a");
|
|
|
|
|
2021-11-21 07:46:54 +00:00
|
|
|
let tree1 = testutils::create_tree(repo, &[(&a_path, "before")]);
|
|
|
|
let tree2 = testutils::create_tree(repo, &[(&a_a_path, "after")]);
|
2021-06-05 21:29:40 +00:00
|
|
|
|
2022-12-28 07:34:24 +00:00
|
|
|
let matcher = FilesMatcher::new(&[a_path.clone()]);
|
2021-06-05 21:29:40 +00:00
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![],
|
|
|
|
removed: vec![a_path.clone()]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree1.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![a_path.clone()],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2022-12-28 07:34:24 +00:00
|
|
|
let matcher = FilesMatcher::new(&[a_a_path.clone()]);
|
2021-06-05 21:29:40 +00:00
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![a_a_path.clone()],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree1.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![],
|
|
|
|
removed: vec![a_a_path.clone()]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2022-12-28 07:34:24 +00:00
|
|
|
let matcher = FilesMatcher::new(&[a_path.clone(), a_a_path.clone()]);
|
2021-06-05 21:29:40 +00:00
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
|
|
|
added: vec![a_a_path.clone()],
|
|
|
|
removed: vec![a_path.clone()]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2).diff_summary(&MergedTree::Legacy(tree1), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
2021-06-14 07:18:38 +00:00
|
|
|
added: vec![a_path],
|
|
|
|
removed: vec![a_a_path]
|
2021-06-05 21:29:40 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-09-12 06:52:38 +00:00
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
#[test_case(true ; "git backend")]
|
2021-06-05 21:29:40 +00:00
|
|
|
fn test_matcher_normal_cases(use_git: bool) {
|
2022-05-21 18:20:51 +00:00
|
|
|
let test_repo = TestRepo::init(use_git);
|
2022-02-05 23:29:05 +00:00
|
|
|
let repo = &test_repo.repo;
|
2021-06-05 21:29:40 +00:00
|
|
|
|
|
|
|
let a_path = RepoPath::from_internal_string("a");
|
|
|
|
let dir1_a_path = RepoPath::from_internal_string("dir1/a");
|
|
|
|
let dir2_b_path = RepoPath::from_internal_string("dir2/b");
|
|
|
|
let z_path = RepoPath::from_internal_string("z");
|
|
|
|
|
2021-11-21 07:46:54 +00:00
|
|
|
let tree1 = testutils::create_tree(repo, &[(&a_path, "before"), (&dir1_a_path, "before")]);
|
2021-06-05 21:29:40 +00:00
|
|
|
// File "a" gets modified
|
|
|
|
// File "dir1/a" gets modified
|
|
|
|
// File "dir2/b" gets created
|
|
|
|
// File "z" gets created
|
|
|
|
let tree2 = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2021-06-05 21:29:40 +00:00
|
|
|
&[
|
|
|
|
(&a_path, "after"),
|
|
|
|
(&dir1_a_path, "after"),
|
|
|
|
(&dir2_b_path, "after"),
|
|
|
|
(&z_path, "after"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
2022-12-28 07:34:24 +00:00
|
|
|
let matcher = FilesMatcher::new(&[a_path.clone(), z_path.clone()]);
|
2021-06-05 21:29:40 +00:00
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![a_path.clone()],
|
|
|
|
added: vec![z_path.clone()],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree1.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
2021-06-14 07:18:38 +00:00
|
|
|
modified: vec![a_path],
|
2021-06-05 21:29:40 +00:00
|
|
|
added: vec![],
|
2021-06-14 07:18:38 +00:00
|
|
|
removed: vec![z_path]
|
2021-06-05 21:29:40 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2022-12-28 07:34:24 +00:00
|
|
|
let matcher = FilesMatcher::new(&[dir1_a_path.clone(), dir2_b_path.clone()]);
|
2021-06-05 21:29:40 +00:00
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree1.clone())
|
|
|
|
.diff_summary(&MergedTree::Legacy(tree2.clone()), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![dir1_a_path.clone()],
|
|
|
|
added: vec![dir2_b_path.clone()],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2023-08-27 16:57:48 +00:00
|
|
|
MergedTree::Legacy(tree2).diff_summary(&MergedTree::Legacy(tree1), &matcher),
|
2021-06-05 21:29:40 +00:00
|
|
|
DiffSummary {
|
2021-06-14 07:18:38 +00:00
|
|
|
modified: vec![dir1_a_path],
|
2021-06-05 21:29:40 +00:00
|
|
|
added: vec![],
|
2021-06-14 07:18:38 +00:00
|
|
|
removed: vec![dir2_b_path]
|
2021-06-05 21:29:40 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|