Jenkins JUnit plugin gives error "ERROR: No test report files were found. Configuration error?"

Jenkins JUnit plugin gives error "ERROR: No test report files were found. Configuration error?"

我在 Kubernetes 集群中有 Jenkins 主容器 运行ning。我有一个单独的 VM 配置为构建从属,以便它可以构建容器。

我在 git 存储库中使用 Multibranch Pipeline 和 Jenkinsfile。

管道构建 Docker 图像,这是一个 Django 应用程序。我已经安装了django_nose,所以它可以生成带有测试结果的xunit文件。

Django 设置有以下选项来启用 xunit 测试结果。

TEST_RUNNER = 'django_nose.NoseTestSuiteRunner'
NOSE_ARGS = [
    '--with-xunit',
    '--xunit-file=/tmp/tests/results/results.xml',
] 

在管道中,我有以下阶段:

stage("Test") {
    sh("docker run --rm -i \
        -v '${env.WORKSPACE}/tests/results/':/tmp/tests/results \
        ${image} python3 manage.py test")
    junit '${env.WORKSPACE}/tests/results/*.xml'
}

它正在将 Jenkins 工作空间中的目录挂载为容器中的卷,以便在容器完成后 Jenkins 可以查看保存的测试结果。

当我 运行 构建时,出现以下错误:

[Pipeline] { (Test)
[Pipeline] sh
[my_project-test-7T6G6Z...QQBYGFA] Running shell script
+ docker run --rm -i -v /home/jenkins/jenkins_home/workspace/my_project-test-7T6G6Z...QQBYGFA/tests/results/:/tmp/tests/results my-registry/username/my_project python3 manage.py test
nosetests --with-xunit --xunit-file=/tmp/tests/results/results.xml --verbosity=1
Creating test database for alias 'default'...
............
----------------------------------------------------------------------
Ran 12 tests in 1.421s

OK
Destroying test database for alias 'default'...
[Pipeline] junit
Recording test results
No test report files were found. Configuration error?
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline

我可以看到 Django 测试 运行正在通过。如果我查看 Jenkins 从虚拟机,我可以看到 results.xml 文件位于它应该位于的位置,并且它包含测试的 XML 结果。

jenkins@jenkins-slave01:~/jenkins_home/workspace$ ls -al /home/jenkins/jenkins_home/workspace/my_project-test-7T6G6Z...QQBYGFA/tests/results/results.xml
-rw-r--r-- 1 root root 1329 Oct  2 09:45 /home/jenkins/jenkins_home/workspace/my_project-test-7T6G6Z...QQBYGFA/tests/results/results.xml
jenkins@jenkins-slave01:~/jenkins_home/workspace$

为什么 Jenkins 无法获取测试结果,因为我可以看到文件已创建?

我找到了答案。 JUnit 需要工作区内的相对路径。您不需要包含工作区的路径。

junit 'tests/results/*.xml'

我遇到这个错误是因为我在测试结果的路径中有一个前导点,例如:

junit './build/outputs/androidTest-results/connected/flavors/DEV/*.xml'

我不确定为什么,但这解决了问题:

junit 'build/outputs/androidTest-results/connected/flavors/DEV/*.xml'