我试图将测试输出记录到文件中并同时运行它们。
为此,我试图使用多进程插件和xunit插件。
我知道他们不能一起工作,xunit不会记录任何内容,因为mutiprocess不会直接发送输出。
https://github.com/nose-devs/nose/issues/2
我正在寻找的是允许我将输出记录到文件的任何替代方法。
原因是我正在运行Selenium Test,并且每次遇到错误时,stacktrace都很大,以至于stdout基本上完全被填满了。
减轻某些负担的方法也可能会有所帮助,Selenium文档非常缺少有关如何配置日志记录输出的信息。
我还尝试了stdout的非常基本的重定向:
#nosetests > file.txt
但这也不起作用。
最佳答案
如果您想使用来自Shell的基本重定向,则可以执行
nosetests &> output.txt
但是根据您的问题,您似乎希望执行以下操作:
$nosetests --processes 4 --with-xunit --xunit-file=test_output.xml
完整示例:
$ls
test_nose.py test_nose.pyc
$cat test_nose.py
import sys
import os
import time
def setUp():
pass
def test_1():
time.sleep(5)
with open('test_pid_' + str(os.getpid()), 'w') as f:
f.write(str(os.getpid()) + '\n')
def test_2():
time.sleep(5)
with open('test_pid_' + str(os.getpid()), 'w') as f:
f.write(str(os.getpid()) + '\n')
def test_3():
time.sleep(5)
with open('test_pid_' + str(os.getpid()), 'w') as f:
f.write(str(os.getpid()) + '\n')
def test_4():
time.sleep(5)
with open('test_pid_' + str(os.getpid()), 'w') as f:
f.write(str(os.getpid()) + '\n')
def tearDown():
pass
$ nosetests --processes 4 --with-xunit --xunit-file=test_output.xml
....
----------------------------------------------------------------------
Ran 4 tests in 5.223s
OK
$ ls
test_nose.py test_output.xml test_pid_55247 test_pid_55249
test_nose.pyc test_pid_55246 test_pid_55248
$ cat test_pid*
55246
55247
55248
55249
$ xmllint -format test_output.xml
<?xml version="1.0" encoding="UTF-8"?>
<testsuite name="nosetests" tests="0" errors="0" failures="0" skip="0"/>
看起来像您所说的那样不起作用:)
但
$nosetests --processes 4 &> output.txt
和
$nosetests --with-xunit --xunit-file=test_output.xml
做。
引用:
Redirect stderr and stdout in a Bash script
$man xmllint
$nosetests -h
关于Python Nose : Log tests results to a file with Multiprocess Plugin,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9162224/