bug48203_multi.phpt 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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. --SKIPIF--
  4. <?php
  5. include 'skipif.inc';
  6. ?>
  7. --FILE--
  8. <?php
  9. include 'server.inc';
  10. function checkForClosedFilePointer($curl_option, $description) {
  11. $fp = fopen(dirname(__FILE__) . '/bug48203.tmp', 'w');
  12. $ch1 = curl_init();
  13. $ch2 = curl_init();
  14. $options = array(
  15. CURLOPT_RETURNTRANSFER => 1,
  16. $curl_option => $fp,
  17. CURLOPT_URL => curl_cli_server_start()
  18. );
  19. // we also need to set CURLOPT_VERBOSE to test CURLOPT_STDERR properly
  20. if (CURLOPT_STDERR == $curl_option) {
  21. $options[CURLOPT_VERBOSE] = 1;
  22. }
  23. if (CURLOPT_INFILE == $curl_option) {
  24. $options[CURLOPT_UPLOAD] = 1;
  25. }
  26. curl_setopt_array($ch1, $options);
  27. curl_setopt_array($ch2, $options);
  28. fclose($fp); // <-- premature close of $fp caused a crash!
  29. $mh = curl_multi_init();
  30. curl_multi_add_handle($mh, $ch1);
  31. curl_multi_add_handle($mh, $ch2);
  32. $active = 0;
  33. do {
  34. curl_multi_exec($mh, $active);
  35. } while ($active > 0);
  36. curl_multi_remove_handle($mh, $ch1);
  37. curl_multi_remove_handle($mh, $ch2);
  38. curl_multi_close($mh);
  39. echo "Ok for $description\n";
  40. }
  41. $options_to_check = array(
  42. "CURLOPT_STDERR", "CURLOPT_WRITEHEADER", "CURLOPT_FILE", "CURLOPT_INFILE"
  43. );
  44. foreach($options_to_check as $option) {
  45. checkForClosedFilePointer(constant($option), $option);
  46. }
  47. ?>
  48. --CLEAN--
  49. <?php @unlink(dirname(__FILE__) . '/bug48203.tmp'); ?>
  50. --EXPECTF--
  51. Warning: curl_multi_exec(): CURLOPT_STDERR resource has gone away, resetting to stderr in %sbug48203_multi.php on line 36
  52. Warning: curl_multi_exec(): CURLOPT_STDERR resource has gone away, resetting to stderr in %sbug48203_multi.php on line 36
  53. %A
  54. Ok for CURLOPT_STDERR
  55. %A
  56. Warning: curl_multi_exec(): CURLOPT_WRITEHEADER resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  57. Warning: curl_multi_exec(): CURLOPT_WRITEHEADER resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  58. Ok for CURLOPT_WRITEHEADER
  59. Warning: curl_multi_exec(): CURLOPT_FILE resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  60. Warning: curl_multi_exec(): CURLOPT_FILE resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  61. %AOk for CURLOPT_FILE
  62. Warning: curl_multi_exec(): CURLOPT_INFILE resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  63. Warning: curl_multi_exec(): CURLOPT_INFILE resource has gone away, resetting to default in %sbug48203_multi.php on line 36
  64. Ok for CURLOPT_INFILE