2020-12-12 08:00:42 +00:00
|
|
|
// Copyright 2020 Google LLC
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
2021-05-15 16:16:31 +00:00
|
|
|
use jujutsu_lib::commit_builder::CommitBuilder;
|
2021-06-05 21:29:40 +00:00
|
|
|
use jujutsu_lib::matchers::EverythingMatcher;
|
2021-05-17 04:55:51 +00:00
|
|
|
use jujutsu_lib::repo_path::RepoPath;
|
2021-05-15 16:16:31 +00:00
|
|
|
use jujutsu_lib::settings::UserSettings;
|
|
|
|
use jujutsu_lib::testutils;
|
2021-09-29 15:44:00 +00:00
|
|
|
use jujutsu_lib::testutils::{assert_rebased, CommitGraphBuilder};
|
2021-05-15 16:16:31 +00:00
|
|
|
use jujutsu_lib::tree::DiffSummary;
|
2020-12-12 08:00:42 +00:00
|
|
|
use test_case::test_case;
|
|
|
|
|
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_initial(use_git: bool) {
|
|
|
|
let settings = testutils::user_settings();
|
2022-02-05 23:37:08 +00:00
|
|
|
let test_repo = testutils::init_repo(&settings, use_git);
|
|
|
|
let repo = &test_repo.repo;
|
2020-12-12 08:00:42 +00:00
|
|
|
let store = repo.store();
|
|
|
|
|
2021-05-17 05:47:31 +00:00
|
|
|
let root_file_path = RepoPath::from_internal_string("file");
|
|
|
|
let dir_file_path = RepoPath::from_internal_string("dir/file");
|
2020-12-12 08:00:42 +00:00
|
|
|
let tree = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&root_file_path, "file contents"),
|
|
|
|
(&dir_file_path, "dir/file contents"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
2021-09-11 16:45:06 +00:00
|
|
|
let mut tx = repo.start_transaction("test");
|
2020-12-12 08:00:42 +00:00
|
|
|
let commit = CommitBuilder::for_new_commit(&settings, store, tree.id().clone())
|
|
|
|
.set_parents(vec![store.root_commit_id().clone()])
|
2021-09-11 16:45:06 +00:00
|
|
|
.write_to_repo(tx.mut_repo());
|
|
|
|
tx.commit();
|
2020-12-12 08:00:42 +00:00
|
|
|
|
|
|
|
assert_eq!(commit.parents(), vec![store.root_commit()]);
|
|
|
|
assert_eq!(commit.predecessors(), vec![]);
|
2021-04-28 15:57:30 +00:00
|
|
|
assert!(!commit.is_open());
|
2020-12-12 08:00:42 +00:00
|
|
|
assert_eq!(commit.description(), "");
|
|
|
|
assert_eq!(commit.author().name, settings.user_name());
|
|
|
|
assert_eq!(commit.author().email, settings.user_email());
|
|
|
|
assert_eq!(commit.committer().name, settings.user_name());
|
|
|
|
assert_eq!(commit.committer().email, settings.user_email());
|
|
|
|
assert_eq!(
|
2021-06-05 21:29:40 +00:00
|
|
|
store
|
|
|
|
.root_commit()
|
|
|
|
.tree()
|
|
|
|
.diff_summary(&commit.tree(), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
2021-05-17 06:40:39 +00:00
|
|
|
added: vec![dir_file_path, root_file_path],
|
2020-12-12 08:00:42 +00:00
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
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_rewrite(use_git: bool) {
|
|
|
|
let settings = testutils::user_settings();
|
2022-02-05 23:37:08 +00:00
|
|
|
let test_repo = testutils::init_repo(&settings, use_git);
|
|
|
|
let repo = &test_repo.repo;
|
2021-02-24 23:33:51 +00:00
|
|
|
let store = repo.store().clone();
|
2020-12-12 08:00:42 +00:00
|
|
|
|
2021-05-17 05:47:31 +00:00
|
|
|
let root_file_path = RepoPath::from_internal_string("file");
|
|
|
|
let dir_file_path = RepoPath::from_internal_string("dir/file");
|
2020-12-12 08:00:42 +00:00
|
|
|
let initial_tree = testutils::create_tree(
|
2021-11-21 07:46:54 +00:00
|
|
|
repo,
|
2020-12-12 08:00:42 +00:00
|
|
|
&[
|
|
|
|
(&root_file_path, "file contents"),
|
|
|
|
(&dir_file_path, "dir/file contents"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
2021-09-11 16:45:06 +00:00
|
|
|
let mut tx = repo.start_transaction("test");
|
2021-02-24 23:33:51 +00:00
|
|
|
let initial_commit =
|
|
|
|
CommitBuilder::for_new_commit(&settings, &store, initial_tree.id().clone())
|
|
|
|
.set_parents(vec![store.root_commit_id().clone()])
|
2021-09-11 16:45:06 +00:00
|
|
|
.write_to_repo(tx.mut_repo());
|
|
|
|
let repo = tx.commit();
|
2020-12-12 08:00:42 +00:00
|
|
|
|
|
|
|
let rewritten_tree = testutils::create_tree(
|
|
|
|
&repo,
|
|
|
|
&[
|
|
|
|
(&root_file_path, "file contents"),
|
|
|
|
(&dir_file_path, "updated dir/file contents"),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
2022-03-10 02:04:19 +00:00
|
|
|
let config = config::Config::builder()
|
|
|
|
.set_override("user.name", "Rewrite User")
|
|
|
|
.unwrap()
|
|
|
|
.set_override("user.email", "rewrite.user@example.com")
|
|
|
|
.unwrap()
|
|
|
|
.build()
|
2020-12-12 08:00:42 +00:00
|
|
|
.unwrap();
|
|
|
|
let rewrite_settings = UserSettings::from_config(config);
|
2021-09-11 16:45:06 +00:00
|
|
|
let mut tx = repo.start_transaction("test");
|
2020-12-12 08:00:42 +00:00
|
|
|
let rewritten_commit =
|
2021-02-24 23:33:51 +00:00
|
|
|
CommitBuilder::for_rewrite_from(&rewrite_settings, &store, &initial_commit)
|
2020-12-12 08:00:42 +00:00
|
|
|
.set_tree(rewritten_tree.id().clone())
|
2021-09-11 16:45:06 +00:00
|
|
|
.write_to_repo(tx.mut_repo());
|
2022-03-21 05:16:53 +00:00
|
|
|
tx.mut_repo().rebase_descendants(&settings);
|
2021-09-11 16:45:06 +00:00
|
|
|
tx.commit();
|
2020-12-12 08:00:42 +00:00
|
|
|
assert_eq!(rewritten_commit.parents(), vec![store.root_commit()]);
|
|
|
|
assert_eq!(
|
|
|
|
rewritten_commit.predecessors(),
|
|
|
|
vec![initial_commit.clone()]
|
|
|
|
);
|
2021-04-28 15:57:30 +00:00
|
|
|
assert!(!rewritten_commit.is_open());
|
2020-12-12 08:00:42 +00:00
|
|
|
assert_eq!(rewritten_commit.author().name, settings.user_name());
|
|
|
|
assert_eq!(rewritten_commit.author().email, settings.user_email());
|
|
|
|
assert_eq!(
|
|
|
|
rewritten_commit.committer().name,
|
|
|
|
rewrite_settings.user_name()
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
rewritten_commit.committer().email,
|
|
|
|
rewrite_settings.user_email()
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
store
|
|
|
|
.root_commit()
|
|
|
|
.tree()
|
2021-06-05 21:29:40 +00:00
|
|
|
.diff_summary(&rewritten_commit.tree(), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![],
|
2021-05-17 06:40:39 +00:00
|
|
|
added: vec![dir_file_path.clone(), root_file_path],
|
2020-12-12 08:00:42 +00:00
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
assert_eq!(
|
2021-06-05 21:29:40 +00:00
|
|
|
initial_commit
|
|
|
|
.tree()
|
|
|
|
.diff_summary(&rewritten_commit.tree(), &EverythingMatcher),
|
2020-12-12 08:00:42 +00:00
|
|
|
DiffSummary {
|
|
|
|
modified: vec![dir_file_path],
|
|
|
|
added: vec![],
|
|
|
|
removed: vec![]
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
2021-09-29 15:44:00 +00:00
|
|
|
|
|
|
|
#[test_case(false ; "local backend")]
|
|
|
|
// #[test_case(true ; "git backend")]
|
|
|
|
fn test_commit_builder_descendants(use_git: bool) {
|
|
|
|
let settings = testutils::user_settings();
|
2022-02-05 23:37:08 +00:00
|
|
|
let test_repo = testutils::init_repo(&settings, use_git);
|
|
|
|
let repo = &test_repo.repo;
|
2021-09-29 15:44:00 +00:00
|
|
|
let store = repo.store().clone();
|
|
|
|
|
|
|
|
let mut tx = repo.start_transaction("test");
|
|
|
|
let mut graph_builder = CommitGraphBuilder::new(&settings, tx.mut_repo());
|
|
|
|
let commit1 = graph_builder.initial_commit();
|
|
|
|
let commit2 = graph_builder.commit_with_parents(&[&commit1]);
|
|
|
|
let commit3 = graph_builder.commit_with_parents(&[&commit2]);
|
|
|
|
let repo = tx.commit();
|
|
|
|
|
|
|
|
// Test with for_new_commit()
|
|
|
|
let mut tx = repo.start_transaction("test");
|
|
|
|
CommitBuilder::for_new_commit(&settings, &store, store.empty_tree_id().clone())
|
|
|
|
.write_to_repo(tx.mut_repo());
|
|
|
|
let mut rebaser = tx.mut_repo().create_descendant_rebaser(&settings);
|
|
|
|
assert!(rebaser.rebase_next().is_none());
|
|
|
|
|
|
|
|
// Test with for_open_commit()
|
|
|
|
let mut tx = repo.start_transaction("test");
|
|
|
|
CommitBuilder::for_open_commit(
|
|
|
|
&settings,
|
|
|
|
&store,
|
|
|
|
commit2.id().clone(),
|
|
|
|
store.empty_tree_id().clone(),
|
|
|
|
)
|
|
|
|
.write_to_repo(tx.mut_repo());
|
|
|
|
let mut rebaser = tx.mut_repo().create_descendant_rebaser(&settings);
|
|
|
|
assert!(rebaser.rebase_next().is_none());
|
|
|
|
|
|
|
|
// Test with for_rewrite_from()
|
|
|
|
let mut tx = repo.start_transaction("test");
|
|
|
|
let commit4 =
|
|
|
|
CommitBuilder::for_rewrite_from(&settings, &store, &commit2).write_to_repo(tx.mut_repo());
|
|
|
|
let mut rebaser = tx.mut_repo().create_descendant_rebaser(&settings);
|
|
|
|
assert_rebased(rebaser.rebase_next(), &commit3, &[&commit4]);
|
|
|
|
assert!(rebaser.rebase_next().is_none());
|
|
|
|
|
|
|
|
// Test with for_rewrite_from() but new change id
|
|
|
|
let mut tx = repo.start_transaction("test");
|
|
|
|
CommitBuilder::for_rewrite_from(&settings, &store, &commit2)
|
|
|
|
.generate_new_change_id()
|
|
|
|
.write_to_repo(tx.mut_repo());
|
|
|
|
let mut rebaser = tx.mut_repo().create_descendant_rebaser(&settings);
|
|
|
|
assert!(rebaser.rebase_next().is_none());
|
|
|
|
}
|