summaryrefslogtreecommitdiff
path: root/ext/xmlwriter
diff options
context:
space:
mode:
authorXinchen Hui <laruence@gmail.com>2019-12-25 13:18:23 +0800
committerXinchen Hui <laruence@gmail.com>2019-12-25 13:18:23 +0800
commit24ccbb00573445b0df5e940a77e7363ace3c31f3 (patch)
tree4dc58c4e7abbc3a031118cebb2bf7ca5899a1d55 /ext/xmlwriter
parente874811221c3bebb94625649d0f726d70a128265 (diff)
parentd8ad2f4695ebd6dc2d4e668d9baeac1c071791a6 (diff)
downloadphp-git-24ccbb00573445b0df5e940a77e7363ace3c31f3.tar.gz
Merge branch 'PHP-7.4'
* PHP-7.4: Fixed bug #79029 (Use After Free's in XMLReader / XMLWriter) Partial fix for bug #79029 Conflicts: ext/xmlwriter/php_xmlwriter.c
Diffstat (limited to 'ext/xmlwriter')
-rw-r--r--ext/xmlwriter/tests/bug79029.phpt32
1 files changed, 32 insertions, 0 deletions
diff --git a/ext/xmlwriter/tests/bug79029.phpt b/ext/xmlwriter/tests/bug79029.phpt
new file mode 100644
index 0000000000..f329b62756
--- /dev/null
+++ b/ext/xmlwriter/tests/bug79029.phpt
@@ -0,0 +1,32 @@
+--TEST--
+#79029 (Use After Free's in XMLReader / XMLWriter)
+--SKIPIF--
+<?php if (!extension_loaded("xmlwriter")) print "skip"; ?>
+--FILE--
+<?php
+$x = array( new XMLWriter() );
+$x[0]->openUri("bug79029.txt");
+$x[0]->startComment();
+@unlink("bug79029.txt");
+
+$x = new XMLWriter();
+$x->openUri("bug79029.txt");
+fclose(@end(get_resources()));
+@unlink("bug79029.txt");
+
+file_put_contents("bug79029.txt", "a");
+$x = new XMLReader();
+$x->open("bug79029.txt");
+fclose(@end(get_resources()));
+@unlink("bug79029.txt");
+?>
+okey
+--CLEAN--
+<?php
+@unlink("bug79029.txt");
+?>
+--EXPECTF--
+Warning: fclose(): %d is not a valid stream resource in %sbug79029.php on line %d
+
+Warning: fclose(): %d is not a valid stream resource in %sbug79029.php on line %d
+okey