5 use BookStack\Actions\ActivityType;
6 use BookStack\Auth\User;
7 use BookStack\Entities\Models\Page;
10 class UserManagementTest extends TestCase
12 public function test_delete()
14 $editor = $this->getEditor();
15 $resp = $this->asAdmin()->delete("settings/users/{$editor->id}");
16 $resp->assertRedirect('/settings/users');
17 $resp = $this->followRedirects($resp);
19 $resp->assertSee('User successfully removed');
20 $this->assertActivityExists(ActivityType::USER_DELETE);
22 $this->assertDatabaseMissing('users', ['id' => $editor->id]);
25 public function test_delete_offers_migrate_option()
27 $editor = $this->getEditor();
28 $resp = $this->asAdmin()->get("settings/users/{$editor->id}/delete");
29 $resp->assertSee('Migrate Ownership');
30 $resp->assertSee('new_owner_id');
33 public function test_delete_with_new_owner_id_changes_ownership()
35 $page = Page::query()->first();
36 $owner = $page->ownedBy;
37 $newOwner = User::query()->where('id', '!=', $owner->id)->first();
39 $this->asAdmin()->delete("settings/users/{$owner->id}", ['new_owner_id' => $newOwner->id]);
40 $this->assertDatabaseHas('pages', [
42 'owned_by' => $newOwner->id,
46 public function test_guest_profile_shows_limited_form()
48 $guest = User::getDefault();
49 $resp = $this->asAdmin()->get('/settings/users/' . $guest->id);
50 $resp->assertSee('Guest');
51 $resp->assertElementNotExists('#password');
54 public function test_guest_profile_cannot_be_deleted()
56 $guestUser = User::getDefault();
57 $resp = $this->asAdmin()->get('/settings/users/' . $guestUser->id . '/delete');
58 $resp->assertSee('Delete User');
59 $resp->assertSee('Guest');
60 $resp->assertElementContains('form[action$="/settings/users/' . $guestUser->id . '"] button', 'Confirm');
62 $resp = $this->delete('/settings/users/' . $guestUser->id);
63 $resp->assertRedirect('/settings/users/' . $guestUser->id);
64 $resp = $this->followRedirects($resp);
65 $resp->assertSee('cannot delete the guest user');