|
@@ -6,7 +6,7 @@
|
|
|
# in the file LICENSE in the source distribution or at
|
|
|
# https://www.openssl.org/source/license.html
|
|
|
|
|
|
-use OpenSSL::Test qw/:DEFAULT bldtop_dir bldtop_file/;
|
|
|
+use OpenSSL::Test qw/:DEFAULT srctop_dir bldtop_dir/;
|
|
|
use OpenSSL::Test::Utils;
|
|
|
use File::Temp qw(tempfile);
|
|
|
|
|
@@ -15,21 +15,17 @@ use File::Temp qw(tempfile);
|
|
|
BEGIN {
|
|
|
setup("test_shlibload");
|
|
|
}
|
|
|
+use lib srctop_dir('Configurations');
|
|
|
use lib bldtop_dir('.');
|
|
|
-use configdata;
|
|
|
+use platform;
|
|
|
|
|
|
plan skip_all => "Test only supported in a shared build" if disabled("shared");
|
|
|
plan skip_all => "Test is disabled on AIX" if config('target') =~ m|^aix|;
|
|
|
|
|
|
plan tests => 10;
|
|
|
|
|
|
-# When libssl and libcrypto are compiled on Linux with "-rpath", but not
|
|
|
-# "--enable-new-dtags", the RPATH takes precedence over LD_LIBRARY_PATH,
|
|
|
-# and we end up running with the wrong libraries. This is resolved by
|
|
|
-# using paths to the shared objects, not just the names.
|
|
|
-
|
|
|
-my $libcrypto = bldtop_file(shlib('libcrypto'));
|
|
|
-my $libssl = bldtop_file(shlib('libssl'));
|
|
|
+my $libcrypto = platform->sharedlib('libcrypto');
|
|
|
+my $libssl = platform->sharedlib('libssl');
|
|
|
|
|
|
(my $fh, my $filename) = tempfile();
|
|
|
ok(run(test(["shlibloadtest", "-crypto_first", $libcrypto, $libssl, $filename])),
|
|
@@ -57,17 +53,6 @@ ok(run(test(["shlibloadtest", "-no_atexit", $libcrypto, $libssl, $filename])),
|
|
|
ok(!check_atexit($fh));
|
|
|
unlink $filename;
|
|
|
|
|
|
-sub shlib {
|
|
|
- my $lib = shift;
|
|
|
- $lib = $unified_info{rename}->{$lib}
|
|
|
- if defined $unified_info{rename}->{$lib};
|
|
|
- $lib = $unified_info{sharednames}->{$lib}
|
|
|
- . ($target{shlib_variant} || "")
|
|
|
- . ($target{shared_extension} || ".so");
|
|
|
- $lib =~ s|\.\$\(SHLIB_VERSION_NUMBER\)|.$config{shlib_version}|;
|
|
|
- return $lib;
|
|
|
-}
|
|
|
-
|
|
|
sub check_atexit {
|
|
|
my $fh = shift;
|
|
|
my $data = <$fh>;
|