当前位置: 首页> 房产> 建材 > 广东网络科技有限公司_信息流广告是什么意思_seo培训_专业网络推广机构

广东网络科技有限公司_信息流广告是什么意思_seo培训_专业网络推广机构

时间:2025/8/11 15:36:12来源:https://blog.csdn.net/weixin_43435891/article/details/147312086 浏览次数:0次
广东网络科技有限公司_信息流广告是什么意思_seo培训_专业网络推广机构

第一个问题:难道使用fixture 会影响用例独立吗?

✅ 简单回答:
使用 fixture ≠ 不独立。
只要你的 fixture 是每次测试都能自己运行、自己产生数据的,那么测试用例依然是“逻辑独立”的。

✅ 怎么判断 fixture 是否影响独立性?

情况是否影响独立性说明
fixture 中 硬编码共享数据(如共享 token)❌ 是耦合的多个用例依赖同一数据,顺序或状态会影响结果
fixture 每次调用都能 重新生成独立数据✅ 不影响比如每个测试都生成新 token、新用户
fixture 被多个用例共享,且包含有状态操作❌ 可能影响比如 fixture 中做了前置清理,多个测试共享它就有影响
fixture 被一个用例专用✅ 安全就像把准备步骤封装起来,依然独立

📌 示例一:✅ 独立的 fixture(没问题)

pythonimport pytest
import requests@pytest.fixture
def valid_token():# 每次都调用登录接口,获取新 tokenresponse = requests.post("http://example.com/api/login", json={"username": "testuser","password": "123456"})assert response.status_code == 200return response.json()["token"]def test_user_info(valid_token):headers = {"Authorization": f"Bearer {valid_token}"}resp = requests.get("http://example.com/api/user/info", headers=headers)assert resp.status_code == 200

✔️ 这个 valid_token fixture 每次都是“自给自足”的,不依赖其他测试状态,所以仍然是独立用例。

⚠️ 示例二:❌ 有耦合风险的 fixture

python# 假设 login_fixture 中手动生成了 token 或写死一个 token
@pytest.fixture(scope="session")
def shared_token():return "abc1234567"  # 固定写死,或者由前置用例创建def test_user_info(shared_token):...

这个 shared_token fixture:

  • 不一定来自当前测试生成

  • 可能是别的用例产生或初始化时产生的

    🛑 这种就存在耦合风险。如果别的地方修改了 token 或状态,可能影响这个用例。

✅ 最佳实践建议:

做法推荐程度理由
每个用例内部写登录逻辑👍 简单但冗余少量可接受✅ 保证测试完全独立,无需依赖外部状态或 fixture,适合初学或用例量较少时
用 fixture 封装登录,但每次自动重新登录✅ 最推荐✅ 实现代码复用 + 独立性兼顾,每个用例拿到的 token 都是最新、唯一、干净的
共享全局 token、session 作为 fixture⚠️ 仅限于性能优化场景,否则不推荐⚠️ 存在用例状态耦合、测试顺序依赖等风险,若 token 被修改或过期会影响所有用例

📌 总结一句话:

只要 fixture 是“每个用例都能独立用”的工具,它就是帮助测试保持独立的;只有当它变成“多个测试共用的状态容器”,才会破坏独立性。

第二个问题:那scope="session"这种级别的都是耦合的吗?

✅ 简短回答:
不是所有 scope=“session” 的 fixture 都导致耦合,关键在于你放了什么内容进去。

🧠 深入理解:fixture 的 scope 只是控制“生命周期”,不等于是否“耦合”。

scope 值生命周期举例
“function”每个用例都执行一次(默认)最独立、最干净
“class”每个类只执行一次类内测试共享
“module”每个测试文件只执行一次跨函数共享
“session”整个测试执行过程只执行一次所有用例共享,最广

✅ 所以:是否“耦合”,取决于 fixture 内部内容是否有状态 / 会变化 / 受上下文影响

📌 下面通过具体例子来解释:

✅ 安全的 session 级别 fixture(无耦合)

python# 这是一个静态配置类 fixture,和用例无状态相关
@pytest.fixture(scope="session")
def base_url():return "http://example.com/api"

✔️ 这个不会耦合,因为它只是一个静态值,多个用例共享没有问题。

⚠️ 有耦合风险的 session 级别 fixture(含状态)

python@pytest.fixture(scope="session")
def shared_token():# 登录一次,所有用例共用resp = requests.post("http://example.com/api/login", json={"username": "testuser", "password": "123456"})return resp.json()["token"]

🛑 如果某个测试改变了用户状态(比如禁用账号、修改密码),其它测试就会失败。这就是“隐性耦合”。

✅ 推荐做法(平衡独立性 & 性能):

✅ 方案一:默认使用 function scope,保持测试独立性

python@pytest.fixture
def fresh_token():# 每个用例登录一次,独立、干净...

✅ 方案二:使用 session,但只放“无状态的共享配置”

python@pytest.fixture(scope="session")
def env_config():return {"base_url": "http://example.com/api","headers": {"Content-Type": "application/json"}}

🔚 总结一句话:

scope=“session” 本身不是坏事,但如果 fixture 中包含用户态、系统态、会变的内容,就可能导致耦合问题。配置类 OK,状态类要谨慎。

关键字:广东网络科技有限公司_信息流广告是什么意思_seo培训_专业网络推广机构

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: