X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2FWallabag%2FApiBundle%2FTests%2FController%2FWallabagRestControllerTest.php;h=2f2d92ee83e524e1a2813b6b487451cb3408efbb;hb=41c9eecfa728df7d8734ca1b0a69c55c93aafcea;hp=2e78d8b2ca9bc6b06879082f11e118649f102d5a;hpb=3500d4099f88f7db22eba42fdb7e8926f1f1cdac;p=github%2Fwallabag%2Fwallabag.git diff --git a/src/Wallabag/ApiBundle/Tests/Controller/WallabagRestControllerTest.php b/src/Wallabag/ApiBundle/Tests/Controller/WallabagRestControllerTest.php index 2e78d8b2..2f2d92ee 100644 --- a/src/Wallabag/ApiBundle/Tests/Controller/WallabagRestControllerTest.php +++ b/src/Wallabag/ApiBundle/Tests/Controller/WallabagRestControllerTest.php @@ -13,7 +13,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase $entry = $this->client->getContainer() ->get('doctrine.orm.entity_manager') ->getRepository('WallabagCoreBundle:Entry') - ->findOneBy(array('user' => 1, 'isArchived' => false)); + ->findOneBy(['user' => 1, 'isArchived' => false]); if (!$entry) { $this->markTestSkipped('No content found in db.'); @@ -44,7 +44,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase $entry = $this->client->getContainer() ->get('doctrine.orm.entity_manager') ->getRepository('WallabagCoreBundle:Entry') - ->findOneBy(array('user' => 2, 'isArchived' => false)); + ->findOneBy(['user' => 2, 'isArchived' => false]); if (!$entry) { $this->markTestSkipped('No content found in db.'); @@ -79,7 +79,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase public function testGetStarredEntries() { - $this->client->request('GET', '/api/entries', array('star' => 1, 'sort' => 'updated')); + $this->client->request('GET', '/api/entries', ['star' => 1, 'sort' => 'updated']); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -101,7 +101,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase public function testGetArchiveEntries() { - $this->client->request('GET', '/api/entries', array('archive' => 1)); + $this->client->request('GET', '/api/entries', ['archive' => 1]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -149,10 +149,11 @@ class WallabagRestControllerTest extends WallabagApiTestCase public function testPostEntry() { - $this->client->request('POST', '/api/entries.json', array( + $this->client->request('POST', '/api/entries.json', [ 'url' => 'http://www.lemonde.fr/pixels/article/2015/03/28/plongee-dans-l-univers-d-ingress-le-jeu-de-google-aux-frontieres-du-reel_4601155_4408996.html', 'tags' => 'google', - )); + 'title' => 'New title for my article', + ]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -162,16 +163,18 @@ class WallabagRestControllerTest extends WallabagApiTestCase $this->assertEquals('http://www.lemonde.fr/pixels/article/2015/03/28/plongee-dans-l-univers-d-ingress-le-jeu-de-google-aux-frontieres-du-reel_4601155_4408996.html', $content['url']); $this->assertEquals(false, $content['is_archived']); $this->assertEquals(false, $content['is_starred']); + $this->assertEquals('New title for my article', $content['title']); $this->assertEquals(1, $content['user_id']); $this->assertCount(1, $content['tags']); } public function testPostSameEntry() { - $this->client->request('POST', '/api/entries.json', array( + $this->client->request('POST', '/api/entries.json', [ 'url' => 'http://www.lemonde.fr/pixels/article/2015/03/28/plongee-dans-l-univers-d-ingress-le-jeu-de-google-aux-frontieres-du-reel_4601155_4408996.html', 'archive' => '1', - )); + 'tags' => 'google, apple', + ]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -181,16 +184,16 @@ class WallabagRestControllerTest extends WallabagApiTestCase $this->assertEquals('http://www.lemonde.fr/pixels/article/2015/03/28/plongee-dans-l-univers-d-ingress-le-jeu-de-google-aux-frontieres-du-reel_4601155_4408996.html', $content['url']); $this->assertEquals(true, $content['is_archived']); $this->assertEquals(false, $content['is_starred']); - $this->assertCount(1, $content['tags']); + $this->assertCount(2, $content['tags']); } public function testPostArchivedAndStarredEntry() { - $this->client->request('POST', '/api/entries.json', array( + $this->client->request('POST', '/api/entries.json', [ 'url' => 'http://www.lemonde.fr/idees/article/2016/02/08/preserver-la-liberte-d-expression-sur-les-reseaux-sociaux_4861503_3232.html', - 'archive' => true, - 'starred' => true, - )); + 'archive' => '1', + 'starred' => '1', + ]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -203,6 +206,24 @@ class WallabagRestControllerTest extends WallabagApiTestCase $this->assertEquals(1, $content['user_id']); } + public function testPostArchivedAndStarredEntryWithoutQuotes() + { + $this->client->request('POST', '/api/entries.json', [ + 'url' => 'http://www.lemonde.fr/idees/article/2016/02/08/preserver-la-liberte-d-expression-sur-les-reseaux-sociaux_4861503_3232.html', + 'archive' => 0, + 'starred' => 1, + ]); + + $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); + + $content = json_decode($this->client->getResponse()->getContent(), true); + + $this->assertGreaterThan(0, $content['id']); + $this->assertEquals('http://www.lemonde.fr/idees/article/2016/02/08/preserver-la-liberte-d-expression-sur-les-reseaux-sociaux_4861503_3232.html', $content['url']); + $this->assertEquals(false, $content['is_archived']); + $this->assertEquals(true, $content['is_starred']); + } + public function testPatchEntry() { $entry = $this->client->getContainer() @@ -217,12 +238,12 @@ class WallabagRestControllerTest extends WallabagApiTestCase // hydrate the tags relations $nbTags = count($entry->getTags()); - $this->client->request('PATCH', '/api/entries/'.$entry->getId().'.json', array( + $this->client->request('PATCH', '/api/entries/'.$entry->getId().'.json', [ 'title' => 'New awesome title', 'tags' => 'new tag '.uniqid(), - 'star' => true, - 'archive' => false, - )); + 'starred' => '1', + 'archive' => '0', + ]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -235,6 +256,37 @@ class WallabagRestControllerTest extends WallabagApiTestCase $this->assertEquals(1, $content['user_id']); } + public function testPatchEntryWithoutQuotes() + { + $entry = $this->client->getContainer() + ->get('doctrine.orm.entity_manager') + ->getRepository('WallabagCoreBundle:Entry') + ->findOneByUser(1); + + if (!$entry) { + $this->markTestSkipped('No content found in db.'); + } + + // hydrate the tags relations + $nbTags = count($entry->getTags()); + + $this->client->request('PATCH', '/api/entries/'.$entry->getId().'.json', [ + 'title' => 'New awesome title', + 'tags' => 'new tag '.uniqid(), + 'starred' => 1, + 'archive' => 0, + ]); + + $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); + + $content = json_decode($this->client->getResponse()->getContent(), true); + + $this->assertEquals($entry->getId(), $content['id']); + $this->assertEquals($entry->getUrl(), $content['url']); + $this->assertEquals('New awesome title', $content['title']); + $this->assertGreaterThan($nbTags, count($content['tags'])); + } + public function testGetTagsEntry() { $entry = $this->client->getContainer() @@ -248,9 +300,9 @@ class WallabagRestControllerTest extends WallabagApiTestCase $this->markTestSkipped('No content found in db.'); } - $tags = array(); + $tags = []; foreach ($entry->getTags() as $tag) { - $tags[] = array('id' => $tag->getId(), 'label' => $tag->getLabel(), 'slug' => $tag->getSlug()); + $tags[] = ['id' => $tag->getId(), 'label' => $tag->getLabel(), 'slug' => $tag->getSlug()]; } $this->client->request('GET', '/api/entries/'.$entry->getId().'/tags'); @@ -273,7 +325,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase $newTags = 'tag1,tag2,tag3'; - $this->client->request('POST', '/api/entries/'.$entry->getId().'/tags', array('tags' => $newTags)); + $this->client->request('POST', '/api/entries/'.$entry->getId().'/tags', ['tags' => $newTags]); $this->assertEquals(200, $this->client->getResponse()->getStatusCode()); @@ -287,7 +339,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase ->getRepository('WallabagCoreBundle:Entry') ->find($entry->getId()); - $tagsInDB = array(); + $tagsInDB = []; foreach ($entryDB->getTags()->toArray() as $tag) { $tagsInDB[$tag->getId()] = $tag->getLabel(); }