770fa761b8
When `mod_unique_id` is enabled the ID generated by it will be used for logging. This allows for correlation of the Apache logs and the ownCloud logs. Testplan: - [ ] When `mod_unique_id` is enabled the request ID equals the one generated by `mod_unique_id`. - [ ] When `mod_unique_id` is not available the request ID is a 20 character long random string - [ ] The generated Id is stable over the lifespan of one request Changeset looks a little bit larger since I had to adjust every unit test using the HTTP\Request class for proper DI. Fixes https://github.com/owncloud/core/issues/13366
93 lines
2.3 KiB
PHP
93 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* ownCloud - App Framework
|
|
*
|
|
* @author Bernhard Posselt
|
|
* @copyright 2012 Bernhard Posselt <dev@bernhard-posselt.com>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
* License as published by the Free Software Foundation; either
|
|
* version 3 of the License, or any later version.
|
|
*
|
|
* This library 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 AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
|
|
namespace OC\AppFramework;
|
|
|
|
use OC\AppFramework\Http\Request;
|
|
use OCP\AppFramework\Middleware;
|
|
|
|
|
|
class ChildMiddleware extends Middleware {};
|
|
|
|
|
|
class MiddlewareTest extends \Test\TestCase {
|
|
|
|
/**
|
|
* @var Middleware
|
|
*/
|
|
private $middleware;
|
|
private $controller;
|
|
private $exception;
|
|
private $api;
|
|
|
|
protected function setUp(){
|
|
parent::setUp();
|
|
|
|
$this->middleware = new ChildMiddleware();
|
|
|
|
$this->api = $this->getMockBuilder(
|
|
'OC\AppFramework\DependencyInjection\DIContainer')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$this->controller = $this->getMock(
|
|
'OCP\AppFramework\Controller',
|
|
[],
|
|
[
|
|
$this->api,
|
|
new Request([], $this->getMockBuilder('\OCP\Security\ISecureRandom')->getMock())
|
|
]
|
|
);
|
|
$this->exception = new \Exception();
|
|
$this->response = $this->getMock('OCP\AppFramework\Http\Response');
|
|
}
|
|
|
|
|
|
public function testBeforeController() {
|
|
$this->middleware->beforeController($this->controller, null);
|
|
$this->assertNull(null);
|
|
}
|
|
|
|
|
|
public function testAfterExceptionRaiseAgainWhenUnhandled() {
|
|
$this->setExpectedException('Exception');
|
|
$afterEx = $this->middleware->afterException($this->controller, null, $this->exception);
|
|
}
|
|
|
|
|
|
public function testAfterControllerReturnResponseWhenUnhandled() {
|
|
$response = $this->middleware->afterController($this->controller, null, $this->response);
|
|
|
|
$this->assertEquals($this->response, $response);
|
|
}
|
|
|
|
|
|
public function testBeforeOutputReturnOutputhenUnhandled() {
|
|
$output = $this->middleware->beforeOutput($this->controller, null, 'test');
|
|
|
|
$this->assertEquals('test', $output);
|
|
}
|
|
|
|
|
|
}
|