getClient(); $client->request('GET', '/users/list'); $this->assertSame(302, $client->getResponse()->getStatusCode()); $this->assertStringContainsString('login', $client->getResponse()->headers->get('location')); } public function testCompleteScenario() { $this->logInAs('admin'); $client = $this->getClient(); // Create a new user in the database $crawler = $client->request('GET', '/users/list'); $this->assertSame(200, $client->getResponse()->getStatusCode(), 'Unexpected HTTP status code for GET /users/'); $crawler = $client->click($crawler->selectLink('user.list.create_new_one')->link()); // Fill in the form and submit it $form = $crawler->selectButton('user.form.save')->form([ 'new_user[username]' => 'test_user', 'new_user[email]' => 'test@test.io', 'new_user[plainPassword][first]' => 'testtest', 'new_user[plainPassword][second]' => 'testtest', ]); $client->submit($form); $client->followRedirect(); $crawler = $client->request('GET', '/users/list'); // Check data in the show view $this->assertGreaterThan(0, $crawler->filter('td:contains("test_user")')->count(), 'Missing element td:contains("test_user")'); // Edit the user $crawler = $client->click($crawler->selectLink('user.list.edit_action')->last()->link()); $form = $crawler->selectButton('user.form.save')->form([ 'user[name]' => 'Foo User', 'user[username]' => 'test_user', 'user[email]' => 'test@test.io', 'user[enabled]' => true, ]); $client->submit($form); $crawler = $client->followRedirect(); // Check the element contains an attribute with value equals "Foo User" $this->assertGreaterThan(0, $crawler->filter('[value="Foo User"]')->count(), 'Missing element [value="Foo User"]'); $crawler = $client->request('GET', '/users/list'); $crawler = $client->click($crawler->selectLink('user.list.edit_action')->last()->link()); // Delete the user $client->submit($crawler->selectButton('user.form.delete')->form()); $crawler = $client->followRedirect(); // Check the user has been delete on the list $this->assertDoesNotMatchRegularExpression('/Foo User/', $client->getResponse()->getContent()); } public function testDeleteDisabledForLoggedUser() { $this->logInAs('admin'); $client = $this->getClient(); $crawler = $client->request('GET', '/users/' . $this->getLoggedInUserId() . '/edit'); $disabled = $crawler->selectButton('user.form.delete')->extract('disabled'); $this->assertSame('disabled', $disabled[0]); } public function testUserSearch() { $this->logInAs('admin'); $client = $this->getClient(); // Search on unread list $crawler = $client->request('GET', '/users/list'); $form = $crawler->filter('form[name=search_users]')->form(); $data = [ 'search_user[term]' => 'admin', ]; $crawler = $client->submit($form, $data); $this->assertCount(2, $crawler->filter('tr')); // 1 result + table header } }