#!/usr/bin/perl
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
use strict;
use warnings;
use Test::More tests => 94;
use Test::Dpkg qw(:paths);
use File::Basename;
use Dpkg::File;
BEGIN {
use_ok('Dpkg::Changelog');
use_ok('Dpkg::Changelog::Debian');
use_ok('Dpkg::Vendor', qw(get_current_vendor));
};
my $datadir = test_get_data_path('t/Dpkg_Changelog');
my $vendor = get_current_vendor();
#########################
foreach my $file ("$datadir/countme", "$datadir/shadow", "$datadir/fields",
"$datadir/regressions", "$datadir/date-format") {
my $changes = Dpkg::Changelog::Debian->new(verbose => 0);
$changes->load($file);
open(my $clog_fh, '<', "$file") or die "can't open $file\n";
my $content = file_slurp($clog_fh);
close($clog_fh);
cmp_ok($content, 'eq', "$changes", "string output of Dpkg::Changelog on $file");
my $errors = $changes->get_parse_errors();
my $basename = basename( $file );
is($errors, '', "Parse example changelog $file without errors" );
my @data = @$changes;
ok(@data, 'data is not empty');
my $str;
if ($file eq "$datadir/countme") {
# test range options
cmp_ok(@data, '==', 7, 'no options -> count');
my $all_versions = join( '/', map { $_->get_version() } @data);
sub check_options {
my ($changes, $data, $options, $count, $versions,
$check_name) = @_;
my @cnt = $changes->get_range($options);
cmp_ok( @cnt, '==', $count, "$check_name -> count" );
if ($count == @$data) {
is_deeply( \@cnt, $data, "$check_name -> returns all" );
} else {
is( join( '/', map { $_->get_version() } @cnt),
$versions, "$check_name -> versions" );
}
}
check_options( $changes, \@data,
{ count => 3 }, 3, '2:2.0-1/1:2.0~rc2-3/1:2.0~rc2-2',
'positive count' );
check_options( $changes, \@data,
{ count => -3 }, 3,
'1:2.0~rc2-1sarge2/1:2.0~rc2-1sarge1/1.5-1',
'negative count' );
check_options( $changes, \@data,
{ count => 1 }, 1, '2:2.0-1',
'count 1' );
check_options( $changes, \@data,
{ count => 1, default_all => 1 }, 1, '2:2.0-1',
'count 1 (d_a 1)' );
check_options( $changes, \@data,
{ count => -1 }, 1, '1.5-1',
'count -1' );
check_options( $changes, \@data,
{ count => 3, offset => 2 }, 3,
'1:2.0~rc2-2/1:2.0~rc2-1sarge3/1:2.0~rc2-1sarge2',
'positve count + positive offset' );
check_options( $changes, \@data,
{ count => -3, offset => 4 }, 3,
'1:2.0~rc2-3/1:2.0~rc2-2/1:2.0~rc2-1sarge3',
'negative count + positive offset' );
check_options( $changes, \@data,
{ count => 4, offset => 5 }, 2,
'1:2.0~rc2-1sarge1/1.5-1',
'positve count + positive offset (>max)' );
check_options( $changes, \@data,
{ count => -4, offset => 2 }, 2,
'2:2.0-1/1:2.0~rc2-3',
'negative count + positive offset (<0)' );
check_options( $changes, \@data,
{ count => 3, offset => -4 }, 3,
'1:2.0~rc2-1sarge3/1:2.0~rc2-1sarge2/1:2.0~rc2-1sarge1',
'positve count + negative offset' );
check_options( $changes, \@data,
{ count => -3, offset => -3 }, 3,
'1:2.0~rc2-3/1:2.0~rc2-2/1:2.0~rc2-1sarge3',
'negative count + negative offset' );
check_options( $changes, \@data,
{ count => 5, offset => -2 }, 2,
'1:2.0~rc2-1sarge1/1.5-1',
'positve count + negative offset (>max)' );
check_options( $changes, \@data,
{ count => -5, offset => -4 }, 3,
'2:2.0-1/1:2.0~rc2-3/1:2.0~rc2-2',
'negative count + negative offset (<0)' );
check_options( $changes, \@data,
{ count => 7 }, 7, '',
'count 7 (max)' );
check_options( $changes, \@data,
{ count => -7 }, 7, '',
'count -7 (-max)' );
check_options( $changes, \@data,
{ count => 10 }, 7, '',
'count 10 (>max)' );
check_options( $changes, \@data,
{ count => -10 }, 7, '',
'count -10 (<-max)' );
check_options( $changes, \@data,
{ from => '1:2.0~rc2-1sarge3' }, 4,
'2:2.0-1/1:2.0~rc2-3/1:2.0~rc2-2/1:2.0~rc2-1sarge3',
'from => "1:2.0~rc2-1sarge3"' );
check_options( $changes, \@data,
{ since => '1:2.0~rc2-1sarge3' }, 3,
'2:2.0-1/1:2.0~rc2-3/1:2.0~rc2-2',
'since => "1:2.0~rc2-1sarge3"' );
$SIG{__WARN__} = sub {};
check_options( $changes, \@data,
{ since => 0 }, 7, '',
'since => 0 returns all');
delete $SIG{__WARN__};
check_options( $changes, \@data,
{ to => '1:2.0~rc2-1sarge2' }, 3,
'1:2.0~rc2-1sarge2/1:2.0~rc2-1sarge1/1.5-1',
'to => "1:2.0~rc2-1sarge2"' );
## no critic (ControlStructures::ProhibitUntilBlocks)
check_options( $changes, \@data,
{ until => '1:2.0~rc2-1sarge2' }, 2,
'1:2.0~rc2-1sarge1/1.5-1',
'until => "1:2.0~rc2-1sarge2"' );
## use critic
#TODO: test combinations
}
if ($file eq "$datadir/fields") {
my $str = $changes->format_range('dpkg', { all => 1 });
my $expected = 'Source: fields
Version: 2.0-0etch1
Distribution: stable
Urgency: high
Maintainer: Frank Lichtenheld
Timestamp: 1200235759
Date: Sun, 13 Jan 2008 15:49:19 +0100
Closes: 1000000 1111111 2222222
Changes:
fields (2.0-0etch1) stable; urgency=low
.
* Upload to stable (Closes: #1111111, #2222222)
* Fix more stuff. (LP: #54321, #2424242)
.
fields (2.0-1) unstable frozen; urgency=medium
.
[ Frank Lichtenheld ]
* Upload to unstable (Closes: #1111111, #2222222)
* Fix stuff. (LP: #12345, #424242)
.
[ Raphaël Hertzog ]
* New upstream release.
- implements a
- implements b
* Update S-V.
.
fields (2.0~b1-1) unstable; urgency=low,xc-userfield=foobar
.
* Beta
.
fields (1.0) experimental; urgency=high,xb-userfield2=foobar
.
* First upload (Closes: #1000000)
Xb-Userfield2: foobar
Xc-Userfield: foobar
';
if ($vendor eq 'Ubuntu') {
$expected =~ s/^(Closes:.*)/$1\nLaunchpad-Bugs-Fixed: 12345 54321 424242 2424242/m;
}
cmp_ok($str, 'eq', $expected, 'fields handling');
$str = $changes->format_range('dpkg', { offset => 1, count => 2 });
$expected = 'Source: fields
Version: 2.0-1
Distribution: unstable frozen
Urgency: medium
Maintainer: Frank Lichtenheld
Timestamp: 1200149359
Date: Sun, 12 Jan 2008 15:49:19 +0100
Closes: 1111111 2222222
Changes:
fields (2.0-1) unstable frozen; urgency=medium
.
[ Frank Lichtenheld ]
* Upload to unstable (Closes: #1111111, #2222222)
* Fix stuff. (LP: #12345, #424242)
.
[ Raphaël Hertzog ]
* New upstream release.
- implements a
- implements b
* Update S-V.
.
fields (2.0~b1-1) unstable; urgency=low,xc-userfield=foobar
.
* Beta
Xc-Userfield: foobar
';
if ($vendor eq 'Ubuntu') {
$expected =~ s/^(Closes:.*)/$1\nLaunchpad-Bugs-Fixed: 12345 424242/m;
}
cmp_ok($str, 'eq', $expected, 'fields handling 2');
$str = $changes->format_range('rfc822', { offset => 2, count => 2 });
$expected = 'Source: fields
Version: 2.0~b1-1
Distribution: unstable
Urgency: low
Maintainer: Frank Lichtenheld
Timestamp: 1200062959
Date: Sun, 11 Jan 2008 15:49:19 +0100
Changes:
fields (2.0~b1-1) unstable; urgency=low,xc-userfield=foobar
.
* Beta
Xc-Userfield: foobar
Source: fields
Version: 1.0
Distribution: experimental
Urgency: high
Maintainer: Frank Lichtenheld
Timestamp: 1199976559
Date: Sun, 10 Jan 2008 15:49:19 +0100
Closes: 1000000
Changes:
fields (1.0) experimental; urgency=high,xb-userfield2=foobar
.
* First upload (Closes: #1000000)
Xb-Userfield2: foobar
';
cmp_ok($str, 'eq', $expected, 'fields handling 3');
# Test Dpkg::Changelog::Entry methods
is($data[1]->get_version(), '2.0-1', 'get_version');
is($data[1]->get_source(), 'fields', 'get_source');
is(scalar $data[1]->get_distributions(), 'unstable', 'get_distribution');
is(join('|', $data[1]->get_distributions()), 'unstable|frozen',
'get_distributions');
is($data[3]->get_optional_fields(),
"Urgency: high\nCloses: 1000000\nXb-Userfield2: foobar\n",
'get_optional_fields');
is($data[1]->get_maintainer(), 'Frank Lichtenheld ',
'get_maintainer');
is($data[1]->get_timestamp(), 'Sun, 12 Jan 2008 15:49:19 +0100',
'get_timestamp');
my @items = $data[1]->get_change_items();
is($items[0], " [ Frank Lichtenheld ]\n", 'change items 1');
is($items[4], ' * New upstream release.
- implements a
- implements b
', 'change items 2');
is($items[5], " * Update S-V.\n", 'change items 3');
}
if ($file eq "$datadir/date-format") {
is($data[0]->get_timestamp(), '01 Jul 2100 23:59:59 -1200',
'get date w/o DoW, and negative timezone offset');
is($data[1]->get_timestamp(), 'Tue, 27 Feb 2050 12:00:00 +1245',
'get date w/ DoW, and positive timezone offset');
is($data[2]->get_timestamp(), 'Mon, 01 Jan 2000 00:00:00 +0000',
'get date w/ DoW, and zero timezone offset');
}
if ($file eq "$datadir/regressions") {
my $f = ($changes->format_range('dpkg'))[0];
is("$f->{Version}", '0', 'version 0 correctly parsed');
}
SKIP: {
skip('avoid spurious warning with only one entry', 2)
if @data == 1;
my $oldest_version = $data[-1]->{Version};
$str = $changes->format_range('dpkg', { since => $oldest_version });
$str = $changes->format_range('rfc822');
ok(1, 'TODO check rfc822 output');
$str = $changes->format_range('rfc822', { since => $oldest_version });
ok(1, 'TODO check rfc822 output with ranges');
}
}
foreach my $test (([ "$datadir/misplaced-tz", 6 ],
[ "$datadir/unreleased", 5, 7 ])) {
my $file = shift @$test;
my $changes = Dpkg::Changelog::Debian->new(verbose => 0);
$changes->load($file);
my @errors = $changes->get_parse_errors();
ok(@errors, 'errors occured');
is_deeply( [ map { $_->[1] } @errors ], $test, 'check line numbers' );
}