3 * Abstract class to construct tests for ORMTable deriving classes.
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
28 * @covers PageORMTableForTesting
30 * @licence GNU GPL v2+
31 * @author Jeroen De Dauw < jeroendedauw@gmail.com >
32 * @author Daniel Kinzler
35 class ORMTableTest
extends MediaWikiTestCase
{
41 protected function getTableClass() {
42 return 'PageORMTableForTesting';
49 public function getTable() {
50 $class = $this->getTableClass();
52 return $class::singleton();
59 public function getRowClass() {
60 return $this->getTable()->getRowClass();
66 public function testSingleton() {
67 $class = $this->getTableClass();
69 $this->assertInstanceOf( $class, $class::singleton() );
70 $this->assertTrue( $class::singleton() === $class::singleton() );
76 public function testIgnoreErrorsOverride() {
77 $table = $this->getTable();
79 $db = $table->getReadDbConnection();
80 $db->ignoreErrors( true );
83 $table->rawSelect( "this is invalid" );
84 $this->fail( "An invalid query should trigger a DBQueryError even if ignoreErrors is enabled." );
85 } catch ( DBQueryError
$ex ) {
86 $this->assertTrue( true, "just making phpunit happy" );
89 $db->ignoreErrors( false );
94 * Dummy ORM table for testing, reading Title objects from the page table.
99 class PageORMTableForTesting
extends ORMTable
{
101 public function __construct() {
102 $this->fieldPrefix
= 'page_';
106 * @see ORMTable::getName
110 public function getName() {
115 * @see ORMTable::getRowClass
119 public function getRowClass() {
124 * @see ORMTable::newRow
128 public function newRow( array $data, $loadDefaults = false ) {
129 return Title
::makeTitle( $data['namespace'], $data['title'] );
133 * @see ORMTable::getFields
137 public function getFields() {
140 'namespace' => 'int',