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 * @licence GNU GPL v2+
29 * @author Jeroen De Dauw < jeroendedauw@gmail.com >
30 * @author Daniel Kinzler
34 * @covers PageORMTableForTesting
36 class ORMTableTest
extends MediaWikiTestCase
{
42 protected function getTableClass() {
43 return 'PageORMTableForTesting';
50 public function getTable() {
51 $class = $this->getTableClass();
53 return $class::singleton();
60 public function getRowClass() {
61 return $this->getTable()->getRowClass();
67 public function testSingleton() {
68 $class = $this->getTableClass();
70 $this->assertInstanceOf( $class, $class::singleton() );
71 $this->assertTrue( $class::singleton() === $class::singleton() );
77 public function testIgnoreErrorsOverride() {
78 $table = $this->getTable();
80 $db = $table->getReadDbConnection();
81 $db->ignoreErrors( true );
84 $table->rawSelect( "this is invalid" );
85 $this->fail( "An invalid query should trigger a DBQueryError even if ignoreErrors is enabled." );
86 } catch ( DBQueryError
$ex ) {
87 $this->assertTrue( true, "just making phpunit happy" );
90 $db->ignoreErrors( false );
95 * Dummy ORM table for testing, reading Title objects from the page table.
100 class PageORMTableForTesting
extends ORMTable
{
103 * @see ORMTable::getName
107 public function getName() {
112 * @see ORMTable::getRowClass
116 public function getRowClass() {
121 * @see ORMTable::newRow
125 public function newRow( array $data, $loadDefaults = false ) {
126 return Title
::makeTitle( $data['namespace'], $data['title'] );
130 * @see ORMTable::getFields
134 public function getFields() {
137 'namespace' => 'int',
143 * @see ORMTable::getFieldPrefix
147 protected function getFieldPrefix() {