File: RenameuserSQLTest.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (71 lines) | stat: -rw-r--r-- 1,838 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?php

use MediaWiki\Block\DatabaseBlock;
use MediaWiki\RenameUser\RenameuserSQL;

/**
 * @group Database
 * @covers \MediaWiki\RenameUser\RenameuserSQL
 */
class RenameuserSQLTest extends MediaWikiIntegrationTestCase {
	public function testRename() {
		$oldUser = $this->getMutableTestUser()->getUser();
		$admin = $this->getTestSysop()->getUser();
		$oldName = $oldUser->getName();
		$newName = 'RenameuserSQL.new';
		$userId = $oldUser->getId();
		$adminActor = $admin->getActorId();

		$this->editPage( __CLASS__, 'test' );

		$blockStatus = $this->getServiceContainer()->getBlockUserFactory()
			->newBlockUser(
				$oldUser,
				$admin,
				'infinity',
				'reason'
			)
			->placeBlock();
		$this->assertStatusGood( $blockStatus );
		/** @var DatabaseBlock $block */
		$block = $blockStatus->getValue();
		$blockId = $block->getId();

		$renamer = new RenameuserSQL( $oldName, $newName, $userId, $admin );
		$this->assertTrue( $renamer->rename() );

		$this->newSelectQueryBuilder()
			->select( 'user_name' )
			->from( 'user' )
			->where( [ 'user_id' => $userId ] )
			->assertFieldValue( $newName );

		$this->newSelectQueryBuilder()
			->select( 'actor_name' )
			->from( 'actor' )
			->where( [ 'actor_user' => $userId ] )
			->assertFieldValue( $newName );

		$this->newSelectQueryBuilder()
			->select( 'log_title' )
			->from( 'logging' )
			->where( [
				'log_type' => 'block',
				'log_actor' => $adminActor
			] )
			->assertFieldValue( $newName );

		$this->newSelectQueryBuilder()
			->select( 'rc_title' )
			->from( 'recentchanges' )
			->where( [
				'rc_actor' => $adminActor,
				'rc_log_type' => 'block'
			] )
			->assertFieldValue( $newName );

		$block = $this->getServiceContainer()->getDatabaseBlockStore()
			->newFromTarget( "#$blockId" );
		$this->assertSame( $newName, $block->getTargetName() );
	}
}