Remove superfluous re- from confirmemail_body_set
[mediawiki.git] / tests / phpunit / includes / site / SiteSQLStoreTest.php
blobcf652e957cb6b8b648d30e928c55436c4428f972
1 <?php
3 /**
4 * Tests for the SiteSQLStore class.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 * http://www.gnu.org/copyleft/gpl.html
21 * @file
22 * @since 1.21
24 * @ingroup Site
25 * @ingroup Test
27 * @group Site
28 * @group Database
30 * @licence GNU GPL v2+
31 * @author Jeroen De Dauw < jeroendedauw@gmail.com >
33 class SiteSQLStoreTest extends MediaWikiTestCase {
35 public function testGetSites() {
36 $expectedSites = TestSites::getSites();
37 TestSites::insertIntoDb();
39 $store = SiteSQLStore::newInstance();
41 $sites = $store->getSites();
43 $this->assertInstanceOf( 'SiteList', $sites );
45 /**
46 * @var Site $site
48 foreach ( $sites as $site ) {
49 $this->assertInstanceOf( 'Site', $site );
52 foreach ( $expectedSites as $site ) {
53 if ( $site->getGlobalId() !== null ) {
54 $this->assertTrue( $sites->hasSite( $site->getGlobalId() ) );
59 public function testSaveSites() {
60 $store = SiteSQLStore::newInstance();
62 $sites = array();
64 $site = new Site();
65 $site->setGlobalId( 'ertrywuutr' );
66 $site->setLanguageCode( 'en' );
67 $sites[] = $site;
69 $site = new MediaWikiSite();
70 $site->setGlobalId( 'sdfhxujgkfpth' );
71 $site->setLanguageCode( 'nl' );
72 $sites[] = $site;
74 $this->assertTrue( $store->saveSites( $sites ) );
76 $site = $store->getSite( 'ertrywuutr' );
77 $this->assertInstanceOf( 'Site', $site );
78 $this->assertEquals( 'en', $site->getLanguageCode() );
79 $this->assertTrue( is_integer( $site->getInternalId() ) );
80 $this->assertTrue( $site->getInternalId() >= 0 );
82 $site = $store->getSite( 'sdfhxujgkfpth' );
83 $this->assertInstanceOf( 'Site', $site );
84 $this->assertEquals( 'nl', $site->getLanguageCode() );
85 $this->assertTrue( is_integer( $site->getInternalId() ) );
86 $this->assertTrue( $site->getInternalId() >= 0 );
89 public function testReset() {
90 $store1 = SiteSQLStore::newInstance();
91 $store2 = SiteSQLStore::newInstance();
93 // initialize internal cache
94 $this->assertGreaterThan( 0, $store1->getSites()->count() );
95 $this->assertGreaterThan( 0, $store2->getSites()->count() );
97 // Clear actual data. Will purge the external cache and reset the internal
98 // cache in $store1, but not the internal cache in store2.
99 $this->assertTrue( $store1->clear() );
101 // sanity check: $store2 should have a stale cache now
102 $this->assertNotNull( $store2->getSite( 'enwiki' ) );
104 // purge cache
105 $store2->reset();
107 // ...now the internal cache of $store2 should be updated and thus empty.
108 $site = $store2->getSite( 'enwiki' );
109 $this->assertNull( $site );
112 public function testClear() {
113 $store = SiteSQLStore::newInstance();
114 $this->assertTrue( $store->clear() );
116 $site = $store->getSite( 'enwiki' );
117 $this->assertNull( $site );
119 $sites = $store->getSites();
120 $this->assertEquals( 0, $sites->count() );