4 * @group ContentHandler
6 * ^--- important, causes temporary tables to be used instead of the real database
8 class RevisionTestContentHandlerUseDB
extends RevisionStorageTest
{
10 protected function setUp() {
11 $this->setMwGlobals( 'wgContentHandlerUseDB', false );
13 $dbw = wfGetDB( DB_MASTER
);
15 $page_table = $dbw->tableName( 'page' );
16 $revision_table = $dbw->tableName( 'revision' );
17 $archive_table = $dbw->tableName( 'archive' );
19 if ( $dbw->fieldExists( $page_table, 'page_content_model' ) ) {
20 $dbw->query( "alter table $page_table drop column page_content_model" );
21 $dbw->query( "alter table $revision_table drop column rev_content_model" );
22 $dbw->query( "alter table $revision_table drop column rev_content_format" );
23 $dbw->query( "alter table $archive_table drop column ar_content_model" );
24 $dbw->query( "alter table $archive_table drop column ar_content_format" );
31 * @covers Revision::selectFields
33 public function testSelectFields() {
34 $fields = Revision
::selectFields();
36 $this->assertTrue( in_array( 'rev_id', $fields ), 'missing rev_id in list of fields' );
37 $this->assertTrue( in_array( 'rev_page', $fields ), 'missing rev_page in list of fields' );
39 in_array( 'rev_timestamp', $fields ),
40 'missing rev_timestamp in list of fields'
42 $this->assertTrue( in_array( 'rev_user', $fields ), 'missing rev_user in list of fields' );
45 in_array( 'rev_content_model', $fields ),
46 'missing rev_content_model in list of fields'
49 in_array( 'rev_content_format', $fields ),
50 'missing rev_content_format in list of fields'
55 * @covers Revision::getContentModel
57 public function testGetContentModel() {
59 $this->makeRevision( [ 'text' => 'hello hello.',
60 'content_model' => CONTENT_MODEL_JAVASCRIPT
] );
62 $this->fail( "Creating JavaScript content on a wikitext page should fail with "
63 . "\$wgContentHandlerUseDB disabled" );
64 } catch ( MWException
$ex ) {
65 $this->assertTrue( true ); // ok
70 * @covers Revision::getContentFormat
72 public function testGetContentFormat() {
74 // @todo change this to test failure on using a non-standard (but supported) format
75 // for a content model supported in the given location. As of 1.21, there are
76 // no alternative formats for any of the standard content models that could be
77 // used for this though.
79 $this->makeRevision( [ 'text' => 'hello hello.',
80 'content_model' => CONTENT_MODEL_JAVASCRIPT
,
81 'content_format' => 'text/javascript' ] );
83 $this->fail( "Creating JavaScript content on a wikitext page should fail with "
84 . "\$wgContentHandlerUseDB disabled" );
85 } catch ( MWException
$ex ) {
86 $this->assertTrue( true ); // ok