当我通过运行以下命令为我的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' 最佳答案 当我在网上查找时,几乎没有任
我所有测试的基准是总是会有一辆出租车至少载有一名乘客。我可以使用一些基本装置轻松实现此设置: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
我想使用pytestmonkeypatch插件,但我不知道如何导入它。我试过:importmonkeypath导入pytest.monkeypatch从pytest导入monkeypatch 最佳答案 它不是插件,它是内置的pytestfixture.简而言之,这意味着您只需编写一个带有monkeypatch参数的测试,测试就会将monkeypatch对象作为该参数。您链接的页面有一个简单的示例:deftest_some_interaction(monkeypatch):monkeypatch.setattr("os.getcwd"
我正在尝试为以下异步、等待方法编写pytest,但我一无所获。classUserDb(object):asyncdefadd_user_info(self,userInfo):returnawaitself.post_route(route='users',json=userInfo)asyncdefpost_route(self,route=None,json=None,params=None):uri=self.uri+routeifrouteelseself.uriasyncwithself.client.post(uri,json=json,params=params)asre
我正在使用pytest测试嵌入式系统的python模型。要测试的功能因平台而异。(我在此上下文中使用“平台”来表示嵌入式系统类型,而不是操作系统类型)。组织我的测试最直接的方法是根据平台类型将它们分配到目录。/platform1/platform2/etc.pytest/platform1由于许多功能跨平台重叠,这很快就变得难以支持。从那以后,我将我的测试移到了一个目录中,每个功能区域的测试分配给一个文件名(例如test_functionalityA.py)。然后,我使用pytest标记来指示文件中的哪些测试适用于给定平台。@pytest.mark.all_platformsdefte
在具有session范围和autouse=True的fixture中定义对象的最佳方法是什么,以便它可用于所有测试?@pytest.fixture(scope='session',autouse=True)defsetup_func(request):obj=SomeObj()接下来,我想要一些魔法,让之前创建的obj将出现在每个测试上下文中,而不需要每个测试都定义setup_funcfixture。deftest_one():obj.do_something_fancy() 最佳答案 我的建议是将fixture添加到conftes