X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/a6633642232efd164d4708967ab59e498fbff896..refs/heads/ldap_host_failover:/tests/User/UserPreferencesTest.php diff --git a/tests/User/UserPreferencesTest.php b/tests/User/UserPreferencesTest.php index 7ffc8f9db..c65b11d7d 100644 --- a/tests/User/UserPreferencesTest.php +++ b/tests/User/UserPreferencesTest.php @@ -1,28 +1,29 @@ -getEditor(); $this->actingAs($editor); - $updateRequest = $this->patch('/settings/users/' . $editor->id.'/change-sort/books', [ - 'sort' => 'created_at', - 'order' => 'desc' + $updateRequest = $this->patch('/settings/users/' . $editor->id . '/change-sort/books', [ + 'sort' => 'created_at', + 'order' => 'desc', ]); $updateRequest->assertStatus(302); $this->assertDatabaseHas('settings', [ 'setting_key' => 'user:' . $editor->id . ':books_sort', - 'value' => 'created_at' + 'value' => 'created_at', ]); $this->assertDatabaseHas('settings', [ 'setting_key' => 'user:' . $editor->id . ':books_sort_order', - 'value' => 'desc' + 'value' => 'desc', ]); $this->assertEquals('created_at', setting()->getForCurrentUser('books_sort')); $this->assertEquals('desc', setting()->getForCurrentUser('books_sort_order')); @@ -33,9 +34,9 @@ class UserPreferencesTest extends TestCase $editor = $this->getEditor(); $this->actingAs($editor); - $updateRequest = $this->patch('/settings/users/' . $editor->id.'/change-sort/bookshelves', [ - 'sort' => 'cat', - 'order' => 'dog' + $updateRequest = $this->patch('/settings/users/' . $editor->id . '/change-sort/bookshelves', [ + 'sort' => 'cat', + 'order' => 'dog', ]); $updateRequest->assertStatus(302); @@ -48,9 +49,9 @@ class UserPreferencesTest extends TestCase $editor = $this->getEditor(); $this->actingAs($editor); - $updateRequest = $this->patch('/settings/users/' . $editor->id.'/change-sort/dogs', [ - 'sort' => 'name', - 'order' => 'asc' + $updateRequest = $this->patch('/settings/users/' . $editor->id . '/change-sort/dogs', [ + 'sort' => 'name', + 'order' => 'asc', ]); $updateRequest->assertStatus(500); @@ -63,24 +64,24 @@ class UserPreferencesTest extends TestCase $editor = $this->getEditor(); $this->actingAs($editor); - $updateRequest = $this->patch('/settings/users/' . $editor->id.'/update-expansion-preference/home-details', ['expand' => 'true']); + $updateRequest = $this->patch('/settings/users/' . $editor->id . '/update-expansion-preference/home-details', ['expand' => 'true']); $updateRequest->assertStatus(204); $this->assertDatabaseHas('settings', [ 'setting_key' => 'user:' . $editor->id . ':section_expansion#home-details', - 'value' => 'true' + 'value' => 'true', ]); $this->assertEquals(true, setting()->getForCurrentUser('section_expansion#home-details')); - $invalidKeyRequest = $this->patch('/settings/users/' . $editor->id.'/update-expansion-preference/my-home-details', ['expand' => 'true']); + $invalidKeyRequest = $this->patch('/settings/users/' . $editor->id . '/update-expansion-preference/my-home-details', ['expand' => 'true']); $invalidKeyRequest->assertStatus(500); } public function test_toggle_dark_mode() { $home = $this->actingAs($this->getEditor())->get('/'); - $home->assertElementNotExists('.dark-mode'); $home->assertSee('Dark Mode'); + $this->withHtml($home)->assertElementNotExists('.dark-mode'); $this->assertEquals(false, setting()->getForCurrentUser('dark-mode-enabled', false)); $prefChange = $this->patch('/settings/users/toggle-dark-mode'); @@ -88,8 +89,82 @@ class UserPreferencesTest extends TestCase $this->assertEquals(true, setting()->getForCurrentUser('dark-mode-enabled')); $home = $this->actingAs($this->getEditor())->get('/'); - $home->assertElementExists('.dark-mode'); + $this->withHtml($home)->assertElementExists('.dark-mode'); $home->assertDontSee('Dark Mode'); $home->assertSee('Light Mode'); } -} \ No newline at end of file + + public function test_dark_mode_defaults_to_config_option() + { + config()->set('setting-defaults.user.dark-mode-enabled', false); + $this->assertEquals(false, setting()->getForCurrentUser('dark-mode-enabled')); + $home = $this->get('/login'); + $this->withHtml($home)->assertElementNotExists('.dark-mode'); + + config()->set('setting-defaults.user.dark-mode-enabled', true); + $this->assertEquals(true, setting()->getForCurrentUser('dark-mode-enabled')); + $home = $this->get('/login'); + $this->withHtml($home)->assertElementExists('.dark-mode'); + } + + public function test_books_view_type_preferences_when_list() + { + $editor = $this->getEditor(); + setting()->putUser($editor, 'books_view_type', 'list'); + + $resp = $this->actingAs($editor)->get('/books'); + $this->withHtml($resp) + ->assertElementNotExists('.featured-image-container') + ->assertElementExists('.content-wrap .entity-list-item'); + } + + public function test_books_view_type_preferences_when_grid() + { + $editor = $this->getEditor(); + setting()->putUser($editor, 'books_view_type', 'grid'); + + $resp = $this->actingAs($editor)->get('/books'); + $this->withHtml($resp)->assertElementExists('.featured-image-container'); + } + + public function test_shelf_view_type_change() + { + $editor = $this->getEditor(); + $shelf = $this->entities->shelf(); + setting()->putUser($editor, 'bookshelf_view_type', 'list'); + + $resp = $this->actingAs($editor)->get($shelf->getUrl())->assertSee('Grid View'); + $this->withHtml($resp) + ->assertElementNotExists('.featured-image-container') + ->assertElementExists('.content-wrap .entity-list-item'); + + $req = $this->patch("/settings/users/{$editor->id}/switch-shelf-view", ['view_type' => 'grid']); + $req->assertRedirect($shelf->getUrl()); + + $resp = $this->actingAs($editor)->get($shelf->getUrl()) + ->assertSee('List View'); + + $this->withHtml($resp) + ->assertElementExists('.featured-image-container') + ->assertElementNotExists('.content-wrap .entity-list-item'); + } + + public function test_update_code_language_favourite() + { + $editor = $this->getEditor(); + $page = $this->entities->page(); + $this->actingAs($editor); + + $this->patch('/settings/users/update-code-language-favourite', ['language' => 'php', 'active' => true]); + $this->patch('/settings/users/update-code-language-favourite', ['language' => 'javascript', 'active' => true]); + + $resp = $this->get($page->getUrl('/edit')); + $resp->assertSee('option:code-editor:favourites="php,javascript"', false); + + $this->patch('/settings/users/update-code-language-favourite', ['language' => 'ruby', 'active' => true]); + $this->patch('/settings/users/update-code-language-favourite', ['language' => 'php', 'active' => false]); + + $resp = $this->get($page->getUrl('/edit')); + $resp->assertSee('option:code-editor:favourites="javascript,ruby"', false); + } +}