| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237 |
- <?php
- /**
- * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
- * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
- *
- * Licensed under The MIT License
- * For full copyright and license information, please see the LICENSE.txt
- * Redistributions of files must retain the above copyright notice
- *
- * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
- * @link https://cakephp.org CakePHP(tm) Project
- * @since 3.0.0
- * @license https://opensource.org/licenses/mit-license.php MIT License
- */
- namespace Cake\Test\TestCase\TestSuite;
- use Cake\Core\Configure;
- use Cake\Core\Plugin;
- use Cake\Event\EventManager;
- use Cake\Http\Response;
- use Cake\Routing\DispatcherFactory;
- use Cake\Routing\RouteBuilder;
- use Cake\Routing\Router;
- use Cake\Routing\Route\InflectedRoute;
- use Cake\TestSuite\IntegrationTestCase;
- use Cake\Test\Fixture\AssertIntegrationTestCase;
- use Cake\Utility\Security;
- use Zend\Diactoros\UploadedFile;
- /**
- * Self test of the IntegrationTestCase
- */
- class IntegrationTestCaseTest extends IntegrationTestCase
- {
- /**
- * Setup method
- *
- * @return void
- */
- public function setUp()
- {
- parent::setUp();
- static::setAppNamespace();
- Router::reload();
- Router::extensions(['json']);
- Router::scope('/', function (RouteBuilder $routes) {
- $routes->setRouteClass(InflectedRoute::class);
- $routes->get('/get/:controller/:action', []);
- $routes->head('/head/:controller/:action', []);
- $routes->options('/options/:controller/:action', []);
- $routes->connect('/:controller/:action/*', []);
- });
- Router::$initialized = true;
- $this->useHttpServer(true);
- $this->configApplication(Configure::read('App.namespace') . '\Application', null);
- DispatcherFactory::clear();
- }
- /**
- * Helper for enabling the legacy stack for backwards compatibility testing.
- *
- * @return void
- */
- protected function useLegacyDispatcher()
- {
- DispatcherFactory::add('Routing');
- DispatcherFactory::add('ControllerFactory');
- $this->useHttpServer(false);
- }
- /**
- * Tests that all data that used by the request is cast to strings
- *
- * @return void
- */
- public function testDataCastToString()
- {
- $data = [
- 'title' => 'Blog Post',
- 'status' => 1,
- 'published' => true,
- 'not_published' => false,
- 'comments' => [
- [
- 'body' => 'Comment',
- 'status' => 1,
- ]
- ],
- 'file' => [
- 'tmp_name' => __FILE__,
- 'size' => 42,
- 'error' => 0,
- 'type' => 'text/plain',
- 'name' => 'Uploaded file'
- ],
- 'pictures' => [
- 'name' => [
- ['file' => 'a-file.png'],
- ['file' => 'a-moose.png']
- ],
- 'type' => [
- ['file' => 'image/png'],
- ['file' => 'image/jpg']
- ],
- 'tmp_name' => [
- ['file' => __FILE__],
- ['file' => __FILE__]
- ],
- 'error' => [
- ['file' => 0],
- ['file' => 0]
- ],
- 'size' => [
- ['file' => 17188],
- ['file' => 2010]
- ],
- ],
- 'upload' => new UploadedFile(__FILE__, 42, 0)
- ];
- $request = $this->_buildRequest('/posts/add', 'POST', $data);
- $this->assertInternalType('string', $request['post']['status']);
- $this->assertInternalType('string', $request['post']['published']);
- $this->assertSame('0', $request['post']['not_published']);
- $this->assertInternalType('string', $request['post']['comments'][0]['status']);
- $this->assertInternalType('integer', $request['post']['file']['error']);
- $this->assertInternalType('integer', $request['post']['file']['size']);
- $this->assertInternalType('integer', $request['post']['pictures']['error'][0]['file']);
- $this->assertInternalType('integer', $request['post']['pictures']['error'][1]['file']);
- $this->assertInternalType('integer', $request['post']['pictures']['size'][0]['file']);
- $this->assertInternalType('integer', $request['post']['pictures']['size'][1]['file']);
- $this->assertInstanceOf(UploadedFile::class, $request['post']['upload']);
- }
- /**
- * Test building a request.
- *
- * @return void
- */
- public function testRequestBuilding()
- {
- $this->configRequest([
- 'headers' => [
- 'X-CSRF-Token' => 'abc123',
- 'Content-Type' => 'application/json',
- 'Accept' => 'application/json'
- ],
- 'base' => '',
- 'webroot' => '/',
- 'environment' => [
- 'PHP_AUTH_USER' => 'foo',
- 'PHP_AUTH_PW' => 'bar'
- ]
- ]);
- $this->cookie('split_token', 'def345');
- $this->session(['User' => ['id' => 1, 'username' => 'mark']]);
- $request = $this->_buildRequest('/tasks/add', 'POST', ['title' => 'First post']);
- $this->assertEquals('abc123', $request['environment']['HTTP_X_CSRF_TOKEN']);
- $this->assertEquals('application/json', $request['environment']['CONTENT_TYPE']);
- $this->assertEquals('/tasks/add', $request['url']);
- $this->assertArrayHasKey('split_token', $request['cookies']);
- $this->assertEquals('def345', $request['cookies']['split_token']);
- $this->assertEquals(['id' => '1', 'username' => 'mark'], $request['session']->read('User'));
- $this->assertEquals('foo', $request['environment']['PHP_AUTH_USER']);
- $this->assertEquals('bar', $request['environment']['PHP_AUTH_PW']);
- }
- /**
- * Test request building adds csrf tokens
- *
- * @return void
- */
- public function testRequestBuildingCsrfTokens()
- {
- $this->enableCsrfToken();
- $request = $this->_buildRequest('/tasks/add', 'POST', ['title' => 'First post']);
- $this->assertArrayHasKey('csrfToken', $request['cookies']);
- $this->assertArrayHasKey('_csrfToken', $request['post']);
- $this->assertSame($request['cookies']['csrfToken'], $request['post']['_csrfToken']);
- $this->cookie('csrfToken', '');
- $request = $this->_buildRequest('/tasks/add', 'POST', [
- '_csrfToken' => 'fale',
- 'title' => 'First post'
- ]);
- $this->assertSame('', $request['cookies']['csrfToken']);
- $this->assertSame('fale', $request['post']['_csrfToken']);
- }
- /**
- * Test multiple actions using CSRF tokens don't fail
- *
- * @return void
- */
- public function testEnableCsrfMultipleRequests()
- {
- $this->enableCsrfToken();
- $first = $this->_buildRequest('/tasks/add', 'POST', ['title' => 'First post']);
- $second = $this->_buildRequest('/tasks/add', 'POST', ['title' => 'Second post']);
- $this->assertSame(
- $first['cookies']['csrfToken'],
- $second['post']['_csrfToken'],
- 'Csrf token should match cookie'
- );
- $this->assertSame(
- $first['post']['_csrfToken'],
- $second['post']['_csrfToken'],
- 'Tokens should be consistent per test method'
- );
- }
- /**
- * Test pre-determined CSRF tokens.
- *
- * @return void
- */
- public function testEnableCsrfPredeterminedCookie()
- {
- $this->enableCsrfToken();
- $value = 'I am a teapot';
- $this->cookie('csrfToken', $value);
- $request = $this->_buildRequest('/tasks/add', 'POST', ['title' => 'First post']);
- $this->assertSame($value, $request['cookies']['csrfToken'], 'Csrf token should match cookie');
- $this->assertSame($value, $request['post']['_csrfToken'], 'Tokens should match');
- }
- /**
- * Test building a request, with query parameters
- *
- * @return void
- */
- public function testRequestBuildingQueryParameters()
- {
- $request = $this->_buildRequest('/tasks/view?archived=yes', 'GET', []);
- $this->assertSame('/tasks/view', $request['url']);
- $this->assertSame('archived=yes', $request['environment']['QUERY_STRING']);
- $this->assertSame('/tasks/view', $request['environment']['REQUEST_URI']);
- }
- /**
- * Test cookie encrypted
- *
- * @see CookieComponentControllerTest
- */
- public function testCookieEncrypted()
- {
- Security::setSalt('abcdabcdabcdabcdabcdabcdabcdabcdabcd');
- $this->cookieEncrypted('KeyOfCookie', 'Encrypted with aes by default');
- $request = $this->_buildRequest('/tasks/view', 'GET', []);
- $this->assertStringStartsWith('Q2FrZQ==.', $request['cookies']['KeyOfCookie']);
- }
- /**
- * Test sending get requests.
- *
- * @group deprecated
- * @return void
- */
- public function testGetLegacy()
- {
- $this->useLegacyDispatcher();
- $this->deprecated(function () {
- $this->assertNull($this->_response);
- $this->get('/request_action/test_request_action');
- $this->assertNotEmpty($this->_response);
- $this->assertInstanceOf('Cake\Http\Response', $this->_response);
- $this->assertEquals('This is a test', $this->_response->getBody());
- $this->_response = null;
- $this->get('/get/request_action/test_request_action');
- $this->assertEquals('This is a test', $this->_response->getBody());
- });
- }
- /**
- * Test sending get request and using default `test_app/config/routes.php`.
- *
- * @return void
- */
- public function testGetUsingApplicationWithPluginRoutes()
- {
- // first clean routes to have Router::$initailized === false
- Router::reload();
- Plugin::unload();
- $this->configApplication(Configure::read('App.namespace') . '\ApplicationWithPluginRoutes', null);
- $this->get('/test_plugin');
- $this->assertResponseOk();
- }
- /**
- * Test sending get request and using default `test_app/config/routes.php`.
- *
- * @return void
- */
- public function testGetUsingApplicationWithDefaultRoutes()
- {
- // first clean routes to have Router::$initailized === false
- Router::reload();
- $this->configApplication(Configure::read('App.namespace') . '\ApplicationWithDefaultRoutes', null);
- $this->get('/some_alias');
- $this->assertResponseOk();
- $this->assertEquals('5', $this->_getBodyAsString());
- }
- /**
- * Test sending head requests.
- *
- * @return void
- */
- public function testHead()
- {
- $this->assertNull($this->_response);
- $this->head('/request_action/test_request_action');
- $this->assertNotEmpty($this->_response);
- $this->assertInstanceOf('Cake\Http\Response', $this->_response);
- $this->assertResponseSuccess();
- $this->_response = null;
- $this->head('/head/request_action/test_request_action');
- $this->assertResponseSuccess();
- }
- /**
- * Test sending options requests.
- *
- * @return void
- */
- public function testOptions()
- {
- $this->assertNull($this->_response);
- $this->options('/request_action/test_request_action');
- $this->assertNotEmpty($this->_response);
- $this->assertInstanceOf('Cake\Http\Response', $this->_response);
- $this->assertResponseSuccess();
- $this->_response = null;
- $this->options('/options/request_action/test_request_action');
- $this->assertResponseSuccess();
- }
- /**
- * Test sending get requests sets the request method
- *
- * @return void
- */
- public function testGetSpecificRouteLegacy()
- {
- $this->useLegacyDispatcher();
- $this->deprecated(function () {
- $this->get('/get/request_action/test_request_action');
- $this->assertResponseOk();
- $this->assertEquals('This is a test', $this->_response->getBody());
- });
- }
- /**
- * Test sending get requests sets the request method
- *
- * @return void
- */
- public function testGetSpecificRouteHttpServer()
- {
- $this->get('/get/request_action/test_request_action');
- $this->assertResponseOk();
- $this->assertEquals('This is a test', $this->_response->getBody());
- }
- /**
- * Test customizing the app class.
- *
- * @return void
- */
- public function testConfigApplication()
- {
- $this->expectException(\LogicException::class);
- $this->expectExceptionMessage('Cannot load "TestApp\MissingApp" for use in integration');
- $this->configApplication('TestApp\MissingApp', []);
- $this->get('/request_action/test_request_action');
- }
- /**
- * Test sending get requests with Http\Server
- *
- * @return void
- */
- public function testGetHttpServer()
- {
- $this->assertNull($this->_response);
- $this->get('/request_action/test_request_action');
- $this->assertNotEmpty($this->_response);
- $this->assertInstanceOf('Cake\Http\Response', $this->_response);
- $this->assertEquals('This is a test', $this->_response->getBody());
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test that the PSR7 requests get query string data
- *
- * @return void
- */
- public function testGetQueryStringHttpServer()
- {
- $this->configRequest(['headers' => ['Content-Type' => 'text/plain']]);
- $this->get('/request_action/params_pass?q=query');
- $this->assertResponseOk();
- $this->assertResponseContains('"q":"query"');
- $this->assertResponseContains('"contentType":"text\/plain"');
- $this->assertHeader('X-Middleware', 'true');
- $request = $this->_controller->request;
- $this->assertContains('/request_action/params_pass?q=query', $request->getRequestTarget());
- }
- /**
- * Test that the PSR7 requests get query string data
- *
- * @group deprecated
- * @return void
- */
- public function testGetQueryStringSetsHere()
- {
- $this->deprecated(function () {
- $this->configRequest(['headers' => ['Content-Type' => 'text/plain']]);
- $this->get('/request_action/params_pass?q=query');
- $this->assertResponseOk();
- $this->assertResponseContains('"q":"query"');
- $this->assertResponseContains('"contentType":"text\/plain"');
- $this->assertHeader('X-Middleware', 'true');
- $request = $this->_controller->request;
- $this->assertContains('/request_action/params_pass?q=query', $request->here());
- $this->assertContains('/request_action/params_pass?q=query', $request->getRequestTarget());
- });
- }
- /**
- * Test that the PSR7 requests get cookies
- *
- * @return void
- */
- public function testGetCookiesHttpServer()
- {
- $this->configRequest(['cookies' => ['split_test' => 'abc']]);
- $this->get('/request_action/cookie_pass');
- $this->assertResponseOk();
- $this->assertResponseContains('"split_test":"abc"');
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test that the PSR7 requests receive post data
- *
- * @return void
- */
- public function testPostDataLegacyDispatcher()
- {
- $this->useLegacyDispatcher();
- $this->deprecated(function () {
- $this->post('/request_action/post_pass', ['title' => 'value']);
- $data = json_decode($this->_response->getBody());
- $this->assertEquals('value', $data->title);
- });
- }
- /**
- * Test that the PSR7 requests receive post data
- *
- * @return void
- */
- public function testPostDataHttpServer()
- {
- $this->post('/request_action/post_pass', ['title' => 'value']);
- $data = json_decode($this->_response->getBody());
- $this->assertEquals('value', $data->title);
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test that the PSR7 requests receive encoded data.
- *
- * @return void
- */
- public function testInputDataHttpServer()
- {
- $this->post('/request_action/input_test', '{"hello":"world"}');
- if ($this->_response->getBody()->isSeekable()) {
- $this->_response->getBody()->rewind();
- }
- $this->assertSame('world', $this->_response->getBody()->getContents());
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test that the PSR7 requests receive encoded data.
- *
- * @return void
- */
- public function testInputDataSecurityToken()
- {
- $this->enableSecurityToken();
- $this->post('/request_action/input_test', '{"hello":"world"}');
- $this->assertSame('world', '' . $this->_response->getBody());
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test that the PSR7 requests get cookies
- *
- * @return void
- */
- public function testSessionHttpServer()
- {
- $this->session(['foo' => 'session data']);
- $this->get('/request_action/session_test');
- $this->assertResponseOk();
- $this->assertResponseContains('session data');
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test sending requests stores references to controller/view/layout.
- *
- * @return void
- */
- public function testRequestSetsProperties()
- {
- $this->post('/posts/index');
- $this->assertInstanceOf('Cake\Controller\Controller', $this->_controller);
- $this->assertNotEmpty($this->_viewName, 'View name not set');
- $this->assertContains('Template' . DS . 'Posts' . DS . 'index.ctp', $this->_viewName);
- $this->assertNotEmpty($this->_layoutName, 'Layout name not set');
- $this->assertContains('Template' . DS . 'Layout' . DS . 'default.ctp', $this->_layoutName);
- $this->assertTemplate('index');
- $this->assertLayout('default');
- $this->assertEquals('value', $this->viewVariable('test'));
- }
- /**
- * Test PSR7 requests store references to controller/view/layout
- *
- * @return void
- */
- public function testRequestSetsPropertiesHttpServer()
- {
- $this->post('/posts/index');
- $this->assertInstanceOf('Cake\Controller\Controller', $this->_controller);
- $this->assertNotEmpty($this->_viewName, 'View name not set');
- $this->assertContains('Template' . DS . 'Posts' . DS . 'index.ctp', $this->_viewName);
- $this->assertNotEmpty($this->_layoutName, 'Layout name not set');
- $this->assertContains('Template' . DS . 'Layout' . DS . 'default.ctp', $this->_layoutName);
- $this->assertTemplate('index');
- $this->assertLayout('default');
- $this->assertEquals('value', $this->viewVariable('test'));
- }
- /**
- * Tests URLs containing extensions.
- *
- * @return void
- */
- public function testRequestWithExt()
- {
- $this->get(['controller' => 'Posts', 'action' => 'ajax', '_ext' => 'json']);
- $this->assertResponseCode(200);
- }
- /**
- * Assert that the stored template doesn't change when cells are rendered.
- *
- * @return void
- */
- public function testAssertTemplateAfterCellRender()
- {
- $this->get('/posts/get');
- $this->assertContains('Template' . DS . 'Posts' . DS . 'get.ctp', $this->_viewName);
- $this->assertTemplate('get');
- $this->assertResponseContains('cellcontent');
- }
- /**
- * Test array URLs
- *
- * @return void
- */
- public function testArrayUrls()
- {
- $this->post(['controller' => 'Posts', 'action' => 'index']);
- $this->assertEquals('value', $this->viewVariable('test'));
- }
- /**
- * Test array URLs with an empty router.
- *
- * @return void
- */
- public function testArrayUrlsEmptyRouter()
- {
- Router::reload();
- $this->assertFalse(Router::$initialized);
- $this->post(['controller' => 'Posts', 'action' => 'index']);
- $this->assertEquals('value', $this->viewVariable('test'));
- }
- /**
- * Test flash and cookie assertions
- *
- * @return void
- */
- public function testFlashSessionAndCookieAsserts()
- {
- $this->post('/posts/index');
- $this->assertSession('An error message', 'Flash.flash.0.message');
- $this->assertCookie(1, 'remember_me');
- $this->assertCookieNotSet('user_id');
- }
- /**
- * Test flash and cookie assertions
- *
- * @return void
- */
- public function testFlashSessionAndCookieAssertsHttpServer()
- {
- $this->post('/posts/index');
- $this->assertSession('An error message', 'Flash.flash.0.message');
- $this->assertCookieNotSet('user_id');
- $this->assertCookie(1, 'remember_me');
- }
- /**
- * Test flash assertions stored with enableRememberFlashMessages() after they
- * are rendered
- *
- * @return void
- */
- public function testFlashAssertionsAfterRender()
- {
- $this->enableRetainFlashMessages();
- $this->get('/posts/index/with_flash');
- $this->assertSession('An error message', 'Flash.flash.0.message');
- }
- /**
- * Test flash assertions stored with enableRememberFlashMessages() even if
- * no view is rendered
- *
- * @return void
- */
- public function testFlashAssertionsWithNoRender()
- {
- $this->enableRetainFlashMessages();
- $this->get('/posts/flashNoRender');
- $this->assertRedirect();
- $this->assertSession('An error message', 'Flash.flash.0.message');
- }
- /**
- * Tests the failure message for assertCookieNotSet
- *
- * @return void
- */
- public function testCookieNotSetFailure()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('Cookie \'remember_me\' has been set');
- $this->post('/posts/index');
- $this->assertCookieNotSet('remember_me');
- }
- /**
- * Tests the failure message for assertCookieNotSet when no
- * response whas generated
- *
- * @return void
- */
- public function testCookieNotSetFailureNoResponse()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('No response set, cannot assert cookies.');
- $this->assertCookieNotSet('remember_me');
- }
- /**
- * Test error handling and error page rendering.
- *
- * @return void
- */
- public function testPostAndErrorHandling()
- {
- $this->post('/request_action/error_method');
- $this->assertResponseNotEmpty();
- $this->assertResponseContains('Not there or here');
- $this->assertResponseContains('<!DOCTYPE html>');
- }
- /**
- * Test posting to a secured form action.
- *
- * @return void
- */
- public function testPostSecuredForm()
- {
- $this->enableSecurityToken();
- $data = [
- 'title' => 'Some title',
- 'body' => 'Some text'
- ];
- $this->post('/posts/securePost', $data);
- $this->assertResponseOk();
- $this->assertResponseContains('Request was accepted');
- }
- /**
- * Test posting to a secured form action with nested data.
- *
- * @return void
- */
- public function testPostSecuredFormNestedData()
- {
- $this->enableSecurityToken();
- $data = [
- 'title' => 'New post',
- 'comments' => [
- ['comment' => 'A new comment']
- ],
- 'tags' => ['_ids' => [1, 2, 3, 4]]
- ];
- $this->post('/posts/securePost', $data);
- $this->assertResponseOk();
- $this->assertResponseContains('Request was accepted');
- }
- /**
- * Test posting to a secured form action.
- *
- * @return void
- */
- public function testPostSecuredFormWithQuery()
- {
- $this->enableSecurityToken();
- $data = [
- 'title' => 'Some title',
- 'body' => 'Some text'
- ];
- $this->post('/posts/securePost?foo=bar', $data);
- $this->assertResponseOk();
- $this->assertResponseContains('Request was accepted');
- }
- /**
- * Test posting to a secured form action with a query that has a part that
- * will be encoded by the security component
- *
- * @return void
- */
- public function testPostSecuredFormWithUnencodedQuery()
- {
- $this->enableSecurityToken();
- $data = [
- 'title' => 'Some title',
- 'body' => 'Some text'
- ];
- $this->post('/posts/securePost?foo=/', $data);
- $this->assertResponseOk();
- $this->assertResponseContains('Request was accepted');
- }
- /**
- * Test posting to a secured form action action.
- *
- * @return void
- */
- public function testPostSecuredFormFailure()
- {
- $data = [
- 'title' => 'Some title',
- 'body' => 'Some text'
- ];
- $this->post('/posts/securePost', $data);
- $this->assertResponseError();
- }
- /**
- * Test that exceptions being thrown are handled correctly.
- *
- * @return void
- */
- public function testWithExpectedException()
- {
- $this->get('/tests_apps/throw_exception');
- $this->assertResponseCode(500);
- }
- /**
- * Test that exceptions being thrown are handled correctly by the psr7 stack.
- *
- * @return void
- */
- public function testWithExpectedExceptionHttpServer()
- {
- DispatcherFactory::clear();
- $this->get('/tests_apps/throw_exception');
- $this->assertResponseCode(500);
- }
- /**
- * Test that exceptions being thrown are handled correctly.
- *
- * @return void
- */
- public function testWithUnexpectedException()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->get('/tests_apps/throw_exception');
- $this->assertResponseCode(501);
- }
- /**
- * Test redirecting and integration tests.
- *
- * @return void
- */
- public function testRedirect()
- {
- $this->post('/tests_apps/redirect_to');
- $this->assertResponseSuccess();
- $this->assertResponseCode(302);
- }
- /**
- * Test redirecting and psr7 stack
- *
- * @return void
- */
- public function testRedirectHttpServer()
- {
- DispatcherFactory::clear();
- $this->post('/tests_apps/redirect_to');
- $this->assertResponseCode(302);
- $this->assertHeader('X-Middleware', 'true');
- }
- /**
- * Test redirecting and integration tests.
- *
- * @return void
- */
- public function testRedirectPermanent()
- {
- $this->post('/tests_apps/redirect_to_permanent');
- $this->assertResponseSuccess();
- $this->assertResponseCode(301);
- }
- /**
- * Test the responseOk status assertion
- *
- * @return void
- */
- public function testAssertResponseStatusCodes()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStatus(200);
- $this->assertResponseOk();
- $this->_response = $this->_response->withStatus(201);
- $this->assertResponseOk();
- $this->_response = $this->_response->withStatus(204);
- $this->assertResponseOk();
- $this->_response = $this->_response->withStatus(202);
- $this->assertResponseSuccess();
- $this->_response = $this->_response->withStatus(302);
- $this->assertResponseSuccess();
- $this->_response = $this->_response->withStatus(400);
- $this->assertResponseError();
- $this->_response = $this->_response->withStatus(417);
- $this->assertResponseError();
- $this->_response = $this->_response->withStatus(500);
- $this->assertResponseFailure();
- $this->_response = $this->_response->withStatus(505);
- $this->assertResponseFailure();
- $this->_response = $this->_response->withStatus(301);
- $this->assertResponseCode(301);
- }
- /**
- * Test the location header assertion.
- *
- * @return void
- */
- public function testAssertRedirect()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withHeader('Location', 'http://localhost/tasks/index');
- $this->assertRedirect();
- $this->assertRedirect('/tasks/index');
- $this->assertRedirect(['controller' => 'Tasks', 'action' => 'index']);
- $this->assertResponseEmpty();
- }
- /**
- * Test the location header assertion.
- *
- * @return void
- */
- public function testAssertNoRedirect()
- {
- $this->_response = new Response();
- $this->assertNoRedirect();
- }
- /**
- * Test the location header assertion.
- *
- * @return void
- */
- public function testAssertNoRedirectFail()
- {
- $test = new AssertIntegrationTestCase('testBadAssertNoRedirect');
- $result = $test->run();
- $this->assertFalse($result->wasSuccessful());
- $this->assertEquals(1, $result->failureCount());
- }
- /**
- * Test the location header assertion string contains
- *
- * @return void
- */
- public function testAssertRedirectContains()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withHeader('Location', 'http://localhost/tasks/index');
- $this->assertRedirectContains('/tasks/index');
- }
- /**
- * Test the header assertion.
- *
- * @return void
- */
- public function testAssertHeader()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withHeader('Etag', 'abc123');
- $this->assertHeader('Etag', 'abc123');
- }
- /**
- * Test the header contains assertion.
- *
- * @return void
- */
- public function testAssertHeaderContains()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withHeader('Etag', 'abc123');
- $this->assertHeaderContains('Etag', 'abc');
- }
- /**
- * Test the content type assertion.
- *
- * @return void
- */
- public function testAssertContentType()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withType('json');
- $this->assertContentType('json');
- $this->assertContentType('application/json');
- }
- /**
- * Test that type() in an action sets the content-type header.
- *
- * @return void
- */
- public function testContentTypeInAction()
- {
- $this->get('/tests_apps/set_type');
- $this->assertHeader('Content-Type', 'application/json; charset=UTF-8');
- $this->assertContentType('json');
- $this->assertContentType('application/json');
- }
- /**
- * Test the content assertion.
- *
- * @return void
- */
- public function testAssertResponseContains()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStringBody('Some content');
- $this->assertResponseContains('content');
- }
- /**
- * Test the content assertion with no case sensitivity.
- *
- * @return void
- */
- public function testAssertResponseContainsWithIgnoreCaseFlag()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStringBody('Some content');
- $this->assertResponseContains('some', 'Failed asserting that the body contains given content', true);
- }
- /**
- * Test the negated content assertion.
- *
- * @return void
- */
- public function testAssertResponseNotContains()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStringBody('Some content');
- $this->assertResponseNotContains('contents');
- }
- /**
- * Test the content regexp assertion.
- *
- * @return void
- */
- public function testAssertResponseRegExp()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStringBody('Some content');
- $this->assertResponseRegExp('/cont/');
- }
- /**
- * Test the content regexp assertion failing
- *
- * @return void
- */
- public function testAssertResponseRegExpNoResponse()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('No response set');
- $this->assertResponseRegExp('/cont/');
- }
- /**
- * Test the negated content regexp assertion.
- *
- * @return void
- */
- public function testAssertResponseNotRegExp()
- {
- $this->_response = new Response();
- $this->_response = $this->_response->withStringBody('Some content');
- $this->assertResponseNotRegExp('/cant/');
- }
- /**
- * Test negated content regexp assertion failing
- *
- * @return void
- */
- public function testAssertResponseNotRegExpNoResponse()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('No response set');
- $this->assertResponseNotRegExp('/cont/');
- }
- /**
- * Test that works in tandem with testEventManagerReset2 to
- * test the EventManager reset.
- *
- * The return value is passed to testEventManagerReset2 as
- * an arguments.
- *
- * @return \Cake\Event\EventManager
- */
- public function testEventManagerReset1()
- {
- $eventManager = EventManager::instance();
- $this->assertInstanceOf('Cake\Event\EventManager', $eventManager);
- return $eventManager;
- }
- /**
- * Test if the EventManager is reset between tests.
- *
- * @depends testEventManagerReset1
- * @return void
- */
- public function testEventManagerReset2($prevEventManager)
- {
- $this->assertInstanceOf('Cake\Event\EventManager', $prevEventManager);
- $this->assertNotSame($prevEventManager, EventManager::instance());
- }
- /**
- * Test sending file in requests.
- *
- * @return void
- */
- public function testSendFile()
- {
- $this->get('/posts/file');
- $this->assertFileResponse(TEST_APP . 'TestApp' . DS . 'Controller' . DS . 'PostsController.php');
- }
- /**
- * Test sending file with psr7 stack
- *
- * @return void
- */
- public function testSendFileHttpServer()
- {
- $this->get('/posts/file');
- $this->assertFileResponse(TEST_APP . 'TestApp' . DS . 'Controller' . DS . 'PostsController.php');
- }
- /**
- * Test that assertFile requires a response
- *
- * @return void
- */
- public function testAssertFileNoResponse()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('No response set, cannot assert file');
- $this->assertFileResponse('foo');
- }
- /**
- * Test that assertFile requires a file
- *
- * @return void
- */
- public function testAssertFileNoFile()
- {
- $this->expectException(\PHPUnit\Framework\AssertionFailedError::class);
- $this->expectExceptionMessage('No file was sent in this response');
- $this->get('/posts/get');
- $this->assertFileResponse('foo');
- }
- /**
- * Test disabling the error handler middleware.
- *
- * @return void
- */
- public function testDisableErrorHandlerMiddleware()
- {
- $this->expectException(\Cake\Routing\Exception\MissingRouteException::class);
- $this->expectExceptionMessage('A route matching "/foo" could not be found.');
- $this->disableErrorHandlerMiddleware();
- $this->get('/foo');
- }
- /**
- * tests getting a secure action while passing a query string
- *
- * @return void
- * @dataProvider methodsProvider
- */
- public function testSecureWithQueryString($method)
- {
- $this->enableSecurityToken();
- $this->{$method}('/posts/securePost/?ids[]=1&ids[]=2');
- $this->assertResponseOk();
- }
- /**
- * data provider for HTTP methods
- *
- * @return array
- */
- public function methodsProvider()
- {
- return [
- 'GET' => ['get'],
- 'POST' => ['post'],
- 'PATCH' => ['patch'],
- 'PUT' => ['put'],
- 'DELETE' => ['delete'],
- ];
- }
- }
|