Skip to main content

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() 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.2.tar.gz (6.7 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.2-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

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

Hashes for django_factory_all-0.1.2.tar.gz
Algorithm Hash digest
SHA256 109524ba27cd7a1bb06878e173bea44f9b0950c0f0a272c5a7cbbfe8782ed471
MD5 c9f4a353a28934a14954e24b50173a3a
BLAKE2b-256 2104034cc56276f2ec389cc673ce6800efd28da515a6181d9d162c9779e555bb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_factory_all-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1681fa05d38b0dd712d0929bcaff807b2c6a0ba9128feced176ce0c842f731ff
MD5 c49fddd73183f0aa9315efc6f0aebcb6
BLAKE2b-256 485a0da556ca10bf9c480eea39be300ee2999726b810e0371d0e99f47007574e

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