django-autofixture 使用文档
2024-12-20 20:08:11作者:咎竹峻Karen
本文档旨在帮助用户了解和使用 django-autofixture 项目,包括安装指南、使用说明、API 使用文档和项目安装方式。
1. 安装指南
项目要求
- 支持 Django 1.4 至 1.9 版本
安装方式
- 将
autofixture包复制到项目目录中。 - 使用
pip命令从 Python 包索引安装django-autofixture:pip install django-autofixture - 如果没有
pip,可以使用easy_install命令安装:easy_install django-autofixture - 在 Django 设置文件中,将
'autofixture'添加到INSTALLED_APPS设置中。
2. 项目使用说明
管理命令
loadtestdata 命令用于加载测试数据,其语法如下:
python manage.py loadtestdata [options] app.Model:# [app.Model:# ...]
示例:创建三个 Category 对象和二十个 Entry 对象
python manage.py loadtestdata blog.Category:3 blog.Entry:20
使用 autofixture 作为单元测试工具
创建 AutoFixture 实例,并调用 create 方法生成测试数据。
示例:创建十个 Entry 对象
from autofixture import AutoFixture
fixture = AutoFixture(Entry)
entries = fixture.create(10)
设置字段值
可以使用 field_values 属性为特定字段设置默认值。
示例:设置 Listing 模型中的 needed_players 字段为 5
from main.models import Listing
fixture = AutoFixture(Listing, field_values={'needed_players': 5})
entries = fixture.create(30)
生成相关模型
可以使用 generate_fk 和 generate_m2m 属性为外键和多对多关系生成相关模型。
示例:自动生成 Entry 模型的作者和分类
fixture = AutoFixture(Entry, generate_fk=['author'], generate_m2m={'categories': (1, 3)})
entries = fixture.create(10)
限制外键模型集合
可以使用 limit_choices_to 属性限制外键字段的模型集合。
示例:将 Entry 模型的 blog 字段限制为不属于 Yoko Ono 的博客
from autofixture import AutoFixture, generators
fixture = AutoFixture(Entry, field_values={
'blog': generators.InstanceSelector(Blog, limit_choices_to={'name__ne': "Yoko Ono's blog"})
})
自定义 autofixture
可以通过子类化 AutoFixture 创建自定义 autofixture。
示例:为 MyModel 模型创建自定义 autofixture
from models import MyModel
from autofixture import generators, register, AutoFixture
class MyModelAutoFixture(AutoFixture):
field_values = {
'name': generators.StaticGenerator('this_is_my_static_name'),
}
register(MyModel, MyModelAutoFixture)
3. 项目 API 使用文档
详细 API 文档请参考 GitHub 项目 wiki。
4. 项目安装方式
请参考第 1 节中的安装指南。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
285
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108