Code Duplication    Length = 78-81 lines in 2 locations

tests/unit/xsDayTimeDurationTest.php 1 location

@@ 9-89 (lines=81) @@
6
/**
7
 * Generated Test Class.
8
 */
9
class xsDayTimeDurationTest extends \PHPUnit_Framework_TestCase
10
{
11
    /**
12
     * Sets up the fixture, for example, opens a network connection.
13
     * This method is called before a test is executed.
14
     */
15
    protected function setUp()
16
    {
17
        parent::setUp();
18
    }
19
20
    /**
21
     * Tears down the fixture, for example, closes a network connection.
22
     * This method is called after a test is executed.
23
     */
24
    protected function tearDown()
25
    {
26
        parent::tearDown();
27
    }
28
29
    /**
30
     * @dataProvider testxsDayTimeDurationValidDataProvider
31
     * @param mixed $input
32
     * @param mixed $message
33
     */
34
    public function testxsDayTimeDurationValid($input, $message)
35
    {
36
        try {
37
            $d = new xsDayTimeDuration($input);
38
            $e = (string)$d;
39
        } catch (\Exception $e) {
40
            $this->fail($message . ' with Exception ' . $e->getMessage());
41
        }
42
    }
43
44
    public function testxsDayTimeDurationValidDataProvider()
45
    {
46
        return array(
47
            array('P2Y6M5DT12H35M30S', '2 years, 6 months, 5 days, 12 hours, 35 minutes, 30 seconds'),
48
            array('P1DT2H', '1 day, 2 hours'),
49
            array('P20M', '20 months (the number of months can be more than 12)'),
50
            array('PT20M', '20 minutes'),
51
            array('P0Y20M0D', '20 months (0 is permitted as a number, but is not required)'),
52
            array('P0Y', '0 years'),
53
            array('-P60D', 'minus 60 days'),
54
            array('PT1M30.5S', '1 minute, 30.5 seconds'),
55
        );
56
    }
57
58
    /**
59
     * @dataProvider testxsDayTimeDurationInvalidDataProvider
60
     * @param mixed $input
61
     * @param mixed $message
62
     */
63
    public function testxsDayTimeDurationInvalid($input, $message)
64
    {
65
        try {
66
            $d = new xsDayTimeDuration($input);
67
            $s = (string)$d;
68
            $this->fail($message);
69
        } catch (\Exception $e) {
70
        }
71
        $this->assertEquals('', $s, $message);
72
    }
73
74
    public function testxsDayTimeDurationInvalidDataProvider()
75
    {
76
        return array(
77
            array('P-20M', 'the minus sign must appear first'),
78
            array('P20MT', 'no time items are present, so "T" must not be present'),
79
            array('P1YM5D', 'no value is specified for months, so "M" must not be present'),
80
            array('P15.5Y', 'only the seconds can be expressed as a decimal'),
81
            array('P1D2H', '"T" must be present to separate days and hours'),
82
            array('1Y2M', '"P" must always be present'),
83
            array('P2M1Y', 'years must appear before months'),
84
            array('P', 'at least one number and designator are required'),
85
            array('PT15.S', 'at least one digit must follow the decimal point if it appears'),
86
            array('', 'an empty value is not valid, unless xsi:nil is used'),
87
        );
88
    }
89
}
90

tests/unit/xsDurationTest.php 1 location

@@ 9-86 (lines=78) @@
6
/**
7
 * Generated Test Class.
8
 */
9
class xsDurationTest extends \PHPUnit_Framework_TestCase
10
{
11
    /**
12
     * @dataProvider testxsDurationValidDataProvider
13
     * @param mixed $input
14
     * @param mixed $message
15
     */
16
    public function testxsDurationValid($input, $message)
17
    {
18
        try {
19
            $d = new xsDuration($input);
20
            $s = (string)$d;
21
        } catch (\Exception $e) {
22
            $this->fail($message . ' with Exception ' . $e->getMessage());
23
        }
24
    }
25
26
    public function testxsDurationValidDataProvider()
27
    {
28
        return array(
29
            array('P2Y6M5DT12H35M30S', '2 years, 6 months, 5 days, 12 hours, 35 minutes, 30 seconds'),
30
            array('P1DT2H', '1 day, 2 hours'),
31
            array('P20M', '20 months (the number of months can be more than 12)'),
32
            array('PT20M', '20 minutes'),
33
            array('P0Y20M0D', '20 months (0 is permitted as a number, but is not required)'),
34
            array('P0Y', '0 years'),
35
            array('-P60D', 'minus 60 days'),
36
            array('PT1M30.5S', '1 minute, 30.5 seconds'),
37
38
        );
39
    }
40
41
    /**
42
     * @dataProvider testxsDurationInvalidDataProvider
43
     * @param mixed $input
44
     * @param mixed $message
45
     */
46
    public function testxsDurationInvalid($input, $message)
47
    {
48
        try {
49
            $d = new xsDuration($input);
50
            $s = (string)$d;
51
            $this->fail($message);
52
        } catch (\Exception $e) {
53
        }
54
        $this->assertEquals('', $s, $message);
55
    }
56
57
    public function testxsDurationInvalidDataProvider()
58
    {
59
        return array(
60
            array('P-20M', 'the minus sign must appear first'),
61
            array('P20MT', 'no time items are present, so "T" must not be present'),
62
            array('P1YM5D', 'no value is specified for months, so "M" must not be present'),
63
            array('P15.5Y', 'only the seconds can be expressed as a decimal'),
64
            array('P1D2H', '"T" must be present to separate days and hours'),
65
            array('1Y2M', '"P" must always be present'),
66
            array('P2M1Y', 'years must appear before months'),
67
            array('P', 'at least one number and designator are required'),
68
            array('PT15.S', 'at least one digit must follow the decimal point if it appears'),
69
            array('', 'an empty value is not valid, unless xsi:nil is used'),
70
        );
71
    }
72
73
    /**
74
     * Sets up the fixture, for example, opens a network connection.
75
     * This method is called before a test is executed.
76
     */
77
    protected function setUp()
78
    {
79
        parent::setUp();
80
    }
81
82
    /**
83
     * Tears down the fixture, for example, closes a network connection.
84
     * This method is called after a test is executed.
85
     */
86
    protected function tearDown()
87
    {
88
        parent::tearDown();
89
    }