Source

perl/keyring/kdewallet / t / 08-verylong-params.t

Diff from to

t/08-verylong-params.t

 use strict;
 use warnings;
 use Test::More;
+use Passwd::Keyring::KDEWallet;
+
 
 if($ENV{DESKTOP_SESSION} || $ENV{DBUS_SESSION_BUS_ADDRESS}) {
     plan tests => 4;
 }
 
 
-use Passwd::Keyring::KDEWallet;
-
 my $APP = "Passwd::KDEWallet::Keyring unit test 08 ";
 $APP .= "X" x (256 - length($APP));
 my $GROUP = "Passwd::KDEWallet::Keyring unit tests ";
 my $PWD =  "B" x 256;
 my $REALM = 'C' x 256;
 
-my $ring = Passwd::Keyring::KDEWallet->new(
-    app=>$APP, group=>$GROUP);
+SKIP: {
+    my $ring; 
 
-ok( defined($ring) && ref $ring eq 'Passwd::Keyring::KDEWallet',   'new() works with long params' );
+    eval {
+        $ring = Passwd::Keyring::KDEWallet->new(
+            app=>$APP, group=>$GROUP);
+    }; if($@) {
+        if($@ =~ /^KWallet not available/) {
+            skip "KWallet not available ($@)", 4;
+        } else {
+            die $@;
+        }
+    }
 
-$ring->set_password($USER, $PWD, $REALM);
+    ok( defined($ring) && ref $ring eq 'Passwd::Keyring::KDEWallet',   'new() works with long params' );
 
-ok( 1, "set_password with long params works" );
+    $ring->set_password($USER, $PWD, $REALM);
 
-ok( $ring->get_password($USER, $REALM) eq $PWD, "get_password with long params works");
+    ok( 1, "set_password with long params works" );
 
-ok( $ring->clear_password($USER, $REALM) eq 1, "clear_password with long params works");
+    ok( $ring->get_password($USER, $REALM) eq $PWD, "get_password with long params works");
 
+    ok( $ring->clear_password($USER, $REALM) eq 1, "clear_password with long params works");
+
+}