|                                                                                                                                                                         |  | <?phpuse Symfony\Component\HttpFoundation\Request;use Symfony\Component\HttpFoundation\Response;
class TokenTest extends PHPUnit\Framework\TestCase{
    private $http;
    public function setUp(): void    {        $this->client = new Token();        $this->client->http = new p3k\HTTP\Test(dirname(__FILE__).'/data/');    }
    private function token($params)    {        $request = new Request($params);        $response = new Response();        return $this->client->token($request, $response);    }
    public function testMissingURL()    {        $response = $this->token([]);
        $body = $response->getContent();        $this->assertEquals(400, $response->getStatusCode());        $data = json_decode($body);        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('invalid_request', $data->error);    }
    public function testInvalidURL()    {        $url = 'ftp://example.com/foo';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(400, $response->getStatusCode());        $data = json_decode($body);        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('invalid_url', $data->error);    }
    public function testMissingCode()    {        $response = $this->token(['source' => 'http://example.com/']);
        $body = $response->getContent();        $this->assertEquals(400, $response->getStatusCode());        $data = json_decode($body);        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('invalid_request', $data->error);    }
    public function testNoLinkHeaders()    {        $url = 'http://private.example.com/no-link-headers';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('no_token_endpoint', $data->error);    }
    public function testNoTokenEndpointOneLinkHeader()    {        $url = 'http://private.example.com/no-token-endpoint-one-link-header';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('no_token_endpoint', $data->error);    }
    public function testNoTokenEndpointTwoLinkHeaders()    {        $url = 'http://private.example.com/no-token-endpoint-two-link-headers';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('no_token_endpoint', $data->error);    }
    public function testTokenEndpointInOAuth2Rel()    {        $url = 'http://private.example.com/oauth2-token-endpoint';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectNotHasAttribute('error', $data);        $this->assertEquals('1234', $data->access_token);    }
    public function testTokenEndpointInIndieAuthRel()    {        $url = 'http://private.example.com/token-endpoint';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectNotHasAttribute('error', $data);        $this->assertEquals('1234', $data->access_token);    }
    public function testTokenEndpointWithMultipleRelLinks()    {        $url = 'http://private.example.com/multiple-rels';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectNotHasAttribute('error', $data);        $this->assertEquals('1234', $data->access_token);    }
    public function testBadTokenEndpointResponse()    {        $url = 'http://private.example.com/token-endpoint-bad-response';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('this-string-passed-through-from-token-endpoint', $data->error);    }
    public function testTokenEndpointTimeout()    {        $url = 'http://private.example.com/token-endpoint-timeout';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $data = json_decode($body);
        $this->assertObjectHasAttribute('error', $data);        $this->assertEquals('timeout', $data->error);    }
    public function testTokenEndpointReturnsNotJSON()    {        $url = 'http://private.example.com/token-endpoint-notjson';        $response = $this->token(['source' => $url, 'code' => '1234']);
        $body = $response->getContent();        $this->assertEquals(200, $response->getStatusCode());        $this->assertEquals('text/plain', $response->headers->get('content-type'));        $this->assertEquals('Invalid request', $body);    }
}
 |