wiki.techinc.nl/tests/phpunit/includes/HooksTest.php
daniel 503ce75e27 Fix behavior of Hooks class.
Until now, Hooks::run() would execute hooks registered via $wgHooks, but
Hooks:isRegistered() would not consider them and Hooks::getHandlers() would
not return them. That is inconsistent and misleading. This change aims to
make the methods of the Hooks class behave consistently, and allows them
to be used as a generic way of interacting with hooks.

Change-Id: I39bd5de2bc8ccbe8df729446363960af9d29b0be
2012-10-08 13:45:58 +02:00

137 lines
3.6 KiB
PHP

<?php
class HooksTest extends MediaWikiTestCase {
public function testOldStyleHooks() {
$foo = 'Foo';
$bar = 'Bar';
$i = new NothingClass();
global $wgHooks;
$wgHooks['MediaWikiHooksTest001'][] = array( $i, 'someNonStatic' );
wfRunHooks( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'fOO', $foo, 'Standard method' );
$foo = 'Foo';
$wgHooks['MediaWikiHooksTest001'][] = $i;
wfRunHooks( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'foo', $foo, 'onEventName style' );
$foo = 'Foo';
$wgHooks['MediaWikiHooksTest001'][] = array( $i, 'someNonStaticWithData', 'baz' );
wfRunHooks( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'baz', $foo, 'Data included' );
$foo = 'Foo';
$wgHooks['MediaWikiHooksTest001'][] = array( $i, 'someStatic' );
wfRunHooks( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'bah', $foo, 'Standard static method' );
//$foo = 'Foo';
unset( $wgHooks['MediaWikiHooksTest001'] );
}
public function testNewStyleHooks() {
$foo = 'Foo';
$bar = 'Bar';
$i = new NothingClass();
Hooks::register( 'MediaWikiHooksTest001', array( $i, 'someNonStatic' ) );
Hooks::run( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'fOO', $foo, 'Standard method' );
$foo = 'Foo';
Hooks::register( 'MediaWikiHooksTest001', $i );
Hooks::run( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'foo', $foo, 'onEventName style' );
$foo = 'Foo';
Hooks::register( 'MediaWikiHooksTest001', array( $i, 'someNonStaticWithData', 'baz' ) );
Hooks::run( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'baz', $foo, 'Data included' );
$foo = 'Foo';
Hooks::register( 'MediaWikiHooksTest001', array( $i, 'someStatic' ) );
Hooks::run( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 'bah', $foo, 'Standard static method' );
$foo = 'Foo';
Hooks::clear( 'MediaWikiHooksTest001' );
}
public function testNewStyleHookInteraction() {
global $wgHooks;
$a = new NothingClass();
$b = new NothingClass();
// make sure to start with a clean slate
Hooks::clear( 'MediaWikiHooksTest001' );
unset( $wgHooks['MediaWikiHooksTest001'] );
$wgHooks['MediaWikiHooksTest001'][] = $a;
$this->assertTrue( Hooks::isRegistered( 'MediaWikiHooksTest001' ), 'Hook registered via $wgHooks should be noticed by Hooks::isRegistered' );
Hooks::register( 'MediaWikiHooksTest001', $b );
$this->assertEquals( 2, count( Hooks::getHandlers( 'MediaWikiHooksTest001' ) ), 'Hooks::getHandlers() should return hooks registered via wgHooks as well as Hooks::register' );
$foo = 'quux';
$bar = 'qaax';
Hooks::run( 'MediaWikiHooksTest001', array( &$foo, &$bar ) );
$this->assertEquals( 1, $a->calls, 'Hooks::run() should run hooks registered via wgHooks as well as Hooks::register' );
$this->assertEquals( 1, $b->calls, 'Hooks::run() should run hooks registered via wgHooks as well as Hooks::register' );
// clean up
Hooks::clear( 'MediaWikiHooksTest001' );
unset( $wgHooks['MediaWikiHooksTest001'] );
}
}
class NothingClass {
public $calls = 0;
static public function someStatic( &$foo, &$bar ) {
$foo = 'bah';
return true;
}
public function someNonStatic( &$foo, &$bar ) {
$this->calls++;
$foo = 'fOO';
$bar = 'bAR';
return true;
}
public function onMediaWikiHooksTest001( &$foo, &$bar ) {
$this->calls++;
$foo = 'foo';
return true;
}
public function someNonStaticWithData( $foo, &$bar ) {
$this->calls++;
$bar = $foo;
return true;
}
}