summaryrefslogtreecommitdiffstatshomepage
path: root/tests/t0107-snapshot.sh
blob: 132d2e9551c1c635efce60b3c902db42d890eb69 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/bin/sh

. ./setup.sh

prepare_tests "Verify snapshot"

run_test 'get foo/snapshot/master.tar.gz' '
	cgit_url "foo/snapshot/master.tar.gz" >trash/tmp
'

run_test 'check html headers' '
	head -n 1 trash/tmp |
	grep "Content-Type: application/x-gzip" &&

	head -n 2 trash/tmp |
	grep "Content-Disposition: inline; filename=.master.tar.gz."
'

run_test 'strip off the header lines' '
	tail -n +6 trash/tmp > trash/master.tar.gz
'

run_test 'verify gzip format' '
	gunzip --test trash/master.tar.gz
'

run_test 'untar' '
	rm -rf trash/master &&
	tar -xf trash/master.tar.gz -C trash
'

run_test 'count files' '
	c=$(ls -1 trash/master/ | wc -l) &&
	test $c = 5
'

run_test 'verify untarred file-5' '
	grep "^5$" trash/master/file-5 &&
	test $(cat trash/master/file-5 | wc -l) = 1
'

run_test 'get foo/snapshot/master.zip' '
	cgit_url "foo/snapshot/master.zip" >trash/tmp
'

run_test 'check HTML headers (zip)' '
	head -n 1 trash/tmp |
	grep "Content-Type: application/x-zip" &&

	head -n 2 trash/tmp |
	grep "Content-Disposition: inline; filename=.master.zip."
'

run_test 'strip off the header lines (zip)' '
	tail -n +6 trash/tmp >trash/master.zip
'

run_test 'verify zip format' '
	unzip -t trash/master.zip
'

run_test 'unzip' '
	rm -rf trash/master &&
	unzip trash/master.zip -d trash
'

run_test 'count files (zip)' '
	c=$(ls -1 trash/master/ | wc -l) &&
	test $c = 5
'

run_test 'verify unzipped file-5' '
	 grep "^5$" trash/master/file-5 &&
	 test $(cat trash/master/file-5 | wc -l) = 1
'

tests_done
); found_path = 1; return 0; } int cgit_print_file(char *path, const char *head) { unsigned char sha1[20]; enum object_type type; char *buf; unsigned long size; struct commit *commit; const char *paths[] = {path, NULL}; if (get_sha1(head, sha1)) return -1; type = sha1_object_info(sha1, &size); if(type == OBJ_COMMIT && path) { commit = lookup_commit_reference(sha1); match_path = path; matched_sha1 = sha1; found_path = 0; read_tree_recursive(commit->tree, "", 0, 0, paths, walk_tree, NULL); if (!found_path) return -1; type = sha1_object_info(sha1, &size); } if (type == OBJ_BAD) return -1; buf = read_sha1_file(sha1, &type, &size); if (!buf) return -1; buf[size] = '\0'; html_raw(buf, size); return 0; } void cgit_print_blob(const char *hex, char *path, const char *head) { unsigned char sha1[20]; enum object_type type; char *buf; unsigned long size; struct commit *commit; const char *paths[] = {path, NULL}; if (hex) { if (get_sha1_hex(hex, sha1)){ cgit_print_error(fmt("Bad hex value: %s", hex)); return; } } else { if (get_sha1(head,sha1)) { cgit_print_error(fmt("Bad ref: %s", head)); return; } } type = sha1_object_info(sha1, &size); if((!hex) && type == OBJ_COMMIT && path) { commit = lookup_commit_reference(sha1); match_path = path; matched_sha1 = sha1; read_tree_recursive(commit->tree, "", 0, 0, paths, walk_tree, NULL); type = sha1_object_info(sha1,&size); } if (type == OBJ_BAD) { cgit_print_error(fmt("Bad object name: %s", hex)); return; } buf = read_sha1_file(sha1, &type, &size); if (!buf) { cgit_print_error(fmt("Error reading object %s", hex)); return; } buf[size] = '\0'; ctx.page.mimetype = ctx.qry.mimetype; if (!ctx.page.mimetype) { if (buffer_is_binary(buf, size)) ctx.page.mimetype = "application/octet-stream"; else ctx.page.mimetype = "text/plain"; } ctx.page.filename = path; cgit_print_http_headers(&ctx); html_raw(buf, size); }