3 namespace Tests\Wallabag\CoreBundle\Controller
;
5 use Tests\Wallabag\CoreBundle\WallabagCoreTestCase
;
6 use Wallabag\CoreBundle\Entity\Config
;
7 use Wallabag\UserBundle\Entity\User
;
9 class ConfigControllerTest
extends WallabagCoreTestCase
11 public function testLogin()
13 $client = $this->getClient();
15 $client->request('GET', '/new');
17 $this->assertEquals(302, $client->getResponse()->getStatusCode());
18 $this->assertContains('login', $client->getResponse()->headers
->get('location'));
21 public function testIndex()
23 $this->logInAs('admin');
24 $client = $this->getClient();
26 $crawler = $client->request('GET', '/config');
28 $this->assertEquals(200, $client->getResponse()->getStatusCode());
30 $this->assertCount(1, $crawler->filter('button[id=config_save]'));
31 $this->assertCount(1, $crawler->filter('button[id=change_passwd_save]'));
32 $this->assertCount(1, $crawler->filter('button[id=update_user_save]'));
33 $this->assertCount(1, $crawler->filter('button[id=rss_config_save]'));
36 public function testUpdate()
38 $this->logInAs('admin');
39 $client = $this->getClient();
41 $crawler = $client->request('GET', '/config');
43 $this->assertEquals(200, $client->getResponse()->getStatusCode());
45 $form = $crawler->filter('button[id=config_save]')->form();
48 'config[theme]' => 'baggy',
49 'config[items_per_page]' => '30',
50 'config[reading_speed]' => '0.5',
51 'config[language]' => 'en',
54 $client->submit($form, $data);
56 $this->assertEquals(302, $client->getResponse()->getStatusCode());
58 $crawler = $client->followRedirect();
60 $this->assertContains('flashes.config.notice.config_saved', $crawler->filter('body')->extract(['_text'])[0]);
63 public function testChangeReadingSpeed()
65 $this->logInAs('admin');
66 $client = $this->getClient();
68 $crawler = $client->request('GET', '/unread/list');
69 $form = $crawler->filter('button[id=submit-filter]')->form();
71 'entry_filter[readingTime][right_number]' => 22,
72 'entry_filter[readingTime][left_number]' => 22,
74 $crawler = $client->submit($form, $dataFilters);
75 $this->assertCount(1, $crawler->filter('div[class=entry]'));
77 // Change reading speed
78 $crawler = $client->request('GET', '/config');
79 $form = $crawler->filter('button[id=config_save]')->form();
81 'config[reading_speed]' => '2',
83 $client->submit($form, $data);
85 // Is the entry still available via filters?
86 $crawler = $client->request('GET', '/unread/list');
87 $form = $crawler->filter('button[id=submit-filter]')->form();
88 $crawler = $client->submit($form, $dataFilters);
89 $this->assertCount(0, $crawler->filter('div[class=entry]'));
91 // Restore old configuration
92 $crawler = $client->request('GET', '/config');
93 $form = $crawler->filter('button[id=config_save]')->form();
95 'config[reading_speed]' => '0.5',
97 $client->submit($form, $data);
100 public function dataForUpdateFailed()
104 'config[theme]' => 'baggy',
105 'config[items_per_page]' => '',
106 'config[language]' => 'en',
112 * @dataProvider dataForUpdateFailed
114 public function testUpdateFailed($data)
116 $this->logInAs('admin');
117 $client = $this->getClient();
119 $crawler = $client->request('GET', '/config');
121 $this->assertEquals(200, $client->getResponse()->getStatusCode());
123 $form = $crawler->filter('button[id=config_save]')->form();
125 $crawler = $client->submit($form, $data);
127 $this->assertEquals(200, $client->getResponse()->getStatusCode());
129 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
130 $this->assertContains('This value should not be blank', $alert[0]);
133 public function dataForChangePasswordFailed()
138 'change_passwd[old_password]' => 'material',
139 'change_passwd[new_password][first]' => '',
140 'change_passwd[new_password][second]' => '',
142 'validator.password_wrong_value',
146 'change_passwd[old_password]' => 'mypassword',
147 'change_passwd[new_password][first]' => '',
148 'change_passwd[new_password][second]' => '',
150 'This value should not be blank',
154 'change_passwd[old_password]' => 'mypassword',
155 'change_passwd[new_password][first]' => 'hop',
156 'change_passwd[new_password][second]' => '',
158 'validator.password_must_match',
162 'change_passwd[old_password]' => 'mypassword',
163 'change_passwd[new_password][first]' => 'hop',
164 'change_passwd[new_password][second]' => 'hop',
166 'validator.password_too_short',
172 * @dataProvider dataForChangePasswordFailed
174 public function testChangePasswordFailed($data, $expectedMessage)
176 $this->logInAs('admin');
177 $client = $this->getClient();
179 $crawler = $client->request('GET', '/config');
181 $this->assertEquals(200, $client->getResponse()->getStatusCode());
183 $form = $crawler->filter('button[id=change_passwd_save]')->form();
185 $crawler = $client->submit($form, $data);
187 $this->assertEquals(200, $client->getResponse()->getStatusCode());
189 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
190 $this->assertContains($expectedMessage, $alert[0]);
193 public function testChangePassword()
195 $this->logInAs('admin');
196 $client = $this->getClient();
198 $crawler = $client->request('GET', '/config');
200 $this->assertEquals(200, $client->getResponse()->getStatusCode());
202 $form = $crawler->filter('button[id=change_passwd_save]')->form();
205 'change_passwd[old_password]' => 'mypassword',
206 'change_passwd[new_password][first]' => 'mypassword',
207 'change_passwd[new_password][second]' => 'mypassword',
210 $client->submit($form, $data);
212 $this->assertEquals(302, $client->getResponse()->getStatusCode());
214 $crawler = $client->followRedirect();
216 $this->assertContains('flashes.config.notice.password_updated', $crawler->filter('body')->extract(['_text'])[0]);
219 public function dataForUserFailed()
224 'update_user[name]' => '',
225 'update_user[email]' => '',
227 'fos_user.email.blank',
231 'update_user[name]' => '',
232 'update_user[email]' => 'test',
234 'fos_user.email.invalid',
240 * @dataProvider dataForUserFailed
242 public function testUserFailed($data, $expectedMessage)
244 $this->logInAs('admin');
245 $client = $this->getClient();
247 $crawler = $client->request('GET', '/config');
249 $this->assertEquals(200, $client->getResponse()->getStatusCode());
251 $form = $crawler->filter('button[id=update_user_save]')->form();
253 $crawler = $client->submit($form, $data);
255 $this->assertEquals(200, $client->getResponse()->getStatusCode());
257 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
258 $this->assertContains($expectedMessage, $alert[0]);
261 public function testUserUpdate()
263 $this->logInAs('admin');
264 $client = $this->getClient();
266 $crawler = $client->request('GET', '/config');
268 $this->assertEquals(200, $client->getResponse()->getStatusCode());
270 $form = $crawler->filter('button[id=update_user_save]')->form();
273 'update_user[name]' => 'new name',
274 'update_user[email]' => 'admin@wallabag.io',
277 $client->submit($form, $data);
279 $this->assertEquals(302, $client->getResponse()->getStatusCode());
281 $crawler = $client->followRedirect();
283 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
284 $this->assertContains('flashes.config.notice.user_updated', $alert[0]);
287 public function testRssUpdateResetToken()
289 $this->logInAs('admin');
290 $client = $this->getClient();
293 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
295 ->getRepository('WallabagUserBundle:User')
296 ->findOneByUsername('admin');
299 $this->markTestSkipped('No user found in db.');
302 $config = $user->getConfig();
303 $config->setRssToken(null);
304 $em->persist($config);
307 $crawler = $client->request('GET', '/config');
309 $this->assertEquals(200, $client->getResponse()->getStatusCode());
311 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
312 $this->assertContains('config.form_rss.no_token', $body[0]);
314 $client->request('GET', '/generate-token');
315 $this->assertEquals(302, $client->getResponse()->getStatusCode());
317 $crawler = $client->followRedirect();
319 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
320 $this->assertNotContains('config.form_rss.no_token', $body[0]);
323 public function testGenerateTokenAjax()
325 $this->logInAs('admin');
326 $client = $this->getClient();
333 ['HTTP_X-Requested-With' => 'XMLHttpRequest']
336 $this->assertEquals(200, $client->getResponse()->getStatusCode());
337 $content = json_decode($client->getResponse()->getContent(), true);
338 $this->assertArrayHasKey('token', $content);
341 public function testRssUpdate()
343 $this->logInAs('admin');
344 $client = $this->getClient();
346 $crawler = $client->request('GET', '/config');
348 $this->assertEquals(200, $client->getResponse()->getStatusCode());
350 $form = $crawler->filter('button[id=rss_config_save]')->form();
353 'rss_config[rss_limit]' => 12,
356 $client->submit($form, $data);
358 $this->assertEquals(302, $client->getResponse()->getStatusCode());
360 $crawler = $client->followRedirect();
362 $this->assertContains('flashes.config.notice.rss_updated', $crawler->filter('body')->extract(['_text'])[0]);
365 public function dataForRssFailed()
370 'rss_config[rss_limit]' => 0,
372 'This value should be 1 or more.',
376 'rss_config[rss_limit]' => 1000000000000,
378 'validator.rss_limit_too_hight',
384 * @dataProvider dataForRssFailed
386 public function testRssFailed($data, $expectedMessage)
388 $this->logInAs('admin');
389 $client = $this->getClient();
391 $crawler = $client->request('GET', '/config');
393 $this->assertEquals(200, $client->getResponse()->getStatusCode());
395 $form = $crawler->filter('button[id=rss_config_save]')->form();
397 $crawler = $client->submit($form, $data);
399 $this->assertEquals(200, $client->getResponse()->getStatusCode());
401 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
402 $this->assertContains($expectedMessage, $alert[0]);
405 public function testTaggingRuleCreation()
407 $this->logInAs('admin');
408 $client = $this->getClient();
410 $crawler = $client->request('GET', '/config');
412 $this->assertTrue($client->getResponse()->isSuccessful());
414 $form = $crawler->filter('button[id=tagging_rule_save]')->form();
417 'tagging_rule[rule]' => 'readingTime <= 3',
418 'tagging_rule[tags]' => 'short reading',
421 $client->submit($form, $data);
423 $this->assertEquals(302, $client->getResponse()->getStatusCode());
425 $crawler = $client->followRedirect();
427 $this->assertContains('flashes.config.notice.tagging_rules_updated', $crawler->filter('body')->extract(['_text'])[0]);
429 $editLink = $crawler->filter('.mode_edit')->last()->link();
431 $crawler = $client->click($editLink);
432 $this->assertEquals(302, $client->getResponse()->getStatusCode());
433 $this->assertContains('?tagging-rule=', $client->getResponse()->headers
->get('location'));
435 $crawler = $client->followRedirect();
437 $form = $crawler->filter('button[id=tagging_rule_save]')->form();
440 'tagging_rule[rule]' => 'readingTime <= 30',
441 'tagging_rule[tags]' => 'short reading',
444 $client->submit($form, $data);
446 $this->assertEquals(302, $client->getResponse()->getStatusCode());
448 $crawler = $client->followRedirect();
450 $this->assertContains('flashes.config.notice.tagging_rules_updated', $crawler->filter('body')->extract(['_text'])[0]);
452 $this->assertContains('readingTime <= 30', $crawler->filter('body')->extract(['_text'])[0]);
454 $deleteLink = $crawler->filter('.delete')->last()->link();
456 $crawler = $client->click($deleteLink);
457 $this->assertEquals(302, $client->getResponse()->getStatusCode());
459 $crawler = $client->followRedirect();
460 $this->assertContains('flashes.config.notice.tagging_rules_deleted', $crawler->filter('body')->extract(['_text'])[0]);
463 public function dataForTaggingRuleFailed()
468 'tagging_rule[rule]' => 'unknownVar <= 3',
469 'tagging_rule[tags]' => 'cool tag',
478 'tagging_rule[rule]' => 'length(domainName) <= 42',
479 'tagging_rule[tags]' => 'cool tag',
490 * @dataProvider dataForTaggingRuleFailed
492 public function testTaggingRuleCreationFail($data, $messages)
494 $this->logInAs('admin');
495 $client = $this->getClient();
497 $crawler = $client->request('GET', '/config');
499 $this->assertTrue($client->getResponse()->isSuccessful());
501 $form = $crawler->filter('button[id=tagging_rule_save]')->form();
503 $crawler = $client->submit($form, $data);
505 $this->assertEquals(200, $client->getResponse()->getStatusCode());
507 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
509 foreach ($messages as $message) {
510 $this->assertContains($message, $body[0]);
514 public function testDeletingTaggingRuleFromAnOtherUser()
516 $this->logInAs('bob');
517 $client = $this->getClient();
519 $rule = $client->getContainer()->get('doctrine.orm.entity_manager')
520 ->getRepository('WallabagCoreBundle:TaggingRule')
523 $crawler = $client->request('GET', '/tagging-rule/edit/'.$rule->getId());
525 $this->assertEquals(403, $client->getResponse()->getStatusCode());
526 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
527 $this->assertContains('You can not access this tagging rule', $body[0]);
530 public function testEditingTaggingRuleFromAnOtherUser()
532 $this->logInAs('bob');
533 $client = $this->getClient();
535 $rule = $client->getContainer()->get('doctrine.orm.entity_manager')
536 ->getRepository('WallabagCoreBundle:TaggingRule')
539 $crawler = $client->request('GET', '/tagging-rule/edit/'.$rule->getId());
541 $this->assertEquals(403, $client->getResponse()->getStatusCode());
542 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
543 $this->assertContains('You can not access this tagging rule', $body[0]);
546 public function testDemoMode()
548 $this->logInAs('admin');
549 $client = $this->getClient();
551 $config = $client->getContainer()->get('craue_config');
552 $config->set('demo_mode_enabled', 1);
553 $config->set('demo_mode_username', 'admin');
555 $crawler = $client->request('GET', '/config');
557 $this->assertEquals(200, $client->getResponse()->getStatusCode());
559 $form = $crawler->filter('button[id=change_passwd_save]')->form();
562 'change_passwd[old_password]' => 'mypassword',
563 'change_passwd[new_password][first]' => 'mypassword',
564 'change_passwd[new_password][second]' => 'mypassword',
567 $client->submit($form, $data);
569 $this->assertEquals(302, $client->getResponse()->getStatusCode());
570 $this->assertContains('flashes.config.notice.password_not_updated_demo', $client->getContainer()->get('session')->getFlashBag()->get('notice')[0]);
572 $config->set('demo_mode_enabled', 0);
573 $config->set('demo_mode_username', 'wallabag');
576 public function testDeleteUserButtonVisibility()
578 $this->logInAs('admin');
579 $client = $this->getClient();
581 $crawler = $client->request('GET', '/config');
583 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
584 $this->assertContains('config.form_user.delete_account', $body[0]);
586 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
589 ->getRepository('WallabagUserBundle:User')
590 ->findOneByUsername('empty');
591 $user->setExpired(1);
595 ->getRepository('WallabagUserBundle:User')
596 ->findOneByUsername('bob');
597 $user->setExpired(1);
602 $crawler = $client->request('GET', '/config');
604 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
605 $this->assertNotContains('config.form_user.delete_account', $body[0]);
607 $client->request('GET', '/account/delete');
608 $this->assertEquals(403, $client->getResponse()->getStatusCode());
611 ->getRepository('WallabagUserBundle:User')
612 ->findOneByUsername('empty');
613 $user->setExpired(0);
617 ->getRepository('WallabagUserBundle:User')
618 ->findOneByUsername('bob');
619 $user->setExpired(0);
625 public function testDeleteAccount()
627 $client = $this->getClient();
628 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
631 $user->setName('Wallace');
632 $user->setEmail('wallace@wallabag.org');
633 $user->setUsername('wallace');
634 $user->setPlainPassword('wallace');
635 $user->setEnabled(true);
636 $user->addRole('ROLE_SUPER_ADMIN');
640 $config = new Config($user);
642 $config->setTheme('material');
643 $config->setItemsPerPage(30);
644 $config->setReadingSpeed(1);
645 $config->setLanguage('en');
646 $config->setPocketConsumerKey('xxxxx');
648 $em->persist($config);
651 $this->logInAs('wallace');
653 // create entry to check after user deletion
654 // that this entry is also deleted
655 $crawler = $client->request('GET', '/new');
657 $this->assertEquals(200, $client->getResponse()->getStatusCode());
659 $form = $crawler->filter('form[name=entry]')->form();
661 'entry[url]' => $url = 'https://github.com/wallabag/wallabag',
664 $client->submit($form, $data);
665 $this->assertEquals(302, $client->getResponse()->getStatusCode());
667 $crawler = $client->request('GET', '/config');
669 $deleteLink = $crawler->filter('.delete-account')->last()->link();
671 $client->click($deleteLink);
672 $this->assertEquals(302, $client->getResponse()->getStatusCode());
674 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
676 ->getRepository('WallabagUserBundle:User')
677 ->createQueryBuilder('u')
678 ->where('u.username = :username')->setParameter('username', 'wallace')
680 ->getOneOrNullResult()
683 $this->assertNull($user);
685 $entries = $client->getContainer()
686 ->get('doctrine.orm.entity_manager')
687 ->getRepository('WallabagCoreBundle:Entry')
688 ->findByUser($this->getLoggedInUserId());
690 $this->assertEmpty($entries);