- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将以下列表从我的命令行传递到我的 pytest 代码(如 python 中的 argparser),任何人都可以帮助我如何做到这一点吗?
pytest -vs test_sample.py --html=results.html --A_list=['A1', 'A2'] --B_list=['B1'] --C_list=['C1', 'C2']
这是我的 pytest 代码。
import pytest
@pytest.fixture(scope="session", params=A_list) # here A_list is a list and it has to be passed from command line
def get_A_list(request):
print("inside fixture get_A_list - element in A_list: ".format(request.param))
yield request.param
@pytest.fixture(scope="module", params=B_list) # here B_list is a list and it has to be passed from command line
def get_B_list(request, get_A_list):
print("inside fixture get_B_list - element in A_list: {}, element in B_list: {}: ".format(get_A_list, request.param))
yield request.param
@pytest.mark.parametrize("c", C_list) # here C_list is a list and it has to be passed from command line
def test_functionality(get_A_list, get_B_list, c):
print("inside function test_functionality - element in A_list: {}, element in B_list: {}, element in C_list: {}: ".format(get_A_list, get_B_list, c))
test_functionality 是我的测试用例函数。测试用例的数量应基于命令行中传递的列表的长度
对于上述列表,它必须按以下顺序执行测试用例。
test_functionality[A1-B1-C1]
test_functionality[A1-B1-C2]
test_functionality[A2-B1-C1]
test_functionality[A2-B1-C2]
我需要使用 A_list 中的元素在 **fixture get_A_list 中执行一些操作....同样,我需要使用 A_list 和 B_list 中的元素在 fixture get_B_list 中执行一些操作 .........像这样我有 4 个装置,最后我需要在 test_functionality 中执行测试用例,它将使用 A_list 、 B_list 、 C_list 等中的元素。
最后的输出应该如下所示..
inside fixture get_A_list - element in A_list: A1
inside fixture get_B_list - element in A_list: A1, element in B_list: B1
inside function test_functionality - element in A_list: A1, element in B_list: B1, element in C_list: C1
inside function test_functionality - element in A_list: A1, element in B_list: B1, element in C_list: C2
inside function test_functionality - element in A_list: A1, element in B_list: B1, element in C_list: C3
inside fixture get_A_list - element in A_list: A2
inside fixture get_B_list - element in A_list: A2, element in B_list: B1
inside function test_functionality - element in A_list: A2, element in B_list: B1, element in C_list: C1
inside function test_functionality - element in A_list: A2, element in B_list: B1, element in C_list: C2
inside function test_functionality - element in A_list: A2, element in B_list: B1, element in C_list: C3
最佳答案
这里的问题是 params
参数是在加载时读取的,此时有关命令行参数的信息尚不可用,因此您不能像示例中那样设置它们。
最好的方法可能是重构您的代码,这样就不需要了。如果您能够做到这一点,那么您就不需要额外的固定装置,
无论如何,您首先必须注册您的命令行参数:
conftest.py
def pytest_addoption(parser):
parser.addoption("--A_list", action="store")
parser.addoption("--B_list", action="store")
parser.addoption("--C_list", action="store")
现在,如果您可以重构您的代码,使固定装置不依赖于参数,您就可以根据传递的命令行参数对您的测试进行参数化。如果您将参数作为逗号分隔列表传递,您可以执行如下操作:
测试.py
import pytest
@pytest.hookimpl
def pytest_generate_tests(metafunc):
# collect fixture names with values
option_values = {
"a": metafunc.config.option.A_list,
"b": metafunc.config.option.B_list,
"c": metafunc.config.option.C_list
}
# add parametrization for each fixture name
for name, value in option_values.items():
if name in metafunc.fixturenames and value is not None:
metafunc.parametrize(name, value.split(","))
def test_functionality1(a, b, c):
print(a, b, c)
这将按所需顺序创建参数化测试。
如果那不可能,您可以尝试在运行时创建您的装置(更多信息请参见 this post):
conftest.py
# define the functions used as fixtures
def a_list_fixture(request):
print(f"get_A_list: {request.param}")
yield request.param
def b_list_fixture(request, get_A_list):
print(f"get_B_list: {get_A_list}, {request.param}")
yield request.param
# at session start, create the fixtures with the correct params
def pytest_sessionstart(session):
a_list = session.config.option.A_list
if a_list:
a_list = a_list.split(",")
name = "get_A_list"
fn = pytest.fixture(scope='session', name=name,
params=a_list)(a_list_fixture)
setattr(sys.modules[__name__], "{}_func".format(name), fn)
b_list = session.config.option.B_list
if b_list:
b_list = b_list.split(",")
name = "get_B_list"
fn = pytest.fixture(scope='session', name=name,
params=b_list)(b_list_fixture)
setattr(sys.modules[__name__], "{}_func".format(name), fn)
请注意,您仍然需要像上面那样为 c
参数化函数:
测试.py
import pytest
@pytest.hookimpl
def pytest_generate_tests(metafunc):
c_value = metafunc.config.option.C_list
if "c" in metafunc.fixturenames and value is not None:
metafunc.parametrize("c", value.split(","))
def test_functionality(get_A_list, get_B_list, c):
print(f"test_functionality {get_A_list}, {get_B_list}, {c}")
这将创建所需的参数化测试:
pytest -vv --A_list="A1,A2"--B_list="B1"--C_list="C1,C2"
:
================================================= test session starts =================================================
...
collected 4 items
so/cmd_line_args/test.py::test_functionality[C1-A1-B1] PASSED [ 25%]
so/cmd_line_args/test.py::test_functionality[C2-A1-B1] PASSED [ 50%]
so/cmd_line_args/test.py::test_functionality[C1-A2-B1] PASSED [ 75%]
so/cmd_line_args/test.py::test_functionality[C2-A2-B1] PASSED [100%]
================================================== 4 passed in 0.28s ==================================================
请注意,参数顺序不符合要求,但这只是一个表面问题。以下是 print
函数的输出:
pytest -s --A_list="A1,A2"--B_list="B1"--C_list="C1,C2"
================================================= test session starts =================================================
...
collected 4 items
test.py get_A_list: A1
get_B_list: A1, B1
test_functionality A1, B1, C1
.test_functionality A1, B1, C2
.get_A_list: A2
get_B_list: A2, B1
test_functionality A2, B1, C1
.test_functionality A2, B1, C2
.
================================================== 4 passed in 0.27s ==================================================
关于python - 如何通过命令行将多个列表参数传递给多个pytest装置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61864930/
我需要在整体超时的情况下停止测试用例,而不是在测试用例级别。 所以如果让我说我有 300 个测试用例,我想超时,总时间为 300 秒。 有没有办法做到这一点? 用于运行 pytest 的示例命令 py
我会默认使用一些参数( -n 2 )运行 pytest 但如果我只输入 pytest ... ,我不希望默认使用该参数直接运行pytest。这可能吗? 如果我包括这个: [pytest] addopt
给定以下模型: import pytest class DummyFile(pytest.File): def collect(self): yield DummyItem(s
对于 pytest,我正在使用库 pytest-dependency 设置依赖项.我还为这些测试添加了标记。这是一个 ECM: # test_test.py import pytest @pytest
我想使用逻辑来控制我的测试的顺序,这将在它们已经运行时动态重新排序它们。 我的用例是这样的:我正在使用 xdist 并行化我的测试,并且每个测试都使用来自公共(public)和有限池的外部资源。一些测
我需要标记要跳过的某些测试。但是,有些测试是参数化的,我只需要能够跳过某些场景。 我使用 py.test -m "hermes_only" 调用测试或 py.test -m "not hermes_o
问题是我给定的 fixture 函数具有外部依赖性,这会导致“错误”(例如无法访问的网络/资源不足等)。 我想跳过 fixture ,然后跳过任何依赖于该 fixture 的测试。 做这样的事情是行不
我正在试用 pytest首次。我如何抑制发出的关于我的代码所依赖的其他人的代码的警告而不抑制关于我自己的代码的警告? 现在我的 pytest.ini 中有这个所以我不必看到 pytest 警告我关于
我试图跳过依赖于命令行参数值的特定测试。我尝试使用 pytest.config.getoption("--some-custom-argument") 获取参数值就像这里描述的一样 related q
我目前使用的是 python 3.5.1 和 3.6 以及最新版本的 pytest。当使用参数化测试运行 pytest 时,我希望任何失败的测试仅显示失败的测试,而不是参数化测试的所有设置。 解释一下
在我的测试套件中,我有一些数据生成装置,用于许多参数化测试。其中一些测试希望这些装置在每个 session 中只运行一次,而另一些则需要它们运行每个功能。例如,我可能有一个类似于: @pytest.f
我想在运行时获取测试名称和测试结果。 我有 setup和 tearDown我的脚本中的方法。在 setup ,我需要获取测试名称,并在 tearDown我需要得到测试结果和测试执行时间。 有没有办法我
有没有办法在 PyTest fixture 中定义标记? 当我指定 -m "not slow" 时,我试图禁用慢速测试在 pytest 中。 我已经能够禁用单个测试,但不能禁用用于多个测试的 fixt
我最低限度地使用 pytest 作为针对工作中各种 API 产品的大型自动化集成测试的通用测试运行器,并且我一直在尝试寻找一个同样通用的拆卸函数示例,该函数在任何测试完成时运行,无论成功或失败。 我的
即使在写入管道时,如何强制 pytest 以颜色显示结果?似乎没有任何命令行选项可以这样做。 最佳答案 从 2.5.0 开始,py.test 有选项 --color=yes 从 2.7.0 开始,还应
作为一组更大的测试的一小部分,我有一套测试函数,我想在每个对象列表上运行。基本上,我有一组插件和一组“插件测试”。 天真地,我可以只列出一个带有插件参数的测试函数列表和一个插件列表,然后进行测试,我在
我想为 pytest-xdist 产生的每个子进程/网关创建一个单独的日志文件。是否有一种优雅的方法可以找出 pytest 当前所在的子进程/网关?我正在使用位于 conftest.py 的 sess
我的测试脚本如下 @pytest.fixture(scope="Module", Autouse="True") def setup_test(): ....................
我正在尝试像这样参数化我的类测试: @pytest.mark.parametrize('current_user', ["test_profile_premium", "test_profile_fr
我不明白如何正确运行一个简单的测试(功能文件和 python 文件) 与图书馆 pytest-bdd . 来自官方documentation ,我无法理解要发出什么命令来运行测试。 我尝试使用 pyt
我是一名优秀的程序员,十分优秀!