Laravel PHPunit测试返回500

时间:2020-08-20 14:37:48

标签: php laravel phpunit laravel-7 testcase

对于Laravel API,我已经编写了PHPUnit测试,但是每当我运行它时,都会收到如下所示的500错误

1) Tests\Feature\CompanyTest::orgTest
Expected status code 200 but received 500.
Failed asserting that 200 is identical to 500.

实际上,问题是我创建了2个单独的subdomains in my local for running the web (web.local) and API (api.local) environment。每当从Web域调用API时,它都会返回Access-Control-Allow-Origin,因此我在laravel中添加了 cors中间件。由于这个cors中间件,每当我运行PHP单元测试时,都会在laravel日志中收到以下错误,

local.ERROR:无法修改标头信息-标头已 发送人(输出始于 /vendor/phpunit/phpunit/src/Util/Printer.php:119) {“ exception”:“ [object](ErrorException(code:0):无法修改标头 信息-已发送的标头(输出始于 /vendor/phpunit/phpunit/src/Util/Printer.php:119)在 /app/Http/Middleware/Cors.php:18)

我的Cors中间件代码如下

Middlaware / cors.php

public function handle($request, Closure $next)
    {
        header('Access-Control-Allow-Origin:  http://web.local');
        header('Access-Control-Allow-Headers:  Content-Type, X-Auth-Token, Authorization, Origin');
        header('Access-Control-Allow-Methods:  POST, PUT');
        return $next($request);
    }

Kernel.php

$中间件阵列

\App\Http\Middleware\Cors::class

$ routeMiddleware阵列

'cors' => \App\Http\Middleware\Cors::class,

我还尝试了Laravel 7 CORS支持,方法是在 Config \ cors.php 文件中添加以下代码,但没有成功。

Config \ cors.php代码

return [    
    'paths' => ['api/*'],    
    'allowed_methods' => ['POST, PUT'],    
    'allowed_origins' => ['http://web.local'],    
    'allowed_origins_patterns' => [],    
    'allowed_headers' => ['Content-Type, X-Auth-Token, Authorization, Origin'],    
    'exposed_headers' => [],    
    'max_age' => 0,    
    'supports_credentials' => false,    
];

我已经搜索了该错误并尝试了许多解决方案,但无法成功。任何人,请让我知道发生了什么问题。谢谢!

2 个答案:

答案 0 :(得分:0)

我刚刚遇到了这个问题,我通过安装php-sqlite解决了它,具体取决于您的php版本:

sudo apt-get install php7.2-sqlite3

希望有帮助

答案 1 :(得分:0)

由于另一个 cors 问题,我最终来到这里 :D 但你问题的答案是你不能添加 header 除非它没有打印到标准输出,甚至没有打印新行。因此,在第一次输出之后,PHP 将永远不会接受任何新的标头,因为它已经被处理并且无法修改它们,这就是您收到该错误的原因。

为了添加这些标题,您可以将它们添加到响应对象中:

public function handle($request, Closure $next)
    {
        $response = $next($request);

        $response->headers->set('Access-Control-Allow-Origin', 'http://web.local');
        $response->headers->set('Access-Control-Allow-Headers', 'Content-Type, X-Auth-Token, Authorization, Origin');
        $response->headers->set('Access-Control-Allow-Methods', 'POST, PUT');

       return $response;
    }

我希望对你或任何从谷歌来到这里的人有所帮助:D