* Add a h2 header to the begin of the results
[mediawiki.git] / maintenance / runJobs.php
blobd610b8cc32b43fdb2e76725c3093aa4d4e7fe960
1 <?php
2 /**
3 * @file
4 * @ingroup Maintenance
5 */
7 $optionsWithArgs = array( 'maxjobs', 'type' );
8 $wgUseNormalUser = true;
9 require_once( 'commandLine.inc' );
10 require_once( "$IP/includes/JobQueue.php" );
11 require_once( "$IP/includes/FakeTitle.php" );
13 if ( isset( $options['maxjobs'] ) ) {
14 $maxJobs = $options['maxjobs'];
15 } else {
16 $maxJobs = 10000;
19 $type = false;
20 if ( isset( $options['type'] ) )
21 $type = $options['type'];
23 $wgTitle = Title::newFromText( 'RunJobs.php' );
25 $dbw = wfGetDB( DB_MASTER );
26 $n = 0;
27 $conds = '';
28 if ($type !== false)
29 $conds = "job_cmd = " . $dbw->addQuotes($type);
31 while ( $dbw->selectField( 'job', 'count(*)', $conds, 'runJobs.php' ) ) {
32 $offset=0;
33 for (;;) {
34 $job = ($type == false) ?
35 Job::pop($offset)
36 : Job::pop_type($type);
38 if ($job == false)
39 break;
41 wfWaitForSlaves( 5 );
42 print wfTimestamp( TS_DB ) . " " . $job->id . " " . $job->toString() . "\n";
43 $offset=$job->id;
44 if ( !$job->run() ) {
45 print wfTimestamp( TS_DB ) . " Error: {$job->error}\n";
47 if ( $maxJobs && ++$n > $maxJobs ) {
48 break 2;