diff options
Diffstat (limited to 'tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php')
-rw-r--r-- | tests/Wallabag/CoreBundle/Helper/ContentProxyTest.php | 294 |
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 @@ | |||
3 | namespace Tests\Wallabag\CoreBundle\Helper; | 3 | namespace Tests\Wallabag\CoreBundle\Helper; |
4 | 4 | ||
5 | use Psr\Log\NullLogger; | 5 | use Psr\Log\NullLogger; |
6 | use Monolog\Logger; | ||
7 | use Monolog\Handler\TestHandler; | ||
6 | use Wallabag\CoreBundle\Helper\ContentProxy; | 8 | use Wallabag\CoreBundle\Helper\ContentProxy; |
7 | use Wallabag\CoreBundle\Entity\Entry; | 9 | use Wallabag\CoreBundle\Entity\Entry; |
8 | use Wallabag\CoreBundle\Entity\Tag; | 10 | use Wallabag\CoreBundle\Entity\Tag; |
9 | use Wallabag\UserBundle\Entity\User; | 11 | use Wallabag\UserBundle\Entity\User; |
12 | use Wallabag\CoreBundle\Helper\RuleBasedTagger; | ||
13 | use Graby\Graby; | ||
10 | 14 | ||
11 | class ContentProxyTest extends \PHPUnit_Framework_TestCase | 15 | class 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(); |