From efeda8a5b4b2ad1921f78884b9737b388f3e5575 Mon Sep 17 00:00:00 2001 From: Alex Bouma Date: Sat, 6 Oct 2018 15:05:58 +0200 Subject: [PATCH 1/3] Do not return error id if we know we did not send the error --- lib/Raven/Client.php | 15 +++++++++------ test/Raven/Tests/ClientTest.php | 19 +++++++++++++++++-- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/lib/Raven/Client.php b/lib/Raven/Client.php index 971a23340..2f39949c3 100644 --- a/lib/Raven/Client.php +++ b/lib/Raven/Client.php @@ -934,7 +934,11 @@ public function capture($data, $stack = null, $vars = null) $this->process($data); if (!$this->store_errors_for_bulk_send) { - $this->send($data); + if ($this->send($data) === false) { + $this->_last_event_id = null; + + return null; + } } else { $this->_pending_events[] = $data; } @@ -1032,21 +1036,20 @@ public function send(&$data) && call_user_func_array($this->send_callback, array(&$data)) === false ) { // if send_callback returns false, end native send - return; + return false; } if (!$this->server) { - return; + return false; } if ($this->transport) { - call_user_func($this->transport, $this, $data); - return; + return call_user_func($this->transport, $this, $data); } // should this event be sampled? if (rand(1, 100) / 100.0 > $this->sample_rate) { - return; + return false; } $message = $this->encode($data); diff --git a/test/Raven/Tests/ClientTest.php b/test/Raven/Tests/ClientTest.php index 6d68467eb..0c128ce55 100644 --- a/test/Raven/Tests/ClientTest.php +++ b/test/Raven/Tests/ClientTest.php @@ -38,9 +38,14 @@ public function send(&$data) { if (is_callable($this->send_callback) && call_user_func_array($this->send_callback, array(&$data)) === false) { // if send_callback returns falsely, end native send - return; + return false; } + $this->__sent_events[] = $data; + + if (!$this->server) { + return false; + } } public static function is_http_request() @@ -1337,11 +1342,21 @@ public function testCaptureLastError() */ public function testGetLastEventID() { - $client = new Dummy_Raven_Client(); + $client = new Dummy_Raven_Client('http://public:secret@example.com/1'); $client->capture(array('message' => 'test', 'event_id' => 'abc')); $this->assertEquals('abc', $client->getLastEventID()); } + /** + * @covers Raven_Client::getLastEventID + */ + public function testGetLastEventIDWithoutServer() + { + $client = new Dummy_Raven_Client(); + $client->capture(array('message' => 'test', 'event_id' => 'abc')); + $this->assertEquals(null, $client->getLastEventID()); + } + /** * @covers Raven_Client::setTransport */ From f824156bc5416768ae818f8e9cd2a1ab2df5293e Mon Sep 17 00:00:00 2001 From: Alex Bouma Date: Sat, 6 Oct 2018 15:13:18 +0200 Subject: [PATCH 2/3] Add test for setting event ID to null if no event was sent on the last capture call --- test/Raven/Tests/ClientTest.php | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/test/Raven/Tests/ClientTest.php b/test/Raven/Tests/ClientTest.php index 0c128ce55..0f528a01b 100644 --- a/test/Raven/Tests/ClientTest.php +++ b/test/Raven/Tests/ClientTest.php @@ -1357,6 +1357,21 @@ public function testGetLastEventIDWithoutServer() $this->assertEquals(null, $client->getLastEventID()); } + /** + * @covers Raven_Client::getLastEventID + */ + public function testGetLastEventIDWithoutServerOverwritesEarlierEvents() + { + $client = new Dummy_Raven_Client('http://public:secret@example.com/1'); + $client->capture(array('message' => 'test', 'event_id' => 'abc')); + $this->assertEquals('abc', $client->getLastEventID()); + + $client->server = null; + + $client->capture(array('message' => 'test', 'event_id' => 'abc')); + $this->assertEquals(null, $client->getLastEventID()); + } + /** * @covers Raven_Client::setTransport */ From a5f1c7d466f85702de78523c78fa6d340db58397 Mon Sep 17 00:00:00 2001 From: Alex Bouma Date: Sat, 6 Oct 2018 15:20:56 +0200 Subject: [PATCH 3/3] Fix tests using error id to see if events were sent --- test/DummyRaven/Dummy_Raven_Client.php | 85 +++++++++++++++++++ test/Raven/Tests/ClientTest.php | 84 ------------------ .../phpt/fatal_reported_twice_regression.phpt | 3 +- test/bootstrap.php | 2 + 4 files changed, 89 insertions(+), 85 deletions(-) create mode 100644 test/DummyRaven/Dummy_Raven_Client.php diff --git a/test/DummyRaven/Dummy_Raven_Client.php b/test/DummyRaven/Dummy_Raven_Client.php new file mode 100644 index 000000000..7d3e56823 --- /dev/null +++ b/test/DummyRaven/Dummy_Raven_Client.php @@ -0,0 +1,85 @@ +__sent_events; + } + + public function send(&$data) + { + if (is_callable($this->send_callback) && call_user_func_array($this->send_callback, array(&$data)) === false) { + // if send_callback returns falsely, end native send + return false; + } + + $this->__sent_events[] = $data; + + if (!$this->server) { + return false; + } + } + + public static function is_http_request() + { + return true; + } + + public static function get_auth_header($timestamp, $client, $api_key, $secret_key) + { + return parent::get_auth_header($timestamp, $client, $api_key, $secret_key); + } + + public function get_http_data() + { + return parent::get_http_data(); + } + + public function get_user_data() + { + return parent::get_user_data(); + } + + public function setInputStream($input) + { + static::$input_stream = isset($_SERVER['CONTENT_TYPE']) ? $input : false; + } + + protected static function getInputStream() + { + return static::$input_stream ? static::$input_stream : file_get_contents('php://input'); + } + + public function buildCurlCommand($url, $data, $headers) + { + return parent::buildCurlCommand($url, $data, $headers); + } + + // short circuit breadcrumbs + public function registerDefaultBreadcrumbHandlers() + { + $this->dummy_breadcrumbs_handlers_has_set = true; + } + + public function registerShutdownFunction() + { + $this->dummy_shutdown_handlers_has_set = true; + } + + /** + * Expose the current url method to test it + * + * @return string + */ + public function test_get_current_url() + { + return $this->get_current_url(); + } +} diff --git a/test/Raven/Tests/ClientTest.php b/test/Raven/Tests/ClientTest.php index 0f528a01b..4908c2bd2 100644 --- a/test/Raven/Tests/ClientTest.php +++ b/test/Raven/Tests/ClientTest.php @@ -21,90 +21,6 @@ function invalid_encoding() } -// XXX: Is there a better way to stub the client? -class Dummy_Raven_Client extends Raven_Client -{ - private $__sent_events = array(); - private static $input_stream; - public $dummy_breadcrumbs_handlers_has_set = false; - public $dummy_shutdown_handlers_has_set = false; - - public function getSentEvents() - { - return $this->__sent_events; - } - - public function send(&$data) - { - if (is_callable($this->send_callback) && call_user_func_array($this->send_callback, array(&$data)) === false) { - // if send_callback returns falsely, end native send - return false; - } - - $this->__sent_events[] = $data; - - if (!$this->server) { - return false; - } - } - - public static function is_http_request() - { - return true; - } - - public static function get_auth_header($timestamp, $client, $api_key, $secret_key) - { - return parent::get_auth_header($timestamp, $client, $api_key, $secret_key); - } - - public function get_http_data() - { - return parent::get_http_data(); - } - - public function get_user_data() - { - return parent::get_user_data(); - } - - public function setInputStream($input) - { - static::$input_stream = isset($_SERVER['CONTENT_TYPE']) ? $input : false; - } - - protected static function getInputStream() - { - return static::$input_stream ? static::$input_stream : file_get_contents('php://input'); - } - - public function buildCurlCommand($url, $data, $headers) - { - return parent::buildCurlCommand($url, $data, $headers); - } - - // short circuit breadcrumbs - public function registerDefaultBreadcrumbHandlers() - { - $this->dummy_breadcrumbs_handlers_has_set = true; - } - - public function registerShutdownFunction() - { - $this->dummy_shutdown_handlers_has_set = true; - } - - /** - * Expose the current url method to test it - * - * @return string - */ - public function test_get_current_url() - { - return $this->get_current_url(); - } -} - class Dummy_Raven_Client_With_Overrided_Direct_Send extends Raven_Client { public $_send_http_asynchronous_curl_exec_called = false; diff --git a/test/Raven/phpt/fatal_reported_twice_regression.phpt b/test/Raven/phpt/fatal_reported_twice_regression.phpt index 1ff56ab2a..37f73f9eb 100644 --- a/test/Raven/phpt/fatal_reported_twice_regression.phpt +++ b/test/Raven/phpt/fatal_reported_twice_regression.phpt @@ -8,9 +8,10 @@ while (!file_exists($vendor.'/vendor')) { $vendor = dirname($vendor); } require $vendor.'/test/bootstrap.php'; +require_once __DIR__.'/../../DummyRaven/Dummy_Raven_Client.php'; error_reporting(E_ALL); -$client = new \Raven_Client(); +$client = new \Dummy_Raven_Client('http://public:secret@example.com/1'); set_error_handler(function () use ($client) { echo 'Previous error handler is called' . PHP_EOL; echo 'Error is ' . ($client->getLastEventID() !== null ? 'reported correctly' : 'NOT reported'); diff --git a/test/bootstrap.php b/test/bootstrap.php index 1544bc388..ee4c25ed9 100644 --- a/test/bootstrap.php +++ b/test/bootstrap.php @@ -15,3 +15,5 @@ require_once dirname(__FILE__).'/../lib/Raven/Autoloader.php'; Raven_Autoloader::register(); + +require_once dirname(__FILE__).'/DummyRaven/Dummy_Raven_Client.php';