3 namespace Tests\Wallabag\CoreBundle\Controller
;
5 use Tests\Wallabag\CoreBundle\WallabagCoreTestCase
;
7 class ConfigControllerTest
extends WallabagCoreTestCase
9 public function testLogin()
11 $client = $this->getClient();
13 $client->request('GET', '/new');
15 $this->assertEquals(302, $client->getResponse()->getStatusCode());
16 $this->assertContains('login', $client->getResponse()->headers
->get('location'));
19 public function testIndex()
21 $this->logInAs('admin');
22 $client = $this->getClient();
24 $crawler = $client->request('GET', '/config');
26 $this->assertEquals(200, $client->getResponse()->getStatusCode());
28 $this->assertCount(1, $crawler->filter('button[id=config_save]'));
29 $this->assertCount(1, $crawler->filter('button[id=change_passwd_save]'));
30 $this->assertCount(1, $crawler->filter('button[id=update_user_save]'));
31 $this->assertCount(1, $crawler->filter('button[id=new_user_save]'));
32 $this->assertCount(1, $crawler->filter('button[id=rss_config_save]'));
35 public function testUpdate()
37 $this->logInAs('admin');
38 $client = $this->getClient();
40 $crawler = $client->request('GET', '/config');
42 $this->assertEquals(200, $client->getResponse()->getStatusCode());
44 $form = $crawler->filter('button[id=config_save]')->form();
47 'config[theme]' => 'baggy',
48 'config[items_per_page]' => '30',
49 'config[reading_speed]' => '0.5',
50 'config[language]' => 'en',
53 $client->submit($form, $data);
55 $this->assertEquals(302, $client->getResponse()->getStatusCode());
57 $crawler = $client->followRedirect();
59 $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
60 $this->assertContains('flashes.config.notice.config_saved', $alert[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->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
217 $this->assertContains('flashes.config.notice.password_updated', $alert[0]);
220 public function dataForUserFailed()
225 'update_user[name]' => '',
226 'update_user[email]' => '',
228 'fos_user.email.blank',
232 'update_user[name]' => '',
233 'update_user[email]' => 'test',
235 'fos_user.email.invalid',
241 * @dataProvider dataForUserFailed
243 public function testUserFailed($data, $expectedMessage)
245 $this->logInAs('admin');
246 $client = $this->getClient();
248 $crawler = $client->request('GET', '/config');
250 $this->assertEquals(200, $client->getResponse()->getStatusCode());
252 $form = $crawler->filter('button[id=update_user_save]')->form();
254 $crawler = $client->submit($form, $data);
256 $this->assertEquals(200, $client->getResponse()->getStatusCode());
258 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
259 $this->assertContains($expectedMessage, $alert[0]);
262 public function testUserUpdate()
264 $this->logInAs('admin');
265 $client = $this->getClient();
267 $crawler = $client->request('GET', '/config');
269 $this->assertEquals(200, $client->getResponse()->getStatusCode());
271 $form = $crawler->filter('button[id=update_user_save]')->form();
274 'update_user[name]' => 'new name',
275 'update_user[email]' => 'admin@wallabag.io',
278 $client->submit($form, $data);
280 $this->assertEquals(302, $client->getResponse()->getStatusCode());
282 $crawler = $client->followRedirect();
284 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
285 $this->assertContains('flashes.config.notice.user_updated', $alert[0]);
288 public function dataForNewUserFailed()
293 'new_user[username]' => '',
294 'new_user[plainPassword][first]' => '',
295 'new_user[plainPassword][second]' => '',
296 'new_user[email]' => '',
298 'fos_user.username.blank',
302 'new_user[username]' => 'a',
303 'new_user[plainPassword][first]' => 'mypassword',
304 'new_user[plainPassword][second]' => 'mypassword',
305 'new_user[email]' => '',
307 'fos_user.username.short',
311 'new_user[username]' => 'wallace',
312 'new_user[plainPassword][first]' => 'mypassword',
313 'new_user[plainPassword][second]' => 'mypassword',
314 'new_user[email]' => 'test',
316 'fos_user.email.invalid',
320 'new_user[username]' => 'admin',
321 'new_user[plainPassword][first]' => 'wallacewallace',
322 'new_user[plainPassword][second]' => 'wallacewallace',
323 'new_user[email]' => 'wallace@wallace.me',
325 'fos_user.username.already_used',
329 'new_user[username]' => 'wallace',
330 'new_user[plainPassword][first]' => 'mypassword1',
331 'new_user[plainPassword][second]' => 'mypassword2',
332 'new_user[email]' => 'wallace@wallace.me',
334 'validator.password_must_match',
340 * @dataProvider dataForNewUserFailed
342 public function testNewUserFailed($data, $expectedMessage)
344 $this->logInAs('admin');
345 $client = $this->getClient();
347 $crawler = $client->request('GET', '/config');
349 $this->assertEquals(200, $client->getResponse()->getStatusCode());
351 $form = $crawler->filter('button[id=new_user_save]')->form();
353 $crawler = $client->submit($form, $data);
355 $this->assertEquals(200, $client->getResponse()->getStatusCode());
357 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
358 $this->assertContains($expectedMessage, $alert[0]);
361 public function testNewUserCreated()
363 $this->logInAs('admin');
364 $client = $this->getClient();
366 $crawler = $client->request('GET', '/config');
368 $this->assertEquals(200, $client->getResponse()->getStatusCode());
370 $form = $crawler->filter('button[id=new_user_save]')->form();
373 'new_user[username]' => 'wallace',
374 'new_user[plainPassword][first]' => 'wallace1',
375 'new_user[plainPassword][second]' => 'wallace1',
376 'new_user[email]' => 'wallace@wallace.me',
379 $client->submit($form, $data);
381 $this->assertEquals(302, $client->getResponse()->getStatusCode());
383 $crawler = $client->followRedirect();
385 $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
386 $this->assertContains('flashes.config.notice.user_added', $alert[0]);
388 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
390 ->getRepository('WallabagUserBundle:User')
391 ->findOneByUsername('wallace');
393 $this->assertTrue(false !== $user);
394 $this->assertTrue($user->isEnabled());
395 $this->assertEquals('material', $user->getConfig()->getTheme());
396 $this->assertEquals(12, $user->getConfig()->getItemsPerPage());
397 $this->assertEquals(50, $user->getConfig()->getRssLimit());
398 $this->assertEquals('en', $user->getConfig()->getLanguage());
399 $this->assertEquals(1, $user->getConfig()->getReadingSpeed());
402 public function testRssUpdateResetToken()
404 $this->logInAs('admin');
405 $client = $this->getClient();
408 $em = $client->getContainer()->get('doctrine.orm.entity_manager');
410 ->getRepository('WallabagUserBundle:User')
411 ->findOneByUsername('admin');
414 $this->markTestSkipped('No user found in db.');
417 $config = $user->getConfig();
418 $config->setRssToken(null);
419 $em->persist($config);
422 $crawler = $client->request('GET', '/config');
424 $this->assertEquals(200, $client->getResponse()->getStatusCode());
426 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
427 $this->assertContains('config.form_rss.no_token', $body[0]);
429 $client->request('GET', '/generate-token');
430 $this->assertEquals(302, $client->getResponse()->getStatusCode());
432 $crawler = $client->followRedirect();
434 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
435 $this->assertNotContains('config.form_rss.no_token', $body[0]);
438 public function testGenerateTokenAjax()
440 $this->logInAs('admin');
441 $client = $this->getClient();
448 ['HTTP_X-Requested-With' => 'XMLHttpRequest']
451 $this->assertEquals(200, $client->getResponse()->getStatusCode());
452 $content = json_decode($client->getResponse()->getContent(), true);
453 $this->assertArrayHasKey('token', $content);
456 public function testRssUpdate()
458 $this->logInAs('admin');
459 $client = $this->getClient();
461 $crawler = $client->request('GET', '/config');
463 $this->assertEquals(200, $client->getResponse()->getStatusCode());
465 $form = $crawler->filter('button[id=rss_config_save]')->form();
468 'rss_config[rss_limit]' => 12,
471 $client->submit($form, $data);
473 $this->assertEquals(302, $client->getResponse()->getStatusCode());
475 $crawler = $client->followRedirect();
477 $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
478 $this->assertContains('flashes.config.notice.rss_updated', $alert[0]);
481 public function dataForRssFailed()
486 'rss_config[rss_limit]' => 0,
488 'This value should be 1 or more.',
492 'rss_config[rss_limit]' => 1000000000000,
494 'validator.rss_limit_too_hight',
500 * @dataProvider dataForRssFailed
502 public function testRssFailed($data, $expectedMessage)
504 $this->logInAs('admin');
505 $client = $this->getClient();
507 $crawler = $client->request('GET', '/config');
509 $this->assertEquals(200, $client->getResponse()->getStatusCode());
511 $form = $crawler->filter('button[id=rss_config_save]')->form();
513 $crawler = $client->submit($form, $data);
515 $this->assertEquals(200, $client->getResponse()->getStatusCode());
517 $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
518 $this->assertContains($expectedMessage, $alert[0]);
521 public function testTaggingRuleCreation()
523 $this->logInAs('admin');
524 $client = $this->getClient();
526 $crawler = $client->request('GET', '/config');
528 $this->assertTrue($client->getResponse()->isSuccessful());
530 $form = $crawler->filter('button[id=tagging_rule_save]')->form();
533 'tagging_rule[rule]' => 'readingTime <= 3',
534 'tagging_rule[tags]' => 'short reading',
537 $client->submit($form, $data);
539 $this->assertEquals(302, $client->getResponse()->getStatusCode());
541 $crawler = $client->followRedirect();
543 $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
544 $this->assertContains('flashes.config.notice.tagging_rules_updated', $alert[0]);
546 $deleteLink = $crawler->filter('.delete')->last()->link();
548 $crawler = $client->click($deleteLink);
549 $this->assertEquals(302, $client->getResponse()->getStatusCode());
551 $crawler = $client->followRedirect();
552 $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(['_text']));
553 $this->assertContains('flashes.config.notice.tagging_rules_deleted', $alert[0]);
556 public function dataForTaggingRuleFailed()
561 'tagging_rule[rule]' => 'unknownVar <= 3',
562 'tagging_rule[tags]' => 'cool tag',
571 'tagging_rule[rule]' => 'length(domainName) <= 42',
572 'tagging_rule[tags]' => 'cool tag',
583 * @dataProvider dataForTaggingRuleFailed
585 public function testTaggingRuleCreationFail($data, $messages)
587 $this->logInAs('admin');
588 $client = $this->getClient();
590 $crawler = $client->request('GET', '/config');
592 $this->assertTrue($client->getResponse()->isSuccessful());
594 $form = $crawler->filter('button[id=tagging_rule_save]')->form();
596 $crawler = $client->submit($form, $data);
598 $this->assertEquals(200, $client->getResponse()->getStatusCode());
600 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
602 foreach ($messages as $message) {
603 $this->assertContains($message, $body[0]);
607 public function testDeletingTaggingRuleFromAnOtherUser()
609 $this->logInAs('bob');
610 $client = $this->getClient();
612 $rule = $client->getContainer()->get('doctrine.orm.entity_manager')
613 ->getRepository('WallabagCoreBundle:TaggingRule')
616 $crawler = $client->request('GET', '/tagging-rule/delete/'.$rule->getId());
618 $this->assertEquals(403, $client->getResponse()->getStatusCode());
619 $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
620 $this->assertContains('You can not access this tagging rule', $body[0]);
623 public function testDemoMode()
625 $this->logInAs('admin');
626 $client = $this->getClient();
628 $config = $client->getContainer()->get('craue_config');
629 $config->set('demo_mode_enabled', 1);
630 $config->set('demo_mode_username', 'admin');
632 $crawler = $client->request('GET', '/config');
634 $this->assertEquals(200, $client->getResponse()->getStatusCode());
636 $form = $crawler->filter('button[id=change_passwd_save]')->form();
639 'change_passwd[old_password]' => 'mypassword',
640 'change_passwd[new_password][first]' => 'mypassword',
641 'change_passwd[new_password][second]' => 'mypassword',
644 $client->submit($form, $data);
646 $this->assertEquals(302, $client->getResponse()->getStatusCode());
647 $this->assertContains('flashes.config.notice.password_not_updated_demo', $client->getContainer()->get('session')->getFlashBag()->get('notice')[0]);
649 $config->set('demo_mode_enabled', 0);
650 $config->set('demo_mode_username', 'wallabag');