From 487a6deabc1334d92c5c1a55357c35b2b1089754 Mon Sep 17 00:00:00 2001 From: Ilya Grigoriev Date: Thu, 2 May 2024 17:00:20 -0700 Subject: [PATCH] better test for bug #3223 --- lib/tests/test_local_working_copy.rs | 56 ++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) diff --git a/lib/tests/test_local_working_copy.rs b/lib/tests/test_local_working_copy.rs index 8c06660e27c..ae4620dc57d 100644 --- a/lib/tests/test_local_working_copy.rs +++ b/lib/tests/test_local_working_copy.rs @@ -19,6 +19,7 @@ use std::os::unix::net::UnixListener; use std::path::Path; use std::sync::Arc; +use insta::{assert_debug_snapshot, assert_snapshot}; use itertools::Itertools; use jj_lib::backend::{MergedTreeId, TreeId, TreeValue}; use jj_lib::file_util::{check_symlink_support, try_symlink}; @@ -328,6 +329,61 @@ fn test_conflict_subdirectory() { .unwrap(); } +#[test] +fn test_conflict_empty_vs_nonempty_issue_3223() { + let settings = testutils::user_settings(); + let mut test_workspace = TestWorkspace::init(&settings); + let repo = &test_workspace.repo; + + let path = RepoPath::from_internal_string("file"); + let empty_tree = create_tree(repo, &[]); + let tree1 = create_tree(repo, &[(path, "")]); // empty file + let tree2 = create_tree(repo, &[(path, "nonempty")]); + let merged_tree = tree1.merge(&empty_tree, &tree2).unwrap(); + // The tree representation is conflicted... + assert_debug_snapshot!(tree_entries(&merged_tree), @r###" + [ + ( + "file", + Some( + Conflicted( + [ + Some( + File { + id: FileId( + "482ae5a29fbe856c7272", + ), + executable: false, + }, + ), + None, + Some( + File { + id: FileId( + "2f381f1aab1e326fe57d", + ), + executable: false, + }, + ), + ], + ), + ), + ), + ] + "###); + // let commit1 = commit_with_tree(repo.store(), tree1.id()); + let merged_commit = commit_with_tree(repo.store(), merged_tree.id()); + let repo = &test_workspace.repo; + let ws = &mut test_workspace.workspace; + // ws.check_out(repo.op_id().clone(), None, &commit1).unwrap(); + ws.check_out(repo.op_id().clone(), None, &merged_commit) + .unwrap(); + let file_contents = std::fs::read_to_string(path.to_fs_path(ws.workspace_root())).unwrap(); + // The file on disk does *not* have conflict markers. + // So, it's impossible to resolve the conflict. + assert_snapshot!(file_contents, @"nonempty"); +} + #[test] fn test_tree_builder_file_directory_transition() { let settings = testutils::user_settings();