Un package Django pour générer automatiquement des instances de modèles.
Project description
ModelFactory
ModelFactory est une classe utilitaire pour Django qui facilite la génération d’instances valides de modèles.
Elle prend en charge les relations (ForeignKey, OneToOne, ManyToMany), les champs uniques, les contraintes d’intégrité et peut générer automatiquement des utilisateurs Django (User).
⚠️ Important : Cette classe fonctionne uniquement dans un environnement Django.
Fonctionnalités principales
-
Génération automatique de toutes les valeurs d’un modèle, sans avoir besoin de fournir un seul argument.
-
Gestion automatique des relations (
ForeignKey,OneToOne,ManyToMany). -
Respect des contraintes uniques et des contraintes d’intégrité.
-
Deux façons principales de créer des instances :
create(): crée et sauvegarde l’instance en base.build(): crée l’instance sans la sauvegarder.
-
Possibilité de surcharger certaines valeurs en passant des arguments à
create()oubuild(). -
build_create_kwargs(): génère uniquement les données sous forme de dictionnaire, sans créer l’instance.
Comment l’utiliser
- Copier le fichier
model_factory.pydans votre projet Django. - Importer la classe :
from myapp.model_factory import ModelFactory
factory = ModelFactory()
Créer un utilisateur Django
user = factory.create_user()
print(factory.credentials_user)
# {'username': 'généré automatiquement', 'password': 'généré automatiquement'}
- Les valeurs
username,password,email,first_name,last_namesont générées automatiquement si elles ne sont pas fournies. - Vous pouvez surcharger certaines valeurs via
create_user(username="john_doe").
Créer une instance d’un modèle
Sans fournir le moindre argument
from myapp.models import Article
article = factory.create(Article)
print(article.title) # Généré automatiquement
print(article.id) # Sauvegardé en base
- L’instance est complète et valide, toutes les relations sont gérées automatiquement.
- Vous n’avez rien à fournir, la classe s’occupe de tout.
Avec surcharges de valeurs
article = factory.create(Article, title="Titre personnalisé")
print(article.title) # "Titre personnalisé"
- Les champs que vous fournissez remplacent les valeurs générées automatiquement.
Construire une instance sans sauvegarder
article = factory.build(Article)
print(article.pk) # None, pas encore sauvegardé
factory.save() # Sauvegarde l'instance et les relations ManyToMany
print(article.pk) # Maintenant l'ID est assigné
- Permet de générer un objet pour inspection ou modification avant la sauvegarde.
Générer juste les données sans créer l’instance
data = factory.build_create_kwargs(Article)
print(data)
# {'title': 'Titre généré automatiquement', 'content': 'Texte généré', ...}
- Utile si vous voulez obtenir un dictionnaire de valeurs valides pour tests ou fixtures, sans créer l’objet en base.
Exemple complet avec ManyToMany
from myapp.models import Tag, Article
factory = ModelFactory(m2m_count=2)
article = factory.create(Article)
print(article.tags.all()) # Tags générés automatiquement
- Les objets liés sont créés automatiquement selon
m2m_count.
Points importants
- Tout peut être généré automatiquement, aucune valeur n’est obligatoire.
- Les champs uniques sont protégés et régénérés en cas de conflit.
- Les relations circulaires sont limitées par
max_depth. - Le cache interne est réinitialisé pour chaque création afin d’éviter les conflits.
- Conçu pour Django uniquement.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file django_factory_all-0.1.2.tar.gz.
File metadata
- Download URL: django_factory_all-0.1.2.tar.gz
- Upload date:
- Size: 6.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
109524ba27cd7a1bb06878e173bea44f9b0950c0f0a272c5a7cbbfe8782ed471
|
|
| MD5 |
c9f4a353a28934a14954e24b50173a3a
|
|
| BLAKE2b-256 |
2104034cc56276f2ec389cc673ce6800efd28da515a6181d9d162c9779e555bb
|
File details
Details for the file django_factory_all-0.1.2-py3-none-any.whl.
File metadata
- Download URL: django_factory_all-0.1.2-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1681fa05d38b0dd712d0929bcaff807b2c6a0ba9128feced176ce0c842f731ff
|
|
| MD5 |
c49fddd73183f0aa9315efc6f0aebcb6
|
|
| BLAKE2b-256 |
485a0da556ca10bf9c480eea39be300ee2999726b810e0371d0e99f47007574e
|