FoundationAuthorizesRequestsTraitTest.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. namespace Illuminate\Tests\Foundation;
  3. use Illuminate\Auth\Access\AuthorizationException;
  4. use Illuminate\Auth\Access\Gate;
  5. use Illuminate\Auth\Access\Response;
  6. use Illuminate\Container\Container;
  7. use Illuminate\Contracts\Auth\Access\Gate as GateContract;
  8. use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
  9. use PHPUnit\Framework\TestCase;
  10. class FoundationAuthorizesRequestsTraitTest extends TestCase
  11. {
  12. protected function tearDown(): void
  13. {
  14. Container::setInstance(null);
  15. }
  16. public function testBasicGateCheck()
  17. {
  18. unset($_SERVER['_test.authorizes.trait']);
  19. $gate = $this->getBasicGate();
  20. $gate->define('baz', function () {
  21. $_SERVER['_test.authorizes.trait'] = true;
  22. return true;
  23. });
  24. $response = (new FoundationTestAuthorizeTraitClass)->authorize('baz');
  25. $this->assertInstanceOf(Response::class, $response);
  26. $this->assertTrue($_SERVER['_test.authorizes.trait']);
  27. }
  28. public function testExceptionIsThrownIfGateCheckFails()
  29. {
  30. $this->expectException(AuthorizationException::class);
  31. $this->expectExceptionMessage('This action is unauthorized.');
  32. $gate = $this->getBasicGate();
  33. $gate->define('baz', function () {
  34. return false;
  35. });
  36. (new FoundationTestAuthorizeTraitClass)->authorize('baz');
  37. }
  38. public function testPoliciesMayBeCalled()
  39. {
  40. unset($_SERVER['_test.authorizes.trait.policy']);
  41. $gate = $this->getBasicGate();
  42. $gate->policy(FoundationAuthorizesRequestTestClass::class, FoundationAuthorizesRequestTestPolicy::class);
  43. $response = (new FoundationTestAuthorizeTraitClass)->authorize('update', new FoundationAuthorizesRequestTestClass);
  44. $this->assertInstanceOf(Response::class, $response);
  45. $this->assertTrue($_SERVER['_test.authorizes.trait.policy']);
  46. }
  47. public function testPolicyMethodMayBeGuessedPassingModelInstance()
  48. {
  49. unset($_SERVER['_test.authorizes.trait.policy']);
  50. $gate = $this->getBasicGate();
  51. $gate->policy(FoundationAuthorizesRequestTestClass::class, FoundationAuthorizesRequestTestPolicy::class);
  52. $response = (new FoundationTestAuthorizeTraitClass)->authorize(new FoundationAuthorizesRequestTestClass);
  53. $this->assertInstanceOf(Response::class, $response);
  54. $this->assertTrue($_SERVER['_test.authorizes.trait.policy']);
  55. }
  56. public function testPolicyMethodMayBeGuessedPassingClassName()
  57. {
  58. unset($_SERVER['_test.authorizes.trait.policy']);
  59. $gate = $this->getBasicGate();
  60. $gate->policy('\\'.FoundationAuthorizesRequestTestClass::class, FoundationAuthorizesRequestTestPolicy::class);
  61. $response = (new FoundationTestAuthorizeTraitClass)->authorize('\\'.FoundationAuthorizesRequestTestClass::class);
  62. $this->assertInstanceOf(Response::class, $response);
  63. $this->assertTrue($_SERVER['_test.authorizes.trait.policy']);
  64. }
  65. public function testPolicyMethodMayBeGuessedAndNormalized()
  66. {
  67. unset($_SERVER['_test.authorizes.trait.policy']);
  68. $gate = $this->getBasicGate();
  69. $gate->policy(FoundationAuthorizesRequestTestClass::class, FoundationAuthorizesRequestTestPolicy::class);
  70. (new FoundationTestAuthorizeTraitClass)->store(new FoundationAuthorizesRequestTestClass);
  71. $this->assertTrue($_SERVER['_test.authorizes.trait.policy']);
  72. }
  73. public function getBasicGate()
  74. {
  75. $container = Container::setInstance(new Container);
  76. $gate = new Gate($container, function () {
  77. return (object) ['id' => 1];
  78. });
  79. $container->instance(GateContract::class, $gate);
  80. return $gate;
  81. }
  82. }
  83. class FoundationAuthorizesRequestTestClass
  84. {
  85. //
  86. }
  87. class FoundationAuthorizesRequestTestPolicy
  88. {
  89. public function create()
  90. {
  91. $_SERVER['_test.authorizes.trait.policy'] = true;
  92. return true;
  93. }
  94. public function update()
  95. {
  96. $_SERVER['_test.authorizes.trait.policy'] = true;
  97. return true;
  98. }
  99. public function testPolicyMethodMayBeGuessedPassingModelInstance()
  100. {
  101. $_SERVER['_test.authorizes.trait.policy'] = true;
  102. return true;
  103. }
  104. public function testPolicyMethodMayBeGuessedPassingClassName()
  105. {
  106. $_SERVER['_test.authorizes.trait.policy'] = true;
  107. return true;
  108. }
  109. }
  110. class FoundationTestAuthorizeTraitClass
  111. {
  112. use AuthorizesRequests;
  113. public function store($object)
  114. {
  115. $this->authorize($object);
  116. }
  117. }