summaryrefslogtreecommitdiff
path: root/tests/integration/publish_tests.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/integration/publish_tests.rs')
-rw-r--r--tests/integration/publish_tests.rs31
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/integration/publish_tests.rs b/tests/integration/publish_tests.rs
index f6ee1b371..a033f5d07 100644
--- a/tests/integration/publish_tests.rs
+++ b/tests/integration/publish_tests.rs
@@ -708,3 +708,34 @@ fn allow_dirty_not_in_repo() {
let output = output.combined_output();
assert_contains!(output, "Successfully published");
}
+
+#[test]
+fn allow_dirty_dry_run() {
+ let context = publish_context_builder_with_git_checks().build();
+ let temp_dir = context.temp_dir().path();
+ temp_dir.join("deno.json").write_json(&json!({
+ "name": "@foo/bar",
+ "version": "1.0.0",
+ "exports": "./main.ts",
+ }));
+
+ temp_dir.join("main.ts").write("");
+
+ let cmd = Command::new("git")
+ .arg("init")
+ .arg(temp_dir.as_path())
+ .output()
+ .unwrap();
+ assert!(cmd.status.success());
+
+ let output = context
+ .new_command()
+ .arg("publish")
+ .arg("--dry-run")
+ .arg("--token")
+ .arg("sadfasdf")
+ .run();
+ output.assert_exit_code(1);
+ let output = output.combined_output();
+ assert_contains!(output, "Aborting due to uncommitted changes. Check in source code or run with --allow-dirty");
+}