]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Tests/Controller/WallabagRestControllerTest.php
remove useless code
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Tests / Controller / WallabagRestControllerTest.php
CommitLineData
68c6f1bd
NL
1<?php
2
3namespace Wallabag\CoreBundle\Tests\Controller;
4
874e3e10 5use Wallabag\CoreBundle\Tests\WallabagTestCase;
68c6f1bd 6
874e3e10 7class WallabagRestControllerTest extends WallabagTestCase
68c6f1bd 8{
19aee7cd
NL
9 /**
10 * Generate HTTP headers for authenticate user on API
11 *
12 * @param $username
13 * @param $password
14 * @param $salt
15 *
16 * @return array
17 */
18 private function generateHeaders($username, $password, $salt)
19 {
20 $encryptedPassword = sha1($password.$username.$salt);
21 $nonce = substr(md5(uniqid('nonce_', true)), 0, 16);
22
23 $now = new \DateTime('now', new \DateTimeZone('UTC'));
24 $created = (string) $now->format('Y-m-d\TH:i:s\Z');
25 $digest = base64_encode(sha1(base64_decode($nonce).$created.$encryptedPassword, true));
26
27 return array(
19aee7cd
NL
28 'HTTP_AUTHORIZATION' => 'Authorization profile="UsernameToken"',
29 'HTTP_x-wsse' => 'X-WSSE: UsernameToken Username="'.$username.'", PasswordDigest="'.$digest.'", Nonce="'.$nonce.'", Created="'.$created.'"',
30 );
31 }
32
f5deb024
NL
33 public function testGetSalt()
34 {
35 $client = $this->createClient();
36 $client->request('GET', '/api/salts/admin.json');
37 $this->assertEquals(200, $client->getResponse()->getStatusCode());
f170f315 38 $this->assertNotEmpty(json_decode($client->getResponse()->getContent()));
f5deb024
NL
39
40 $client->request('GET', '/api/salts/notfound.json');
41 $this->assertEquals(404, $client->getResponse()->getStatusCode());
42 }
43
59f18f9a
NL
44 public function testWithBadHeaders()
45 {
46 $client = $this->createClient();
59f18f9a
NL
47
48 $entry = $client->getContainer()
49 ->get('doctrine.orm.entity_manager')
50 ->getRepository('WallabagCoreBundle:Entry')
51 ->findOneByIsArchived(false);
52
53 if (!$entry) {
54 $this->markTestSkipped('No content found in db.');
55 }
56
57 $badHeaders = array(
58 'HTTP_AUTHORIZATION' => 'Authorization profile="UsernameToken"',
59 'HTTP_x-wsse' => 'X-WSSE: UsernameToken Username="admin", PasswordDigest="Wr0ngDig3st", Nonce="n0Nc3", Created="2015-01-01T13:37:00Z"',
60 );
61
62 $client->request('GET', '/api/entries/'.$entry->getId().'.json', array(), array(), $badHeaders);
63 $this->assertEquals(403, $client->getResponse()->getStatusCode());
64 }
65
19aee7cd 66 public function testGetOneEntry()
f5deb024 67 {
68c6f1bd 68 $client = $this->createClient();
e1dd7f70 69 $client->request('GET', '/api/salts/admin.json');
c9fa9677 70 $salt = json_decode($client->getResponse()->getContent());
e1dd7f70 71
d9085c63 72 $headers = $this->generateHeaders('admin', 'mypassword', $salt[0]);
e1dd7f70 73
c9fa9677
NL
74 $entry = $client->getContainer()
75 ->get('doctrine.orm.entity_manager')
76 ->getRepository('WallabagCoreBundle:Entry')
77 ->findOneByIsArchived(false);
78
79 if (!$entry) {
80 $this->markTestSkipped('No content found in db.');
81 }
82
83 $client->request('GET', '/api/entries/'.$entry->getId().'.json', array(), array(), $headers);
84 $this->assertContains($entry->getTitle(), $client->getResponse()->getContent());
e1dd7f70 85
19aee7cd
NL
86 $this->assertTrue(
87 $client->getResponse()->headers->contains(
88 'Content-Type',
89 'application/json'
90 )
e1dd7f70 91 );
19aee7cd
NL
92 }
93
94 public function testGetEntries()
95 {
96 $client = $this->createClient();
97 $client->request('GET', '/api/salts/admin.json');
c9fa9677 98 $salt = json_decode($client->getResponse()->getContent());
19aee7cd 99
d9085c63 100 $headers = $this->generateHeaders('admin', 'mypassword', $salt[0]);
e1dd7f70
NL
101
102 $client->request('GET', '/api/entries', array(), array(), $headers);
d9b71755
NL
103
104 $this->assertEquals(200, $client->getResponse()->getStatusCode());
105
d9b71755
NL
106 $this->assertGreaterThanOrEqual(1, count(json_decode($client->getResponse()->getContent())));
107
e1dd7f70 108 $this->assertContains('Mailjet', $client->getResponse()->getContent());
68c6f1bd
NL
109
110 $this->assertTrue(
111 $client->getResponse()->headers->contains(
112 'Content-Type',
113 'application/json'
114 )
115 );
68c6f1bd 116 }
c9fa9677
NL
117
118 public function testDeleteEntry()
119 {
120 $client = $this->createClient();
121 $client->request('GET', '/api/salts/admin.json');
122 $salt = json_decode($client->getResponse()->getContent());
123
d9085c63 124 $headers = $this->generateHeaders('admin', 'mypassword', $salt[0]);
c9fa9677
NL
125
126 $entry = $client->getContainer()
127 ->get('doctrine.orm.entity_manager')
128 ->getRepository('WallabagCoreBundle:Entry')
1d147791 129 ->findOneByUser(1);
c9fa9677
NL
130
131 if (!$entry) {
132 $this->markTestSkipped('No content found in db.');
133 }
134
135 $client->request('DELETE', '/api/entries/'.$entry->getId().'.json', array(), array(), $headers);
136
137 $this->assertEquals(200, $client->getResponse()->getStatusCode());
138
1d147791
NL
139 // We'll try to delete this entry again
140 $client->request('GET', '/api/salts/admin.json');
141 $salt = json_decode($client->getResponse()->getContent());
142
143 $headers = $this->generateHeaders('admin', 'test', $salt[0]);
144
145 $client->request('DELETE', '/api/entries/'.$entry->getId().'.json', array(), array(), $headers);
146
147 $this->assertEquals(404, $client->getResponse()->getStatusCode());
c9fa9677 148 }
46bbd8d3
NL
149
150 public function testGetTagsEntry()
151 {
152 $client = $this->createClient();
153 $client->request('GET', '/api/salts/admin.json');
154 $salt = json_decode($client->getResponse()->getContent());
155 $headers = $this->generateHeaders('admin', 'test', $salt[0]);
156
157 $entry = $client->getContainer()
158 ->get('doctrine.orm.entity_manager')
159 ->getRepository('WallabagCoreBundle:Entry')
092ca707
NL
160 ->findOneWithTags(1);
161
46bbd8d3
NL
162 if (!$entry) {
163 $this->markTestSkipped('No content found in db.');
164 }
165
166 $tags = array();
167 foreach ($entry->getTags() as $tag) {
168 $tags[] = array('id' => $tag->getId(), 'label' => $tag->getLabel());
169 }
170
171 $client->request('GET', '/api/entries/'.$entry->getId().'/tags', array(), array(), $headers);
172
173 $this->assertEquals(json_encode($tags), $client->getResponse()->getContent());
174 }
a36737f4
NL
175
176 public function testPostTagsOnEntry()
177 {
178 $client = $this->createClient();
179 $client->request('GET', '/api/salts/admin.json');
180 $salt = json_decode($client->getResponse()->getContent());
181 $headers = $this->generateHeaders('admin', 'test', $salt[0]);
182
183 $entry = $client->getContainer()
184 ->get('doctrine.orm.entity_manager')
185 ->getRepository('WallabagCoreBundle:Entry')
186 ->findOneByUser(1);
187
188 if (!$entry) {
189 $this->markTestSkipped('No content found in db.');
190 }
191
192 $newTags = 'tag1,tag2,tag3';
193
194 $client->request('POST', '/api/entries/'.$entry->getId().'/tags', array('tags' => $newTags), array(), $headers);
195
196 $this->assertEquals(200, $client->getResponse()->getStatusCode());
197
198 $entryDB = $client->getContainer()
199 ->get('doctrine.orm.entity_manager')
200 ->getRepository('WallabagCoreBundle:Entry')
201 ->find($entry->getId());
202
203 $tagsInDB = array();
204 foreach ($entryDB->getTags()->toArray() as $tag) {
205 $tagsInDB[$tag->getId()] = $tag->getLabel();
206 }
207
208 foreach (explode(',', $newTags) as $tag) {
209 $this->assertContains($tag, $tagsInDB);
210 }
211 }
2734044a 212}