我们在一个单独的python文件中定义了所有自定义断言,该文件不是测试模块。例如:custom_asserts.pyclassCustomAsserts(object):defsilly_assert(self,foo,bar):assertfoo==bar,'someerrormessage'如果我们在测试中直接使用assert,我们会得到关于AssertionError的额外信息,这非常有用。在测试中直接使用断言的输出:>assert'foo'=='bar','someerrormessage'EAssertionError:someerrormessageEassert'foo'
我有一些单元测试,但我正在寻找一种方法来标记一些特定的单元测试以跳过它们,除非您在调用测试时声明了一个选项。例子:如果我调用pytesttest_reports.py,我希望不运行一些特定的单元测试。但是如果我调用pytest-test_reports,然后我希望运行所有测试。我查看了@pytest.mark.skipif(condition)标记但无法完全弄清楚,所以不确定我是否在正确的轨道上。这里的任何指导都会很棒! 最佳答案 我们在conftest.py中使用带有addoption的标记测试用例:@pytest.mark.no
当我通过运行以下命令为我的python项目运行测试时:pythonsetup.pytest(or)pytestproject_name我收到以下错误:.../project_name/.eggs/pytest_asyncio-0.9.0-py3.6.egg/pytest_asyncio/plugin.py",line8,infrom_pytest.pythonimporttransfer_markersImportError:cannotimportname'transfer_markers' 最佳答案 当我在网上查找时,几乎没有任
我正在尝试使用mock和@patch装饰器为Python应用程序构建测试。给定以下目录结构:|--mypackage||--mymodule|||--__init__.py||\--somefile.py|\--myothermodule||--tests|||--__init__.py||\--test_func_to_test.py|\--__init__.py\--__init__.py文件内容在哪里:#mypackage/mymodule/somefile.pydefsome_function():return'A'#mypackage/myothermodule/__init
我的模块结构:foo:-load()#fromDBbar:-check()#withuser-take_action()我想通过模拟加载和检查来测试take_action(基本上加载值并在执行操作之前与用户进行检查)。这是模拟:mock_load=Mock(side_effects=[,,])#differentdatasetsmock_check=Mock(return_value=True)#Userapproval如何使用patch.multiple在Python2.6中实现这一点?withpatch.multiple(??):#proceedtotesttake_action
我所有测试的基准是总是会有一辆出租车至少载有一名乘客。我可以使用一些基本装置轻松实现此设置:fromblahimportPassenger,Taxi@pytest.fixturedefpassenger():returnPassenger()@pytest.fixturedeftaxi(passenger):returnTaxi(rear_seat=passenger)测试基线很简单:deftest_taxi_contains_passenger(taxi)asserttaxi.has_passenger()当我开始需要更复杂的测试设置时,我的问题就出现了。在某些情况下,我需要出租车搭
在我的一些测试中,由于时间和时区问题,它们在Travis上失败了,所以我想为我的测试模拟系统时间。我该怎么做? 最佳答案 @Brian-Kruger的回答是最好的。我已投票取消删除它。同时...使用freezegun(repo)。自述文件:fromfreezegunimportfreeze_time@freeze_time("2012-01-14")deftest():assertdatetime.datetime.now()==datetime.datetime(2012,1,14)
我的python测试代码中有几个标记:@pytest.mark.slowtest@pytest.mark.webtest@pytest.mark.stagingtest我能够使用标记有选择地运行测试,例如pytest-mslowtest如何在不求助于pytest-m"not(slowtestorwebtestorstagingtest)"的情况下运行未标记的测试?如您所想,我们将来可能会使用其他标记... 最佳答案 我发现另一个有用的选项是使用pytest.ini添加默认选项。我们明确地写下要跳过的标记。它需要在pytest.ini
我想将我的Django(版本1.6x)应用程序切换为使用pytest-django进行测试。因此我通过pip安装了最新的pytest-django并获得了这些版本:pytest==2.6.4pytest-django==2.7.0对于常规的django测试,我正在使用自定义测试套件运行器扩展DjangoTestSuiteRunner,我在settings.py中配置了它:设置.py:TEST_RUNNER="dcmanager.tests.runner.ManagedModelTestRunner"运行者.py:importunittestfromdjango.confimportse
在最新版本的pytest中,可以很容易地创建函数、类、模块或session作用域的固定装置,如下所示:@pytest.fixture(scope="module")defdb():returnDB()这会创建一个fixture,每个使用它的python模块只会调用一次。但是每个python包需要调用一次的固定装置呢?(有了nose,可以使用包的__init__.py中的setUp/tearDown方法来完成) 最佳答案 对于包或目录级别的fixture,您可以使用scope='session'在您需要的目录中的conftest.py