Edit file File name : UserControllerTest.php Content :<?php /* * This file is part of the Kimai time-tracking app. * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace App\Tests\Controller; use App\Entity\Timesheet; use App\Entity\User; use App\Tests\DataFixtures\TimesheetFixtures; /** * @group integration */ class UserControllerTest extends ControllerBaseTest { public function testIsSecure() { $this->assertUrlIsSecured('/admin/user/'); } public function testIsSecureForRole() { $this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/user/'); } public function testIndexAction() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->assertAccessIsGranted($client, '/admin/user/'); $this->assertHasDataTable($client); $this->assertDataTableRowCount($client, 'datatable_user_admin', 7); $this->assertPageActions($client, [ 'search' => '#', 'visibility' => '#', 'download toolbar-action' => $this->createUrl('/admin/user/export'), 'create' => $this->createUrl('/admin/user/create'), 'settings modal-ajax-form' => $this->createUrl('/admin/system-config/edit/user'), 'help' => 'https://www.kimai.org/documentation/users.html' ]); } public function testIndexActionWithSearchTermQuery() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->request($client, '/admin/user/'); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form.searchform')->form(); $client->submit($form, [ 'searchTerm' => 'hourly_rate:35 tony', 'role' => 'ROLE_TEAMLEAD', 'visibility' => 1, 'pageSize' => 50, 'page' => 1, ]); $this->assertTrue($client->getResponse()->isSuccessful()); $this->assertHasDataTable($client); $this->assertDataTableRowCount($client, 'datatable_user_admin', 1); } public function testExportIsSecureForRole() { $this->assertUrlIsSecuredForRole(User::ROLE_ADMIN, '/admin/user/export'); } public function testExportAction() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->assertAccessIsGranted($client, '/admin/user/export'); $this->assertExcelExportResponse($client, 'kimai-users_'); } public function testExportActionWithSearchTermQuery() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->request($client, '/admin/user/'); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form.searchform')->form(); $form->getFormNode()->setAttribute('action', $this->createUrl('/admin/user/export')); $client->submit($form, [ 'searchTerm' => 'hourly_rate:35 tony', 'role' => 'ROLE_TEAMLEAD', 'visibility' => 1, 'pageSize' => 50, 'page' => 1, ]); $this->assertExcelExportResponse($client, 'kimai-users_'); } public function testCreateAction() { $username = '亚历山德拉' . uniqid(); $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->assertAccessIsGranted($client, '/admin/user/create'); $form = $client->getCrawler()->filter('form[name=user_create]')->form(); $this->assertTrue($form->has('user_create[create_more]')); $this->assertFalse($form->get('user_create[create_more]')->hasValue()); $client->submit($form, [ 'user_create' => [ 'username' => $username, 'alias' => $username, 'plainPassword' => ['first' => '12345678', 'second' => '12345678'], 'email' => 'foobar@example.com', 'enabled' => 1, ] ]); $this->assertIsRedirect($client, $this->createUrl('/profile/' . urlencode($username) . '/edit')); $client->followRedirect(); $form = $client->getCrawler()->filter('form[name=user_edit]')->form(); $this->assertEquals($username, $form->get('user_edit[alias]')->getValue()); } public function testCreateActionWithCreateMore() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->assertAccessIsGranted($client, '/admin/user/create'); $form = $client->getCrawler()->filter('form[name=user_create]')->form(); $this->assertTrue($form->has('user_create[create_more]')); $client->submit($form, [ 'user_create' => [ 'username' => 'foobar@example.com', 'plainPassword' => ['first' => 'abcdef', 'second' => 'abcdef'], 'email' => 'foobar@example.com', 'enabled' => 1, 'create_more' => true, ] ]); $this->assertFalse($client->getResponse()->isRedirect()); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form[name=user_create]')->form(); $this->assertTrue($form->has('user_create[create_more]')); $this->assertTrue($form->get('user_create[create_more]')->hasValue()); $this->assertEquals(1, $form->get('user_create[create_more]')->getValue()); } public function testDeleteAction() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $this->request($client, '/admin/user/4/delete'); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form[name=form]')->form(); $this->assertStringEndsWith($this->createUrl('/admin/user/4/delete'), $form->getUri()); $client->submit($form); $client->followRedirect(); $this->assertHasDataTable($client); $this->assertHasFlashSuccess($client); $this->request($client, '/admin/user/4/edit'); $this->assertFalse($client->getResponse()->isSuccessful()); } public function testDeleteActionWithTimesheetEntries() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $em = $this->getEntityManager(); $user = $this->getUserByRole(User::ROLE_USER); $fixture = new TimesheetFixtures(); $fixture->setUser($user); $fixture->setAmount(10); $this->importFixture($fixture); $timesheets = $em->getRepository(Timesheet::class)->findAll(); $this->assertEquals(10, \count($timesheets)); $this->request($client, '/admin/user/' . $user->getId() . '/delete'); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form[name=form]')->form(); $this->assertStringEndsWith($this->createUrl('/admin/user/' . $user->getId() . '/delete'), $form->getUri()); $client->submit($form); $this->assertIsRedirect($client, $this->createUrl('/admin/user/')); $client->followRedirect(); $this->assertHasFlashDeleteSuccess($client); $em->clear(); $timesheets = $em->getRepository(Timesheet::class)->count([]); $this->assertEquals(0, $timesheets); $this->request($client, '/admin/user/' . $user->getId() . '/edit'); $this->assertFalse($client->getResponse()->isSuccessful()); } public function testDeleteActionWithUserReplacementAndTimesheetEntries() { $client = $this->getClientForAuthenticatedUser(User::ROLE_SUPER_ADMIN); $em = $this->getEntityManager(); $user = $this->getUserByRole(User::ROLE_USER); $userNew = $this->getUserByRole(User::ROLE_TEAMLEAD); $this->assertNotEquals($userNew->getId(), $user->getId()); $fixture = new TimesheetFixtures(); $fixture->setUser($user); $fixture->setAmount(10); $this->importFixture($fixture); $timesheets = $em->getRepository(Timesheet::class)->findAll(); $this->assertEquals(10, \count($timesheets)); foreach ($timesheets as $timesheet) { $this->assertEquals($user->getId(), $timesheet->getUser()->getId()); } $this->request($client, '/admin/user/' . $user->getId() . '/delete'); $this->assertTrue($client->getResponse()->isSuccessful()); $form = $client->getCrawler()->filter('form[name=form]')->form(); $this->assertStringEndsWith($this->createUrl('/admin/user/' . $user->getId() . '/delete'), $form->getUri()); $client->submit($form, [ 'form' => [ 'user' => $userNew->getId() ] ]); $this->assertIsRedirect($client, $this->createUrl('/admin/user/')); $client->followRedirect(); $this->assertHasFlashDeleteSuccess($client); $em->clear(); $timesheets = $em->getRepository(Timesheet::class)->findAll(); $this->assertEquals(10, \count($timesheets)); foreach ($timesheets as $timesheet) { $this->assertEquals($userNew->getId(), $timesheet->getUser()->getId()); } $this->request($client, '/admin/user/' . $user->getId() . '/edit'); $this->assertFalse($client->getResponse()->isSuccessful()); } /** * @dataProvider getValidationTestData */ public function testValidationForCreateAction(array $formData, array $validationFields) { $this->assertFormHasValidationError( User::ROLE_SUPER_ADMIN, '/admin/user/create', 'form[name=user_create]', $formData, $validationFields ); } public function getValidationTestData() { return [ [ // invalid fields: username, password_second, email, enabled [ 'user_create' => [ 'username' => '', 'plainPassword' => ['first' => 'sdfsdf123'], 'alias' => 'ycvyxcb', 'title' => '34rtwrtewrt', 'email' => '', ] ], [ '#user_create_username', '#user_create_plainPassword_first', '#user_create_email', ] ], // invalid fields: username, password, email, enabled [ [ 'user_create' => [ 'username' => 'x', 'plainPassword' => ['first' => 'sdfsdf123', 'second' => 'sdfxxxxxxx'], 'alias' => 'ycvyxcb', 'title' => '34rtwrtewrt', 'email' => 'ydfbvsdfgs', ] ], [ '#user_create_username', '#user_create_plainPassword_first', '#user_create_email', ] ], // invalid fields: password (too short) [ [ 'user_create' => [ 'username' => 'test123', 'plainPassword' => ['first' => 'test123', 'second' => 'test123'], 'alias' => 'ycvyxcb', 'title' => '34rtwrtewrt', 'email' => 'ydfbvsdfgs@example.com', ] ], [ '#user_create_plainPassword_first', ] ], ]; } } Save