View source
<?php
namespace Drupal\Tests\user\Functional;
use Drupal\Tests\BrowserTestBase;
class UserSearchTest extends BrowserTestBase {
public static $modules = [
'search',
];
protected $defaultTheme = 'stark';
public function testUserSearch() {
$user1 = $this
->drupalCreateUser([
'access user profiles',
'search content',
], "foo+bar");
$this
->drupalLogin($user1);
$keys = $user1
->getEmail();
$edit = [
'keys' => $keys,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText(t('Your search yielded no results.'), 'Search by email did not work for non-admin user');
$this
->assertText('no results', 'Search by email gave no-match message');
$keys = 'nomatch';
$edit = [
'keys' => $keys,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText('no results', 'Non-matching search gave appropriate message');
$keys = $user1
->getAccountName();
$edit = [
'keys' => $keys,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertSession()
->linkExists($keys, 0, 'Search by username worked for non-admin user');
$subkey = substr($keys, 1, 5);
$edit = [
'keys' => $subkey,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertSession()
->linkExists($keys, 0, 'Search by username substring worked for non-admin user');
$subkey = substr($keys, 0, 2) . '*' . substr($keys, 4, 2);
$edit = [
'keys' => $subkey,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertSession()
->linkExists($keys, 0, 'Search with wildcard worked for non-admin user');
$user2 = $this
->drupalCreateUser([
'administer users',
'access user profiles',
'search content',
]);
$this
->drupalLogin($user2);
$keys = $user2
->getEmail();
$edit = [
'keys' => $keys,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText($keys, 'Search by email works for administrative user');
$this
->assertText($user2
->getAccountName(), 'Search by email resulted in username on page for administrative user');
$subkey = substr($keys, 1, 5);
$edit = [
'keys' => $subkey,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText($keys, 'Search by email substring works for administrative user');
$this
->assertText($user2
->getAccountName(), 'Search by email substring resulted in username on page for administrative user');
$subkey = substr($keys, 0, 2) . '*' . substr($keys, 4, 2);
$edit = [
'keys' => $subkey,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText($user2
->getAccountName(), 'Search for email wildcard resulted in username on page for administrative user');
$keys = $user1
->getAccountName();
$edit = [
'keys' => $keys,
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText($keys, 'Search by username works for admin user');
$this
->assertText($user1
->getEmail(), 'Search by username for admin shows email address too');
$blocked_user = $this
->drupalCreateUser();
$blocked_user
->block();
$blocked_user
->save();
$edit = [
'keys' => $blocked_user
->getAccountName(),
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText($blocked_user
->getAccountName(), 'Blocked users are listed on the user search results for users with the "administer users" permission.');
$this
->drupalLogin($user1);
$edit = [
'keys' => $blocked_user
->getAccountName(),
];
$this
->drupalPostForm('search/user', $edit, t('Search'));
$this
->assertText(t('Your search yielded no results.'), 'Blocked users are hidden from the user search results.');
$user3 = $this
->drupalCreateUser([
'search content',
]);
$this
->drupalLogin($user3);
$this
->drupalGet('search/user');
$this
->assertSession()
->statusCodeEquals(403);
$user4 = $this
->drupalCreateUser([
'access user profiles',
]);
$this
->drupalLogin($user4);
$this
->drupalGet('search/user');
$this
->assertSession()
->statusCodeEquals(403);
$this
->drupalLogout();
}
}