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.1.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.1-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django_factory_all-0.1.1.tar.gz
  • Upload date:
  • Size: 6.6 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.1.tar.gz
Algorithm Hash digest
SHA256 b188975bb6b345ad5b07dfcce26fe270464aa1c772c1e131227fcac0748e487a
MD5 5b30905114012aa415a4be068142ab35
BLAKE2b-256 a44cd6d67be636d500c90b1b3d458c5f399d2adc1c4a5124868db4b71dcfcfdc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_factory_all-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 810a88cab12216f0e7f7181677cdf5b06145fe214bb1b098b19ff5bf4a654d23
MD5 6c258374c4119c53c363bc705bec7fc4
BLAKE2b-256 d304a254482135cbd2f3d0bbec3883f31aba9be488618f61de35b52d630d3292

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