Fix GH-17408: Assertion failure Zend/zend_exceptions.c

`zend_test_create_throwing_resource` sets the exception in the `test`
call frame and unwinds to `main`. It then throws for the `resource`
variable and verifies that the exception opline is set. However, it
wasn't set in `main`, it was set at the `test` call frame and rethrown later.
The assertion is too conservative, but the end result is right, so drop
the assertion.

Closes GH-17533.

Co-authored-by: Ilija Tovilo <ilija.tovilo@me.com>
This commit is contained in:
Niels Dossche 2025-01-20 21:41:46 +01:00
parent 191e16b703
commit 5344bcca97
No known key found for this signature in database
GPG key ID: A17A7C526FE17078
3 changed files with 24 additions and 1 deletions

2
NEWS
View file

@ -12,6 +12,8 @@ PHP NEWS
. Fixed NULL arithmetic during system program execution on Windows. (cmb, . Fixed NULL arithmetic during system program execution on Windows. (cmb,
nielsdos) nielsdos)
. Fixed potential OOB when checking for trailing spaces on Windows. (cmb) . Fixed potential OOB when checking for trailing spaces on Windows. (cmb)
. Fixed bug GH-17408 (Assertion failure Zend/zend_exceptions.c).
(nielsdos, ilutov)
- DOM: - DOM:
. Fixed bug GH-17500 (Segfault with requesting nodeName on nameless doctype). . Fixed bug GH-17500 (Segfault with requesting nodeName on nameless doctype).

View file

@ -193,7 +193,6 @@ ZEND_API ZEND_COLD void zend_throw_exception_internal(zend_object *exception) /*
zend_exception_set_previous(exception, EG(exception)); zend_exception_set_previous(exception, EG(exception));
EG(exception) = exception; EG(exception) = exception;
if (previous) { if (previous) {
ZEND_ASSERT(is_handle_exception_set() && "HANDLE_EXCEPTION not set?");
return; return;
} }
} }

View file

@ -0,0 +1,22 @@
--TEST--
GH-17408 (Assertion failure Zend/zend_exceptions.c)
--EXTENSIONS--
zend_test
--FILE--
<?php
function test() {
$resource = zend_test_create_throwing_resource();
zend_test_create_throwing_resource();
}
test();
?>
--EXPECTF--
Fatal error: Uncaught Exception: Throwing resource destructor called in %s:%d
Stack trace:
#0 %s(%d): test()
#1 {main}
Next Exception: Throwing resource destructor called in %s:%d
Stack trace:
#0 {main}
thrown in %s on line %d