X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/87e18b80684dedc761e669d375f59b548e4ab52f..refs/pull/2393/head:/tests/TestCase.php diff --git a/tests/TestCase.php b/tests/TestCase.php index b008080d9..2c901981a 100644 --- a/tests/TestCase.php +++ b/tests/TestCase.php @@ -1,9 +1,6 @@ actingAs($this->getAdmin()); - } + use SharedTestHelpers; /** - * Get the current admin user. - * @return mixed + * The base URL to use while testing the application. + * @var string */ - public function getAdmin() { - if($this->admin === null) { - $adminRole = Role::getSystemRole('admin'); - $this->admin = $adminRole->users->first(); - } - return $this->admin; - } + protected $baseUrl = 'http://localhost'; /** - * Set the current user context to be an editor. + * Assert the session contains a specific entry. + * @param string $key * @return $this */ - public function asEditor() + protected function assertSessionHas(string $key) { - return $this->actingAs($this->getEditor()); + $this->assertTrue(session()->has($key), "Session does not contain a [{$key}] entry"); + return $this; } - /** - * Get a editor user. - * @return mixed + * Override of the get method so we can get visibility of custom TestResponse methods. + * @param string $uri + * @param array $headers + * @return TestResponse */ - public function getEditor() { - if($this->editor === null) { - $editorRole = Role::getRole('editor'); - $this->editor = $editorRole->users->first(); - } - return $this->editor; + public function get($uri, array $headers = []) + { + 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) + { + $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; + } + + $this->assertDatabaseHas('activities', $detailsToCheck); } } \ No newline at end of file