85 lines
2.3 KiB
PHP
85 lines
2.3 KiB
PHP
|
|
<?php
|
||
|
|
/**
|
||
|
|
* This program is free software; you can redistribute it and/or modify
|
||
|
|
* it under the terms of the GNU General Public License as published by
|
||
|
|
* the Free Software Foundation; either version 2 of the License, or
|
||
|
|
* (at your option) any later version.
|
||
|
|
*
|
||
|
|
* This program is distributed in the hope that it will be useful,
|
||
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
|
* GNU General Public License for more details.
|
||
|
|
*
|
||
|
|
* You should have received a copy of the GNU General Public License along
|
||
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
|
* http://www.gnu.org/copyleft/gpl.html
|
||
|
|
*
|
||
|
|
* @file
|
||
|
|
* @ingroup Testing
|
||
|
|
*/
|
||
|
|
|
||
|
|
class DbTestRecorder extends DbTestPreviewer {
|
||
|
|
public $version;
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Set up result recording; insert a record for the run with the date
|
||
|
|
* and all that fun stuff
|
||
|
|
*/
|
||
|
|
function start() {
|
||
|
|
$this->db->begin( __METHOD__ );
|
||
|
|
|
||
|
|
if ( !$this->db->tableExists( 'testrun' )
|
||
|
|
|| !$this->db->tableExists( 'testitem' )
|
||
|
|
) {
|
||
|
|
print "WARNING> `testrun` table not found in database. Trying to create table.\n";
|
||
|
|
$this->db->sourceFile( $this->db->patchPath( 'patch-testrun.sql' ) );
|
||
|
|
echo "OK, resuming.\n";
|
||
|
|
}
|
||
|
|
|
||
|
|
parent::start();
|
||
|
|
|
||
|
|
$this->db->insert( 'testrun',
|
||
|
|
[
|
||
|
|
'tr_date' => $this->db->timestamp(),
|
||
|
|
'tr_mw_version' => $this->version,
|
||
|
|
'tr_php_version' => PHP_VERSION,
|
||
|
|
'tr_db_version' => $this->db->getServerVersion(),
|
||
|
|
'tr_uname' => php_uname()
|
||
|
|
],
|
||
|
|
__METHOD__ );
|
||
|
|
if ( $this->db->getType() === 'postgres' ) {
|
||
|
|
$this->curRun = $this->db->currentSequenceValue( 'testrun_id_seq' );
|
||
|
|
} else {
|
||
|
|
$this->curRun = $this->db->insertId();
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Record an individual test item's success or failure to the db
|
||
|
|
*
|
||
|
|
* @param string $test
|
||
|
|
* @param bool $result
|
||
|
|
*/
|
||
|
|
function record( $test, $subtest, $result ) {
|
||
|
|
parent::record( $test, $subtest, $result );
|
||
|
|
|
||
|
|
$this->db->insert( 'testitem',
|
||
|
|
[
|
||
|
|
'ti_run' => $this->curRun,
|
||
|
|
'ti_name' => $this->getName( $test, $subtest ),
|
||
|
|
'ti_success' => $result ? 1 : 0,
|
||
|
|
],
|
||
|
|
__METHOD__ );
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Commit transaction and clean up for result recording
|
||
|
|
*/
|
||
|
|
function end() {
|
||
|
|
$this->db->commit( __METHOD__ );
|
||
|
|
parent::end();
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|