]> git.cameronkatri.com Git - cgit.git/blobdiff - tests/t0107-snapshot.sh
global: replace hard coded hash length
[cgit.git] / tests / t0107-snapshot.sh
index 7e6f5bf2085e549ea49ecb23c017a6c942d42299..c164d3e2572c4400962f1e14940381fed2d23eaa 100755 (executable)
@@ -16,7 +16,7 @@ test_expect_success 'check html headers' '
 '
 
 test_expect_success 'strip off the header lines' '
-       tail -n +6 tmp > master.tar.gz
+       strip_headers <tmp >master.tar.gz
 '
 
 test_expect_success 'verify gzip format' '
@@ -38,6 +38,132 @@ test_expect_success 'verify untarred file-5' '
        test_line_count = 1 master/file-5
 '
 
+if test -n "$(which lzip 2>/dev/null)"; then
+       test_set_prereq LZIP
+else
+       say 'Skipping LZIP validation tests: lzip not found'
+fi
+
+test_expect_success LZIP 'get foo/snapshot/master.tar.lz' '
+       cgit_url "foo/snapshot/master.tar.lz" >tmp
+'
+
+test_expect_success LZIP 'check html headers' '
+       head -n 1 tmp |
+       grep "Content-Type: application/x-lzip" &&
+
+       head -n 2 tmp |
+       grep "Content-Disposition: inline; filename=.master.tar.lz."
+'
+
+test_expect_success LZIP 'strip off the header lines' '
+       strip_headers <tmp >master.tar.lz
+'
+
+test_expect_success LZIP 'verify lzip format' '
+       lzip --test master.tar.lz &&
+       cp master.tar.lz /tmp/.
+'
+
+test_expect_success LZIP 'untar' '
+       rm -rf master &&
+       tar --lzip -xf master.tar.lz
+'
+
+test_expect_success LZIP 'count files' '
+       ls master/ >output &&
+       test_line_count = 5 output
+'
+
+test_expect_success LZIP 'verify untarred file-5' '
+       grep "^5$" master/file-5 &&
+       test_line_count = 1 master/file-5
+'
+
+if test -n "$(which xz 2>/dev/null)"; then
+       test_set_prereq XZ
+else
+       say 'Skipping XZ validation tests: xz not found'
+fi
+
+test_expect_success XZ 'get foo/snapshot/master.tar.xz' '
+       cgit_url "foo/snapshot/master.tar.xz" >tmp
+'
+
+test_expect_success XZ 'check html headers' '
+       head -n 1 tmp |
+       grep "Content-Type: application/x-xz" &&
+
+       head -n 2 tmp |
+       grep "Content-Disposition: inline; filename=.master.tar.xz."
+'
+
+test_expect_success XZ 'strip off the header lines' '
+       strip_headers <tmp >master.tar.xz
+'
+
+test_expect_success XZ 'verify xz format' '
+       xz --test master.tar.xz &&
+       cp master.tar.xz /tmp/.
+'
+
+test_expect_success XZ 'untar' '
+       rm -rf master &&
+       tar --xz -xf master.tar.xz
+'
+
+test_expect_success XZ 'count files' '
+       ls master/ >output &&
+       test_line_count = 5 output
+'
+
+test_expect_success XZ 'verify untarred file-5' '
+       grep "^5$" master/file-5 &&
+       test_line_count = 1 master/file-5
+'
+
+if test -n "$(which zstd 2>/dev/null)"; then
+       test_set_prereq ZSTD
+else
+       say 'Skipping ZSTD validation tests: zstd not found'
+fi
+
+test_expect_success ZSTD 'get foo/snapshot/master.tar.zst' '
+       cgit_url "foo/snapshot/master.tar.zst" >tmp
+'
+
+test_expect_success ZSTD 'check html headers' '
+       head -n 1 tmp |
+       grep "Content-Type: application/x-zstd" &&
+
+       head -n 2 tmp |
+       grep "Content-Disposition: inline; filename=.master.tar.zst."
+'
+
+test_expect_success ZSTD 'strip off the header lines' '
+       strip_headers <tmp >master.tar.zst
+'
+
+test_expect_success ZSTD 'verify zstd format' '
+       zstd --test master.tar.zst &&
+       cp master.tar.zst /tmp/.
+'
+
+test_expect_success ZSTD 'untar' '
+       rm -rf master &&
+       tar --zstd -xf master.tar.zst
+'
+
+test_expect_success ZSTD 'count files' '
+       ls master/ >output &&
+       test_line_count = 5 output
+'
+
+test_expect_success ZSTD 'verify untarred file-5' '
+       grep "^5$" master/file-5 &&
+       test_line_count = 1 master/file-5
+'
+
 test_expect_success 'get foo/snapshot/master.zip' '
        cgit_url "foo/snapshot/master.zip" >tmp
 '
@@ -51,24 +177,30 @@ test_expect_success 'check HTML headers (zip)' '
 '
 
 test_expect_success 'strip off the header lines (zip)' '
-       tail -n +6 tmp >master.zip
+       strip_headers <tmp >master.zip
 '
 
-test_expect_success 'verify zip format' '
+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
 '
 
-test_expect_success 'unzip' '
+test_expect_success UNZIP 'unzip' '
        rm -rf master &&
        unzip master.zip
 '
 
-test_expect_success 'count files (zip)' '
+test_expect_success UNZIP 'count files (zip)' '
        ls master/ >output &&
        test_line_count = 5 output
 '
 
-test_expect_success 'verify unzipped file-5' '
+test_expect_success UNZIP 'verify unzipped file-5' '
        grep "^5$" master/file-5 &&
        test_line_count = 1 master/file-5
 '