ModelFaker
is a utility that generates fake data for SQLAlchemy models.
It leverages the power of the Faker library to create realistic yet random data that can be used
to populate your database during development or for testing your application's functionality.
It supports a wide range of data types, including basic types, enums, and relationships between models.
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.
Test Status: | |
---|---|
Version Info: | |
Compatibility: | |
Downloads: |
pip install sqlalchemy-fake-model
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.
For all type of appications:
from sqlalchemy_fake_model import ModelFaker
from path-to-model import Users
from path-to-session import session
ModelFaker(Users, session).create(5)
For appications using one of the Supported Frameworks:
from sqlalchemy_fake_model import ModelFaker
from path-to-model import Users
ModelFaker(Users).create(5)
The ModelFaker module supports the following data types:
- String - Generates random strings of varying lengths.
- Text - Generates random text values of varying lengths.
- Integer - Generates random integers within a specified range.
- Float - Generates random floating-point numbers within a specified range.
- Boolean - Generates random boolean values.
- Date - Generates random date values within a specified range.
- DateTime - Generates random datetime values within a specified range.
- Enum - Generates random values from a specified list of choices.
- Relationship - Generates random values for relationships between models.
- Json - Generates random data in the custom json format.
The ModelFaker module also supports default values for fields. These values will be used if no other value is specified.
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.
The ModelFaker module supports nullable fields. If a field is nullable, it will generate None values for that field.
Following example would result in a None value for the field:
description: Column[String] = db.Column(
db.String(255),
nullable=True
)
The ModelFaker module supports max and min values for fields. You can define the range of values for integer and float fields.
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}'
)
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.
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.value
)
The ModelFaker module supports relationships between models. You can define relationships between models, and it will generate the corresponding other part of those relationship.
It supports the following relationship types:
- OneToOne - Generates random values for a one-to-one relationship.
- OneToMany - Generates random values for a one-to-many relationship.
- ManyToMany - Generates random values for a many-to-many relationship.
Following example would result in a creation of an entry for the users table to set up the relationship:
class User(Base):
__tablename__ = "users"
id: Column[Integer] = db.Column(
db.Integer,
primary_key=True
)
class Message(Base):
user_id: Column[Integer] = db.Column(
db.Integer,
db.ForeignKey("users.id"),
nullable=False
)
It is also allowed to use different types as primary key.
The ModelFaker module supports custom data format generation. You can define custom functions to generate data for fields.
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"}}'
)
The ModelFaker module is able to detect the sqlalchemy session automatically for the following frameworks:
- Flask
- Django
- Torando
If you are using one of these frameworks, you can simply leave the session empty and the module will try to get thesession from the framework. If not you have to pass the db session as a parameter.