db = $db; } /** * 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"; } $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 array $test * @param ParserTestResult $result */ function record( $test, ParserTestResult $result ) { $this->db->insert( 'testitem', [ 'ti_run' => $this->curRun, 'ti_name' => $test['desc'], 'ti_success' => $result->isSuccess() ? 1 : 0, ], __METHOD__ ); } /** * Commit transaction and clean up for result recording */ function end() { $this->db->commit( __METHOD__ ); } }