diff --git a/cli/tests/test_working_copy.rs b/cli/tests/test_working_copy.rs index a7bacea3436..52d7a078ac0 100644 --- a/cli/tests/test_working_copy.rs +++ b/cli/tests/test_working_copy.rs @@ -20,6 +20,8 @@ fn test_snapshot_large_file() { test_env.jj_cmd_ok(test_env.env_root(), &["init", "repo", "--git"]); let repo_path = test_env.env_root().join("repo"); + // test a small file using raw-integer-literal syntax, which is interpreted + // in bytes test_env.add_config(r#"snapshot.max-new-file-size = 10"#); std::fs::write(repo_path.join("large"), "a lot of text").unwrap(); let stderr = test_env.jj_cmd_failure(&repo_path, &["files"]); @@ -34,4 +36,21 @@ fn test_snapshot_large_file() { - Run `jj --config-toml 'snapshot.max-new-file-size="13B"' st` This will increase the maximum file size allowed for new files, for this command only. "###); + + // test with a larger file using 'KB' human-readable syntax + test_env.add_config(r#"snapshot.max-new-file-size = "10KB""#); + let big_string = vec![0; 1024 * 11]; + std::fs::write(repo_path.join("large"), big_string).unwrap(); + let stderr = test_env.jj_cmd_failure(&repo_path, &["files"]); + insta::assert_snapshot!(stderr, @r###" + Error: Failed to snapshot the working copy + The file '$TEST_ENV/repo/large' is too large to be snapshotted (11264 bytes). + The maximum size allowed is 10240 bytes. + Hint: This is to prevent large files from being added on accident. You can fix this error by: + - Adding the file to `.gitignore` + - Run `jj config set --repo snapshot.max-new-file-size "11264B"` + This will increase the maximum file size allowed for new files, in this repository only. + - Run `jj --config-toml 'snapshot.max-new-file-size="11264B"' st` + This will increase the maximum file size allowed for new files, for this command only. + "###); }