public-inbox.git  about / heads / tags
an "archives first" approach to mailing lists
blob 6769bf9fdabed667e4158519e3e350cc5e5c51ea 1217 bytes (raw)
name: t/repobrowse_git_atom.t 	 # note: path name is non-authoritative(*)

 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
 
# Copyright (C) 2016 all contributors <meta@public-inbox.org>
# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
use strict;
use warnings;
my $have_xml_feed = eval { require XML::Feed; 1 };
my $test = require './t/repobrowse_common_git.perl';
use Test::More;

test_psgi($test->{app}, sub {
	my ($cb) = @_;
	my $req = 'http://example.com/test.git/atom';
	my $res = $cb->(GET($req));
	is($res->code, 200, 'got 200');
	is($res->header('Content-Type'), 'application/atom+xml',
		'got correct Content-Type');
	my $body = dechunk($res);
	SKIP: {
		skip 'XML::Feed missing', 2 unless $have_xml_feed;
		my $p = XML::Feed->parse(\$body);
		is($p->format, "Atom", "parsed atom feed");
		is(scalar $p->entries, 6, "parsed six entries");
	}
	like($body, qr!<pre\s*[^>]+>\* header:\n  add header</pre>!,
		'body wrapped in <pre>');

	$res = $cb->(GET($req . '/master/foo.txt'));
	is($res->code, 200, 'got 200');
	$body = dechunk($res);
	like($body, qr{\bhref="http://[^/]+/test\.git/}, 'hrefs OK');
	SKIP: {
		skip 'XML::Feed missing', 2 unless $have_xml_feed;
		my $p = XML::Feed->parse(\$body);
		is($p->format, "Atom", "parsed atom feed");
		is(scalar $p->entries, 4, "parsed 4 entries");
	}
});

done_testing();

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

git clone https://public-inbox.org/public-inbox.git
git clone http://7fh6tueqddpjyxjmgtdiueylzoqt6pt7hec3pukyptlmohoowvhde4yd.onion/public-inbox.git