测试仅在Gitlab CI中失败,在本地成功

时间:2018-12-09 18:03:59

标签: laravel phpunit gitlab-ci

我只是从Gitlab CI开始(使用docker executor)。在面对并解决了一些初学者的问题之后,我现在面临着一个非常奇怪的问题。
我所有的单元测试都在本地成功,但是当我使用CI运行它们时,其中一些失败了。

一个例子:

[2018-12-09 18:05:57] testing.ERROR: Trying to get property 'email' of non-object {"userId":834,"email":"hugh.will@example.org","exception":"[object] (ErrorException(code: 0): Trying to get property 'email' of non-object at /builds/.../laravel/framework/src/Illuminate/Mail/Mailable.php:492)  

嗯..我知道此错误的含义,但是由于测试在本地成功完成,因此调试极其困难,而且我不知道从哪里开始。

这是我的.yml文件的test_job部分:

test_job:
  stage: test
  services:
  - mysql:5.7
  - redis:latest
  artifacts:
    when: always
    paths:
    - storage/logs/
  dependencies:
  - build_job
  script:
  - sh .gitlab-test.sh
  tags:
  - docker  

请确定-我的test.sh

#!/bin/sh
set -xe
php -v
ping -c 3 mysql
php artisan migrate
php artisan db:seed --class=TestingSeeder
php vendor/bin/phpunit --coverage-text --colors  

我的问题: 似乎在json的解析失败的地方,但是Mailable是一个Laravel组件,它应该(并且确实可以)工作。
Laravel 5.5和Gitlab CI是否存在任何已知问题? 如何调试仅在Gitlab CI上失败的测试?
使用CI测试Laravel应用程序时可能需要记住一些事情吗?

1 个答案:

答案 0 :(得分:5)

原因是配置错误。
事实证明,大多数失败的测试都是在测试一些与邮件相关的东西。我忘记添加我的smtp凭据。

它没有抱怨凭证丢失/错误,而是返回了这个奇怪的,绝对不相关的错误消息。