SettingControllerTest.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. <?php
  2. namespace Tests\Api\v1\Controllers;
  3. use App\Api\v1\Controllers\SettingController;
  4. use App\Facades\Settings;
  5. use App\Models\User;
  6. use Illuminate\Support\Arr;
  7. use Illuminate\Support\Facades\Route;
  8. use Illuminate\Support\Str;
  9. use PHPUnit\Framework\Attributes\CoversClass;
  10. use PHPUnit\Framework\Attributes\Test;
  11. use Tests\FeatureTestCase;
  12. /**
  13. * SettingController test class
  14. */
  15. #[CoversClass(SettingController::class)]
  16. class SettingControllerTest extends FeatureTestCase
  17. {
  18. /**
  19. * @var \App\Models\User|\Illuminate\Contracts\Auth\Authenticatable
  20. */
  21. protected $user;
  22. protected $admin;
  23. private const SETTING_JSON_STRUCTURE = [
  24. 'key',
  25. 'value',
  26. ];
  27. private const TWOFAUTH_NATIVE_SETTING = 'checkForUpdate';
  28. private const TWOFAUTH_NATIVE_SETTING_DEFAULT_VALUE = true;
  29. private const TWOFAUTH_NATIVE_SETTING_CHANGED_VALUE = false;
  30. private const USER_DEFINED_SETTING = 'mySetting';
  31. private const USER_DEFINED_SETTING_VALUE = 'mySetting';
  32. private const USER_DEFINED_SETTING_CHANGED_VALUE = 'mySetting';
  33. public function setUp() : void
  34. {
  35. parent::setUp();
  36. $this->user = User::factory()->create();
  37. $this->admin = User::factory()->administrator()->create();
  38. }
  39. #[Test]
  40. public function test_all_controller_routes_are_protected_by_admin_middleware()
  41. {
  42. $routes = Route::getRoutes()->getRoutes();
  43. $controllerRoutes = Arr::where($routes, function (\Illuminate\Routing\Route $route, int $key) {
  44. if (Str::startsWith($route->getActionName(), SettingController::class)) {
  45. return $route;
  46. }
  47. });
  48. foreach ($controllerRoutes as $controllerRoute) {
  49. $this->assertContains('admin', $controllerRoute->middleware());
  50. }
  51. }
  52. #[Test]
  53. public function test_index_returns_setting_collection()
  54. {
  55. $response = $this->actingAs($this->admin, 'api-guard')
  56. ->json('GET', '/api/v1/settings')
  57. ->assertOk()
  58. ->assertJsonStructure([
  59. '*' => self::SETTING_JSON_STRUCTURE,
  60. ]);
  61. }
  62. #[Test]
  63. public function test_index_is_forbidden_to_users()
  64. {
  65. $response = $this->actingAs($this->user, 'api-guard')
  66. ->json('GET', '/api/v1/settings')
  67. ->assertForbidden()
  68. ->assertJsonStructure([
  69. 'message',
  70. ]);
  71. }
  72. #[Test]
  73. public function test_show_native_unchanged_setting_returns_consistent_value()
  74. {
  75. $response = $this->actingAs($this->admin, 'api-guard')
  76. ->json('GET', '/api/v1/settings/' . self::TWOFAUTH_NATIVE_SETTING)
  77. ->assertOk()
  78. ->assertExactJson([
  79. 'key' => self::TWOFAUTH_NATIVE_SETTING,
  80. 'value' => self::TWOFAUTH_NATIVE_SETTING_DEFAULT_VALUE,
  81. ]);
  82. }
  83. #[Test]
  84. public function test_show_native_changed_setting_returns_consistent_value()
  85. {
  86. Settings::set(self::TWOFAUTH_NATIVE_SETTING, self::TWOFAUTH_NATIVE_SETTING_CHANGED_VALUE);
  87. $response = $this->actingAs($this->admin, 'api-guard')
  88. ->json('GET', '/api/v1/settings/' . self::TWOFAUTH_NATIVE_SETTING)
  89. ->assertOk()
  90. ->assertExactJson([
  91. 'key' => self::TWOFAUTH_NATIVE_SETTING,
  92. 'value' => self::TWOFAUTH_NATIVE_SETTING_CHANGED_VALUE,
  93. ]);
  94. }
  95. #[Test]
  96. public function test_show_custom_user_setting_returns_consistent_value()
  97. {
  98. Settings::set(self::USER_DEFINED_SETTING, self::USER_DEFINED_SETTING_VALUE);
  99. $response = $this->actingAs($this->admin, 'api-guard')
  100. ->json('GET', '/api/v1/settings/' . self::USER_DEFINED_SETTING)
  101. ->assertOk()
  102. ->assertExactJson([
  103. 'key' => self::USER_DEFINED_SETTING,
  104. 'value' => self::USER_DEFINED_SETTING_VALUE,
  105. ]);
  106. }
  107. #[Test]
  108. public function test_show_missing_setting_returns_not_found()
  109. {
  110. $response = $this->actingAs($this->admin, 'api-guard')
  111. ->json('GET', '/api/v1/settings/missing')
  112. ->assertNotFound();
  113. }
  114. #[Test]
  115. public function test_show_setting_is_forbidden_to_users()
  116. {
  117. $response = $this->actingAs($this->user, 'api-guard')
  118. ->json('GET', '/api/v1/settings/' . self::TWOFAUTH_NATIVE_SETTING)
  119. ->assertForbidden()
  120. ->assertJsonStructure([
  121. 'message',
  122. ]);
  123. }
  124. #[Test]
  125. public function test_store_custom_user_setting_returns_success()
  126. {
  127. $response = $this->actingAs($this->admin, 'api-guard')
  128. ->json('POST', '/api/v1/settings', [
  129. 'key' => self::USER_DEFINED_SETTING,
  130. 'value' => self::USER_DEFINED_SETTING_VALUE,
  131. ])
  132. ->assertCreated()
  133. ->assertExactJson([
  134. 'key' => self::USER_DEFINED_SETTING,
  135. 'value' => self::USER_DEFINED_SETTING_VALUE,
  136. ]);
  137. }
  138. #[Test]
  139. public function test_store_invalid_custom_user_setting_returns_validation_error()
  140. {
  141. $response = $this->actingAs($this->admin, 'api-guard')
  142. ->json('POST', '/api/v1/settings', [
  143. 'key' => null,
  144. 'value' => null,
  145. ])
  146. ->assertStatus(422);
  147. }
  148. #[Test]
  149. public function test_store_existing_custom_user_setting_returns_validation_error()
  150. {
  151. Settings::set(self::USER_DEFINED_SETTING, self::USER_DEFINED_SETTING_VALUE);
  152. $response = $this->actingAs($this->admin, 'api-guard')
  153. ->json('POST', '/api/v1/settings', [
  154. 'key' => self::USER_DEFINED_SETTING,
  155. 'value' => self::USER_DEFINED_SETTING_VALUE,
  156. ])
  157. ->assertStatus(422);
  158. }
  159. #[Test]
  160. public function test_update_unchanged_native_setting_returns_updated_setting()
  161. {
  162. $response = $this->actingAs($this->admin, 'api-guard')
  163. ->json('PUT', '/api/v1/settings/' . self::TWOFAUTH_NATIVE_SETTING, [
  164. 'value' => self::TWOFAUTH_NATIVE_SETTING_CHANGED_VALUE,
  165. ])
  166. ->assertOk()
  167. ->assertExactJson([
  168. 'key' => self::TWOFAUTH_NATIVE_SETTING,
  169. 'value' => self::TWOFAUTH_NATIVE_SETTING_CHANGED_VALUE,
  170. ]);
  171. }
  172. #[Test]
  173. public function test_update_custom_user_setting_returns_updated_setting()
  174. {
  175. Settings::set(self::USER_DEFINED_SETTING, self::USER_DEFINED_SETTING_VALUE);
  176. $response = $this->actingAs($this->admin, 'api-guard')
  177. ->json('PUT', '/api/v1/settings/' . self::USER_DEFINED_SETTING, [
  178. 'value' => self::USER_DEFINED_SETTING_CHANGED_VALUE,
  179. ])
  180. ->assertOk()
  181. ->assertExactJson([
  182. 'key' => self::USER_DEFINED_SETTING,
  183. 'value' => self::USER_DEFINED_SETTING_CHANGED_VALUE,
  184. ]);
  185. }
  186. #[Test]
  187. public function test_update_missing_user_setting_returns_created_setting()
  188. {
  189. $response = $this->actingAs($this->admin, 'api-guard')
  190. ->json('PUT', '/api/v1/settings/' . self::USER_DEFINED_SETTING, [
  191. 'value' => self::USER_DEFINED_SETTING_CHANGED_VALUE,
  192. ])
  193. ->assertOk()
  194. ->assertExactJson([
  195. 'key' => self::USER_DEFINED_SETTING,
  196. 'value' => self::USER_DEFINED_SETTING_CHANGED_VALUE,
  197. ]);
  198. }
  199. #[Test]
  200. public function test_destroy_user_setting_returns_success()
  201. {
  202. Settings::set(self::USER_DEFINED_SETTING, self::USER_DEFINED_SETTING_VALUE);
  203. $response = $this->actingAs($this->admin, 'api-guard')
  204. ->json('DELETE', '/api/v1/settings/' . self::USER_DEFINED_SETTING)
  205. ->assertNoContent();
  206. }
  207. #[Test]
  208. public function test_destroy_native_setting_returns_bad_request()
  209. {
  210. $response = $this->actingAs($this->admin, 'api-guard')
  211. ->json('DELETE', '/api/v1/settings/' . self::TWOFAUTH_NATIVE_SETTING)
  212. ->assertStatus(400)
  213. ->assertJsonStructure([
  214. 'message',
  215. 'reason',
  216. ]);
  217. }
  218. #[Test]
  219. public function test_destroy_missing_user_setting_returns_not_found()
  220. {
  221. $response = $this->actingAs($this->admin, 'api-guard')
  222. ->json('DELETE', '/api/v1/settings/' . self::USER_DEFINED_SETTING)
  223. ->assertNotFound();
  224. }
  225. #[Test]
  226. public function test_destroy_is_forbidden_to_users()
  227. {
  228. Settings::set(self::USER_DEFINED_SETTING, self::USER_DEFINED_SETTING_VALUE);
  229. $response = $this->actingAs($this->user, 'api-guard')
  230. ->json('DELETE', '/api/v1/settings/' . self::USER_DEFINED_SETTING)
  231. ->assertForbidden()
  232. ->assertJsonStructure([
  233. 'message',
  234. ]);
  235. }
  236. }