$this->assertContains('login', $client->getResponse()->headers->get('location'));
}
+ /**
+ * @group NetworkCalls
+ */
public function testQuickstart()
{
$this->logInAs('empty');
$this->assertCount(1, $crawler->filter('form[name=entry]'));
}
+ /**
+ * @group NetworkCalls
+ */
public function testPostNewViaBookmarklet()
{
$this->logInAs('admin');
}
/**
- * This test will require an internet connection.
+ * @group NetworkCalls
*/
public function testPostNewOk()
{
$client->getContainer()->get('craue_config')->set('store_article_headers', 0);
}
+ /**
+ * @group NetworkCalls
+ */
public function testPostWithMultipleAuthors()
{
$url = 'https://www.liberation.fr/planete/2017/04/05/donald-trump-et-xi-jinping-tentative-de-flirt-en-floride_1560768';
$this->assertContains('/view/', $client->getResponse()->getTargetUrl());
}
+ /**
+ * @group NetworkCalls
+ */
public function testPostNewOkUrlExistWithAccent()
{
$this->logInAs('admin');
}
/**
- * This test will require an internet connection.
+ * @group NetworkCalls
*/
public function testPostNewOkUrlExistWithRedirection()
{
}
/**
- * This test will require an internet connection.
+ * @group NetworkCalls
*/
public function testPostNewThatWillBeTagged()
{
}
/**
- * This test will require an internet connection.
+ * @group NetworkCalls
*/
public function testReload()
{
$this->assertCount(2, $crawler->filter('li.entry'));
}
+ public function testSortOnTitle()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $crawler = $client->request('GET', '/unread/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'title',
+ 'entry_sort[sortOrder]' => 'asc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $this->assertCount(4, $crawler->filter('li.entry'));
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ $ids = [1, 2, 4, 5];
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+
+ $ids = array_reverse($ids);
+
+ $crawler = $client->request('GET', '/unread/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'title',
+ 'entry_sort[sortOrder]' => 'desc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+ }
+
+ public function testSortOnCreationDate()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $entry1 = new Entry($this->getLoggedInUser());
+ $entry1->setTitle('test title entry7');
+ $entry1->setCreatedAt(new \DateTime('2013-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry1);
+
+ $entry2 = new Entry($this->getLoggedInUser());
+ $entry2->setTitle('test title entry8');
+ $entry2->setCreatedAt(new \DateTime('2012-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry2);
+
+ $entry3 = new Entry($this->getLoggedInUser());
+ $entry3->setTitle('test title entry9');
+ $entry3->setCreatedAt(new \DateTime('2014-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry3);
+
+ $this->getEntityManager()->flush();
+
+ $crawler = $client->request('GET', '/unread/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'createdAt',
+ 'entry_sort[sortOrder]' => 'asc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $this->assertCount(7, $crawler->filter('li.entry'));
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ $ids = [8, 7, 9, 1, 2, 4, 5];
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+
+ $ids = array_reverse($ids);
+
+ $crawler = $client->request('GET', '/unread/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'createdAt',
+ 'entry_sort[sortOrder]' => 'desc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+ }
+
+ public function testSortOnStarredDate()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $entry1 = new Entry($this->getLoggedInUser());
+ $entry1->setTitle('test title entry7');
+ $entry1->setStarred(true);
+ $entry1->setStarredAt(new \DateTime('2013-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry1);
+
+ $entry2 = new Entry($this->getLoggedInUser());
+ $entry2->setTitle('test title entry8');
+ $entry2->setStarred(true);
+ $entry2->setStarredAt(new \DateTime('2012-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry2);
+
+ $entry3 = new Entry($this->getLoggedInUser());
+ $entry3->setTitle('test title entry9');
+ $entry3->setStarred(true);
+ $entry3->setStarredAt(new \DateTime('2014-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry3);
+
+ $this->getEntityManager()->flush();
+
+ $crawler = $client->request('GET', '/starred/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'starredAt',
+ 'entry_sort[sortOrder]' => 'asc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $this->assertCount(4, $crawler->filter('li.entry'));
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ $ids = [8, 7, 9, 5];
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+
+ $ids = array_reverse($ids);
+
+ $crawler = $client->request('GET', '/starred/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'starredAt',
+ 'entry_sort[sortOrder]' => 'desc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+ }
+
+ public function testSortOnArchivedDate()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $entry1 = new Entry($this->getLoggedInUser());
+ $entry1->setTitle('test title entry7');
+ $entry1->setArchived(true);
+ $entry1->setArchivedAt(new \DateTime('2010-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry1);
+
+ $entry2 = new Entry($this->getLoggedInUser());
+ $entry2->setTitle('test title entry8');
+ $entry2->setArchived(true);
+ $entry2->setArchivedAt(new \DateTime('2000-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry2);
+
+ $entry3 = new Entry($this->getLoggedInUser());
+ $entry3->setTitle('test title entry9');
+ $entry3->setArchived(true);
+ $entry3->setArchivedAt(new \DateTime('2020-04-03T13:37:00'));
+ $this->getEntityManager()->persist($entry3);
+
+ $this->getEntityManager()->flush();
+
+ $crawler = $client->request('GET', '/archive/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'archivedAt',
+ 'entry_sort[sortOrder]' => 'asc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $this->assertCount(4, $crawler->filter('li.entry'));
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ $ids = [8, 7, 9, 6];
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+
+ $ids = array_reverse($ids);
+
+ $crawler = $client->request('GET', '/archive/list');
+ $form = $crawler->filter('button[id=submit-sort]')->form();
+ $data = [
+ 'entry_sort[sortType]' => 'archivedAt',
+ 'entry_sort[sortOrder]' => 'desc',
+ ];
+ $crawler = $client->submit($form, $data);
+
+ $matches = [];
+ preg_match_all('/test title entry([0-9])/', $client->getResponse()->getContent(), $matches);
+
+ $results = array_values(array_unique($matches[0]));
+
+ foreach ($results as $key => $result) {
+ $this->assertSame('test title entry' . $ids[$key], $result);
+ }
+ }
+
public function testShareEntryPublicly()
{
$this->logInAs('admin');
$this->assertSame(404, $client->getResponse()->getStatusCode());
}
+ /**
+ * @group NetworkCalls
+ */
public function testNewEntryWithDownloadImagesEnabled()
{
$this->downloadImagesEnabled = true;
/**
* @dataProvider dataForLanguage
+ * @group NetworkCalls
*/
public function testLanguageValidation($url, $expectedLanguage)
{
}
/**
- * This test will require an internet connection.
+ * @group NetworkCalls
*/
public function testRestrictedArticle()
{
$this->assertSame(302, $client->getResponse()->getStatusCode());
$this->assertContains('/view/', $client->getResponse()->getTargetUrl(), 'All random');
}
+
+ public function testMass()
+ {
+ $this->logInAs('admin');
+ $client = $this->getClient();
+
+ $entry1 = new Entry($this->getLoggedInUser());
+ $entry1->setUrl($this->url);
+ $this->getEntityManager()->persist($entry1);
+
+ $entry2 = new Entry($this->getLoggedInUser());
+ $entry2->setUrl($this->url);
+ $this->getEntityManager()->persist($entry2);
+
+ $this->getEntityManager()->flush();
+ $this->getEntityManager()->clear();
+
+ $entries = [];
+ $entries[] = $entry1->getId();
+ $entries[] = $entry2->getId();
+
+ // Mass actions : archive
+ $client->request('POST', '/mass', [
+ 'toggle-archive' => '',
+ 'entry-checkbox' => $entries,
+ ]);
+
+ $this->assertSame(302, $client->getResponse()->getStatusCode());
+
+ $res = $client->getContainer()
+ ->get('doctrine.orm.entity_manager')
+ ->getRepository('WallabagCoreBundle:Entry')
+ ->find($entry1->getId());
+
+ $this->assertSame(1, $res->isArchived());
+
+ $res = $client->getContainer()
+ ->get('doctrine.orm.entity_manager')
+ ->getRepository('WallabagCoreBundle:Entry')
+ ->find($entry2->getId());
+
+ $this->assertSame(1, $res->isArchived());
+
+ // Mass actions : star
+ $client->request('POST', '/mass', [
+ 'toggle-star' => '',
+ 'entry-checkbox' => $entries,
+ ]);
+
+ $this->assertSame(302, $client->getResponse()->getStatusCode());
+
+ $res = $client->getContainer()
+ ->get('doctrine.orm.entity_manager')
+ ->getRepository('WallabagCoreBundle:Entry')
+ ->find($entry1->getId());
+
+ $this->assertSame(1, $res->isStarred());
+
+ $res = $client->getContainer()
+ ->get('doctrine.orm.entity_manager')
+ ->getRepository('WallabagCoreBundle:Entry')
+ ->find($entry2->getId());
+
+ $this->assertSame(1, $res->isStarred());
+
+ // Mass actions : delete
+ $client->request('POST', '/mass', [
+ 'delete' => '',
+ 'entry-checkbox' => $entries,
+ ]);
+
+ $client->request('GET', '/delete/' . $entry1->getId());
+ $this->assertSame(404, $client->getResponse()->getStatusCode());
+
+ $client->request('GET', '/delete/' . $entry2->getId());
+ $this->assertSame(404, $client->getResponse()->getStatusCode());
+ }
}