diff options
Diffstat (limited to 'scripts/t/Dpkg_Source_Package.t')
-rw-r--r-- | scripts/t/Dpkg_Source_Package.t | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/scripts/t/Dpkg_Source_Package.t b/scripts/t/Dpkg_Source_Package.t new file mode 100644 index 0000000..509e422 --- /dev/null +++ b/scripts/t/Dpkg_Source_Package.t @@ -0,0 +1,62 @@ +#!/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 <https://www.gnu.org/licenses/>. + +use strict; +use warnings; + +use Test::More; +use Test::Dpkg qw(:paths :needs); + +use File::Compare; + +use Dpkg::ErrorHandling; +use Dpkg::OpenPGP::ErrorCodes; + +test_needs_openpgp_backend(); + +plan tests => 6; + +use_ok('Dpkg::Source::Package'); + +report_options(quiet_warnings => 1); + +my $datadir = test_get_data_path(); +my $tmpdir = test_get_temp_path(); +my $ascfile; + +my $p = Dpkg::Source::Package->new(); + +$ascfile = "$tmpdir/package_1.0.orig.tar.enoent"; +is($p->armor_original_tarball_signature("$datadir/nonexistent", $ascfile), + undef, 'no conversion of inexistent file'); + +$ascfile = "$tmpdir/package_1.0.orig.tar.sig2asc"; +is($p->armor_original_tarball_signature("$datadir/package_1.0.orig.tar.sig", $ascfile), + OPENPGP_OK, 'conversion from binary sig to armored asc'); + +ok(compare($ascfile, "$datadir/package_1.0.orig.tar.asc") == 0, + 'binary signature converted to OpenPGP ASCII Armor'); + +# Grab the output messages. +eval { + $ascfile = "$tmpdir/package_1.0.orig.tar.asc2asc"; + is($p->armor_original_tarball_signature("$datadir/package_1.0.orig.tar.asc", $ascfile), + OPENPGP_OK, 'copy instead of converting already armored input'); +}; + +ok(compare($ascfile, "$datadir/package_1.0.orig.tar.asc") == 0, + 'OpenPGP ASCII Armor copied to destination'); + +# TODO: Add actual test cases. |