bug48203_multi.phpt 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. --TEST--
  2. Variation of bug #48203 with curl_multi_exec (Crash when file pointers passed to curl are closed before calling curl_multi_exec)
  3. --EXTENSIONS--
  4. curl
  5. --FILE--
  6. <?php
  7. include 'server.inc';
  8. function checkForClosedFilePointer($target_url, $curl_option, $description) {
  9. $fp = fopen(__DIR__ . '/bug48203.tmp', 'w');
  10. $ch1 = curl_init();
  11. $ch2 = curl_init();
  12. $options = array(
  13. CURLOPT_RETURNTRANSFER => 1,
  14. $curl_option => $fp,
  15. CURLOPT_URL => $target_url,
  16. );
  17. // we also need to set CURLOPT_VERBOSE to test CURLOPT_STDERR properly
  18. if (CURLOPT_STDERR == $curl_option) {
  19. $options[CURLOPT_VERBOSE] = 1;
  20. }
  21. if (CURLOPT_INFILE == $curl_option) {
  22. $options[CURLOPT_UPLOAD] = 1;
  23. }
  24. curl_setopt_array($ch1, $options);
  25. curl_setopt_array($ch2, $options);
  26. fclose($fp); // <-- premature close of $fp caused a crash!
  27. $mh = curl_multi_init();
  28. curl_multi_add_handle($mh, $ch1);
  29. curl_multi_add_handle($mh, $ch2);
  30. $active = 0;
  31. do {
  32. curl_multi_exec($mh, $active);
  33. } while ($active > 0);
  34. curl_multi_remove_handle($mh, $ch1);
  35. curl_multi_remove_handle($mh, $ch2);
  36. curl_multi_close($mh);
  37. // Force curl to output results
  38. fflush(STDERR);
  39. fflush(STDOUT);
  40. echo "Ok for $description\n";
  41. }
  42. $options_to_check = array(
  43. "CURLOPT_STDERR", "CURLOPT_WRITEHEADER", "CURLOPT_FILE", "CURLOPT_INFILE"
  44. );
  45. $target_url = curl_cli_server_start();
  46. foreach($options_to_check as $option) {
  47. checkForClosedFilePointer($target_url, constant($option), $option);
  48. }
  49. ?>
  50. --CLEAN--
  51. <?php @unlink(__DIR__ . '/bug48203.tmp'); ?>
  52. --EXPECTF--
  53. Warning: curl_multi_add_handle(): CURLOPT_STDERR resource has gone away, resetting to stderr in %s on line %d
  54. %A
  55. Warning: curl_multi_add_handle(): CURLOPT_STDERR resource has gone away, resetting to stderr in %s on line %d
  56. %A
  57. Ok for CURLOPT_STDERR
  58. Warning: curl_multi_add_handle(): CURLOPT_WRITEHEADER resource has gone away, resetting to default in %s on line %d
  59. Warning: curl_multi_add_handle(): CURLOPT_WRITEHEADER resource has gone away, resetting to default in %s on line %d
  60. Ok for CURLOPT_WRITEHEADER
  61. Warning: curl_multi_add_handle(): CURLOPT_FILE resource has gone away, resetting to default in %s on line %d
  62. Warning: curl_multi_add_handle(): CURLOPT_FILE resource has gone away, resetting to default in %s on line %d
  63. %AOk for CURLOPT_FILE
  64. Warning: curl_multi_add_handle(): CURLOPT_INFILE resource has gone away, resetting to default in %s on line %d
  65. Warning: curl_multi_add_handle(): CURLOPT_INFILE resource has gone away, resetting to default in %s on line %d
  66. Ok for CURLOPT_INFILE