X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/dabe79a438f22612e7d68c8d1de7817505b59b93..refs/pull/3918/head:/tests/Uploads/UsesImages.php diff --git a/tests/Uploads/UsesImages.php b/tests/Uploads/UsesImages.php index b24b483d9..e2c16c37c 100644 --- a/tests/Uploads/UsesImages.php +++ b/tests/Uploads/UsesImages.php @@ -1,16 +1,17 @@ -getTestImageFilePath($testDataFileName), $fileName, 'image/png', 5238, null, true); + $imagePath = implode(DIRECTORY_SEPARATOR, [sys_get_temp_dir(), $imageFileName]); + $base64FilePath = $this->getTestImageFilePath($base64FileName); + $data = file_get_contents($base64FilePath); + $decoded = base64_decode($data); + file_put_contents($imagePath, $decoded); + + return new UploadedFile($imagePath, $imageFileName, 'image/png', null, true); + } + + /** + * Get a test image that can be uploaded. + */ + protected function getTestImage(string $fileName, ?string $testDataFileName = null): UploadedFile + { + return new UploadedFile($this->getTestImageFilePath($testDataFileName), $fileName, 'image/png', null, true); } /** * Get the raw file data for the test image. + * * @return false|string */ protected function getTestImageContent() @@ -40,25 +56,25 @@ trait UsesImages /** * Get the path for a test image. - * @param $type - * @param $fileName - * @return string */ - protected function getTestImagePath($type, $fileName) + protected function getTestImagePath(string $type, string $fileName): string { - return '/uploads/images/' . $type . '/' . Date('Y-m') . '/' . $fileName; + return '/uploads/images/' . $type . '/' . date('Y-m') . '/' . $fileName; } /** * Uploads an image with the given name. + * * @param $name - * @param int $uploadedTo + * @param int $uploadedTo * @param string $contentType + * * @return \Illuminate\Foundation\Testing\TestResponse */ protected function uploadImage($name, $uploadedTo = 0, $contentType = 'image/png', ?string $testDataFileName = null) { $file = $this->getTestImage($name, $testDataFileName); + return $this->withHeader('Content-Type', $contentType) ->call('POST', '/images/gallery', ['uploaded_to' => $uploadedTo], [], ['file' => $file], []); } @@ -67,13 +83,15 @@ trait UsesImages * Upload a new gallery image. * Returns the image name. * Can provide a page to relate the image to. + * * @param Page|null $page - * @return array + * + * @return array{name: string, path: string, page: Page, response: stdClass} */ protected function uploadGalleryImage(Page $page = null, ?string $testDataFileName = null) { if ($page === null) { - $page = Page::query()->first(); + $page = $this->entities->page(); } $imageName = $testDataFileName ?? 'first-image.png'; @@ -82,24 +100,23 @@ trait UsesImages $upload = $this->uploadImage($imageName, $page->id, 'image/png', $testDataFileName); $upload->assertStatus(200); + return [ - 'name' => $imageName, - 'path' => $relPath, - 'page' => $page, + 'name' => $imageName, + 'path' => $relPath, + 'page' => $page, 'response' => json_decode($upload->getContent()), ]; } /** * Delete an uploaded image. - * @param $relPath */ - protected function deleteImage($relPath) + protected function deleteImage(string $relPath) { $path = public_path($relPath); if (file_exists($path)) { unlink($path); } } - -} \ No newline at end of file +}