summaryrefslogtreecommitdiff
path: root/test/segments/vcs-hg.spec
diff options
context:
space:
mode:
authorDominik Ritter <dritter03@googlemail.com>2018-11-15 03:18:46 +0300
committerDominik Ritter <dritter03@googlemail.com>2018-11-17 00:15:35 +0300
commit7bc5366af1abb572238aa24dfe2552aed1fab966 (patch)
tree85fd3af0e0d4aba7c4450e0f47d92b2db7905182 /test/segments/vcs-hg.spec
parent6085a74abf0d6d34fbf39865495f13fbbf535a12 (diff)
Add tests for branch name vulnerability
Diffstat (limited to 'test/segments/vcs-hg.spec')
-rwxr-xr-xtest/segments/vcs-hg.spec13
1 files changed, 12 insertions, 1 deletions
diff --git a/test/segments/vcs-hg.spec b/test/segments/vcs-hg.spec
index 2903f544..53afbaac 100755
--- a/test/segments/vcs-hg.spec
+++ b/test/segments/vcs-hg.spec
@@ -204,4 +204,15 @@ function testBookmarkIconWorks() {
assertEquals "%K{002} %F{000} default Binitial %k%F{002}%f " "$(build_left_prompt)"
}
-source shunit2/shunit2 \ No newline at end of file
+function testBranchNameScriptingVulnerability() {
+ echo "#!/bin/sh\n\necho 'hacked'\n" > evil_script.sh
+ chmod +x evil_script.sh
+
+ hg branch '$(./evil_script.sh)' >/dev/null
+ hg add . >/dev/null
+ hg commit -m "Initial commit" >/dev/null
+
+ assertEquals "%K{002} %F{000} %f%F{000} \$(./evil_script.sh) %k%F{002}%f " "$(build_left_prompt)"
+}
+
+source shunit2/shunit2