namespace Wallabag\CoreBundle\Tests\Controller;
-use Wallabag\CoreBundle\Tests\WallabagTestCase;
+use Wallabag\CoreBundle\Tests\WallabagCoreTestCase;
-class ConfigControllerTest extends WallabagTestCase
+class ConfigControllerTest extends WallabagCoreTestCase
{
public function testLogin()
{
$this->assertEquals(200, $client->getResponse()->getStatusCode());
- $this->assertCount(1, $crawler->filter('input[type=number]'));
- $this->assertCount(1, $crawler->filter('button[type=submit]'));
+ $this->assertCount(1, $crawler->filter('button[id=config_save]'));
+ $this->assertCount(1, $crawler->filter('button[id=change_passwd_save]'));
+ $this->assertCount(1, $crawler->filter('button[id=update_user_save]'));
+ $this->assertCount(1, $crawler->filter('button[id=new_user_save]'));
+ $this->assertCount(1, $crawler->filter('button[id=rss_config_save]'));
}
public function testUpdate()
$this->assertEquals(200, $client->getResponse()->getStatusCode());
- $form = $crawler->filter('button[type=submit]')->form();
+ $form = $crawler->filter('button[id=config_save]')->form();
$data = array(
'config[theme]' => 'baggy',
'config[items_per_page]' => '30',
- 'config[language]' => 'fr_FR',
+ 'config[reading_speed]' => '0.5',
+ 'config[language]' => 'en',
);
$client->submit($form, $data);
$crawler = $client->followRedirect();
- $this->assertGreaterThan(1, $alert = $crawler->filter('div.flash-notice')->extract(array('_text')));
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
$this->assertContains('Config saved', $alert[0]);
}
array(array(
'config[theme]' => 'baggy',
'config[items_per_page]' => '',
- 'config[language]' => 'fr_FR',
- )),
- array(array(
- 'config[theme]' => 'baggy',
- 'config[items_per_page]' => '12',
- 'config[language]' => '',
+ 'config[language]' => 'en',
)),
);
}
$this->assertEquals(200, $client->getResponse()->getStatusCode());
- $form = $crawler->filter('button[type=submit]')->form();
+ $form = $crawler->filter('button[id=config_save]')->form();
$crawler = $client->submit($form, $data);
$this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(array('_text')));
$this->assertContains('This value should not be blank', $alert[0]);
}
+
+ public function dataForChangePasswordFailed()
+ {
+ return array(
+ array(
+ array(
+ 'change_passwd[old_password]' => 'material',
+ 'change_passwd[new_password][first]' => '',
+ 'change_passwd[new_password][second]' => '',
+ ),
+ 'Wrong value for your current password',
+ ),
+ array(
+ array(
+ 'change_passwd[old_password]' => 'mypassword',
+ 'change_passwd[new_password][first]' => '',
+ 'change_passwd[new_password][second]' => '',
+ ),
+ 'This value should not be blank',
+ ),
+ array(
+ array(
+ 'change_passwd[old_password]' => 'mypassword',
+ 'change_passwd[new_password][first]' => 'hop',
+ 'change_passwd[new_password][second]' => '',
+ ),
+ 'The password fields must match',
+ ),
+ array(
+ array(
+ 'change_passwd[old_password]' => 'mypassword',
+ 'change_passwd[new_password][first]' => 'hop',
+ 'change_passwd[new_password][second]' => 'hop',
+ ),
+ 'Password should by at least',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider dataForChangePasswordFailed
+ */
+ public function testChangePasswordFailed($data, $expectedMessage)
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=change_passwd_save]')->form();
+
+ $crawler = $client->submit($form, $data);
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(array('_text')));
+ $this->assertContains($expectedMessage, $alert[0]);
+ }
+
+ public function testChangePassword()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=change_passwd_save]')->form();
+
+ $data = array(
+ 'change_passwd[old_password]' => 'mypassword',
+ 'change_passwd[new_password][first]' => 'mypassword',
+ 'change_passwd[new_password][second]' => 'mypassword',
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('Password updated', $alert[0]);
+ }
+
+ public function dataForUserFailed()
+ {
+ return array(
+ array(
+ array(
+ 'update_user[name]' => '',
+ 'update_user[email]' => '',
+ ),
+ 'Please enter an email',
+ ),
+ array(
+ array(
+ 'update_user[name]' => '',
+ 'update_user[email]' => 'test',
+ ),
+ 'The email is not valid',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider dataForUserFailed
+ */
+ public function testUserFailed($data, $expectedMessage)
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=update_user_save]')->form();
+
+ $crawler = $client->submit($form, $data);
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(array('_text')));
+ $this->assertContains($expectedMessage, $alert[0]);
+ }
+
+ public function testUserUpdate()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=update_user_save]')->form();
+
+ $data = array(
+ 'update_user[name]' => 'new name',
+ 'update_user[email]' => 'admin@wallabag.io',
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('Information updated', $alert[0]);
+ }
+
+ public function dataForNewUserFailed()
+ {
+ return array(
+ array(
+ array(
+ 'new_user[username]' => '',
+ 'new_user[plainPassword][first]' => '',
+ 'new_user[plainPassword][second]' => '',
+ 'new_user[email]' => '',
+ ),
+ 'Please enter a username',
+ ),
+ array(
+ array(
+ 'new_user[username]' => 'a',
+ 'new_user[plainPassword][first]' => 'mypassword',
+ 'new_user[plainPassword][second]' => 'mypassword',
+ 'new_user[email]' => '',
+ ),
+ 'The username is too short',
+ ),
+ array(
+ array(
+ 'new_user[username]' => 'wallace',
+ 'new_user[plainPassword][first]' => 'mypassword',
+ 'new_user[plainPassword][second]' => 'mypassword',
+ 'new_user[email]' => 'test',
+ ),
+ 'The email is not valid',
+ ),
+ array(
+ array(
+ 'new_user[username]' => 'admin',
+ 'new_user[plainPassword][first]' => 'wallacewallace',
+ 'new_user[plainPassword][second]' => 'wallacewallace',
+ 'new_user[email]' => 'wallace@wallace.me',
+ ),
+ 'The username is already used',
+ ),
+ array(
+ array(
+ 'new_user[username]' => 'wallace',
+ 'new_user[plainPassword][first]' => 'mypassword1',
+ 'new_user[plainPassword][second]' => 'mypassword2',
+ 'new_user[email]' => 'wallace@wallace.me',
+ ),
+ 'The password fields must match',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider dataForNewUserFailed
+ */
+ public function testNewUserFailed($data, $expectedMessage)
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=new_user_save]')->form();
+
+ $crawler = $client->submit($form, $data);
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(array('_text')));
+ $this->assertContains($expectedMessage, $alert[0]);
+ }
+
+ public function testNewUserCreated()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=new_user_save]')->form();
+
+ $data = array(
+ 'new_user[username]' => 'wallace',
+ 'new_user[plainPassword][first]' => 'wallace1',
+ 'new_user[plainPassword][second]' => 'wallace1',
+ 'new_user[email]' => 'wallace@wallace.me',
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('User "wallace" added', $alert[0]);
+
+ $em = $client->getContainer()->get('doctrine.orm.entity_manager');
+ $user = $em
+ ->getRepository('WallabagUserBundle:User')
+ ->findOneByUsername('wallace');
+
+ $this->assertTrue(false !== $user);
+ $this->assertTrue($user->isEnabled());
+ }
+
+ public function testRssUpdateResetToken()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ // reset the token
+ $em = $client->getContainer()->get('doctrine.orm.entity_manager');
+ $user = $em
+ ->getRepository('WallabagUserBundle:User')
+ ->findOneByUsername('admin');
+
+ if (!$user) {
+ $this->markTestSkipped('No user found in db.');
+ }
+
+ $config = $user->getConfig();
+ $config->setRssToken(null);
+ $em->persist($config);
+ $em->flush();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(array('_text')));
+ $this->assertContains('You need to generate a token first.', $body[0]);
+
+ $client->request('GET', '/generate-token');
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(array('_text')));
+ $this->assertNotContains('You need to generate a token first.', $body[0]);
+ }
+
+ public function testGenerateTokenAjax()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $client->request(
+ 'GET',
+ '/generate-token',
+ array(),
+ array(),
+ array('HTTP_X-Requested-With' => 'XMLHttpRequest')
+ );
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+ $content = json_decode($client->getResponse()->getContent(), true);
+ $this->assertArrayHasKey('token', $content);
+ }
+
+ public function testRssUpdate()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ if (500 == $client->getResponse()->getStatusCode()) {
+ var_export($client->getResponse()->getContent());
+ die();
+ }
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=rss_config_save]')->form();
+
+ $data = array(
+ 'rss_config[rss_limit]' => 12,
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('RSS information updated', $alert[0]);
+ }
+
+ public function dataForRssFailed()
+ {
+ return array(
+ array(
+ array(
+ 'rss_config[rss_limit]' => 0,
+ ),
+ 'This value should be 1 or more.',
+ ),
+ array(
+ array(
+ 'rss_config[rss_limit]' => 1000000000000,
+ ),
+ 'This will certainly kill the app',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider dataForRssFailed
+ */
+ public function testRssFailed($data, $expectedMessage)
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=rss_config_save]')->form();
+
+ $crawler = $client->submit($form, $data);
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(array('_text')));
+ $this->assertContains($expectedMessage, $alert[0]);
+ }
+
+ public function testTaggingRuleCreation()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertTrue($client->getResponse()->isSuccessful());
+
+ $form = $crawler->filter('button[id=tagging_rule_save]')->form();
+
+ $data = array(
+ 'tagging_rule[rule]' => 'readingTime <= 3',
+ 'tagging_rule[tags]' => 'short reading',
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('Tagging rules updated', $alert[0]);
+
+ $deleteLink = $crawler->filter('.delete')->last()->link();
+
+ $crawler = $client->click($deleteLink);
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+
+ $crawler = $client->followRedirect();
+ $this->assertGreaterThan(1, $alert = $crawler->filter('div.messages.success')->extract(array('_text')));
+ $this->assertContains('Tagging rule deleted', $alert[0]);
+ }
+
+ public function dataForTaggingRuleFailed()
+ {
+ return array(
+ array(
+ array(
+ 'tagging_rule[rule]' => 'unknownVar <= 3',
+ 'tagging_rule[tags]' => 'cool tag',
+ ),
+ array(
+ 'The variable',
+ 'does not exist.',
+ ),
+ ),
+ array(
+ array(
+ 'tagging_rule[rule]' => 'length(domainName) <= 42',
+ 'tagging_rule[tags]' => 'cool tag',
+ ),
+ array(
+ 'The operator',
+ 'does not exist.',
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider dataForTaggingRuleFailed
+ */
+ public function testTaggingRuleCreationFail($data, $messages)
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertTrue($client->getResponse()->isSuccessful());
+
+ $form = $crawler->filter('button[id=tagging_rule_save]')->form();
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ foreach ($messages as $message) {
+ $this->assertContains($message, $client->getResponse()->getContent());
+ }
+ }
+
+ public function testDeletingTaggingRuleFromAnOtherUser()
+ {
+ $this->logInAs('bob');
+ $client = $this->getClient();
+
+ $rule = $client->getContainer()->get('doctrine.orm.entity_manager')
+ ->getRepository('WallabagCoreBundle:TaggingRule')
+ ->findAll()[0];
+
+ $client->request('GET', '/tagging-rule/delete/'.$rule->getId());
+ $this->assertEquals(403, $client->getResponse()->getStatusCode());
+ $this->assertContains('You can not access this tagging ryle', $client->getResponse()->getContent());
+ }
+
+ public function testDemoMode()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $config = $client->getContainer()->get('craue_config');
+ $config->set('demo_mode_enabled', 1);
+ $config->set('demo_mode_username', 'admin');
+
+ $crawler = $client->request('GET', '/config');
+
+ $this->assertEquals(200, $client->getResponse()->getStatusCode());
+
+ $form = $crawler->filter('button[id=change_passwd_save]')->form();
+
+ $data = array(
+ 'change_passwd[old_password]' => 'mypassword',
+ 'change_passwd[new_password][first]' => 'mypassword',
+ 'change_passwd[new_password][second]' => 'mypassword',
+ );
+
+ $client->submit($form, $data);
+
+ $this->assertEquals(302, $client->getResponse()->getStatusCode());
+ $this->assertContains('In demonstration mode, you can\'t change password for this user.', $client->getContainer()->get('session')->getFlashBag()->get('notice')[0]);
+
+ $config->set('demo_mode_enabled', 0);
+ $config->set('demo_mode_username', 'wallabag');
+ }
}