Completed
Pull Request — master (#12)
by Chad
02:30
created

TTLValidatorTraitTest   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 61
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 2
dl 0
loc 61
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A validateTTLWithValidValues() 0 4 1
A provideValidTTLs() 0 8 1
A validateTTLWithInvalidValue() 0 4 1
A provideInvalidTTLs() 0 8 1
1
<?php
2
3
namespace SubjectivePHPTest\Psr\SimpleCache;
4
5
use SubjectivePHP\Psr\SimpleCache\TTLValidatorTrait;
6
7
/**
8
 * @coversDefaultClass \SubjectivePHP\Psr\SimpleCache\TTLValidatorTrait
9
 * @covers ::<private>
10
 */
11
final class TTLValidatorTraitTest extends \PHPUnit\Framework\TestCase
12
{
13
    use TTLValidatorTrait;
14
15
    /**
16
     * @param mixed $ttl The ttl value which will validate.
17
     *
18
     * @test
19
     * @covers ::validateTTL
20
     * @dataProvider provideValidTTLs
21
     *
22
     * @return void
23
     */
24
    public function validateTTLWithValidValues($ttl)
25
    {
26
        $this->assertNull($this->validateTTL($ttl));
27
    }
28
29
    /**
30
     * Provides valid ttls for testing.
31
     *
32
     * @return array
33
     */
34
    public function provideValidTTLs()
35
    {
36
        return [
37
            ['null' => null],
38
            ['DateInterval' => \DateInterval::createFromDateString('1 day')],
39
            ['int' => 3600],
40
        ];
41
    }
42
43
    /**
44
     * @param mixed $ttl The ttl value which will throw an execption.
45
     *
46
     * @test
47
     * @covers ::validateTTL
48
     * @expectedException \Psr\SimpleCache\InvalidArgumentException
49
     * @dataProvider provideInvalidTTLs
50
     *
51
     * @return void
52
     */
53
    public function validateTTLWithInvalidValue($ttl)
54
    {
55
        $this->validateTTL($ttl);
56
    }
57
58
    /**
59
     * Provides valid ttls for testing.
60
     *
61
     * @return array
62
     */
63
    public function provideInvalidTTLs()
64
    {
65
        return [
66
            ['string' => ''],
67
            ['float' => 1.1],
68
            ['DdateTime' => new \DateTime()],
69
        ];
70
    }
71
}
72