123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- <?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\Tests\Component\HttpFoundation;
-
- use Symfony\Component\HttpFoundation\HeaderBag;
-
- class HeaderBagTest extends \PHPUnit_Framework_TestCase
- {
- /**
- * @covers Symfony\Component\HttpFoundation\HeaderBag::__construct
- */
- public function testConstructor()
- {
- $bag = new HeaderBag(array('foo' => 'bar'));
- $this->assertTrue($bag->has('foo'));
- }
-
- /**
- * @covers Symfony\Component\HttpFoundation\HeaderBag::all
- */
- public function testAll()
- {
- $bag = new HeaderBag(array('foo' => 'bar'));
- $this->assertEquals(array('foo' => array('bar')), $bag->all(), '->all() gets all the input');
-
- $bag = new HeaderBag(array('FOO' => 'BAR'));
- $this->assertEquals(array('foo' => array('BAR')), $bag->all(), '->all() gets all the input key are lower case');
- }
-
- /**
- * @covers Symfony\Component\HttpFoundation\HeaderBag::replace
- */
- public function testReplace()
- {
- $bag = new HeaderBag(array('foo' => 'bar'));
-
- $bag->replace(array('NOPE' => 'BAR'));
- $this->assertEquals(array('nope' => array('BAR')), $bag->all(), '->replace() replaces the input with the argument');
- $this->assertFalse($bag->has('foo'), '->replace() overrides previously set the input');
- }
-
- /**
- * @covers Symfony\Component\HttpFoundation\HeaderBag::get
- */
- public function testGet()
- {
- $bag = new HeaderBag(array('foo' => 'bar', 'fuzz' => 'bizz'));
- $this->assertEquals( 'bar', $bag->get('foo'), '->get return current value');
- $this->assertEquals( 'bar', $bag->get('FoO'), '->get key in case insensitive');
- $this->assertEquals( array('bar'), $bag->get('foo', 'nope', false), '->get return the value as array');
-
- // defaults
- $this->assertNull($bag->get('none'), '->get unknown values returns null');
- $this->assertEquals( 'default', $bag->get('none', 'default'), '->get unknown values returns default');
- $this->assertEquals( array('default'), $bag->get('none', 'default', false), '->get unknown values returns default as array');
-
- $bag->set('foo', 'bor', false);
- $this->assertEquals( 'bar', $bag->get('foo'), '->get return first value');
- $this->assertEquals( array('bar', 'bor'), $bag->get('foo', 'nope', false), '->get return all values as array');
- }
-
- /**
- * @covers Symfony\Component\HttpFoundation\HeaderBag::contains
- */
- public function testContains()
- {
- $bag = new HeaderBag(array('foo' => 'bar', 'fuzz' => 'bizz'));
- $this->assertTrue( $bag->contains('foo', 'bar'), '->contains first value');
- $this->assertTrue( $bag->contains('fuzz', 'bizz'), '->contains second value');
- $this->assertFalse( $bag->contains('nope', 'nope'), '->contains unknown value');
- $this->assertFalse( $bag->contains('foo', 'nope'), '->contains unknown value');
-
- // Multiple values
- $bag->set('foo', 'bor', false);
- $this->assertTrue( $bag->contains('foo', 'bar'), '->contains first value');
- $this->assertTrue( $bag->contains('foo', 'bor'), '->contains second value');
- $this->assertFalse( $bag->contains('foo', 'nope'), '->contains unknown value');
- }
-
- public function testCacheControlDirectiveAccessors()
- {
- $bag = new HeaderBag();
- $bag->addCacheControlDirective('public');
-
- $this->assertTrue($bag->hasCacheControlDirective('public'));
- $this->assertEquals(true, $bag->getCacheControlDirective('public'));
- $this->assertEquals('public', $bag->get('cache-control'));
-
- $bag->addCacheControlDirective('max-age', 10);
- $this->assertTrue($bag->hasCacheControlDirective('max-age'));
- $this->assertEquals(10, $bag->getCacheControlDirective('max-age'));
- $this->assertEquals('max-age=10, public', $bag->get('cache-control'));
-
- $bag->removeCacheControlDirective('max-age');
- $this->assertFalse($bag->hasCacheControlDirective('max-age'));
- }
-
- public function testCacheControlDirectiveParsing()
- {
- $bag = new HeaderBag(array('cache-control' => 'public, max-age=10'));
- $this->assertTrue($bag->hasCacheControlDirective('public'));
- $this->assertEquals(true, $bag->getCacheControlDirective('public'));
-
- $this->assertTrue($bag->hasCacheControlDirective('max-age'));
- $this->assertEquals(10, $bag->getCacheControlDirective('max-age'));
-
- $bag->addCacheControlDirective('s-maxage', 100);
- $this->assertEquals('max-age=10, public, s-maxage=100', $bag->get('cache-control'));
- }
-
- public function testCacheControlDirectiveOverrideWithReplace()
- {
- $bag = new HeaderBag(array('cache-control' => 'private, max-age=100'));
- $bag->replace(array('cache-control' => 'public, max-age=10'));
- $this->assertTrue($bag->hasCacheControlDirective('public'));
- $this->assertEquals(true, $bag->getCacheControlDirective('public'));
-
- $this->assertTrue($bag->hasCacheControlDirective('max-age'));
- $this->assertEquals(10, $bag->getCacheControlDirective('max-age'));
- }
- }
|