当前位置: 首页 > 知识库问答 >
问题:

如何使用pytest夹具作为参数化参数?

诸葛奇玮
2023-03-14

我有一个类似这样的pytest测试:

email_two = generate_email_two()

@pytest.mark.parametrize('email', ['email_one@example.com', email_two])
def test_email_thing(self, email):
        ... # Run some test with the email parameter

现在,作为重构的一部分,我移动了这一行:

email_two = generate_email_two()

放入它自己的夹具中(在conftest.py文件中),因为它在其他地方使用。但是,除了直接导入fixture函数外,是否有其他方法在测试中引用它?我知道funcargs通常是调用fixture的方式,但是在本文中,当我想要调用fixture时,我不在测试函数中。

共有1个答案

端木宏盛
2023-03-14

我最终通过在测试函数中使用for循环来实现这一点,循环处理每封电子邮件。就测试输出而言,这不是最好的方法,但它确实起到了作用。

import pytest
import fireblog.login as login

pytestmark = pytest.mark.usefixtures("test_with_one_theme")

class Test_groupfinder:
    def test_success(self, persona_test_admin_login, pyramid_config):
        emails = ['id5489746@mockmyid.com', persona_test_admin_login['email']]
        for email in emails:
            res = login.groupfinder(email)
            assert res == ['g:admin']

    def test_failure(self, pyramid_config):
        fake_email = 'some_fake_address@example.com'
        res = login.groupfinder(fake_email)
        assert res == ['g:commenter']
 类似资料:
  • 问题内容: 考虑以下Pytest: 该测试使用Pytest固定装置,其本身具有属性。在测试中迭代该属性,以便仅在每个in的断言均成立的情况下测试才通过。 但是,我实际上想做的是生成3个测试,其中2个应该通过,其中1个将失败。我试过了 但这导致 据我了解,在Pytest固定装置中,函数“成为”其返回值,但是在对参数进行参数化时,这似乎尚未发生。如何以所需的方式设置测试? 问题答案: 从 pytest

  • 我的测试结构是 当我收集测试时,我可以看到下面 由于oneTimeSetup1夹具的范围是类,我不确定为什么每个测试函数都在新的浏览器会话中运行。 我们可以有一个单一的Chrome浏览器会话,将执行我的test_one

  • 问题内容: 通常,我会写一个在每个方法中都使用pytest固定装置的测试类。这是一个例子。我希望能够避免必须在每种方法的签名中写入灯具名称。不是干的。如何才能做到这一点? 我希望能够通过将灯具作为测试类的属性来访问灯具。在此示例中,我希望将Google固定装置视为TestGoogle的属性。这可能吗? 问题答案: 当然,只需使用自动使用的夹具即可。这是docs中的相关位置。在您的示例中,更改将引入

  • 问题内容: 我在詹金斯(Jenkins)有一份工作,有2个参数。我要运行另一个没有参数的计划,并从该计划中启动所需的现有计划多次。 新计划需要安排为每15分钟运行一次(将由Jenkins的Scheduler选项完成),该计划的代码将: 连接到数据库 获取所需的记录集 开始循环记录集 存储键/值对(现有作业的参数) 结束循环 完成此操作后,我需要对存储的每个键/值对运行现有作业。我可以使用Jenki

  • 我正在Android中使用以下rxjava依赖项: 我正在尝试创建一个方法,它将把观察者作为参数。我有一些问题,我想是因为这是rxjava2,所以东西更新了,我有点困惑。 让我向你展示我想要完成的事情: 那么如何保存一次性,这样我们就可以退订了呢?

  • 问题内容: 我问这个问题有点傻,因为我似乎是世界上唯一一个不了解这个问题的人,但是无论如何,这都是可行的。我将以Python为例。当我使用原始SQL查询(通常使用ORM)时,我会使用参数化,例如使用SQLite的以下示例: 方法A: 我知道这可行,我知道这是通常推荐的方式。SQL注入易受攻击的方式可以执行以下操作: 方法B: 到目前为止,我可以告诉我了解SQL注入,如本Wikipedia文章中所述