X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/1d1cc19596ac30d40a74ee751011b9bac038c47c..refs/pull/2023/head:/tests/TestCase.php diff --git a/tests/TestCase.php b/tests/TestCase.php index 94751b004..1f1d5ece7 100644 --- a/tests/TestCase.php +++ b/tests/TestCase.php @@ -1,10 +1,6 @@ actingAs($this->getAdmin()); - } - - /** - * Get the current admin user. - * @return mixed - */ - public function getAdmin() { - if($this->admin === null) { - $adminRole = Role::getSystemRole('admin'); - $this->admin = $adminRole->users->first(); - } - return $this->admin; + $this->assertTrue(session()->has($key), "Session does not contain a [{$key}] entry"); + return $this; } /** - * Set the current user context to be an editor. - * @return $this + * Override of the get method so we can get visibility of custom TestResponse methods. + * @param string $uri + * @param array $headers + * @return TestResponse */ - public function asEditor() + public function get($uri, array $headers = []) { - return $this->actingAs($this->getEditor()); - } - - - /** - * Get a editor user. - * @return mixed - */ - public function getEditor() { - if($this->editor === null) { - $editorRole = Role::getRole('editor'); - $this->editor = $editorRole->users->first(); - } - return $this->editor; - } - - /** - * Create and return a new book. - * @param array $input - * @return Book - */ - public function newBook($input = ['name' => 'test book', 'description' => 'My new test book']) { - return $this->app[EntityRepo::class]->createFromInput('book', $input, false); - } - - /** - * Create and return a new test chapter - * @param array $input - * @param Book $book - * @return Chapter - */ - public function newChapter($input = ['name' => 'test chapter', 'description' => 'My new test chapter'], Book $book) { - return $this->app[EntityRepo::class]->createFromInput('chapter', $input, $book); + return parent::get($uri, $headers); } /** - * Create and return a new test page - * @param array $input - * @return Chapter + * Create the test response instance from the given response. + * + * @param \Illuminate\Http\Response $response + * @return TestResponse */ - public function newPage($input = ['name' => 'test page', 'html' => 'My new test page']) { - $book = Book::first(); - $entityRepo = $this->app[EntityRepo::class]; - $draftPage = $entityRepo->getDraftPage($book); - return $entityRepo->publishPageDraft($draftPage, $input); + protected function createTestResponse($response) + { + return TestResponse::fromBaseResponse($response); } /** - * Quickly sets an array of settings. - * @param $settingsArray + * Assert that an activity entry exists of the given key. + * Checks the activity belongs to the given entity if provided. */ - protected function setSettings($settingsArray) + protected function assertActivityExists(string $key, Entity $entity = null) { - $settings = app(SettingService::class); - foreach ($settingsArray as $key => $value) { - $settings->put($key, $value); + $detailsToCheck = ['key' => $key]; + + if ($entity) { + $detailsToCheck['entity_type'] = $entity->getMorphClass(); + $detailsToCheck['entity_id'] = $entity->id; } + + $this->assertDatabaseHas('activities', $detailsToCheck); } } \ No newline at end of file