We have this nice class for unit testing cookie-setting, but the cookie-setting method ignores all the parameters! Fix that. Also provide accessors to check the entire set of cookie data, and the set cookies as a whole. While this does change the semantics of FauxRequest::getcookie() in that the name now needs to be prefixed, no extension in Gerrit uses this method so we should be fine. Also clean up the case of the setCookie and getCookie methods while we're at it. Since PHP method names are case-insensitive, this doesn't even break compatibility with extensions. Change-Id: Ib44a074bf9796bc0b470d557e39465792f399d30
148 lines
4.1 KiB
PHP
148 lines
4.1 KiB
PHP
<?php
|
|
/**
|
|
* Tests for the FauxResponse class
|
|
*
|
|
* Copyright @ 2011 Alexandre Emsenhuber
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*
|
|
* @file
|
|
*/
|
|
|
|
class FauxResponseTest extends MediaWikiTestCase {
|
|
/** @var FauxResponse */
|
|
protected $response;
|
|
|
|
protected function setUp() {
|
|
parent::setUp();
|
|
$this->response = new FauxResponse;
|
|
}
|
|
|
|
/**
|
|
* @covers FauxResponse::setCookie
|
|
* @covers FauxResponse::getCookie
|
|
* @covers FauxResponse::getCookieData
|
|
* @covers FauxResponse::getCookies
|
|
*/
|
|
public function testCookie() {
|
|
$expire = time() + 100;
|
|
$cookie = array(
|
|
'value' => 'val',
|
|
'path' => '/path',
|
|
'domain' => 'domain',
|
|
'secure' => true,
|
|
'httpOnly' => false,
|
|
'raw' => false,
|
|
'expire' => $expire,
|
|
);
|
|
|
|
$this->assertEquals( null, $this->response->getCookie( 'xkey' ), 'Non-existing cookie' );
|
|
$this->response->setCookie( 'key', 'val', $expire, array(
|
|
'prefix' => 'x',
|
|
'path' => '/path',
|
|
'domain' => 'domain',
|
|
'secure' => 1,
|
|
'httpOnly' => 0,
|
|
) );
|
|
$this->assertEquals( 'val', $this->response->getCookie( 'xkey' ), 'Existing cookie' );
|
|
$this->assertEquals( $cookie, $this->response->getCookieData( 'xkey' ),
|
|
'Existing cookie (data)' );
|
|
$this->assertEquals( array( 'xkey' => $cookie ), $this->response->getCookies(),
|
|
'Existing cookies' );
|
|
}
|
|
|
|
/**
|
|
* @covers FauxResponse::getheader
|
|
* @covers FauxResponse::header
|
|
*/
|
|
public function testHeader() {
|
|
$this->assertEquals( null, $this->response->getheader( 'Location' ), 'Non-existing header' );
|
|
|
|
$this->response->header( 'Location: http://localhost/' );
|
|
$this->assertEquals(
|
|
'http://localhost/',
|
|
$this->response->getheader( 'Location' ),
|
|
'Set header'
|
|
);
|
|
|
|
$this->response->header( 'Location: http://127.0.0.1/' );
|
|
$this->assertEquals(
|
|
'http://127.0.0.1/',
|
|
$this->response->getheader( 'Location' ),
|
|
'Same header'
|
|
);
|
|
|
|
$this->response->header( 'Location: http://127.0.0.2/', false );
|
|
$this->assertEquals(
|
|
'http://127.0.0.1/',
|
|
$this->response->getheader( 'Location' ),
|
|
'Same header with override disabled'
|
|
);
|
|
|
|
$this->response->header( 'Location: http://localhost/' );
|
|
$this->assertEquals(
|
|
'http://localhost/',
|
|
$this->response->getheader( 'LOCATION' ),
|
|
'Get header case insensitive'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @covers FauxResponse::getStatusCode
|
|
*/
|
|
public function testResponseCode() {
|
|
$this->response->header( 'HTTP/1.1 200' );
|
|
$this->assertEquals( 200, $this->response->getStatusCode(), 'Header with no message' );
|
|
|
|
$this->response->header( 'HTTP/1.x 201' );
|
|
$this->assertEquals(
|
|
201,
|
|
$this->response->getStatusCode(),
|
|
'Header with no message and protocol 1.x'
|
|
);
|
|
|
|
$this->response->header( 'HTTP/1.1 202 OK' );
|
|
$this->assertEquals( 202, $this->response->getStatusCode(), 'Normal header' );
|
|
|
|
$this->response->header( 'HTTP/1.x 203 OK' );
|
|
$this->assertEquals(
|
|
203,
|
|
$this->response->getStatusCode(),
|
|
'Normal header with no message and protocol 1.x'
|
|
);
|
|
|
|
$this->response->header( 'HTTP/1.x 204 OK', false, 205 );
|
|
$this->assertEquals(
|
|
205,
|
|
$this->response->getStatusCode(),
|
|
'Third parameter overrides the HTTP/... header'
|
|
);
|
|
|
|
$this->response->statusHeader( 210 );
|
|
$this->assertEquals(
|
|
210,
|
|
$this->response->getStatusCode(),
|
|
'Handle statusHeader method'
|
|
);
|
|
|
|
$this->response->header( 'Location: http://localhost/', false, 206 );
|
|
$this->assertEquals(
|
|
206,
|
|
$this->response->getStatusCode(),
|
|
'Third parameter with another header'
|
|
);
|
|
}
|
|
}
|