2016-04-22 11:21:51 +00:00
|
|
|
#! /usr/bin/env perl
|
|
|
|
# Copyright 2015-2016 The OpenSSL Project Authors. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Licensed under the OpenSSL license (the "License"). You may not use
|
|
|
|
# this file except in compliance with the License. You can obtain a copy
|
|
|
|
# in the file LICENSE in the source distribution or at
|
|
|
|
# https://www.openssl.org/source/license.html
|
|
|
|
|
2015-09-09 15:36:21 +00:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use File::Spec::Functions;
|
|
|
|
use File::Copy;
|
|
|
|
use File::Basename;
|
2016-05-28 14:11:01 +00:00
|
|
|
if ($^O ne "VMS") {
|
|
|
|
use File::Glob qw/glob/;
|
|
|
|
}
|
2016-01-30 00:05:33 +00:00
|
|
|
use OpenSSL::Test qw/:DEFAULT bldtop_file/;
|
2015-09-09 15:36:21 +00:00
|
|
|
|
|
|
|
setup("test_rehash");
|
|
|
|
|
2015-09-22 14:16:29 +00:00
|
|
|
#If "openssl rehash -help" fails it's most likely because we're on a platform
|
|
|
|
#that doesn't support the rehash command (e.g. Windows)
|
|
|
|
plan skip_all => "test_rehash is not available on this platform"
|
|
|
|
unless run(app(["openssl", "rehash", "-help"]));
|
|
|
|
|
2015-09-18 19:27:29 +00:00
|
|
|
plan tests => 5;
|
2015-09-09 15:36:21 +00:00
|
|
|
|
|
|
|
indir "rehash.$$" => sub {
|
|
|
|
prepare();
|
|
|
|
ok(run(app(["openssl", "rehash", curdir()])),
|
|
|
|
'Testing normal rehash operations');
|
|
|
|
}, create => 1, cleanup => 1;
|
|
|
|
|
|
|
|
indir "rehash.$$" => sub {
|
|
|
|
prepare(sub { chmod 400, $_ foreach (@_); });
|
|
|
|
ok(run(app(["openssl", "rehash", curdir()])),
|
|
|
|
'Testing rehash operations on readonly files');
|
|
|
|
}, create => 1, cleanup => 1;
|
|
|
|
|
|
|
|
indir "rehash.$$" => sub {
|
|
|
|
ok(run(app(["openssl", "rehash", curdir()])),
|
|
|
|
'Testing rehash operations on empty directory');
|
|
|
|
}, create => 1, cleanup => 1;
|
|
|
|
|
|
|
|
indir "rehash.$$" => sub {
|
|
|
|
prepare();
|
|
|
|
chmod 0500, curdir();
|
2015-09-18 19:27:29 +00:00
|
|
|
SKIP: {
|
|
|
|
if (!ok(!open(FOO, ">unwritable.txt"),
|
2016-02-26 19:30:15 +00:00
|
|
|
"Testing that we aren't running as a privileged user, such as root")) {
|
2015-09-18 19:27:29 +00:00
|
|
|
close FOO;
|
|
|
|
skip "It's pointless to run the next test as root", 1;
|
|
|
|
}
|
|
|
|
isnt(run(app(["openssl", "rehash", curdir()])), 1,
|
|
|
|
'Testing rehash operations on readonly directory');
|
|
|
|
}
|
2015-09-09 15:36:21 +00:00
|
|
|
chmod 0700, curdir(); # make it writable again, so cleanup works
|
|
|
|
}, create => 1, cleanup => 1;
|
|
|
|
|
|
|
|
sub prepare {
|
|
|
|
my @sourcefiles =
|
2016-01-30 00:05:33 +00:00
|
|
|
sort map { glob(bldtop_file('certs', 'demo', "*.$_")) } ('pem',
|
2016-05-28 14:11:01 +00:00
|
|
|
'crt',
|
|
|
|
'cer',
|
|
|
|
'crl');
|
2015-09-09 15:36:21 +00:00
|
|
|
my @destfiles = ();
|
|
|
|
foreach (@sourcefiles) {
|
|
|
|
copy($_, curdir());
|
|
|
|
push @destfiles, catfile(curdir(), basename($_));
|
|
|
|
}
|
|
|
|
foreach (@_) {
|
|
|
|
die "Internal error, argument is not CODE"
|
|
|
|
unless (ref($_) eq 'CODE');
|
|
|
|
$_->(@destfiles);
|
|
|
|
}
|
|
|
|
}
|