]> git.cameronkatri.com Git - cgit.git/blobdiff - tests/t0107-snapshot.sh
auth-filters: do not crash on nil username
[cgit.git] / tests / t0107-snapshot.sh
index c42091a2cf8544a6f42d5378f6096f5a2af77e9d..6cf7aaa6fca5dd8d9c48fca1a4f988db31aff539 100755 (executable)
@@ -1,39 +1,82 @@
 #!/bin/sh
 
+test_description='Verify snapshot'
 . ./setup.sh
 
-prepare_tests "Verify snapshot"
+test_expect_success 'get foo/snapshot/master.tar.gz' '
+       cgit_url "foo/snapshot/master.tar.gz" >tmp
+'
+
+test_expect_success 'check html headers' '
+       head -n 1 tmp |
+       grep "Content-Type: application/x-gzip" &&
 
-run_test 'get foo/snapshot/test.tar.gz' '
-       cgit_url "foo/snapshot/test.tar.gz" >trash/tmp
+       head -n 2 tmp |
+       grep "Content-Disposition: inline; filename=.master.tar.gz."
 '
 
-run_test 'check html headers' '
-       head -n 1 trash/tmp |
-            grep -e "Content-Type: application/x-gzip" &&
+test_expect_success 'strip off the header lines' '
+       strip_headers <tmp >master.tar.gz
+'
+
+test_expect_success 'verify gzip format' '
+       gunzip --test master.tar.gz
+'
+
+test_expect_success 'untar' '
+       rm -rf master &&
+       tar -xzf master.tar.gz
+'
+
+test_expect_success 'count files' '
+       ls master/ >output &&
+       test_line_count = 5 output
+'
 
-       head -n 2 trash/tmp |
-            grep -e "Content-Disposition: inline; filename=.test.tar.gz."
+test_expect_success 'verify untarred file-5' '
+       grep "^5$" master/file-5 &&
+       test_line_count = 1 master/file-5
 '
 
-run_test 'strip off the header lines' '
-        tail -n +6 trash/tmp > trash/test.tar.gz
+test_expect_success 'get foo/snapshot/master.zip' '
+       cgit_url "foo/snapshot/master.zip" >tmp
+'
+
+test_expect_success 'check HTML headers (zip)' '
+       head -n 1 tmp |
+       grep "Content-Type: application/x-zip" &&
+
+       head -n 2 tmp |
+       grep "Content-Disposition: inline; filename=.master.zip."
+'
+
+test_expect_success 'strip off the header lines (zip)' '
+       strip_headers <tmp >master.zip
+'
+
+if test -n "$(which unzip 2>/dev/null)"; then
+       test_set_prereq UNZIP
+else
+       say 'Skipping ZIP validation tests: unzip not found'
+fi
+
+test_expect_success UNZIP 'verify zip format' '
+       unzip -t master.zip
 '
 
-run_test 'verify gzip format' 'gunzip --test trash/test.tar.gz'
-run_test 'untar' '
-       rm -rf trash/foo &&
-       tar -xf trash/test.tar.gz -C trash
+test_expect_success UNZIP 'unzip' '
+       rm -rf master &&
+       unzip master.zip
 '
 
-run_test 'count files' '
-       c=$(ls -1 trash/foo/ | wc -l) &&
-       test $c = 5
+test_expect_success UNZIP 'count files (zip)' '
+       ls master/ >output &&
+       test_line_count = 5 output
 '
 
-run_test 'verify untarred file-5' '
-        grep -e "^5$" trash/foo/file-5 &&
-        test $(cat trash/foo/file-5 | wc -l) = 1
+test_expect_success UNZIP 'verify unzipped file-5' '
+       grep "^5$" master/file-5 &&
+       test_line_count = 1 master/file-5
 '
 
-tests_done
+test_done