| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
 | <?php
 /*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
 
 namespace Symfony\Component\HttpFoundation\Tests;
 
 use Symfony\Component\HttpFoundation\AcceptHeaderItem;
 
 class AcceptHeaderItemTest extends \PHPUnit_Framework_TestCase
 {
 /**
 * @dataProvider provideFromStringData
 */
 public function testFromString($string, $value, array $attributes)
 {
 $item = AcceptHeaderItem::fromString($string);
 $this->assertEquals($value, $item->getValue());
 $this->assertEquals($attributes, $item->getAttributes());
 }
 
 public function provideFromStringData()
 {
 return array(
 array(
 'text/html',
 'text/html', array(),
 ),
 array(
 '"this;should,not=matter"',
 'this;should,not=matter', array(),
 ),
 array(
 "text/plain; charset=utf-8;param=\"this;should,not=matter\";\tfootnotes=true",
 'text/plain', array('charset' => 'utf-8', 'param' => 'this;should,not=matter', 'footnotes' => 'true'),
 ),
 array(
 '"this;should,not=matter";charset=utf-8',
 'this;should,not=matter', array('charset' => 'utf-8'),
 ),
 );
 }
 
 /**
 * @dataProvider provideToStringData
 */
 public function testToString($value, array $attributes, $string)
 {
 $item = new AcceptHeaderItem($value, $attributes);
 $this->assertEquals($string, (string) $item);
 }
 
 public function provideToStringData()
 {
 return array(
 array(
 'text/html', array(),
 'text/html',
 ),
 array(
 'text/plain', array('charset' => 'utf-8', 'param' => 'this;should,not=matter', 'footnotes' => 'true'),
 'text/plain;charset=utf-8;param="this;should,not=matter";footnotes=true',
 ),
 );
 }
 
 public function testValue()
 {
 $item = new AcceptHeaderItem('value', array());
 $this->assertEquals('value', $item->getValue());
 
 $item->setValue('new value');
 $this->assertEquals('new value', $item->getValue());
 
 $item->setValue(1);
 $this->assertEquals('1', $item->getValue());
 }
 
 public function testQuality()
 {
 $item = new AcceptHeaderItem('value', array());
 $this->assertEquals(1.0, $item->getQuality());
 
 $item->setQuality(0.5);
 $this->assertEquals(0.5, $item->getQuality());
 
 $item->setAttribute('q', 0.75);
 $this->assertEquals(0.75, $item->getQuality());
 $this->assertFalse($item->hasAttribute('q'));
 }
 
 public function testAttribute()
 {
 $item = new AcceptHeaderItem('value', array());
 $this->assertEquals(array(), $item->getAttributes());
 $this->assertFalse($item->hasAttribute('test'));
 $this->assertNull($item->getAttribute('test'));
 $this->assertEquals('default', $item->getAttribute('test', 'default'));
 
 $item->setAttribute('test', 'value');
 $this->assertEquals(array('test' => 'value'), $item->getAttributes());
 $this->assertTrue($item->hasAttribute('test'));
 $this->assertEquals('value', $item->getAttribute('test'));
 $this->assertEquals('value', $item->getAttribute('test', 'default'));
 }
 }
 
 |