bug54992.phpt 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. --TEST--
  2. Bug #54992: Stream not closed and error not returned when SSL CN_match fails
  3. --EXTENSIONS--
  4. openssl
  5. --SKIPIF--
  6. <?php
  7. if (!function_exists("proc_open")) die("skip no proc_open");
  8. ?>
  9. --FILE--
  10. <?php
  11. $certFile = __DIR__ . DIRECTORY_SEPARATOR . 'bug54992.pem.tmp';
  12. $cacertFile = __DIR__ . DIRECTORY_SEPARATOR . 'bug54992-ca.pem.tmp';
  13. $serverCode = <<<'CODE'
  14. $serverUri = "ssl://127.0.0.1:64321";
  15. $serverFlags = STREAM_SERVER_BIND | STREAM_SERVER_LISTEN;
  16. $serverCtx = stream_context_create(['ssl' => [
  17. 'local_cert' => '%s',
  18. ]]);
  19. $server = stream_socket_server($serverUri, $errno, $errstr, $serverFlags, $serverCtx);
  20. phpt_notify();
  21. @stream_socket_accept($server, 1);
  22. CODE;
  23. $serverCode = sprintf($serverCode, $certFile);
  24. $peerName = 'bug54992_actual_peer_name';
  25. $wrongPeerName = 'bug54992_expected_peer_name';
  26. $clientCode = <<<'CODE'
  27. $serverUri = "ssl://127.0.0.1:64321";
  28. $clientFlags = STREAM_CLIENT_CONNECT;
  29. $clientCtx = stream_context_create(['ssl' => [
  30. 'verify_peer' => true,
  31. 'cafile' => '%s',
  32. 'peer_name' => '%s',
  33. ]]);
  34. phpt_wait();
  35. $client = stream_socket_client($serverUri, $errno, $errstr, 2, $clientFlags, $clientCtx);
  36. var_dump($client);
  37. CODE;
  38. $clientCode = sprintf($clientCode, $cacertFile, $wrongPeerName);
  39. include 'CertificateGenerator.inc';
  40. $certificateGenerator = new CertificateGenerator();
  41. $certificateGenerator->saveCaCert($cacertFile);
  42. $certificateGenerator->saveNewCertAsFileWithKey($peerName, $certFile);
  43. include 'ServerClientTestCase.inc';
  44. ServerClientTestCase::getInstance()->run($clientCode, $serverCode);
  45. ?>
  46. --CLEAN--
  47. <?php
  48. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'bug54992.pem.tmp');
  49. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'bug54992-ca.pem.tmp');
  50. ?>
  51. --EXPECTF--
  52. Warning: stream_socket_client(): Peer certificate CN=`bug54992_actual_peer_name' did not match expected CN=`bug54992_expected_peer_name' in %s on line %d
  53. Warning: stream_socket_client(): Failed to enable crypto in %s on line %d
  54. Warning: stream_socket_client(): Unable to connect to ssl://127.0.0.1:64321 (Unknown error) in %s on line %d
  55. bool(false)