Uwe Kleine-König <[email protected]> wrote:
>       $ prove t/pop3d.t
>       t/pop3d.t .. skipped: certs/ missing for t/pop3d.t, run /usr/bin/perl 
> ./create-certs.perl in certs/

>       t/pop3d.t (Wstat: 0 Tests: 2 Failed: 0)
>         Parse errors: Bad plan.  You planned 0 tests but ran 2.

> It looks better after I called the create-certs script, but IMHO it
> should work as is and just skip the two tests as advertised?

Oops, yes, fix at bottom.

> After calling the create-certs script I get:
> 
>       t/pop3d.t .. 1/? Not enough arguments for PublicInbox::Daemon::run at 
> blib/script/public-inbox-pop3d line 8, near "'pop3://0.0.0.0:110')"
>       Execution of blib/script/public-inbox-pop3d aborted due to compilation 
> errors.

You need to use `prove -b' to add blib/{lib,arch} to the search
path.  Omitting -b means you're using the system-wide installed
version.

`prove -l' also works for this project for users who don't run
`make' first (uses ./lib instead of blib/...) since this project
has no XS.

> Then it hangs. I'm not fluent enough in Perl to fix that quickly myself
> and my today's time to look into public-inbox is running out, so I
> thought I let you know.

No worries, I should be online more the rest of the year :>

--------8<-------
Subject: [PATCH] t/pop3d: skip all tests if no certs are found

This test could be written with optional OpenSSL dependencies, but
it's probably not worth it since IO::Socket::SSL seems pretty
common.

Reported-by: Uwe Kleine-König <[email protected]>
Link: 
https://public-inbox.org/meta/[email protected]/
---
 t/pop3d.t | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)

diff --git a/t/pop3d.t b/t/pop3d.t
index 7248c03f..dc52b0cf 100644
--- a/t/pop3d.t
+++ b/t/pop3d.t
@@ -4,6 +4,13 @@
 use v5.12;
 use PublicInbox::TestCommon;
 use Socket qw(IPPROTO_TCP SOL_SOCKET);
+my $cert = 'certs/server-cert.pem';
+my $key = 'certs/server-key.pem';
+unless (-r $key && -r $cert) {
+       plan skip_all =>
+               "certs/ missing for $0, run $^X ./create-certs.perl in certs/";
+}
+
 # Net::POP3 is part of the standard library, but distros may split it off...
 require_mods(qw(DBD::SQLite Net::POP3 IO::Socket::SSL));
 require_git('2.6'); # for v2
@@ -44,14 +51,6 @@ my $pop3s_addr = tcp_host_port($pop3s);
 my $stls_addr = tcp_host_port($stls);
 my $plain_addr = tcp_host_port($plain);
 my $env = { PI_CONFIG => $pi_config };
-my $cert = 'certs/server-cert.pem';
-my $key = 'certs/server-key.pem';
-
-unless (-r $key && -r $cert) {
-       plan skip_all =>
-               "certs/ missing for $0, run $^X ./create-certs.perl in certs/";
-}
-
 my $old = start_script(['-pop3d', '-W0',
        "--stdout=$tmpdir/plain.out", "--stderr=$olderr" ],
        $env, { 3 => $plain });

Reply via email to