File: require.t

package info (click to toggle)
apache2 2.4.66-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 59,500 kB
  • sloc: ansic: 212,331; python: 13,830; perl: 11,307; sh: 7,258; php: 1,320; javascript: 1,314; awk: 749; makefile: 715; lex: 374; yacc: 161; xml: 2
file content (55 lines) | stat: -rw-r--r-- 1,472 bytes parent folder | download | duplicates (6)
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
use strict;
use warnings FATAL => 'all';

use Apache::Test;
use Apache::TestRequest;

#if keepalives are on, renegotiation not happen again once
#a client cert is presented.  so on test #3, the cert from #2
#will be used.  this test scenerio would never
#happen in real-life, so just disable keepalives here.
Apache::TestRequest::user_agent_keepalive(0);

my $sslrequire_oid_needed_version = '2.1.7';
my $have_sslrequire_oid = have_min_apache_version($sslrequire_oid_needed_version);

plan tests => 10, need_lwp;

Apache::TestRequest::scheme('https');

my $url = '/require/asf/index.html';

ok GET_RC($url, cert => undef) != 200;

ok GET_RC($url, cert => 'client_ok') == 200;

ok GET_RC($url, cert => 'client_revoked') != 200;

$url = '/require/snakeoil/index.html';

ok GET_RC($url, cert => 'client_ok') != 200;

ok GET_RC($url, cert => 'client_snakeoil') == 200;

ok GET_RC('/require/strcmp/index.html', cert => undef) == 200;

ok GET_RC('/require/intcmp/index.html', cert => undef) == 200;

if ($have_sslrequire_oid) {

    $url = '/require/certext/index.html';

    ok GET_RC($url, cert => undef) != 200;

    if (!have_min_apache_version("2.4.0")) { 
       skip "not backported, see 2.2.19 vote thread for analysis";
    }
    else { 
        ok GET_RC($url, cert => 'client_ok') == 200;
    }

    ok GET_RC($url, cert => 'client_snakeoil') != 200;

} else {
    skip "skipping certificate extension test (httpd < $sslrequire_oid_needed_version)" foreach (1..3);
}