Skip to main content

Un package Django pour générer automatiquement des instances de modèles.

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

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() ou build().

  • build_create_kwargs(): génère uniquement les données sous forme de dictionnaire, sans créer l’instance.


Comment l’utiliser

  1. Copier le fichier model_factory.py dans votre projet Django.
  2. 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_name sont 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

  1. Tout peut être généré automatiquement, aucune valeur n’est obligatoire.
  2. Les champs uniques sont protégés et régénérés en cas de conflit.
  3. Les relations circulaires sont limitées par max_depth.
  4. Le cache interne est réinitialisé pour chaque création afin d’éviter les conflits.
  5. Conçu pour Django uniquement.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_factory_all-0.1.0.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_factory_all-0.1.0-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file django_factory_all-0.1.0.tar.gz.

File metadata

  • Download URL: django_factory_all-0.1.0.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for django_factory_all-0.1.0.tar.gz
Algorithm Hash digest
SHA256 37791294c7c6854a00287529afdbaac9cee5cda46692e58e49c250532bf047c0
MD5 bba2eb45ed13f26b95728e5041807c5a
BLAKE2b-256 5fad85f2cb8a33b4dbc8179402ca4f8551e983833458b1ef20250236be3f848f

See more details on using hashes here.

File details

Details for the file django_factory_all-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_factory_all-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cd0566101741d508f5293308bf8e26e8b6e189dbd782f9d2bef7e815cd2a1bd0
MD5 060d15484118637aa203fcd124a12be9
BLAKE2b-256 c6dc6a33c0da5313c3bd3eae61bfed0adbf987df5059e93d9d18f85b8c50b6ae

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page