File: 30_error.t

package info (click to toggle)
libnet-ssleay-perl 1.36-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 940 kB
  • ctags: 798
  • sloc: perl: 3,668; ansic: 2,711; makefile: 7
file content (68 lines) | stat: -rw-r--r-- 1,873 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/usr/bin/perl

use strict;
use warnings;
use Test::More;

eval "use Test::Exception; use Test::Warn; use Test::NoWarnings; 1;";
plan skip_all => 'Requires Test::Exception, Test::Warn and Test::NoWarnings' if $@;
plan tests => 11;

use Net::SSLeay;
Net::SSLeay::load_error_strings();

{
    throws_ok(sub {
            Net::SSLeay::die_now('test')
    }, qr/^$$: test\n$/, 'die_now dies without errors');

    lives_ok(sub {
            Net::SSLeay::die_if_ssl_error('test');
    }, 'die_if_ssl_error lives without errors');

    put_err();
    throws_ok(sub {
            Net::SSLeay::die_now('test');
    }, qr/^$$: test\n$/, 'die_now dies with errors');

    put_err();
    throws_ok(sub {
            Net::SSLeay::die_if_ssl_error('test');
    }, qr/^$$: test\n$/, 'die_if_ssl_error dies with errors');
}

{
    local $Net::SSLeay::trace = 1;

    throws_ok(sub {
            Net::SSLeay::die_now('foo');
    }, qr/^$$: foo\n$/, 'die_now dies without arrors and with trace');

    lives_ok(sub {
            Net::SSLeay::die_if_ssl_error('foo');
    }, 'die_if_ssl_error lives without errors and with trace');

    put_err();
    warning_like(sub {
            throws_ok(sub {
                    Net::SSLeay::die_now('foo');
            }, qr/^$$: foo\n$/, 'die_now dies with errors and trace');
    }, qr/^foo $$: 1 - error:2006d080/i, 'die_now raises warnings about the occured error when tracing');

    put_err();
    warning_like(sub {
            throws_ok(sub {
                Net::SSLeay::die_if_ssl_error('foo');
            }, qr/^$$: foo\n$/, 'die_if_ssl_error dies with errors and trace');
    }, qr/^foo $$: 1 - error:2006d080/i, 'die_if_ssl_error raises warnings about the occured error when tracing');
}

sub put_err {
    Net::SSLeay::ERR_put_error(
        32, #lib
       109, #func
       128, #reason
         1, #file
         1, #line
    );
}