Failed Conditions
Push — ng ( 7370de...a36c25 )
by Florent
19:12
created

ClientSecretBasicAuthenticationMethodTest   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 72
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 7

Importance

Changes 0
Metric Value
wmc 5
lcom 1
cbo 7
dl 0
loc 72
rs 10
c 0
b 0
f 0

5 Methods

Rating   Name   Duplication   Size   Complexity  
A genericCalls() 0 7 1
A theClientIdCannotBeFoundInTheRequest() 0 10 1
A theClientIdAndClientSecretHaveBeenFoundInTheRequest() 0 10 1
A theClientIsAuthenticated() 0 15 1
A theClientConfigurationCanBeChecked() 0 8 1
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * The MIT License (MIT)
7
 *
8
 * Copyright (c) 2014-2018 Spomky-Labs
9
 *
10
 * This software may be modified and distributed under the terms
11
 * of the MIT license.  See the LICENSE file for details.
12
 */
13
14
namespace OAuth2Framework\Component\Server\TokenEndpoint\Tests;
15
16
use OAuth2Framework\Component\Server\Core\Client\Client;
17
use OAuth2Framework\Component\Server\Core\Client\ClientId;
18
use OAuth2Framework\Component\Server\Core\DataBag\DataBag;
19
use OAuth2Framework\Component\Server\Core\UserAccount\UserAccountId;
20
use OAuth2Framework\Component\Server\TokenEndpoint\AuthenticationMethod\ClientSecretBasic;
21
use PHPUnit\Framework\TestCase;
22
use Psr\Http\Message\ServerRequestInterface;
23
24
/**
25
 * @group TokenEndpoint
26
 * @group AuthenticationMethod
27
 */
28
final class ClientSecretBasicAuthenticationMethodTest extends TestCase
29
{
30
    /**
31
     * @test
32
     */
33
    public function genericCalls()
34
    {
35
        $method = new ClientSecretBasic('My Service');
36
37
        self::assertEquals(['Basic realm="My Service",charset="UTF-8"'], $method->getSchemesParameters());
38
        self::assertEquals(['client_secret_basic'], $method->getSupportedAuthenticationMethods());
39
    }
40
41
    /**
42
     * @test
43
     */
44
    public function theClientIdCannotBeFoundInTheRequest()
45
    {
46
        $method = new ClientSecretBasic('My Service');
47
        $request = $this->prophesize(ServerRequestInterface::class);
48
        $request->getHeader("Authorization")->willReturn(null);
49
50
        $clientId = $method->findClientId($request->reveal(), $credentials);
51
        self::assertNull($clientId);
52
        self::assertNull($credentials);
53
    }
54
55
    /**
56
     * @test
57
     */
58
    public function theClientIdAndClientSecretHaveBeenFoundInTheRequest()
59
    {
60
        $method = new ClientSecretBasic('My Service');
61
        $request = $this->prophesize(ServerRequestInterface::class);
62
        $request->getHeader("Authorization")->willReturn(['Basic '.base64_encode('CLIENT_ID:CLIENT_SECRET')]);
63
64
        $clientId = $method->findClientId($request->reveal(), $credentials);
65
        self::assertInstanceOf(ClientId::class, $clientId);
66
        self::assertEquals('CLIENT_SECRET', $credentials);
67
    }
68
69
    /**
70
     * @test
71
     */
72
    public function theClientIsAuthenticated()
73
    {
74
        $method = new ClientSecretBasic('My Service');
75
        $request = $this->prophesize(ServerRequestInterface::class);
76
        $client = Client::createEmpty();
77
        $client = $client->create(
78
            ClientId::create('CLIENT_ID'),
79
            DataBag::create([
80
                'client_secret' => 'CLIENT_SECRET'
81
            ]),
82
            UserAccountId::create('USER_ACCOUNT_ID')
83
        );
84
85
        self::assertTrue($method->isClientAuthenticated($client, 'CLIENT_SECRET', $request->reveal()));
86
    }
87
88
    /**
89
     * @test
90
     */
91
    public function theClientConfigurationCanBeChecked()
92
    {
93
        $method = new ClientSecretBasic('My Service');
94
        $validatedParameters = $method->checkClientConfiguration(DataBag::create([]), DataBag::create([]));
95
96
        self::assertTrue($validatedParameters->has('client_secret'));
97
        self::assertTrue($validatedParameters->has('client_secret_expires_at'));
98
    }
99
}
100