UI自动化测试中的Mixin设计模式

🧩 什么是 Mixin 设计模式?

一句话定义:

Mixin 是一种"只提供能力、不独立存在"的类,用来给其他类横向加功能。

它不是:

  • ❌ 业务对象

  • ❌ 完整组件

它是:

  • ✅ 行为片段(capability)

  • ✅ 可组合的能力模块


📐 Mixin vs 继承(先破一个常见误区)

❌ 传统继承(问题多)

复制代码
BasePage
 ├── LoginPage
 │    └── LoginPageWithRetry
 │         └── LoginPageWithRetryAndLog

问题:

  • 继承链爆炸

  • 横向能力无法复用

  • 测试维护成本极高


✅ Mixin(组合能力)

复制代码
Page = BasePage
     + RetryMixin
     + LoggingMixin
     + AIAssistMixin

📌 能力是"加上去的",不是"继承来的"


🧠 Mixin 的三个核心特征

特征 说明
不独立实例化 不单独 new
不保存核心状态 只用宿主对象
专注一个能力 单一职责

🐍 Python 中的 Mixin(标准写法)

1️⃣ 定义 Mixin(只写能力)

python 复制代码
class RetryMixin:
    def retry(self, func, times=3):
        for i in range(times):
            try:
                return func()
            except Exception:
                if i == times - 1:
                    raise

2️⃣ 组合进主类

python 复制代码
class BasePage:
    def __init__(self, page):
        self.page = page


class LoginPage(BasePage, RetryMixin):
    def login(self):
        self.retry(lambda: self.page.click("#login"))

📌 Mixin 永远写在 BasePage 后面(Python MRO 规则)


🧪 测试 & Page Object 中的典型 Mixin 用法

✅ 1. 重试能力(最常见)

python 复制代码
class RetryClickMixin:
    def click_with_retry(self, selector):
        self.retry(lambda: self.page.click(selector))

✅ 2. 等待 & 稳定性能力

python 复制代码
class WaitMixin:
    def wait_visible(self, selector, timeout=5000):
        self.page.wait_for_selector(selector, timeout=timeout)

✅ 3. AI 能力

python 复制代码
class AILocatorMixin:
    def ai_click(self, desc):
        ai.action(desc)
python 复制代码
class ProductPage(BasePage, WaitMixin, AILocatorMixin):
    def add_first_product(self):
        try:
            self.page.click('[data-testid="add"]')
        except:
            self.ai_click("点击商品列表第一个加入购物车按钮")

👉 AI 是能力,不是主流程


🔥 这点很重要:Mixin ≠ 工具类

❌ 工具类(反模式)

python 复制代码
Utils.retry_click(page, selector)

问题:

  • 上下文丢失

  • 不可扩展

  • 代码散落


✅ Mixin(有上下文)

python 复制代码
self.click_with_retry(selector)

📌 Mixin 天然绑定 Page / Driver / Context


🧬 Mixin + Page Object 的推荐结构

复制代码
python 复制代码
pages/
 ├── base_page.py
 ├── login_page.py
 └── product_page.py

mixins/
 ├── retry_mixin.py
 ├── wait_mixin.py
 ├── ai_mixin.py
 └── log_mixin.py
python 复制代码
class ProductPage(
    BasePage,
    WaitMixin,
    RetryMixin,
    AILocatorMixin
):
    pass

⚠️ Mixin 的 4 个铁律(踩坑预警)

1️⃣ 一个 Mixin 只做一件事

❌ Retry + Log + Assert

✅ RetryMixin / LogMixin / AssertMixin


2️⃣ 不要在 Mixin 里定义 __init__

(除非你真的懂 MRO)


3️⃣ Mixin 不要依赖另一个 Mixin

否则顺序地狱 💣


4️⃣ 不要用 Mixin 表达"是什么"

Mixin 表达的是:

"你能做什么"


🆚 Mixin vs 装饰器(你可能也在纠结)

场景 用哪个
横向能力 ✅ Mixin
单个函数增强 装饰器
动态注入 装饰器
Page / Driver 能力 ✅ Mixin
相关推荐
用户8356290780519 分钟前
无需 Office:Python 批量转换 PPT 为图片
后端·python
markfeng82 小时前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi3 小时前
Chapter 2 - Python中的变量和简单的数据类型
python
JordanHaidee3 小时前
Python 中 `if x:` 到底在判断什么?
后端·python
ServBay3 小时前
10分钟彻底终结冗长代码,Python f-string 让你重获编程自由
后端·python
闲云一鹤3 小时前
Python 入门(二)- 使用 FastAPI 快速生成后端 API 接口
python·fastapi
Rockbean4 小时前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
曲幽5 小时前
FastAPI + Ollama 实战:搭一个能查天气的AI助手
python·ai·lora·torch·fastapi·web·model·ollama·weatherapi
用户60648767188966 小时前
国内开发者如何接入 Claude API?中转站方案实战指南(Python/Node.js 完整示例)
人工智能·python·api
只与明月听6 小时前
RAG深入学习之Chunk
前端·人工智能·python