]> git.immae.eu Git - github/wallabag/wallabag.git/blame - tests/Wallabag/CoreBundle/Helper/DownloadImagesTest.php
Fix image downloading on null image path
[github/wallabag/wallabag.git] / tests / Wallabag / CoreBundle / Helper / DownloadImagesTest.php
CommitLineData
7f559418
JB
1<?php
2
3namespace Tests\Wallabag\CoreBundle\Helper;
4
7f559418 5use GuzzleHttp\Client;
7f559418
JB
6use GuzzleHttp\Message\Response;
7use GuzzleHttp\Stream\Stream;
f808b016
JB
8use GuzzleHttp\Subscriber\Mock;
9use Monolog\Handler\TestHandler;
10use Monolog\Logger;
bd91bd5c 11use PHPUnit\Framework\TestCase;
f808b016 12use Wallabag\CoreBundle\Helper\DownloadImages;
7f559418 13
bd91bd5c 14class DownloadImagesTest extends TestCase
7f559418 15{
fcad69a4
JB
16 public function dataForSuccessImage()
17 {
18 return [
19 'imgur' => [
20 '<div><img src="http://i.imgur.com/T9qgcHc.jpg" /></div>',
21 'http://imgur.com/gallery/WxtWY',
22 ],
23 'image with &' => [
24 '<div><img src="https://i2.wp.com/www.tvaddons.ag/wp-content/uploads/2017/01/Screen-Shot-2017-01-07-at-10.17.40-PM.jpg?w=640&amp;ssl=1" /></div>',
25 'https://www.tvaddons.ag/realdebrid-kodi-jarvis/',
26 ],
27 ];
28 }
29
30 /**
31 * @dataProvider dataForSuccessImage
32 */
33 public function testProcessHtml($html, $url)
7f559418
JB
34 {
35 $client = new Client();
36
37 $mock = new Mock([
f808b016 38 new Response(200, ['content-type' => 'image/png'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
7f559418
JB
39 ]);
40
41 $client->getEmitter()->attach($mock);
42
43 $logHandler = new TestHandler();
f808b016 44 $logger = new Logger('test', [$logHandler]);
7f559418 45
f808b016 46 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
41ada277 47
fcad69a4 48 $res = $download->processHtml(123, $html, $url);
7f559418 49
fcad69a4
JB
50 // this the base path of all image (since it's calculated using the entry id: 123)
51 $this->assertContains('http://wallabag.io/assets/images/9/b/9b0ead26/', $res);
7f559418
JB
52 }
53
54 public function testProcessHtmlWithBadImage()
55 {
56 $client = new Client();
57
58 $mock = new Mock([
59 new Response(200, ['content-type' => 'application/json'], Stream::factory('')),
60 ]);
61
62 $client->getEmitter()->attach($mock);
63
64 $logHandler = new TestHandler();
f808b016 65 $logger = new Logger('test', [$logHandler]);
7f559418 66
f808b016 67 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
e0597476 68 $res = $download->processHtml(123, '<div><img src="http://i.imgur.com/T9qgcHc.jpg" /></div>', 'http://imgur.com/gallery/WxtWY');
7f559418
JB
69
70 $this->assertContains('http://i.imgur.com/T9qgcHc.jpg', $res, 'Image were not replace because of content-type');
71 }
72
73 public function singleImage()
74 {
75 return [
76 ['image/pjpeg', 'jpeg'],
77 ['image/jpeg', 'jpeg'],
78 ['image/png', 'png'],
79 ['image/gif', 'gif'],
80 ];
81 }
82
83 /**
84 * @dataProvider singleImage
85 */
86 public function testProcessSingleImage($header, $extension)
87 {
88 $client = new Client();
89
90 $mock = new Mock([
f808b016 91 new Response(200, ['content-type' => $header], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
7f559418
JB
92 ]);
93
94 $client->getEmitter()->attach($mock);
95
96 $logHandler = new TestHandler();
f808b016 97 $logger = new Logger('test', [$logHandler]);
7f559418 98
f808b016 99 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
e0597476 100 $res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
7f559418 101
f808b016 102 $this->assertContains('/assets/images/9/b/9b0ead26/ebe60399.' . $extension, $res);
7f559418
JB
103 }
104
48656e0e
JB
105 public function testProcessSingleImageWithBadUrl()
106 {
107 $client = new Client();
108
109 $mock = new Mock([
110 new Response(404, []),
111 ]);
112
113 $client->getEmitter()->attach($mock);
114
115 $logHandler = new TestHandler();
f808b016 116 $logger = new Logger('test', [$logHandler]);
48656e0e 117
f808b016 118 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
e0597476 119 $res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
48656e0e
JB
120
121 $this->assertFalse($res, 'Image can not be found, so it will not be replaced');
122 }
123
7f559418
JB
124 public function testProcessSingleImageWithBadImage()
125 {
126 $client = new Client();
127
128 $mock = new Mock([
129 new Response(200, ['content-type' => 'image/png'], Stream::factory('')),
130 ]);
131
132 $client->getEmitter()->attach($mock);
133
134 $logHandler = new TestHandler();
f808b016 135 $logger = new Logger('test', [$logHandler]);
7f559418 136
f808b016 137 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
e0597476 138 $res = $download->processSingleImage(123, 'http://i.imgur.com/T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
7f559418
JB
139
140 $this->assertFalse($res, 'Image can not be loaded, so it will not be replaced');
141 }
142
143 public function testProcessSingleImageFailAbsolute()
144 {
145 $client = new Client();
146
147 $mock = new Mock([
f808b016 148 new Response(200, ['content-type' => 'image/png'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
7f559418
JB
149 ]);
150
151 $client->getEmitter()->attach($mock);
152
153 $logHandler = new TestHandler();
f808b016 154 $logger = new Logger('test', [$logHandler]);
7f559418 155
f808b016 156 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
e0597476 157 $res = $download->processSingleImage(123, '/i.imgur.com/T9qgcHc.jpg', 'imgur.com/gallery/WxtWY');
7f559418
JB
158
159 $this->assertFalse($res, 'Absolute image can not be determined, so it will not be replaced');
160 }
577c0b6d
JB
161
162 public function testProcessRealImage()
163 {
164 $client = new Client();
165
166 $mock = new Mock([
f808b016 167 new Response(200, ['content-type' => null], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
577c0b6d
JB
168 ]);
169
170 $client->getEmitter()->attach($mock);
171
172 $logHandler = new TestHandler();
f808b016 173 $logger = new Logger('test', [$logHandler]);
577c0b6d 174
f808b016 175 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
577c0b6d
JB
176
177 $res = $download->processSingleImage(
178 123,
179 'https://cdn.theconversation.com/files/157200/article/width926/gsj2rjp2-1487348607.jpg',
180 'https://theconversation.com/conversation-avec-gerald-bronner-ce-nest-pas-la-post-verite-qui-nous-menace-mais-lextension-de-notre-credulite-73089'
181 );
182
183 $this->assertContains('http://wallabag.io/assets/images/9/b/9b0ead26/', $res, 'Content-Type was empty but data is ok for an image');
184 $this->assertContains('DownloadImages: Checking extension (alternative)', $logHandler->getRecords()[3]['message']);
185 }
c15bb5ad
S
186
187 public function testProcessImageWithSrcset()
188 {
189 $client = new Client();
190
191 $mock = new Mock([
192 new Response(200, ['content-type' => 'image/jpeg'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
193 new Response(200, ['content-type' => 'image/jpeg'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
194 new Response(200, ['content-type' => 'image/jpeg'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
195 ]);
196
197 $client->getEmitter()->attach($mock);
198
199 $logHandler = new TestHandler();
200 $logger = new Logger('test', [$logHandler]);
201
202 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
203 $res = $download->processHtml(123, '<p><img class="alignnone wp-image-1153" src="http://piketty.blog.lemonde.fr/files/2017/10/F1FR-530x375.jpg" alt="" width="628" height="444" srcset="http://piketty.blog.lemonde.fr/files/2017/10/F1FR-530x375.jpg 530w, http://piketty.blog.lemonde.fr/files/2017/10/F1FR-768x543.jpg 768w, http://piketty.blog.lemonde.fr/files/2017/10/F1FR-900x636.jpg 900w" sizes="(max-width: 628px) 100vw, 628px" /></p>', 'http://piketty.blog.lemonde.fr/2017/10/12/budget-2018-la-jeunesse-sacrifiee/');
204
205 $this->assertNotContains('http://piketty.blog.lemonde.fr/', $res, 'Image srcset attribute were not replaced');
206 }
3fbbe0d9
S
207
208 public function testProcessImageWithNullPath()
209 {
210 $client = new Client();
211
212 $mock = new Mock([
213 new Response(200, ['content-type' => null], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
214 ]);
215
216 $client->getEmitter()->attach($mock);
217
218 $logHandler = new TestHandler();
219 $logger = new Logger('test', [$logHandler]);
220
221 $download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
222
223 $res = $download->processSingleImage(
224 123,
225 null,
226 'https://framablog.org/2018/06/30/engagement-atypique/'
227 );
228 $this->assertFalse($res);
229 }
7f559418 230}