EnableTest.php 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. /**
  3. * @copyright 2016, Roeland Jago Douma <roeland@famdouma.nl>
  4. *
  5. * @author Roeland Jago Douma <roeland@famdouma.nl>
  6. *
  7. * @license GNU AGPL version 3 or any later version
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License as
  11. * published by the Free Software Foundation, either version 3 of the
  12. * License, or (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Affero General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. *
  22. */
  23. namespace Tests\Core\Command\User;
  24. use OC\Core\Command\User\Enable;
  25. use OCP\IUser;
  26. use OCP\IUserManager;
  27. use Symfony\Component\Console\Input\InputInterface;
  28. use Symfony\Component\Console\Output\OutputInterface;
  29. use Test\TestCase;
  30. class EnableTest extends TestCase {
  31. /** @var IUserManager|\PHPUnit\Framework\MockObject\MockObject */
  32. protected $userManager;
  33. /** @var InputInterface|\PHPUnit\Framework\MockObject\MockObject */
  34. protected $consoleInput;
  35. /** @var OutputInterface|\PHPUnit\Framework\MockObject\MockObject */
  36. protected $consoleOutput;
  37. /** @var Disable */
  38. protected $command;
  39. protected function setUp(): void {
  40. parent::setUp();
  41. $this->userManager = $this->createMock(IUserManager::class);
  42. $this->consoleInput = $this->createMock(InputInterface::class);
  43. $this->consoleOutput = $this->createMock(OutputInterface::class);
  44. $this->command = new Enable($this->userManager);
  45. }
  46. public function testValidUser() {
  47. $user = $this->createMock(IUser::class);
  48. $user->expects($this->once())
  49. ->method('setEnabled')
  50. ->with(true);
  51. $this->userManager
  52. ->method('get')
  53. ->with('user')
  54. ->willReturn($user);
  55. $this->consoleInput
  56. ->method('getArgument')
  57. ->with('uid')
  58. ->willReturn('user');
  59. $this->consoleOutput->expects($this->once())
  60. ->method('writeln')
  61. ->with($this->stringContains('The specified user is enabled'));
  62. self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]);
  63. }
  64. public function testInvalidUser() {
  65. $this->userManager->expects($this->once())
  66. ->method('get')
  67. ->with('user')
  68. ->willReturn(null);
  69. $this->consoleInput
  70. ->method('getArgument')
  71. ->with('uid')
  72. ->willReturn('user');
  73. $this->consoleOutput->expects($this->once())
  74. ->method('writeln')
  75. ->with($this->stringContains('User does not exist'));
  76. self::invokePrivate($this->command, 'execute', [$this->consoleInput, $this->consoleOutput]);
  77. }
  78. }