SettingControllerTest.php 9.1 KB

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