tests: demonstrate sparsed-away paths lost on stale-workspace recovery

As shown by the updated test case, when we recover from a working copy
pointing to a lost operation, the new working-copy commit after
snapshotting will have lost any files outside the sparse patterns.
This commit is contained in:
Martin von Zweigbergk 2024-03-15 20:51:59 -07:00 committed by Martin von Zweigbergk
parent 0d197791a0
commit ffb12680a6

View file

@ -419,12 +419,24 @@ fn test_workspaces_current_op_discarded_by_other() {
std::fs::write(main_path.join("modified"), "base\n").unwrap(); std::fs::write(main_path.join("modified"), "base\n").unwrap();
std::fs::write(main_path.join("deleted"), "base\n").unwrap(); std::fs::write(main_path.join("deleted"), "base\n").unwrap();
std::fs::write(main_path.join("sparse"), "base\n").unwrap();
test_env.jj_cmd_ok(&main_path, &["new"]); test_env.jj_cmd_ok(&main_path, &["new"]);
std::fs::write(main_path.join("modified"), "main\n").unwrap(); std::fs::write(main_path.join("modified"), "main\n").unwrap();
test_env.jj_cmd_ok(&main_path, &["new"]); test_env.jj_cmd_ok(&main_path, &["new"]);
test_env.jj_cmd_ok(&main_path, &["workspace", "add", "../secondary"]); test_env.jj_cmd_ok(&main_path, &["workspace", "add", "../secondary"]);
// Make unsnapshotted writes in the secondary working copy // Make unsnapshotted writes in the secondary working copy
test_env.jj_cmd_ok(
&secondary_path,
&[
"sparse",
"set",
"--clear",
"--add=modified",
"--add=deleted",
"--add=added",
],
);
std::fs::write(secondary_path.join("modified"), "secondary\n").unwrap(); std::fs::write(secondary_path.join("modified"), "secondary\n").unwrap();
std::fs::remove_file(secondary_path.join("deleted")).unwrap(); std::fs::remove_file(secondary_path.join("deleted")).unwrap();
std::fs::write(secondary_path.join("added"), "secondary\n").unwrap(); std::fs::write(secondary_path.join("added"), "secondary\n").unwrap();
@ -443,13 +455,13 @@ fn test_workspaces_current_op_discarded_by_other() {
], ],
); );
insta::assert_snapshot!(stdout, @r###" insta::assert_snapshot!(stdout, @r###"
@ ca4014fc13 abandon commit 9e69961a6cb8dc42410fa11421c5ce14c9ba4dba3d85c99b3f5d7214e01c09211d3f6abf0a5502038bc9531d4d7828a4b3e978ca4f64f6cb5b00f4181c1710cc @ 716b8d737e abandon commit 8ac26d0060e2be7f3fce2b5ebd2eb0c75053666f6cbc41bee50bb6da463868704a0bcf1ed9848761206d77694a71e3c657e5e250245e342779df1b00f0da9009
b7e3c248b3 Create initial working-copy commit in workspace secondary bb8aec2a1c Create initial working-copy commit in workspace secondary
3a464a164b add workspace 'secondary' af6f39b411 add workspace 'secondary'
1a8a57ad06 new empty commit 05c14c7e78 new empty commit
34dce00889 snapshot working copy 92bb962606 snapshot working copy
64b8644c69 new empty commit 553e0ea3a4 new empty commit
983fc29dc3 snapshot working copy b3755a9026 snapshot working copy
17dbb2fe40 add workspace 'default' 17dbb2fe40 add workspace 'default'
cecfee9647 initialize repo cecfee9647 initialize repo
0000000000 0000000000
@ -460,10 +472,10 @@ fn test_workspaces_current_op_discarded_by_other() {
test_env.jj_cmd_ok(&main_path, &["util", "gc", "--expire=now"]); test_env.jj_cmd_ok(&main_path, &["util", "gc", "--expire=now"]);
insta::assert_snapshot!(get_log_output(&test_env, &main_path), @r###" insta::assert_snapshot!(get_log_output(&test_env, &main_path), @r###"
@ b026dbb4ded8 default@ ec4904a30161 secondary@
11b31a7bf02c secondary@ @ 74769415363f default@
cab81fe8ecb0 bd711986720f
000000000000 000000000000
"###); "###);
@ -476,29 +488,38 @@ fn test_workspaces_current_op_discarded_by_other() {
let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["workspace", "update-stale"]); let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["workspace", "update-stale"]);
insta::assert_snapshot!(stderr, @r###" insta::assert_snapshot!(stderr, @r###"
Failed to read working copy's current operation; attempting recovery. Error message from read attempt: Object b7e3c248b31b30b9ebe9bc0960bb5138a9832745f0e02d76e7dc9e65a44fcfd092cdf9e22e6ca84498dc496dd08c22027ecc3ba8fc45ab54bf565b9cda13eca6 of type operation not found Failed to read working copy's current operation; attempting recovery. Error message from read attempt: Object bb8aec2a1ca33ebafdfe8866bc4ad3464dffd25634fde19d1025625880791b141d35753e10737c41b2bc133ab84047312f3021d905bb711960253e7f430100fc of type operation not found
Created and checked out recovery commit 1e90e5d2ab94 Created and checked out recovery commit 30ee0d1fbd7a
"###); "###);
insta::assert_snapshot!(stdout, @""); insta::assert_snapshot!(stdout, @"");
insta::assert_snapshot!(get_log_output(&test_env, &main_path), @r###" insta::assert_snapshot!(get_log_output(&test_env, &main_path), @r###"
bffc5782a10d secondary@ 8fd911b4e595 secondary@
11b31a7bf02c ec4904a30161
@ b026dbb4ded8 default@ @ 74769415363f default@
cab81fe8ecb0 bd711986720f
000000000000 000000000000
"###); "###);
// The sparse patterns should remain
let stdout = test_env.jj_cmd_success(&secondary_path, &["sparse", "list"]);
insta::assert_snapshot!(stdout, @r###"
added
deleted
modified
"###);
let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["st"]); let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["st"]);
insta::assert_snapshot!(stderr, @""); insta::assert_snapshot!(stderr, @"");
// TODO: The file outside the sparse patterns should still be there
insta::assert_snapshot!(stdout, @r###" insta::assert_snapshot!(stdout, @r###"
Working copy changes: Working copy changes:
A added A added
D deleted D deleted
M modified M modified
Working copy : kpqxywon bffc5782 (no description set) D sparse
Parent commit: rzvqmyuk 11b31a7b (empty) (no description set) Working copy : kmkuslsw 8fd911b4 (no description set)
Parent commit: rzvqmyuk ec4904a3 (empty) (no description set)
"###); "###);
// The modified file should have the same contents it had before (not reset to // The modified file should have the same contents it had before (not reset to
// the base contents) // the base contents)
@ -509,9 +530,9 @@ fn test_workspaces_current_op_discarded_by_other() {
let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["obslog"]); let (stdout, stderr) = test_env.jj_cmd_ok(&secondary_path, &["obslog"]);
insta::assert_snapshot!(stderr, @""); insta::assert_snapshot!(stderr, @"");
insta::assert_snapshot!(stdout, @r###" insta::assert_snapshot!(stdout, @r###"
@ kpqxywon test.user@example.com 2001-02-03 04:05:17.000 +07:00 secondary@ bffc5782 @ kmkuslsw test.user@example.com 2001-02-03 04:05:18.000 +07:00 secondary@ 8fd911b4
(no description set) (no description set)
kpqxywon hidden test.user@example.com 2001-02-03 04:05:17.000 +07:00 1e90e5d2 kmkuslsw hidden test.user@example.com 2001-02-03 04:05:18.000 +07:00 30ee0d1f
(empty) (no description set) (empty) (no description set)
"###); "###);
} }