wallabag/tests/Wallabag/CoreBundle/Controller/ConfigControllerTest.php

694 lines
22 KiB
PHP
Raw Normal View History

2015-02-16 20:28:49 +00:00
<?php
2016-06-01 19:27:35 +00:00
namespace Tests\Wallabag\CoreBundle\Controller;
2015-02-16 20:28:49 +00:00
2016-06-01 19:27:35 +00:00
use Tests\Wallabag\CoreBundle\WallabagCoreTestCase;
2016-10-08 12:07:13 +00:00
use Wallabag\CoreBundle\Entity\Config;
use Wallabag\UserBundle\Entity\User;
2015-02-16 20:28:49 +00:00
2015-03-29 08:53:10 +00:00
class ConfigControllerTest extends WallabagCoreTestCase
2015-02-16 20:28:49 +00:00
{
public function testLogin()
{
$client = $this->getClient();
$client->request('GET', '/new');
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$this->assertContains('login', $client->getResponse()->headers->get('location'));
}
public function testIndex()
{
$this->logInAs('admin');
$client = $this->getClient();
$crawler = $client->request('GET', '/config');
$this->assertEquals(200, $client->getResponse()->getStatusCode());
2015-02-17 20:03:23 +00:00
$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]'));
2015-03-28 20:43:49 +00:00
$this->assertCount(1, $crawler->filter('button[id=rss_config_save]'));
2015-02-16 20:28:49 +00:00
}
public function testUpdate()
{
$this->logInAs('admin');
$client = $this->getClient();
$crawler = $client->request('GET', '/config');
$this->assertEquals(200, $client->getResponse()->getStatusCode());
2015-02-17 20:03:23 +00:00
$form = $crawler->filter('button[id=config_save]')->form();
2015-02-16 20:28:49 +00:00
$data = [
2015-12-29 08:59:46 +00:00
'config[theme]' => 'baggy',
2015-02-16 20:28:49 +00:00
'config[items_per_page]' => '30',
2016-03-18 12:12:09 +00:00
'config[reading_speed]' => '0.5',
2015-10-01 14:28:38 +00:00
'config[language]' => 'en',
];
2015-02-16 20:28:49 +00:00
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
2016-10-01 14:47:48 +00:00
$this->assertContains('flashes.config.notice.config_saved', $crawler->filter('body')->extract(['_text'])[0]);
2015-02-16 20:28:49 +00:00
}
2016-05-02 19:14:23 +00:00
public function testChangeReadingSpeed()
{
$this->logInAs('admin');
$client = $this->getClient();
$crawler = $client->request('GET', '/unread/list');
$form = $crawler->filter('button[id=submit-filter]')->form();
$dataFilters = [
'entry_filter[readingTime][right_number]' => 22,
'entry_filter[readingTime][left_number]' => 22,
];
$crawler = $client->submit($form, $dataFilters);
$this->assertCount(1, $crawler->filter('div[class=entry]'));
// Change reading speed
$crawler = $client->request('GET', '/config');
$form = $crawler->filter('button[id=config_save]')->form();
$data = [
'config[reading_speed]' => '2',
];
$client->submit($form, $data);
// Is the entry still available via filters?
$crawler = $client->request('GET', '/unread/list');
$form = $crawler->filter('button[id=submit-filter]')->form();
$crawler = $client->submit($form, $dataFilters);
$this->assertCount(0, $crawler->filter('div[class=entry]'));
// Restore old configuration
$crawler = $client->request('GET', '/config');
$form = $crawler->filter('button[id=config_save]')->form();
$data = [
'config[reading_speed]' => '0.5',
];
$client->submit($form, $data);
}
2015-02-16 20:28:49 +00:00
public function dataForUpdateFailed()
{
return [
[[
2015-12-29 08:59:46 +00:00
'config[theme]' => 'baggy',
2015-02-16 20:28:49 +00:00
'config[items_per_page]' => '',
2015-10-01 14:28:38 +00:00
'config[language]' => 'en',
]],
];
2015-02-16 20:28:49 +00:00
}
/**
* @dataProvider dataForUpdateFailed
*/
public function testUpdateFailed($data)
{
$this->logInAs('admin');
$client = $this->getClient();
$crawler = $client->request('GET', '/config');
$this->assertEquals(200, $client->getResponse()->getStatusCode());
2015-02-17 20:03:23 +00:00
$form = $crawler->filter('button[id=config_save]')->form();
2015-02-16 20:28:49 +00:00
$crawler = $client->submit($form, $data);
$this->assertEquals(200, $client->getResponse()->getStatusCode());
$this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
2015-02-16 20:28:49 +00:00
$this->assertContains('This value should not be blank', $alert[0]);
}
2015-02-17 20:03:23 +00:00
public function dataForChangePasswordFailed()
{
return [
[
[
2015-08-04 20:51:21 +00:00
'change_passwd[old_password]' => 'material',
2015-02-17 20:03:23 +00:00
'change_passwd[new_password][first]' => '',
'change_passwd[new_password][second]' => '',
],
'validator.password_wrong_value',
],
[
[
2015-02-17 20:03:23 +00:00
'change_passwd[old_password]' => 'mypassword',
'change_passwd[new_password][first]' => '',
'change_passwd[new_password][second]' => '',
],
'This value should not be blank',
],
[
[
2015-02-17 20:03:23 +00:00
'change_passwd[old_password]' => 'mypassword',
'change_passwd[new_password][first]' => 'hop',
'change_passwd[new_password][second]' => '',
],
'validator.password_must_match',
],
[
[
2015-02-17 20:03:23 +00:00
'change_passwd[old_password]' => 'mypassword',
'change_passwd[new_password][first]' => 'hop',
'change_passwd[new_password][second]' => 'hop',
],
'validator.password_too_short',
],
];
2015-02-17 20:03:23 +00:00
}
/**
* @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(['_text']));
2015-02-17 20:03:23 +00:00
$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 = [
2015-02-17 20:03:23 +00:00
'change_passwd[old_password]' => 'mypassword',
'change_passwd[new_password][first]' => 'mypassword',
'change_passwd[new_password][second]' => 'mypassword',
];
2015-02-17 20:03:23 +00:00
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
2016-10-01 14:47:48 +00:00
$this->assertContains('flashes.config.notice.password_updated', $crawler->filter('body')->extract(['_text'])[0]);
2015-02-17 20:03:23 +00:00
}
public function dataForUserFailed()
{
return [
[
[
'update_user[name]' => '',
'update_user[email]' => '',
],
'fos_user.email.blank',
],
[
[
'update_user[name]' => '',
'update_user[email]' => 'test',
],
'fos_user.email.invalid',
],
];
}
/**
* @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(['_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 = [
'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('body')->extract(['_text']));
2016-03-11 13:48:46 +00:00
$this->assertContains('flashes.config.notice.user_updated', $alert[0]);
}
2015-02-22 08:30:25 +00:00
2015-03-28 20:43:49 +00:00
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')
2015-03-28 20:43:49 +00:00
->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(['_text']));
$this->assertContains('config.form_rss.no_token', $body[0]);
2015-03-28 20:43:49 +00:00
$client->request('GET', '/generate-token');
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
$this->assertNotContains('config.form_rss.no_token', $body[0]);
2015-03-28 20:43:49 +00:00
}
public function testGenerateTokenAjax()
{
$this->logInAs('admin');
$client = $this->getClient();
$client->request(
'GET',
'/generate-token',
[],
[],
['HTTP_X-Requested-With' => 'XMLHttpRequest']
2015-03-28 20:43:49 +00:00
);
$this->assertEquals(200, $client->getResponse()->getStatusCode());
2015-04-01 19:53:57 +00:00
$content = json_decode($client->getResponse()->getContent(), true);
2015-03-28 20:43:49 +00:00
$this->assertArrayHasKey('token', $content);
}
public function testRssUpdate()
{
$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();
$data = [
2015-03-28 20:43:49 +00:00
'rss_config[rss_limit]' => 12,
];
2015-03-28 20:43:49 +00:00
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
2016-10-01 14:47:48 +00:00
$this->assertContains('flashes.config.notice.rss_updated', $crawler->filter('body')->extract(['_text'])[0]);
2015-03-28 20:43:49 +00:00
}
public function dataForRssFailed()
{
return [
[
[
2015-03-28 20:43:49 +00:00
'rss_config[rss_limit]' => 0,
],
2015-03-28 20:43:49 +00:00
'This value should be 1 or more.',
],
[
[
2015-03-28 20:43:49 +00:00
'rss_config[rss_limit]' => 1000000000000,
],
'validator.rss_limit_too_hight',
],
];
2015-03-28 20:43:49 +00:00
}
/**
* @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(['_text']));
2015-03-28 20:43:49 +00:00
$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 = [
'tagging_rule[rule]' => 'readingTime <= 3',
'tagging_rule[tags]' => 'short reading',
];
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
2016-10-01 14:47:48 +00:00
$this->assertContains('flashes.config.notice.tagging_rules_updated', $crawler->filter('body')->extract(['_text'])[0]);
$editLink = $crawler->filter('.mode_edit')->last()->link();
$crawler = $client->click($editLink);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$this->assertContains('?tagging-rule=', $client->getResponse()->headers->get('location'));
$crawler = $client->followRedirect();
$form = $crawler->filter('button[id=tagging_rule_save]')->form();
$data = [
'tagging_rule[rule]' => 'readingTime <= 30',
'tagging_rule[tags]' => 'short reading',
];
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
$this->assertContains('flashes.config.notice.tagging_rules_updated', $crawler->filter('body')->extract(['_text'])[0]);
$this->assertContains('readingTime <= 30', $crawler->filter('body')->extract(['_text'])[0]);
2015-11-13 20:23:39 +00:00
$deleteLink = $crawler->filter('.delete')->last()->link();
$crawler = $client->click($deleteLink);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$crawler = $client->followRedirect();
2016-10-01 14:47:48 +00:00
$this->assertContains('flashes.config.notice.tagging_rules_deleted', $crawler->filter('body')->extract(['_text'])[0]);
}
public function dataForTaggingRuleFailed()
{
return [
[
[
'tagging_rule[rule]' => 'unknownVar <= 3',
'tagging_rule[tags]' => 'cool tag',
],
[
'The variable',
'does not exist.',
],
],
[
[
'tagging_rule[rule]' => 'length(domainName) <= 42',
'tagging_rule[tags]' => 'cool tag',
],
[
'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();
$crawler = $client->submit($form, $data);
$this->assertEquals(200, $client->getResponse()->getStatusCode());
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
foreach ($messages as $message) {
$this->assertContains($message, $body[0]);
}
}
public function testDeletingTaggingRuleFromAnOtherUser()
{
$this->logInAs('bob');
$client = $this->getClient();
$rule = $client->getContainer()->get('doctrine.orm.entity_manager')
->getRepository('WallabagCoreBundle:TaggingRule')
->findAll()[0];
2016-10-01 14:47:48 +00:00
$crawler = $client->request('GET', '/tagging-rule/edit/'.$rule->getId());
$this->assertEquals(403, $client->getResponse()->getStatusCode());
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
$this->assertContains('You can not access this tagging rule', $body[0]);
}
public function testEditingTaggingRuleFromAnOtherUser()
{
$this->logInAs('bob');
$client = $this->getClient();
$rule = $client->getContainer()->get('doctrine.orm.entity_manager')
->getRepository('WallabagCoreBundle:TaggingRule')
->findAll()[0];
$crawler = $client->request('GET', '/tagging-rule/edit/'.$rule->getId());
$this->assertEquals(403, $client->getResponse()->getStatusCode());
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
$this->assertContains('You can not access this tagging rule', $body[0]);
}
2016-02-22 12:33:22 +00:00
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 = [
2016-02-22 12:33:22 +00:00
'change_passwd[old_password]' => 'mypassword',
'change_passwd[new_password][first]' => 'mypassword',
'change_passwd[new_password][second]' => 'mypassword',
];
2016-02-22 12:33:22 +00:00
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
2016-03-11 13:48:46 +00:00
$this->assertContains('flashes.config.notice.password_not_updated_demo', $client->getContainer()->get('session')->getFlashBag()->get('notice')[0]);
2016-02-22 12:33:22 +00:00
$config->set('demo_mode_enabled', 0);
$config->set('demo_mode_username', 'wallabag');
}
2016-09-08 13:47:03 +00:00
public function testDeleteUserButtonVisibility()
{
$this->logInAs('admin');
$client = $this->getClient();
$crawler = $client->request('GET', '/config');
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
$this->assertContains('config.form_user.delete.button', $body[0]);
2016-09-08 13:47:03 +00:00
$em = $client->getContainer()->get('doctrine.orm.entity_manager');
$user = $em
->getRepository('WallabagUserBundle:User')
->findOneByUsername('empty');
$user->setExpired(1);
$em->persist($user);
$user = $em
->getRepository('WallabagUserBundle:User')
->findOneByUsername('bob');
$user->setExpired(1);
$em->persist($user);
$em->flush();
$crawler = $client->request('GET', '/config');
$this->assertGreaterThan(1, $body = $crawler->filter('body')->extract(['_text']));
$this->assertNotContains('config.form_user.delete.button', $body[0]);
2016-09-08 13:47:03 +00:00
$client->request('GET', '/account/delete');
$this->assertEquals(403, $client->getResponse()->getStatusCode());
$user = $em
->getRepository('WallabagUserBundle:User')
->findOneByUsername('empty');
$user->setExpired(0);
$em->persist($user);
$user = $em
->getRepository('WallabagUserBundle:User')
->findOneByUsername('bob');
$user->setExpired(0);
$em->persist($user);
$em->flush();
}
public function testDeleteAccount()
{
$client = $this->getClient();
2016-10-08 12:07:13 +00:00
$em = $client->getContainer()->get('doctrine.orm.entity_manager');
$user = new User();
$user->setName('Wallace');
$user->setEmail('wallace@wallabag.org');
$user->setUsername('wallace');
$user->setPlainPassword('wallace');
$user->setEnabled(true);
$user->addRole('ROLE_SUPER_ADMIN');
$em->persist($user);
$config = new Config($user);
$config->setTheme('material');
$config->setItemsPerPage(30);
$config->setReadingSpeed(1);
$config->setLanguage('en');
$config->setPocketConsumerKey('xxxxx');
$em->persist($config);
$em->flush();
$this->logInAs('wallace');
$loggedInUserId = $this->getLoggedInUserId();
2016-09-08 13:47:03 +00:00
// create entry to check after user deletion
// that this entry is also deleted
$crawler = $client->request('GET', '/new');
$this->assertEquals(200, $client->getResponse()->getStatusCode());
$form = $crawler->filter('form[name=entry]')->form();
$data = [
'entry[url]' => $url = 'https://github.com/wallabag/wallabag',
];
$client->submit($form, $data);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
2016-09-08 13:47:03 +00:00
$crawler = $client->request('GET', '/config');
2016-09-08 14:00:39 +00:00
$deleteLink = $crawler->filter('.delete-account')->last()->link();
2016-09-08 13:47:03 +00:00
$client->click($deleteLink);
$this->assertEquals(302, $client->getResponse()->getStatusCode());
$em = $client->getContainer()->get('doctrine.orm.entity_manager');
$user = $em
->getRepository('WallabagUserBundle:User')
->createQueryBuilder('u')
->where('u.username = :username')->setParameter('username', 'wallace')
->getQuery()
->getOneOrNullResult()
;
2016-09-08 14:00:39 +00:00
$this->assertNull($user);
$entries = $client->getContainer()
->get('doctrine.orm.entity_manager')
->getRepository('WallabagCoreBundle:Entry')
->findByUser($loggedInUserId);
$this->assertEmpty($entries);
2016-09-08 13:47:03 +00:00
}
2015-02-16 20:28:49 +00:00
}