/** @var DeferrableUpdate[] Updates to be deferred until after request end */
private static $postSendUpdates = array();
- /** @var bool Defer updates fully even in CLI mode */
- private static $forceDeferral = false;
-
const ALL = 0; // all updates
const PRESEND = 1; // for updates that should run before flushing output buffer
const POSTSEND = 2; // for updates that should run after flushing output buffer
$queue[] = $update;
}
- if ( self::$forceDeferral ) {
- return; // do not run
- }
-
// CLI scripts may forget to periodically flush these updates,
// so try to handle that rather than OOMing and losing them entirely.
// Try to run the updates as soon as there is no current wiki transaction.
self::$preSendUpdates = array();
self::$postSendUpdates = array();
}
-
- /**
- * @note This method is intended for testing purposes
- * @param bool $value Whether to *always* defer updates, even in CLI mode
- * @since 1.27
- */
- public static function forceDeferral( $value ) {
- self::$forceDeferral = $value;
- }
}
) );
}
- protected function tearDown() {
- parent::tearDown();
- DeferredUpdates::forceDeferral( false );
- }
-
private static function baseStorePath() {
return 'mwstore://localtesting';
}
) )
);
- DeferredUpdates::forceDeferral( true );
+ $this->setMwGlobals( 'wgCommandLineMode', false );
$p = 'container/test-cont/file.txt';
$be->quickCreate( array(
);
DeferredUpdates::doUpdates();
- DeferredUpdates::forceDeferral( false );
$this->assertEquals(
'cattitude',