X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/1d1cc19596ac30d40a74ee751011b9bac038c47c..refs/pull/3000/head:/tests/TestCase.php diff --git a/tests/TestCase.php b/tests/TestCase.php index 94751b004..98e0dfbac 100644 --- a/tests/TestCase.php +++ b/tests/TestCase.php @@ -1,10 +1,8 @@ -actingAs($this->getAdmin()); - } + $this->assertTrue(session()->has($key), "Session does not contain a [{$key}] entry"); - /** - * 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; + 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; + return parent::get($uri, $headers); } /** - * Create and return a new book. - * @param array $input - * @return Book + * Create the test response instance from the given response. + * + * @param \Illuminate\Http\Response $response + * + * @return TestResponse */ - public function newBook($input = ['name' => 'test book', 'description' => 'My new test book']) { - return $this->app[EntityRepo::class]->createFromInput('book', $input, false); + protected function createTestResponse($response) + { + return TestResponse::fromBaseResponse($response); } /** - * Create and return a new test chapter - * @param array $input - * @param Book $book - * @return Chapter + * Assert that an activity entry exists of the given key. + * Checks the activity belongs to the given entity if provided. */ - public function newChapter($input = ['name' => 'test chapter', 'description' => 'My new test chapter'], Book $book) { - return $this->app[EntityRepo::class]->createFromInput('chapter', $input, $book); - } + protected function assertActivityExists(string $type, ?Entity $entity = null, string $detail = '') + { + $detailsToCheck = ['type' => $type]; - /** - * Create and return a new test page - * @param array $input - * @return Chapter - */ - 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); - } + if ($entity) { + $detailsToCheck['entity_type'] = $entity->getMorphClass(); + $detailsToCheck['entity_id'] = $entity->id; + } - /** - * Quickly sets an array of settings. - * @param $settingsArray - */ - protected function setSettings($settingsArray) - { - $settings = app(SettingService::class); - foreach ($settingsArray as $key => $value) { - $settings->put($key, $value); + if ($detail) { + $detailsToCheck['detail'] = $detail; } + + $this->assertDatabaseHas('activities', $detailsToCheck); } -} \ No newline at end of file +}