aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php')
-rw-r--r--tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php294
1 files changed, 161 insertions, 133 deletions
diff --git a/tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php b/tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php
index 4f70ed0c..a3570125 100644
--- a/tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php
+++ b/tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php
@@ -3,10 +3,14 @@
3namespace Tests\Wallabag\CoreBundle\Helper; 3namespace Tests\Wallabag\CoreBundle\Helper;
4 4
5use Psr\Log\NullLogger; 5use Psr\Log\NullLogger;
6use Monolog\Logger;
7use Monolog\Handler\TestHandler;
6use Wallabag\CoreBundle\Helper\ContentProxy; 8use Wallabag\CoreBundle\Helper\ContentProxy;
7use Wallabag\CoreBundle\Entity\Entry; 9use Wallabag\CoreBundle\Entity\Entry;
8use Wallabag\CoreBundle\Entity\Tag; 10use Wallabag\CoreBundle\Entity\Tag;
9use Wallabag\UserBundle\Entity\User; 11use Wallabag\UserBundle\Entity\User;
12use Wallabag\CoreBundle\Helper\RuleBasedTagger;
13use Graby\Graby;
10 14
11class ContentProxyTest extends \PHPUnit_Framework_TestCase 15class ContentProxyTest extends \PHPUnit_Framework_TestCase
12{ 16{
@@ -33,8 +37,9 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
33 'language' => '', 37 'language' => '',
34 ]); 38 ]);
35 39
36 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 40 $proxy = new ContentProxy($graby, $tagger, $this->getLogger(), $this->fetchingErrorMessage);
37 $entry = $proxy->updateEntry(new Entry(new User()), 'http://user@:80'); 41 $entry = new Entry(new User());
42 $proxy->updateEntry($entry, 'http://user@:80');
38 43
39 $this->assertEquals('http://user@:80', $entry->getUrl()); 44 $this->assertEquals('http://user@:80', $entry->getUrl());
40 $this->assertEmpty($entry->getTitle()); 45 $this->assertEmpty($entry->getTitle());
@@ -67,8 +72,9 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
67 'language' => '', 72 'language' => '',
68 ]); 73 ]);
69 74
70 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 75 $proxy = new ContentProxy($graby, $tagger, $this->getLogger(), $this->fetchingErrorMessage);
71 $entry = $proxy->updateEntry(new Entry(new User()), 'http://0.0.0.0'); 76 $entry = new Entry(new User());
77 $proxy->updateEntry($entry, 'http://0.0.0.0');
72 78
73 $this->assertEquals('http://0.0.0.0', $entry->getUrl()); 79 $this->assertEquals('http://0.0.0.0', $entry->getUrl());
74 $this->assertEmpty($entry->getTitle()); 80 $this->assertEmpty($entry->getTitle());
@@ -106,12 +112,13 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
106 ], 112 ],
107 ]); 113 ]);
108 114
109 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 115 $proxy = new ContentProxy($graby, $tagger, $this->getLogger(), $this->fetchingErrorMessage);
110 $entry = $proxy->updateEntry(new Entry(new User()), 'http://domain.io'); 116 $entry = new Entry(new User());
117 $proxy->updateEntry($entry, 'http://domain.io');
111 118
112 $this->assertEquals('http://domain.io', $entry->getUrl()); 119 $this->assertEquals('http://domain.io', $entry->getUrl());
113 $this->assertEquals('my title', $entry->getTitle()); 120 $this->assertEquals('my title', $entry->getTitle());
114 $this->assertEquals($this->fetchingErrorMessage . '<p><i>But we found a short description: </i></p>desc', $entry->getContent()); 121 $this->assertEquals($this->fetchingErrorMessage.'<p><i>But we found a short description: </i></p>desc', $entry->getContent());
115 $this->assertEmpty($entry->getPreviewPicture()); 122 $this->assertEmpty($entry->getPreviewPicture());
116 $this->assertEmpty($entry->getLanguage()); 123 $this->assertEmpty($entry->getLanguage());
117 $this->assertEmpty($entry->getHttpStatus()); 124 $this->assertEmpty($entry->getHttpStatus());
@@ -147,8 +154,9 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
147 ], 154 ],
148 ]); 155 ]);
149 156
150 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 157 $proxy = new ContentProxy($graby, $tagger, $this->getLogger(), $this->fetchingErrorMessage);
151 $entry = $proxy->updateEntry(new Entry(new User()), 'http://0.0.0.0'); 158 $entry = new Entry(new User());
159 $proxy->updateEntry($entry, 'http://0.0.0.0');
152 160
153 $this->assertEquals('http://1.1.1.1', $entry->getUrl()); 161 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
154 $this->assertEquals('this is my title', $entry->getTitle()); 162 $this->assertEquals('this is my title', $entry->getTitle());
@@ -188,8 +196,9 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
188 ], 196 ],
189 ]); 197 ]);
190 198
191 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 199 $proxy = new ContentProxy($graby, $tagger, $this->getLogger(), $this->fetchingErrorMessage);
192 $entry = $proxy->updateEntry(new Entry(new User()), 'http://0.0.0.0'); 200 $entry = new Entry(new User());
201 $proxy->updateEntry($entry, 'http://0.0.0.0');
193 202
194 $this->assertEquals('http://1.1.1.1', $entry->getUrl()); 203 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
195 $this->assertEquals('this is my title', $entry->getTitle()); 204 $this->assertEquals('this is my title', $entry->getTitle());
@@ -208,16 +217,24 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
208 $tagger->expects($this->once()) 217 $tagger->expects($this->once())
209 ->method('tag'); 218 ->method('tag');
210 219
211 $graby = $this->getMockBuilder('Graby\Graby')->getMock(); 220 $proxy = new ContentProxy((new Graby()), $tagger, $this->getLogger(), $this->fetchingErrorMessage);
212 221 $entry = new Entry(new User());
213 $proxy = new ContentProxy($graby, $tagger, $this->getTagRepositoryMock(), $this->getLogger(), $this->fetchingErrorMessage); 222 $proxy->updateEntry(
214 $entry = $proxy->updateEntry(new Entry(new User()), 'http://0.0.0.0', [ 223 $entry,
215 'html' => str_repeat('this is my content', 325), 224 'http://0.0.0.0',
216 'title' => 'this is my title', 225 [
217 'url' => 'http://1.1.1.1', 226 'html' => str_repeat('this is my content', 325),
218 'content_type' => 'text/html', 227 'title' => 'this is my title',
219 'language' => 'fr', 228 'url' => 'http://1.1.1.1',
220 ]); 229 'content_type' => 'text/html',
230 'language' => 'fr',
231 'date' => '1395635872',
232 'authors' => ['Jeremy', 'Nico', 'Thomas'],
233 'all_headers' => [
234 'Cache-Control' => 'no-cache',
235 ],
236 ]
237 );
221 238
222 $this->assertEquals('http://1.1.1.1', $entry->getUrl()); 239 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
223 $this->assertEquals('this is my title', $entry->getTitle()); 240 $this->assertEquals('this is my title', $entry->getTitle());
@@ -226,161 +243,172 @@ class ContentProxyTest extends \PHPUnit_Framework_TestCase
226 $this->assertEquals('fr', $entry->getLanguage()); 243 $this->assertEquals('fr', $entry->getLanguage());
227 $this->assertEquals(4.0, $entry->getReadingTime()); 244 $this->assertEquals(4.0, $entry->getReadingTime());
228 $this->assertEquals('1.1.1.1', $entry->getDomainName()); 245 $this->assertEquals('1.1.1.1', $entry->getDomainName());
246 $this->assertEquals('24/03/2014', $entry->getPublishedAt()->format('d/m/Y'));
247 $this->assertContains('Jeremy', $entry->getPublishedBy());
248 $this->assertContains('Nico', $entry->getPublishedBy());
249 $this->assertContains('Thomas', $entry->getPublishedBy());
250 $this->assertContains('no-cache', $entry->getHeaders());
229 } 251 }
230 252
231 public function testTaggerThrowException() 253 public function testWithForcedContentAndDatetime()
232 { 254 {
233 $graby = $this->getMockBuilder('Graby\Graby')
234 ->disableOriginalConstructor()
235 ->getMock();
236
237 $tagger = $this->getTaggerMock(); 255 $tagger = $this->getTaggerMock();
238 $tagger->expects($this->once()) 256 $tagger->expects($this->once())
239 ->method('tag') 257 ->method('tag');
240 ->will($this->throwException(new \Exception()));
241
242 $tagRepo = $this->getTagRepositoryMock();
243 $proxy = new ContentProxy($graby, $tagger, $tagRepo, $this->getLogger(), $this->fetchingErrorMessage);
244
245 $entry = $proxy->updateEntry(new Entry(new User()), 'http://0.0.0.0', [
246 'html' => str_repeat('this is my content', 325),
247 'title' => 'this is my title',
248 'url' => 'http://1.1.1.1',
249 'content_type' => 'text/html',
250 'language' => 'fr',
251 ]);
252
253 $this->assertCount(0, $entry->getTags());
254 }
255
256 public function testAssignTagsWithArrayAndExtraSpaces()
257 {
258 $graby = $this->getMockBuilder('Graby\Graby')
259 ->disableOriginalConstructor()
260 ->getMock();
261 258
262 $tagRepo = $this->getTagRepositoryMock(); 259 $logHandler = new TestHandler();
263 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage); 260 $logger = new Logger('test', [$logHandler]);
264 261
262 $proxy = new ContentProxy((new Graby()), $tagger, $logger, $this->fetchingErrorMessage);
265 $entry = new Entry(new User()); 263 $entry = new Entry(new User());
264 $proxy->updateEntry(
265 $entry,
266 'http://1.1.1.1',
267 [
268 'html' => str_repeat('this is my content', 325),
269 'title' => 'this is my title',
270 'url' => 'http://1.1.1.1',
271 'content_type' => 'text/html',
272 'language' => 'fr',
273 'date' => '2016-09-08T11:55:58+0200',
274 ]
275 );
266 276
267 $proxy->assignTagsToEntry($entry, [' tag1', 'tag2 ']); 277 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
268 278 $this->assertEquals('this is my title', $entry->getTitle());
269 $this->assertCount(2, $entry->getTags()); 279 $this->assertContains('this is my content', $entry->getContent());
270 $this->assertEquals('tag1', $entry->getTags()[0]->getLabel()); 280 $this->assertEquals('text/html', $entry->getMimetype());
271 $this->assertEquals('tag2', $entry->getTags()[1]->getLabel()); 281 $this->assertEquals('fr', $entry->getLanguage());
282 $this->assertEquals(4.0, $entry->getReadingTime());
283 $this->assertEquals('1.1.1.1', $entry->getDomainName());
284 $this->assertEquals('08/09/2016', $entry->getPublishedAt()->format('d/m/Y'));
272 } 285 }
273 286
274 public function testAssignTagsWithString() 287 public function testWithForcedContentAndBadDate()
275 { 288 {
276 $graby = $this->getMockBuilder('Graby\Graby') 289 $tagger = $this->getTaggerMock();
277 ->disableOriginalConstructor() 290 $tagger->expects($this->once())
278 ->getMock(); 291 ->method('tag');
279 292
280 $tagRepo = $this->getTagRepositoryMock(); 293 $logger = new Logger('foo');
281 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage); 294 $handler = new TestHandler();
295 $logger->pushHandler($handler);
282 296
297 $proxy = new ContentProxy((new Graby()), $tagger, $logger, $this->fetchingErrorMessage);
283 $entry = new Entry(new User()); 298 $entry = new Entry(new User());
299 $proxy->updateEntry(
300 $entry,
301 'http://1.1.1.1',
302 [
303 'html' => str_repeat('this is my content', 325),
304 'title' => 'this is my title',
305 'url' => 'http://1.1.1.1',
306 'content_type' => 'text/html',
307 'language' => 'fr',
308 'date' => '01 02 2012',
309 ]
310 );
284 311
285 $proxy->assignTagsToEntry($entry, 'tag1, tag2'); 312 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
286 313 $this->assertEquals('this is my title', $entry->getTitle());
287 $this->assertCount(2, $entry->getTags()); 314 $this->assertContains('this is my content', $entry->getContent());
288 $this->assertEquals('tag1', $entry->getTags()[0]->getLabel()); 315 $this->assertEquals('text/html', $entry->getMimetype());
289 $this->assertEquals('tag2', $entry->getTags()[1]->getLabel()); 316 $this->assertEquals('fr', $entry->getLanguage());
290 } 317 $this->assertEquals(4.0, $entry->getReadingTime());
291 318 $this->assertEquals('1.1.1.1', $entry->getDomainName());
292 public function testAssignTagsWithEmptyArray() 319 $this->assertNull($entry->getPublishedAt());
293 {
294 $graby = $this->getMockBuilder('Graby\Graby')
295 ->disableOriginalConstructor()
296 ->getMock();
297
298 $tagRepo = $this->getTagRepositoryMock();
299 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage);
300
301 $entry = new Entry(new User());
302 320
303 $proxy->assignTagsToEntry($entry, []); 321 $records = $handler->getRecords();
304 322
305 $this->assertCount(0, $entry->getTags()); 323 $this->assertCount(1, $records);
324 $this->assertContains('Error while defining date', $records[0]['message']);
306 } 325 }
307 326
308 public function testAssignTagsWithEmptyString() 327 public function testTaggerThrowException()
309 { 328 {
310 $graby = $this->getMockBuilder('Graby\Graby') 329 $tagger = $this->getTaggerMock();
311 ->disableOriginalConstructor() 330 $tagger->expects($this->once())
312 ->getMock(); 331 ->method('tag')
313 332 ->will($this->throwException(new \Exception()));
314 $tagRepo = $this->getTagRepositoryMock();
315 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage);
316 333
334 $proxy = new ContentProxy((new Graby()), $tagger, $this->getLogger(), $this->fetchingErrorMessage);
317 $entry = new Entry(new User()); 335 $entry = new Entry(new User());
318 336 $proxy->updateEntry(
319 $proxy->assignTagsToEntry($entry, ''); 337 $entry,
338 'http://1.1.1.1',
339 [
340 'html' => str_repeat('this is my content', 325),
341 'title' => 'this is my title',
342 'url' => 'http://1.1.1.1',
343 'content_type' => 'text/html',
344 'language' => 'fr',
345 ]
346 );
320 347
321 $this->assertCount(0, $entry->getTags()); 348 $this->assertCount(0, $entry->getTags());
322 } 349 }
323 350
324 public function testAssignTagsAlreadyAssigned() 351 public function dataForCrazyHtml()
325 { 352 {
326 $graby = $this->getMockBuilder('Graby\Graby') 353 return [
327 ->disableOriginalConstructor() 354 'script and comment' => [
328 ->getMock(); 355 '<strong>Script inside:</strong> <!--[if gte IE 4]><script>alert(\'lol\');</script><![endif]--><br />',
329 356 'lol',
330 $tagRepo = $this->getTagRepositoryMock(); 357 ],
331 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage); 358 'script' => [
332 359 '<strong>Script inside:</strong><script>alert(\'lol\');</script>',
333 $tagEntity = new Tag(); 360 'script',
334 $tagEntity->setLabel('tag1'); 361 ],
335 362 ];
336 $entry = new Entry(new User());
337 $entry->addTag($tagEntity);
338
339 $proxy->assignTagsToEntry($entry, 'tag1, tag2');
340
341 $this->assertCount(2, $entry->getTags());
342 $this->assertEquals('tag1', $entry->getTags()[0]->getLabel());
343 $this->assertEquals('tag2', $entry->getTags()[1]->getLabel());
344 } 363 }
345 364
346 public function testAssignTagsNotFlushed() 365 /**
366 * @dataProvider dataForCrazyHtml
367 */
368 public function testWithCrazyHtmlContent($html, $escapedString)
347 { 369 {
348 $graby = $this->getMockBuilder('Graby\Graby') 370 $tagger = $this->getTaggerMock();
349 ->disableOriginalConstructor() 371 $tagger->expects($this->once())
350 ->getMock(); 372 ->method('tag');
351
352 $tagRepo = $this->getTagRepositoryMock();
353 $tagRepo->expects($this->never())
354 ->method('__call');
355
356 $proxy = new ContentProxy($graby, $this->getTaggerMock(), $tagRepo, $this->getLogger(), $this->fetchingErrorMessage);
357
358 $tagEntity = new Tag();
359 $tagEntity->setLabel('tag1');
360 373
374 $proxy = new ContentProxy((new Graby()), $tagger, $this->getLogger(), $this->fetchingErrorMessage);
361 $entry = new Entry(new User()); 375 $entry = new Entry(new User());
376 $proxy->updateEntry(
377 $entry,
378 'http://1.1.1.1',
379 [
380 'html' => $html,
381 'title' => 'this is my title',
382 'url' => 'http://1.1.1.1',
383 'content_type' => 'text/html',
384 'language' => 'fr',
385 'status' => '200',
386 'open_graph' => [
387 'og_title' => 'my OG title',
388 'og_description' => 'OG desc',
389 'og_image' => 'http://3.3.3.3/cover.jpg',
390 ],
391 ]
392 );
362 393
363 $proxy->assignTagsToEntry($entry, 'tag1', [$tagEntity]); 394 $this->assertEquals('http://1.1.1.1', $entry->getUrl());
364 395 $this->assertEquals('this is my title', $entry->getTitle());
365 $this->assertCount(1, $entry->getTags()); 396 $this->assertNotContains($escapedString, $entry->getContent());
366 $this->assertEquals('tag1', $entry->getTags()[0]->getLabel()); 397 $this->assertEquals('http://3.3.3.3/cover.jpg', $entry->getPreviewPicture());
398 $this->assertEquals('text/html', $entry->getMimetype());
399 $this->assertEquals('fr', $entry->getLanguage());
400 $this->assertEquals('200', $entry->getHttpStatus());
401 $this->assertEquals('1.1.1.1', $entry->getDomainName());
367 } 402 }
368 403
369 private function getTaggerMock() 404 private function getTaggerMock()
370 { 405 {
371 return $this->getMockBuilder('Wallabag\CoreBundle\Helper\RuleBasedTagger') 406 return $this->getMockBuilder(RuleBasedTagger::class)
372 ->setMethods(['tag']) 407 ->setMethods(['tag'])
373 ->disableOriginalConstructor() 408 ->disableOriginalConstructor()
374 ->getMock(); 409 ->getMock();
375 } 410 }
376 411
377 private function getTagRepositoryMock()
378 {
379 return $this->getMockBuilder('Wallabag\CoreBundle\Repository\TagRepository')
380 ->disableOriginalConstructor()
381 ->getMock();
382 }
383
384 private function getLogger() 412 private function getLogger()
385 { 413 {
386 return new NullLogger(); 414 return new NullLogger();