Merge "Added release notes for 'ContentHandler::runLegacyHooks' removal"
[mediawiki.git] / tests / phpunit / includes / RevisionStorageTestContentHandlerUseDB.php
blob9e667f21863484e2850ce5ea77cd065116dbeefb
1 <?php
3 /**
4 * @group ContentHandler
5 * @group Database
6 * ^--- important, causes temporary tables to be used instead of the real database
7 */
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" );
27 parent::setUp();
30 /**
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' );
38 $this->assertTrue(
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' );
44 $this->assertFalse(
45 in_array( 'rev_content_model', $fields ),
46 'missing rev_content_model in list of fields'
48 $this->assertFalse(
49 in_array( 'rev_content_format', $fields ),
50 'missing rev_content_format in list of fields'
54 /**
55 * @covers Revision::getContentModel
57 public function testGetContentModel() {
58 try {
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
69 /**
70 * @covers Revision::getContentFormat
72 public function testGetContentFormat() {
73 try {
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