@@ -7,11 +7,14 @@ if (!function_exists("proc_open")) die("skip no proc_open");
7
7
?>
8
8
--FILE--
9
9
<?php
10
+ $ certFile = __DIR__ . DIRECTORY_SEPARATOR . 'bug65729.pem.tmp ' ;
11
+ $ cacertFile = __DIR__ . DIRECTORY_SEPARATOR . 'bug65729-ca.pem.tmp ' ;
12
+
10
13
$ serverCode = <<<'CODE'
11
14
$serverUri = "ssl://127.0.0.1:64321";
12
15
$serverFlags = STREAM_SERVER_BIND | STREAM_SERVER_LISTEN;
13
16
$serverCtx = stream_context_create(['ssl' => [
14
- 'local_cert' => __DIR__ . '/bug65729.pem '
17
+ 'local_cert' => '%s '
15
18
]]);
16
19
17
20
$server = stream_socket_server($serverUri, $errno, $errstr, $serverFlags, $serverCtx);
@@ -22,6 +25,7 @@ $serverCode = <<<'CODE'
22
25
@stream_socket_accept($server, 1);
23
26
}
24
27
CODE;
28
+ $ serverCode = sprintf ($ serverCode , $ certFile );
25
29
26
30
$ clientCode = <<<'CODE'
27
31
$serverUri = "ssl://127.0.0.1:64321";
@@ -32,18 +36,29 @@ $clientCode = <<<'CODE'
32
36
$expected_names = ['foo.test.com.sg', 'foo.test.com', 'FOO.TEST.COM', 'foo.bar.test.com'];
33
37
foreach ($expected_names as $expected_name) {
34
38
$clientCtx = stream_context_create(['ssl' => [
35
- 'verify_peer' => true,
36
- 'allow_self_signed' => true,
39
+ 'verify_peer' => true,
37
40
'peer_name' => $expected_name,
41
+ 'cafile' => '%s',
38
42
]]);
39
43
40
44
var_dump(stream_socket_client($serverUri, $errno, $errstr, 2, $clientFlags, $clientCtx));
41
45
}
42
46
CODE;
47
+ $ clientCode = sprintf ($ clientCode , $ cacertFile );
48
+
49
+ include 'CertificateGenerator.inc ' ;
50
+ $ certificateGenerator = new CertificateGenerator ();
51
+ $ certificateGenerator ->saveCaCert ($ cacertFile );
52
+ $ certificateGenerator ->saveNewCertAsFileWithKey ('*.test.com ' , $ certFile );
43
53
44
54
include 'ServerClientTestCase.inc ' ;
45
55
ServerClientTestCase::getInstance ()->run ($ clientCode , $ serverCode );
46
56
?>
57
+ --CLEAN--
58
+ <?php
59
+ @unlink (__DIR__ . DIRECTORY_SEPARATOR . 'bug65729.pem.tmp ' );
60
+ @unlink (__DIR__ . DIRECTORY_SEPARATOR . 'bug65729-ca.pem.tmp ' );
61
+ ?>
47
62
--EXPECTF--
48
63
Warning: stream_socket_client(): Peer certificate CN=`*.test.com' did not match expected CN=`foo.test.com.sg' in %s on line %d
49
64
0 commit comments