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
相关推荐
郝学胜-神的一滴2 小时前
Python美学的三重奏:深入浅出列表、字典与生成器推导式
开发语言·网络·数据结构·windows·python·程序人生·算法
deephub2 小时前
分类数据 EDA 实战:如何发现隐藏的层次结构
人工智能·python·机器学习·数据分析·数据可视化
深蓝电商API2 小时前
常见反爬机制分类及对应破解思路
爬虫·python
张3蜂2 小时前
身份证识别接口方案
人工智能·python·开源
ZCXZ12385296a2 小时前
物流自动化环境下的纸箱检测与识别_YOLO13-SEG-REPVGGOREPA模型应用
运维·自动化
知行合一。。。3 小时前
程序中的log4j、stderr、stdout日志
python·单元测试·log4j
wxin_VXbishe3 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·spring boot·python·spring·django·php
sg_knight3 小时前
原型模式(Prototype)
python·设计模式·开发·原型模式
weixin_433179333 小时前
Python - 软件对象
开发语言·python