]> BookStack Code Mirror - bookstack/blob - tests/ImageTest.php
add missing polish translations for comments
[bookstack] / tests / ImageTest.php
1 <?php namespace Tests;
2
3 use BookStack\Image;
4 use BookStack\Page;
5
6 class ImageTest extends TestCase
7 {
8     /**
9      * Get the path to our basic test image.
10      * @return string
11      */
12     protected function getTestImageFilePath()
13     {
14         return base_path('tests/test-data/test-image.png');
15     }
16
17     /**
18      * Get a test image that can be uploaded
19      * @param $fileName
20      * @return \Illuminate\Http\UploadedFile
21      */
22     protected function getTestImage($fileName)
23     {
24         return new \Illuminate\Http\UploadedFile($this->getTestImageFilePath(), $fileName, 'image/jpeg', 5238);
25     }
26
27     /**
28      * Get the path for a test image.
29      * @param $type
30      * @param $fileName
31      * @return string
32      */
33     protected function getTestImagePath($type, $fileName)
34     {
35         return '/uploads/images/' . $type . '/' . Date('Y-m-M') . '/' . $fileName;
36     }
37
38     /**
39      * Uploads an image with the given name.
40      * @param $name
41      * @param int $uploadedTo
42      * @return \Illuminate\Foundation\Testing\TestResponse
43      */
44     protected function uploadImage($name, $uploadedTo = 0)
45     {
46         $file = $this->getTestImage($name);
47         return $this->call('POST', '/images/gallery/upload', ['uploaded_to' => $uploadedTo], [], ['file' => $file], []);
48     }
49
50     /**
51      * Delete an uploaded image.
52      * @param $relPath
53      */
54     protected function deleteImage($relPath)
55     {
56         $path = public_path($relPath);
57         if (file_exists($path)) {
58             unlink($path);
59         }
60     }
61
62
63     public function test_image_upload()
64     {
65         $page = Page::first();
66         $admin = $this->getAdmin();
67         $this->actingAs($admin);
68
69         $imageName = 'first-image.png';
70         $relPath = $this->getTestImagePath('gallery', $imageName);
71         $this->deleteImage($relPath);
72
73         $upload = $this->uploadImage($imageName, $page->id);
74         $upload->assertStatus(200);
75
76         $this->assertTrue(file_exists(public_path($relPath)), 'Uploaded image not found at path: '. public_path($relPath));
77
78         $this->deleteImage($relPath);
79
80         $this->assertDatabaseHas('images', [
81             'url' => $this->baseUrl . $relPath,
82             'type' => 'gallery',
83             'uploaded_to' => $page->id,
84             'path' => $relPath,
85             'created_by' => $admin->id,
86             'updated_by' => $admin->id,
87             'name' => $imageName
88         ]);
89
90     }
91
92     public function test_image_delete()
93     {
94         $page = Page::first();
95         $this->asAdmin();
96         $imageName = 'first-image.png';
97
98         $this->uploadImage($imageName, $page->id);
99         $image = Image::first();
100         $relPath = $this->getTestImagePath('gallery', $imageName);
101
102         $delete = $this->delete( '/images/' . $image->id);
103         $delete->assertStatus(200);
104
105         $this->assertDatabaseMissing('images', [
106             'url' => $this->baseUrl . $relPath,
107             'type' => 'gallery'
108         ]);
109
110         $this->assertFalse(file_exists(public_path($relPath)), 'Uploaded image has not been deleted as expected');
111     }
112
113     public function testBase64Get()
114     {
115         $page = Page::first();
116         $this->asAdmin();
117         $imageName = 'first-image.png';
118
119         $this->uploadImage($imageName, $page->id);
120         $image = Image::first();
121
122         $imageGet = $this->getJson("/images/base64/{$image->id}");
123         $imageGet->assertJson([
124             'content' => 'iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAIAAAACDbGyAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEcDCo5iYNs+gAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAAFElEQVQI12O0jN/KgASYGFABqXwAZtoBV6Sl3hIAAAAASUVORK5CYII='
125         ]);
126     }
127
128     public function test_drawing_base64_upload()
129     {
130         $page = Page::first();
131         $editor = $this->getEditor();
132         $this->actingAs($editor);
133
134         $upload = $this->postJson('images/drawing/upload', [
135             'uploaded_to' => $page->id,
136             'image' => 'image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAIAAAACDbGyAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEcDCo5iYNs+gAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAAFElEQVQI12O0jN/KgASYGFABqXwAZtoBV6Sl3hIAAAAASUVORK5CYII='
137         ]);
138
139         $upload->assertStatus(200);
140         $upload->assertJson([
141             'type' => 'drawio',
142             'uploaded_to' => $page->id,
143             'created_by' => $editor->id,
144             'updated_by' => $editor->id,
145         ]);
146
147         $image = Image::where('type', '=', 'drawio')->first();
148         $this->assertTrue(file_exists(public_path($image->path)), 'Uploaded image not found at path: '. public_path($image->path));
149
150         $testImageData = file_get_contents($this->getTestImageFilePath());
151         $uploadedImageData = file_get_contents(public_path($image->path));
152         $this->assertTrue($testImageData === $uploadedImageData, "Uploaded image file data does not match our test image as expected");
153     }
154
155     public function test_drawing_replacing()
156     {
157         $page = Page::first();
158         $editor = $this->getEditor();
159         $this->actingAs($editor);
160
161         $this->postJson('images/drawing/upload', [
162             'uploaded_to' => $page->id,
163             'image' => 'image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAIAAAACDbGyAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEcDQ4S1RUeKwAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAAFElEQVQI12NctNWSAQkwMaACUvkAfCkBmjyhGl4AAAAASUVORK5CYII='
164         ]);
165
166         $image = Image::where('type', '=', 'drawio')->first();
167
168         $replace = $this->putJson("images/drawing/upload/{$image->id}", [
169             'image' => 'image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAIAAAACDbGyAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEcDCo5iYNs+gAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAAFElEQVQI12O0jN/KgASYGFABqXwAZtoBV6Sl3hIAAAAASUVORK5CYII='
170         ]);
171
172         $replace->assertStatus(200);
173         $replace->assertJson([
174             'type' => 'drawio',
175             'uploaded_to' => $page->id,
176             'created_by' => $editor->id,
177             'updated_by' => $editor->id,
178         ]);
179
180         $this->assertTrue(file_exists(public_path($image->path)), 'Uploaded image not found at path: '. public_path($image->path));
181
182         $testImageData = file_get_contents($this->getTestImageFilePath());
183         $uploadedImageData = file_get_contents(public_path($image->path));
184         $this->assertTrue($testImageData === $uploadedImageData, "Uploaded image file data does not match our test image as expected");
185     }
186
187     public function test_user_images_deleted_on_user_deletion()
188     {
189         $editor = $this->getEditor();
190         $this->actingAs($editor);
191
192         $imageName = 'profile.png';
193         $relPath = $this->getTestImagePath('gallery', $imageName);
194         $this->deleteImage($relPath);
195
196         $file = $this->getTestImage($imageName);
197         $this->call('POST', '/images/user/upload', [], [], ['file' => $file], []);
198         $this->call('POST', '/images/user/upload', [], [], ['file' => $file], []);
199
200         $profileImages = Image::where('type', '=', 'user')->where('created_by', '=', $editor->id)->get();
201         $this->assertTrue($profileImages->count() === 2, "Found profile images does not match upload count");
202
203         $userDelete = $this->asAdmin()->delete("/settings/users/{$editor->id}");
204         $userDelete->assertStatus(302);
205         $this->assertDatabaseMissing('images', [
206             'type' => 'user',
207             'created_by' => $editor->id
208         ]);
209     }
210
211 }
Morty Proxy This is a proxified and sanitized view of the page, visit original site.