mirror of
https://github.com/wallabag/wallabag.git
synced 2024-11-23 17:41:01 +00:00
commit
6ab56c7b2c
6 changed files with 70 additions and 18 deletions
|
@ -50,6 +50,6 @@ before_install:
|
||||||
- if [[ $TRAVIS_REPO_SLUG = wallabag/wallabag ]]; then cp .composer-auth.json ~/.composer/auth.json; fi;
|
- if [[ $TRAVIS_REPO_SLUG = wallabag/wallabag ]]; then cp .composer-auth.json ~/.composer/auth.json; fi;
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- travis_wait composer update --no-interaction --no-progress
|
- travis_wait composer install --no-interaction --no-progress --prefer-dist -o
|
||||||
- ant prepare-$DB
|
- ant prepare-$DB
|
||||||
- bin/phpunit -v
|
- bin/phpunit -v
|
||||||
|
|
|
@ -88,4 +88,22 @@ class AnnotationRepository extends EntityRepository
|
||||||
->getQuery()
|
->getQuery()
|
||||||
->getOneOrNullResult();
|
->getOneOrNullResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used only in test case to get the right annotation associated to the right user.
|
||||||
|
*
|
||||||
|
* @param string $username
|
||||||
|
*
|
||||||
|
* @return Annotation
|
||||||
|
*/
|
||||||
|
public function findOneByUsername($username)
|
||||||
|
{
|
||||||
|
return $this->createQueryBuilder('a')
|
||||||
|
->leftJoin('a.user', 'u')
|
||||||
|
->where('u.username = :username')->setParameter('username', $username)
|
||||||
|
->orderBy('a.id', 'DESC')
|
||||||
|
->setMaxResults(1)
|
||||||
|
->getQuery()
|
||||||
|
->getSingleResult();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,11 +11,12 @@ class AnnotationControllerTest extends WallabagAnnotationTestCase
|
||||||
$annotation = $this->client->getContainer()
|
$annotation = $this->client->getContainer()
|
||||||
->get('doctrine.orm.entity_manager')
|
->get('doctrine.orm.entity_manager')
|
||||||
->getRepository('WallabagAnnotationBundle:Annotation')
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
->findOneBy(array('user' => 1));
|
->findOneByUsername('admin');
|
||||||
|
|
||||||
if (!$annotation) {
|
if (!$annotation) {
|
||||||
$this->markTestSkipped('No content found in db.');
|
$this->markTestSkipped('No content found in db.');
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->logInAs('admin');
|
$this->logInAs('admin');
|
||||||
$crawler = $this->client->request('GET', 'annotations/'.$annotation->getEntry()->getId().'.json');
|
$crawler = $this->client->request('GET', 'annotations/'.$annotation->getEntry()->getId().'.json');
|
||||||
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
@ -32,18 +33,25 @@ class AnnotationControllerTest extends WallabagAnnotationTestCase
|
||||||
$entry = $this->client->getContainer()
|
$entry = $this->client->getContainer()
|
||||||
->get('doctrine.orm.entity_manager')
|
->get('doctrine.orm.entity_manager')
|
||||||
->getRepository('WallabagCoreBundle:Entry')
|
->getRepository('WallabagCoreBundle:Entry')
|
||||||
->findOneBy(array('user' => 1));
|
->findOneByUsernameAndNotArchived('admin');
|
||||||
|
|
||||||
$headers = array('CONTENT_TYPE' => 'application/json');
|
$headers = array('CONTENT_TYPE' => 'application/json');
|
||||||
$content = json_encode(array(
|
$content = json_encode(array(
|
||||||
'text' => 'my annotation',
|
'text' => 'my annotation',
|
||||||
'quote' => 'my quote',
|
'quote' => 'my quote',
|
||||||
'range' => '[{"start":"","startOffset":24,"end":"","endOffset":31}]',
|
'ranges' => array('start' => '', 'startOffset' => 24, 'end' => '', 'endOffset' => 31),
|
||||||
));
|
));
|
||||||
$crawler = $this->client->request('POST', 'annotations/'.$entry->getId().'.json', array(), array(), $headers, $content);
|
$crawler = $this->client->request('POST', 'annotations/'.$entry->getId().'.json', array(), array(), $headers, $content);
|
||||||
|
|
||||||
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
|
||||||
|
$content = json_decode($this->client->getResponse()->getContent(), true);
|
||||||
|
|
||||||
|
$this->assertEquals('Big boss', $content['user']);
|
||||||
|
$this->assertEquals('v1.0', $content['annotator_schema_version']);
|
||||||
|
$this->assertEquals('my annotation', $content['text']);
|
||||||
|
$this->assertEquals('my quote', $content['quote']);
|
||||||
|
|
||||||
$annotation = $this->client->getContainer()
|
$annotation = $this->client->getContainer()
|
||||||
->get('doctrine.orm.entity_manager')
|
->get('doctrine.orm.entity_manager')
|
||||||
->getRepository('WallabagAnnotationBundle:Annotation')
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
|
@ -57,25 +65,56 @@ class AnnotationControllerTest extends WallabagAnnotationTestCase
|
||||||
$annotation = $this->client->getContainer()
|
$annotation = $this->client->getContainer()
|
||||||
->get('doctrine.orm.entity_manager')
|
->get('doctrine.orm.entity_manager')
|
||||||
->getRepository('WallabagAnnotationBundle:Annotation')
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
->findOneBy(array('user' => 1));
|
->findOneByUsername('admin');
|
||||||
|
|
||||||
$this->logInAs('admin');
|
$this->logInAs('admin');
|
||||||
|
|
||||||
$headers = array('CONTENT_TYPE' => 'application/json');
|
$headers = array('CONTENT_TYPE' => 'application/json');
|
||||||
$content = json_encode(array(
|
$content = json_encode(array(
|
||||||
'text' => 'a modified annotation',
|
'text' => 'a modified annotation',
|
||||||
));
|
));
|
||||||
$crawler = $this->client->request('PUT', 'annotations/'.$annotation->getId().'.json', array(), array(), $headers, $content);
|
$crawler = $this->client->request('PUT', 'annotations/'.$annotation->getId().'.json', array(), array(), $headers, $content);
|
||||||
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
|
||||||
$content = json_decode($this->client->getResponse()->getContent(), true);
|
$content = json_decode($this->client->getResponse()->getContent(), true);
|
||||||
|
|
||||||
|
$this->assertEquals('Big boss', $content['user']);
|
||||||
|
$this->assertEquals('v1.0', $content['annotator_schema_version']);
|
||||||
|
$this->assertEquals('a modified annotation', $content['text']);
|
||||||
|
$this->assertEquals('my quote', $content['quote']);
|
||||||
|
|
||||||
|
$annotationUpdated = $this->client->getContainer()
|
||||||
|
->get('doctrine.orm.entity_manager')
|
||||||
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
|
->findOneById($annotation->getId());
|
||||||
|
$this->assertEquals('a modified annotation', $annotationUpdated->getText());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeleteAnnotation()
|
||||||
|
{
|
||||||
|
$annotation = $this->client->getContainer()
|
||||||
|
->get('doctrine.orm.entity_manager')
|
||||||
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
|
->findOneByUsername('admin');
|
||||||
|
|
||||||
|
$this->logInAs('admin');
|
||||||
|
|
||||||
|
$headers = array('CONTENT_TYPE' => 'application/json');
|
||||||
|
$content = json_encode(array(
|
||||||
|
'text' => 'a modified annotation',
|
||||||
|
));
|
||||||
|
$crawler = $this->client->request('DELETE', 'annotations/'.$annotation->getId().'.json', array(), array(), $headers, $content);
|
||||||
|
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
|
||||||
|
$content = json_decode($this->client->getResponse()->getContent(), true);
|
||||||
|
|
||||||
$this->assertEquals('a modified annotation', $content['text']);
|
$this->assertEquals('a modified annotation', $content['text']);
|
||||||
|
|
||||||
$annotationUpdated = $this->client->getContainer()
|
$annotationDeleted = $this->client->getContainer()
|
||||||
->get('doctrine.orm.entity_manager')
|
->get('doctrine.orm.entity_manager')
|
||||||
->getRepository('WallabagAnnotationBundle:Annotation')
|
->getRepository('WallabagAnnotationBundle:Annotation')
|
||||||
->findAnnotationById($annotation->getId());
|
->findOneById($annotation->getId());
|
||||||
$this->assertEquals('a modified annotation', $annotationUpdated->getText());
|
|
||||||
|
$this->assertNull($annotationDeleted);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -162,12 +162,12 @@ class WallabagRestControllerTest extends WallabagApiTestCase
|
||||||
$this->assertCount(1, $content['tags']);
|
$this->assertCount(1, $content['tags']);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testPostArchivedEntry()
|
public function testPostArchivedAndStarredEntry()
|
||||||
{
|
{
|
||||||
$this->client->request('POST', '/api/entries.json', array(
|
$this->client->request('POST', '/api/entries.json', array(
|
||||||
'url' => 'http://www.lemonde.fr/idees/article/2016/02/08/preserver-la-liberte-d-expression-sur-les-reseaux-sociaux_4861503_3232.html',
|
'url' => 'http://www.lemonde.fr/idees/article/2016/02/08/preserver-la-liberte-d-expression-sur-les-reseaux-sociaux_4861503_3232.html',
|
||||||
'archive' => true,
|
'archive' => true,
|
||||||
'starred' => false,
|
'starred' => true,
|
||||||
));
|
));
|
||||||
|
|
||||||
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
$this->assertEquals(200, $this->client->getResponse()->getStatusCode());
|
||||||
|
@ -177,7 +177,7 @@ class WallabagRestControllerTest extends WallabagApiTestCase
|
||||||
$this->assertGreaterThan(0, $content['id']);
|
$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('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(true, $content['is_archived']);
|
$this->assertEquals(true, $content['is_archived']);
|
||||||
$this->assertEquals(false, $content['is_starred']);
|
$this->assertEquals(true, $content['is_starred']);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testPatchEntry()
|
public function testPatchEntry()
|
||||||
|
|
|
@ -16,7 +16,6 @@ use Wallabag\CoreBundle\Form\Type\RssType;
|
||||||
use Wallabag\CoreBundle\Form\Type\TaggingRuleType;
|
use Wallabag\CoreBundle\Form\Type\TaggingRuleType;
|
||||||
use Wallabag\CoreBundle\Form\Type\UserInformationType;
|
use Wallabag\CoreBundle\Form\Type\UserInformationType;
|
||||||
use Wallabag\CoreBundle\Tools\Utils;
|
use Wallabag\CoreBundle\Tools\Utils;
|
||||||
use Wallabag\UserBundle\Entity\User;
|
|
||||||
|
|
||||||
class ConfigController extends Controller
|
class ConfigController extends Controller
|
||||||
{
|
{
|
||||||
|
|
|
@ -302,8 +302,6 @@ class PocketImportTest extends \PHPUnit_Framework_TestCase
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
"favorite": "1",
|
"favorite": "1",
|
||||||
"status": "1",
|
"status": "1",
|
||||||
"resolved_title": "The Massive Ryder Cup Preview",
|
|
||||||
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
"is_article": "1",
|
"is_article": "1",
|
||||||
"has_video": "1",
|
"has_video": "1",
|
||||||
|
@ -317,8 +315,6 @@ class PocketImportTest extends \PHPUnit_Framework_TestCase
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
"favorite": "1",
|
"favorite": "1",
|
||||||
"status": "0",
|
"status": "0",
|
||||||
"resolved_title": "The Massive Ryder Cup Preview",
|
|
||||||
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
"is_article": "1",
|
"is_article": "1",
|
||||||
"has_video": "0",
|
"has_video": "0",
|
||||||
|
|
Loading…
Reference in a new issue