]>
Commit | Line | Data |
---|---|---|
1 | <?php | |
2 | ||
3 | namespace Tests\Wallabag\ApiBundle\Controller; | |
4 | ||
5 | use Tests\Wallabag\CoreBundle\WallabagCoreTestCase; | |
6 | use Wallabag\ApiBundle\Entity\Client; | |
7 | ||
8 | class DeveloperControllerTest extends WallabagCoreTestCase | |
9 | { | |
10 | public function testCreateClient() | |
11 | { | |
12 | $this->logInAs('admin'); | |
13 | $client = $this->getClient(); | |
14 | $em = $client->getContainer()->get('doctrine.orm.entity_manager'); | |
15 | $nbClients = $em->getRepository('WallabagApiBundle:Client')->findAll(); | |
16 | ||
17 | $crawler = $client->request('GET', '/developer/client/create'); | |
18 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
19 | ||
20 | $form = $crawler->filter('button[type=submit]')->form(); | |
21 | ||
22 | $data = [ | |
23 | 'client[name]' => 'My app', | |
24 | ]; | |
25 | ||
26 | $crawler = $client->submit($form, $data); | |
27 | ||
28 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
29 | ||
30 | $newNbClients = $em->getRepository('WallabagApiBundle:Client')->findAll(); | |
31 | $this->assertGreaterThan(count($nbClients), count($newNbClients)); | |
32 | ||
33 | $this->assertGreaterThan(1, $alert = $crawler->filter('.settings ul li strong')->extract(['_text'])); | |
34 | $this->assertContains('My app', $alert[0]); | |
35 | } | |
36 | ||
37 | public function testCreateTokenFromPasswords() | |
38 | { | |
39 | $client = $this->getClient(); | |
40 | $apiClient = $this->createApiClientForUser('admin'); | |
41 | ||
42 | $client->request('POST', '/oauth/v2/token', [ | |
43 | 'grant_type' => 'password', | |
44 | 'client_id' => $apiClient->getPublicId(), | |
45 | 'client_secret' => $apiClient->getSecret(), | |
46 | 'username' => 'admin', | |
47 | 'password' => 'mypassword', | |
48 | ]); | |
49 | ||
50 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
51 | ||
52 | $data = json_decode($client->getResponse()->getContent(), true); | |
53 | $this->assertArrayHasKey('access_token', $data); | |
54 | $this->assertArrayHasKey('expires_in', $data); | |
55 | $this->assertArrayHasKey('token_type', $data); | |
56 | $this->assertArrayHasKey('refresh_token', $data); | |
57 | } | |
58 | ||
59 | public function testCreateTokenFromClientCredentialsOnly() | |
60 | { | |
61 | $client = $this->getClient(); | |
62 | $apiClient = $this->createApiClientForUser('admin', ['client_credentials']); | |
63 | ||
64 | $client->request('POST', '/oauth/v2/token', [ | |
65 | 'grant_type' => 'client_credentials', | |
66 | 'client_id' => $apiClient->getPublicId(), | |
67 | 'client_secret' => $apiClient->getSecret(), | |
68 | ]); | |
69 | ||
70 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
71 | ||
72 | $data = json_decode($client->getResponse()->getContent(), true); | |
73 | $this->assertArrayHasKey('access_token', $data); | |
74 | $this->assertArrayHasKey('expires_in', $data); | |
75 | $this->assertArrayHasKey('token_type', $data); | |
76 | // Client Credentials created-clients have no refresh tokens | |
77 | } | |
78 | ||
79 | public function testListingClient() | |
80 | { | |
81 | $this->logInAs('admin'); | |
82 | $client = $this->getClient(); | |
83 | $em = $client->getContainer()->get('doctrine.orm.entity_manager'); | |
84 | $nbClients = $em->getRepository('WallabagApiBundle:Client')->findAll(); | |
85 | ||
86 | $crawler = $client->request('GET', '/developer'); | |
87 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
88 | $this->assertEquals(count($nbClients), $crawler->filter('ul[class=collapsible] li')->count()); | |
89 | } | |
90 | ||
91 | public function testDeveloperHowto() | |
92 | { | |
93 | $this->logInAs('admin'); | |
94 | $client = $this->getClient(); | |
95 | ||
96 | $crawler = $client->request('GET', '/developer/howto/first-app'); | |
97 | $this->assertEquals(200, $client->getResponse()->getStatusCode()); | |
98 | } | |
99 | ||
100 | public function testRemoveClient() | |
101 | { | |
102 | $client = $this->getClient(); | |
103 | $adminApiClient = $this->createApiClientForUser('admin'); | |
104 | $em = $client->getContainer()->get('doctrine.orm.entity_manager'); | |
105 | ||
106 | // Try to remove an admin's client with a wrong user | |
107 | $this->logInAs('bob'); | |
108 | $client->request('GET', '/developer'); | |
109 | $this->assertContains('no_client', $client->getResponse()->getContent()); | |
110 | ||
111 | $this->logInAs('bob'); | |
112 | $client->request('GET', '/developer/client/delete/'.$adminApiClient->getId()); | |
113 | $this->assertEquals(403, $client->getResponse()->getStatusCode()); | |
114 | ||
115 | // Try to remove the admin's client with the good user | |
116 | $this->logInAs('admin'); | |
117 | $crawler = $client->request('GET', '/developer'); | |
118 | ||
119 | $link = $crawler | |
120 | ->filter('div[class=collapsible-body] p a') | |
121 | ->eq(0) | |
122 | ->link() | |
123 | ; | |
124 | ||
125 | $client->click($link); | |
126 | $this->assertEquals(302, $client->getResponse()->getStatusCode()); | |
127 | ||
128 | $this->assertNull( | |
129 | $em->getRepository('WallabagApiBundle:Client')->find($adminApiClient->getId()), | |
130 | 'The client should have been removed' | |
131 | ); | |
132 | } | |
133 | ||
134 | /** | |
135 | * @param string $username | |
136 | * | |
137 | * @param array $grantTypes | |
138 | * @return Client | |
139 | */ | |
140 | private function createApiClientForUser($username, $grantTypes = ['password']) | |
141 | { | |
142 | $client = $this->getClient(); | |
143 | $em = $client->getContainer()->get('doctrine.orm.entity_manager'); | |
144 | $userManager = $client->getContainer()->get('fos_user.user_manager'); | |
145 | $user = $userManager->findUserBy(array('username' => $username)); | |
146 | $apiClient = new Client($user); | |
147 | $apiClient->setName('My app'); | |
148 | $apiClient->setAllowedGrantTypes($grantTypes); | |
149 | $em->persist($apiClient); | |
150 | $em->flush(); | |
151 | ||
152 | return $apiClient; | |
153 | } | |
154 | } |