summaryrefslogtreecommitdiff
path: root/_test
diff options
context:
space:
mode:
authorMichael Hamann <michael@content-space.de>2012-06-30 13:37:23 +0200
committerMichael Hamann <michael@content-space.de>2012-06-30 13:38:27 +0200
commit772c924913365ea9be90e667f6d06cdcef3ab4ec (patch)
tree8982a6142ff3ef4aea1776aab334fd1a6a010348 /_test
parent430db121ade4ad520e7c2e0518bc0fb4fd969484 (diff)
downloadrpg-772c924913365ea9be90e667f6d06cdcef3ab4ec.tar.gz
rpg-772c924913365ea9be90e667f6d06cdcef3ab4ec.tar.bz2
Add a test case for nested events, this tests 8cb3706df5ad54c654bffb76a69ac0ca1006521e
Diffstat (limited to '_test')
-rw-r--r--_test/tests/inc/events_nested.test.php36
1 files changed, 36 insertions, 0 deletions
diff --git a/_test/tests/inc/events_nested.test.php b/_test/tests/inc/events_nested.test.php
new file mode 100644
index 000000000..fe5e395bb
--- /dev/null
+++ b/_test/tests/inc/events_nested.test.php
@@ -0,0 +1,36 @@
+<?php
+
+/**
+ * This tests if event handlers can trigger the same event again.
+ * This is used by plugins that modify cache handling and use metadata
+ * for checking cache validity which triggers another cache use event.
+ */
+class events_nested_test extends DokuWikiTest {
+ function test_nested_events() {
+ global $EVENT_HANDLER;
+ $firstcount = 0;
+ $secondcount = 0;
+
+ $EVENT_HANDLER->register_hook('NESTED_EVENT', 'BEFORE', null,
+ function() use (&$firstcount) {
+ $firstcount++;
+ if ($firstcount == 1) {
+ $param = array();
+ trigger_event('NESTED_EVENT', $param);
+ }
+ }
+ );
+
+ $EVENT_HANDLER->register_hook('NESTED_EVENT', 'BEFORE', null,
+ function() use (&$secondcount) {
+ $secondcount++;
+ }
+ );
+
+ $param = array();
+ trigger_event('NESTED_EVENT', $param);
+
+ $this->assertEquals(2, $firstcount);
+ $this->assertEquals(2, $secondcount);
+ }
+}