aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorJoas Schilling <nickvergessen@gmx.de>2015-01-09 18:39:11 +0100
committerJoas Schilling <nickvergessen@gmx.de>2015-01-09 18:39:11 +0100
commitd9bdd05c8065eecc99c55b827a8af575fcb08f1b (patch)
treee2ca1fe517d6ba1f98ca6149fe63eca97cfecb29 /tests
parent3350df131fec7a2a558ec0d1c0ef714fbfa4fa35 (diff)
parent8a9c2c055c7fbc199bad3e6fbfb0235a910b87e2 (diff)
downloadforums-d9bdd05c8065eecc99c55b827a8af575fcb08f1b.tar
forums-d9bdd05c8065eecc99c55b827a8af575fcb08f1b.tar.gz
forums-d9bdd05c8065eecc99c55b827a8af575fcb08f1b.tar.bz2
forums-d9bdd05c8065eecc99c55b827a8af575fcb08f1b.tar.xz
forums-d9bdd05c8065eecc99c55b827a8af575fcb08f1b.zip
Merge pull request #3128 from omniError/ticket/13306
[ticket/13306] add error level to collector
Diffstat (limited to 'tests')
-rw-r--r--tests/error_collector_test.php30
1 files changed, 29 insertions, 1 deletions
diff --git a/tests/error_collector_test.php b/tests/error_collector_test.php
index 1d8ef367f5..b92c4fa6bb 100644
--- a/tests/error_collector_test.php
+++ b/tests/error_collector_test.php
@@ -17,7 +17,7 @@ class phpbb_error_collector_test extends phpbb_test_case
{
public function test_collection()
{
- $collector = new \phpbb\error_collector;
+ $collector = new \phpbb\error_collector(E_ALL | E_STRICT); // php set_error_handler() default
$collector->install();
// Cause a warning
@@ -35,4 +35,32 @@ class phpbb_error_collector_test extends phpbb_test_case
$this->assertStringStartsWith('Errno 2: Division by zero at ', $error_contents);
$this->assertStringEndsWith(" line $line", $error_contents);
}
+
+ public function test_collection_with_mask()
+ {
+ $collector = new \phpbb\error_collector(E_ALL & ~E_NOTICE); // not collecting notices
+ $collector->install();
+
+ // Cause a warning
+ 1/0; $line = __LINE__;
+
+ // Cause a notice
+ $array = array('ITEM' => 'value');
+ $value = $array[ITEM]; $line2 = __LINE__;
+
+ $collector->uninstall();
+
+ // The notice should not be collected
+ $this->assertEmpty($collector->errors[1]);
+
+ list($errno, $msg_text, $errfile, $errline) = $collector->errors[0];
+ $error_contents = $collector->format_errors();
+
+ $this->assertEquals($errno, 2);
+
+ // Unfortunately $error_contents will contain the full path here,
+ // because the tests directory is outside of phpbb root path.
+ $this->assertStringStartsWith('Errno 2: Division by zero at ', $error_contents);
+ $this->assertStringEndsWith(" line $line", $error_contents);
+ }
}