Import: Handle uploads with sha1 starting with 0 properly
[mediawiki.git] / tests / phpunit / includes / specials / SpecialRecentchangesTest.php
blob384b0006c9451114970ed787d243250a724d32ad
1 <?php
2 /**
3 * Test class for SpecialRecentchanges class
5 * Copyright © 2011, Antoine Musso
7 * @author Antoine Musso
8 * @group Database
10 * @covers SpecialRecentChanges
12 class SpecialRecentchangesTest extends MediaWikiTestCase {
14 protected function setUp() {
15 parent::setUp();
16 $this->setMwGlobals( 'wgRCWatchCategoryMembership', true );
19 /**
20 * @var SpecialRecentChanges
22 protected $rc;
24 /** helper to test SpecialRecentchanges::buildMainQueryConds() */
25 private function assertConditions( $expected, $requestOptions = null, $message = '' ) {
26 $context = new RequestContext;
27 $context->setRequest( new FauxRequest( $requestOptions ) );
29 # setup the rc object
30 $this->rc = new SpecialRecentChanges();
31 $this->rc->setContext( $context );
32 $formOptions = $this->rc->setup( null );
34 #  Filter out rc_timestamp conditions which depends on the test runtime
35 # This condition is not needed as of march 2, 2011 -- hashar
36 # @todo FIXME: Find a way to generate the correct rc_timestamp
37 $queryConditions = array_filter(
38 $this->rc->buildMainQueryConds( $formOptions ),
39 'SpecialRecentchangesTest::filterOutRcTimestampCondition'
42 $this->assertEquals(
43 $expected,
44 $queryConditions,
45 $message
49 /** return false if condition begin with 'rc_timestamp ' */
50 private static function filterOutRcTimestampCondition( $var ) {
51 return ( false === strpos( $var, 'rc_timestamp ' ) );
54 public function testRcNsFilter() {
55 $this->assertConditions(
56 array( # expected
57 'rc_bot' => 0,
58 0 => "rc_type != '6'",
59 1 => "rc_namespace = '0'",
61 array(
62 'namespace' => NS_MAIN,
64 "rc conditions with no options (aka default setting)"
68 public function testRcNsFilterInversion() {
69 $this->assertConditions(
70 array( # expected
71 'rc_bot' => 0,
72 0 => "rc_type != '6'",
73 1 => sprintf( "rc_namespace != '%s'", NS_MAIN ),
75 array(
76 'namespace' => NS_MAIN,
77 'invert' => 1,
79 "rc conditions with namespace inverted"
83 /**
84 * @bug 2429
85 * @dataProvider provideNamespacesAssociations
87 public function testRcNsFilterAssociation( $ns1, $ns2 ) {
88 $this->assertConditions(
89 array( # expected
90 'rc_bot' => 0,
91 0 => "rc_type != '6'",
92 1 => sprintf( "(rc_namespace = '%s' OR rc_namespace = '%s')", $ns1, $ns2 ),
94 array(
95 'namespace' => $ns1,
96 'associated' => 1,
98 "rc conditions with namespace inverted"
103 * @bug 2429
104 * @dataProvider provideNamespacesAssociations
106 public function testRcNsFilterAssociationWithInversion( $ns1, $ns2 ) {
107 $this->assertConditions(
108 array( # expected
109 'rc_bot' => 0,
110 0 => "rc_type != '6'",
111 1 => sprintf( "(rc_namespace != '%s' AND rc_namespace != '%s')", $ns1, $ns2 ),
113 array(
114 'namespace' => $ns1,
115 'associated' => 1,
116 'invert' => 1,
118 "rc conditions with namespace inverted"
123 * Provides associated namespaces to test recent changes
124 * namespaces association filtering.
126 public static function provideNamespacesAssociations() {
127 return array( # (NS => Associated_NS)
128 array( NS_MAIN, NS_TALK ),
129 array( NS_TALK, NS_MAIN ),