Skip to main content

A library to generate complex fake database-entries based on SQLAlchemy models

Project description

sqlalchemy-fake-model

PyPI Version Python Versions License Tests Coverage Monthly Downloads Total Downloads

Quality Gate Status Security Rating Reliability Rating Maintainability Rating
Vulnerabilities Bugs Code Smells Lines of Code

Description

ModelFaker is a powerful utility that generates realistic fake data for SQLAlchemy models. It leverages the Faker library to create structured, random data that's perfect for development, testing, and database seeding.

Key Features:

  • Support for all common SQLAlchemy data types
  • Automatic relationship handling (OneToOne, OneToMany, ManyToMany)
  • Custom data format generation with JSON support
  • Framework integration (Flask, Django, Tornado)
  • Configurable min/max values and constraints
  • Nullable field support with intelligent defaults

Thank you for using sqlalchemy-fake-model!

If you have any questions or suggestions, please feel free to open an issue on GitHub here.

If you don't want to miss any updates, please star the repository. This will help me to understand how many people are interested in this project.

Installation

pip install sqlalchemy-fake-model

Quickstart

To use the ModelFaker module, you need to create a new instance of the ModelFaker class and pass the SQLAlchemy model you want to generate fake data for. Now you just need to provide a session to create the data in. For that you can either simply pass the session or if you use one of the Supported Frameworks, you can leave the session empty and the module will try to get the session from the framework.

Usage

Basic Usage:

from sqlalchemy_fake_model import ModelFaker
from your_app.models import User
from your_app.database import session

# Create 5 fake users with explicit session
ModelFaker(User, session).create(5)

Framework Integration:

For applications using Flask, Django, or Tornado:

from sqlalchemy_fake_model import ModelFaker
from your_app.models import User

# Session is automatically detected
ModelFaker(User).create(5)

Set-up Models

Supported Data Types

The ModelFaker module supports the following data types:

  1. String - Generates random strings of varying lengths.
  2. Text - Generates random text values of varying lengths.
  3. Integer - Generates random integers within a specified range.
  4. Float - Generates random floating-point numbers within a specified range.
  5. Boolean - Generates random boolean values.
  6. Date - Generates random date values within a specified range.
  7. DateTime - Generates random datetime values within a specified range.
  8. Enum - Generates random values from a specified list of choices.
  9. Relationship - Generates random values for relationships between models.
  10. Json - Generates random data in the custom json format.

Default values

The ModelFaker module also supports default values for fields. These values will be used if no other value is specified.

Example implementation of default values

Following example would result in a default value of 0 for the field:

is_deleted: Column[Boolean] = db.Column(
    db.Boolean,
    nullable=False,
    server_default="0"
)

You can use default or server_default to set default values for fields.

Nullable fields

The ModelFaker module supports nullable fields. If a field is nullable, it will generate None values for that field.

Example implementation of nullable fields

Following example would result in a None value for the field:

description: Column[String] = db.Column(
    db.String(255),
    nullable=True
)

Define max and min values

The ModelFaker module supports max and min values for fields. You can define the range of values for integer and float fields.

Example implementation of max and min values

Following example would result in a random integer value between 1 and 100:

age: Column[Integer] = db.Column(
    db.Integer(),
    nullable=False,
    info='{"min": 1, "max": 100}'
)

Define enum fields

The ModelFaker module supports enum fields. You can define a list of choices for an enum field, and it will generate random values from that list.

Example implementation of enum field

Following example would result in a random value from the list of choices:

status: Column[Enum] = db.Column(
    Enum(StatusTypesEnum),
    nullable=False
)

The enum class StatusTypesEnum could look like this:

from enum import Enum

class StatusTypesEnum(Enum):

    CREATED = "created"

    PUBLISHED = "published"

    CANCELED = "canceled"

It also allows a default enum value:

status: Column[Enum] = db.Column(
    Enum(StatusTypesEnum),
    nullable=False,
    default=StatusTypesEnum.ACTIVE
)

Define relationships

ModelFaker automatically handles relationships between models, creating the necessary related records to maintain referential integrity. It supports all SQLAlchemy relationship types:

  • OneToOne - Creates one related record
  • OneToMany - Creates multiple related records
  • ManyToMany - Creates and links multiple records through association tables

Example - User with Messages:

class User(Base):
    __tablename__ = "users"

    id: Column[Integer] = db.Column(Integer, primary_key=True)
    name: Column[String] = db.Column(String(100))
    messages = relationship("Message", back_populates="user")

class Message(Base):
    __tablename__ = "messages"

    id: Column[Integer] = db.Column(Integer, primary_key=True)
    content: Column[String] = db.Column(String(500))
    user_id: Column[Integer] = db.Column(Integer, ForeignKey("users.id"))
    user = relationship("User", back_populates="messages")

# This automatically creates users for each message
ModelFaker(Message).create(10)

Note: Different primary key types (UUID, String, etc.) are fully supported.

Define custom data format

The ModelFaker module supports custom data format generation. You can define custom functions to generate data for fields.

Example implementation of custom data format

Following example would result in a json list of strings eg. string[] in the database:

emails: Column[Text] = db.Column(
    db.Text(),
    nullable=False,
    default='[]',
    doc='["string"], ["integer"]'
)

Another example would result in a json object eg. object in the database:

address: Column[Text] = db.Column(
    db.Text(),
    nullable=False,
    default='{}',
    doc='{"street": "string", "location": {"city": ""string", "zip": "string"}}'
)

Supported Frameworks

ModelFaker provides seamless integration with popular web frameworks by automatically detecting and using their SQLAlchemy sessions:

Supported Frameworks:

  • Flask - Flask-SQLAlchemy integration
  • Django - Django ORM integration
  • Tornado - Tornado SQLAlchemy integration

How it works:

When using supported frameworks, ModelFaker automatically detects the current session context, eliminating the need to manually pass session objects:

# In a Flask application
@app.route('/seed-data')
def seed_data():
    # No session needed - automatically detected
    ModelFaker(User).create(100)
    return "Data seeded successfully!"

Manual Session:

For other frameworks or custom setups, pass the session explicitly:

from sqlalchemy.orm import sessionmaker

Session = sessionmaker(bind=engine)
session = Session()

ModelFaker(User, session).create(100)

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

sqlalchemy_fake_model-0.1.1.tar.gz (17.0 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: sqlalchemy_fake_model-0.1.1.tar.gz
  • Upload date:
  • Size: 17.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sqlalchemy_fake_model-0.1.1.tar.gz
Algorithm Hash digest
SHA256 1d5738742080655225ccbda5392d9d12302a6eabdebd23e857a7283c28ccca73
MD5 e7c8aced90a2938636db90c0780fb96b
BLAKE2b-256 dded3471983c691a6edf8d751b16707b8918291f26f7dd4b63d55b2cf5c55395

See more details on using hashes here.

Provenance

The following attestation bundles were made for sqlalchemy_fake_model-0.1.1.tar.gz:

Publisher: publish-to-pypi.yaml on LeanderCS/sqlalchemy-fake-model

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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