## Mock data generation
This is small project for generating artificial / mock data, conforming to the specified DB schema.
It can be useful to either generate pseudo-realistic data in the database, or prepare large amounts of mock data for stress testing.
The package allows for generating mock data for specified database schema.
## Simple configuration file schema:
```
{
"connection": "postgresql+psycopg2://admin:test@172.17.0.1:5432/ChmielDB",
"tables": {
"Projects":{
"id": "PK serial",
"project_name": "first_name",
"project_owner": "FK Users.id"
},
"Users": {
"id": "PK serial",
"first_name": "first_name",
"last_name": "last_name",
"email": "email UNIQUE",
"password": "password",
"role": "OPTION IN (USER, ADMIN)",
"address": "address",
"birth_date": "timestamp",
"phone_number": "phone"
},
"IntermediaryTable: Projects_Users": {
"project_id": "FK Projects.id",
"user_id": "FK Users.id"
},
},
"objects_count": {
"Users": 25,
"Projects": 10,
"Projects_Users": 250,
}
```
## Advanced configuration file schema:
```
{
"connection": "postgresql+psycopg2://admin:test@172.22.0.1:5432/JobMarketDB",
"tables": {
"app_users": {
"user_id": "PK UUID",
"company": "FK_UUID company.company_id",
"email": "email UNIQUE",
"first_name": "first_name",
"last_name": "last_name",
"phone": "first_name",
"role": "OPTION IN (USER,ADMIN)",
"is_blocked": "bool",
"email_verified": "bool",
"employee_verified": "bool",
"created_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"password_hash": "first_name"
},
"skills": {
"skill_id": "PK UUID",
"profile_id": "FK_UUID user_profiles.profile_id",
"skill_name": "first_name",
"proficiency_level": "first_name",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"chat_messages": {
"message_id": "PK UUID",
"chat_id": "FK_UUID chats.chat_id",
"content": "long_text RANGE(6, 20)",
"created_by": "FK_UUID app_users.user_id",
"created_by_display": "first_name",
"read_by": "first_name",
"deleted_by": "first_name",
"created_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"job": {
"job_id": "PK UUID",
"company_id": "FK_UUID company.company_id",
"job_title": "first_name",
"job_description": "long_text RANGE(6, 20)",
"required_skills": "jsonb:json1",
"required_experience": "long_text RANGE(6, 20)",
"location": "first_name",
"salary": "float RANGE(100,12000) DISTRIBUTION(normal,mean=1,std=1)",
"created_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00) RANGE()"
},
"experiences": {
"experience_id": "PK UUID",
"profile_id": "FK_UUID user_profiles.profile_id",
"company_name": "FK_UUID company.company_id",
"role": "first_name",
"start_date": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"end_date": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"educations": {
"education_id": "PK UUID",
"profile_id": "first_name",
"institution_name": "first_name",
"degree": "first_name",
"location": "country+city(\"en_US\",\"en_GB\",\"fr_FR\",\"de_DE\",\"it_IT\",\"es_ES\",\"pl_PL\",\"nl_NL\",\"pt_PT\",\"sv_SE\",\"da_DK\",\"fi_FI\",\"no_NO\",\"cs_CZ\",\"hu_HU\",\"en_CA\",\"sk_SK\")",
"start_date": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"end_date": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"company": {
"company_id": "PK UUID",
"company_name": "first_name",
"location": "first_name",
"industry": "first_name",
"description": "first_name",
"verified": "bool",
"created_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"chats": {
"chat_id": "PK UUID",
"name": "first_name",
"created_by": "first_name",
"deleted_by": "first_name",
"last_message": "first_name",
"tags": "first_name",
"created_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"IntermediaryTable: user_chats":{
"chat_id": "FK_UUID chats.chat_id",
"user_id": "FK_UUID app_users.user_id"
},
"user_profiles": {
"profile_id": "PK UUID",
"user_id": "FK_UUID app_users.user_id",
"resume_path": "first_name",
"profile_picture_path": "first_name",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
},
"user_settings": {
"settings_id": "PK UUID",
"user_id": "FK_UUID app_users.user_id",
"offers_notification": "bool",
"newsletter_notification": "bool",
"recruiter_messages": "bool",
"push_notification": "bool",
"updated_at": "timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)"
}
},
"json_schemas": [
{
"json1": {
"fields": [
{
"skills": {
"type": "array",
"item_count": "RANGE(1, 5)",
"content": {
"type": "object",
"fields": {
"name": {
"type": "string",
"options": ["Python", "JavaScript", "Java", "C++", "Go", "Ruby"]
},
"level": {
"type": "integer",
"range": [1, 5]
}
}
}
}
}
]
}
}
],
"objects_count": {
"app_users": 200,
"skills": 500,
"chat_messages": 8000,
"job": 250,
"experiences": 100,
"educations": 200,
"company": 20,
"chats": 50,
"user_profiles": 500,
"user_settings": 500,
"user_chats": 10000
}
}
```
### Allowed column keywords:
TODO
#### Disclaimer:
The program only checks for uniqueness and integrity withing itself, there can still be error if there's already existing data in the database.
Raw data
{
"_id": null,
"home_page": null,
"name": "db-mockdata",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "mock, database, faker",
"author": null,
"author_email": "Mateusz Molenda <devexperrior@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/9b/25/0a6376bb989e0ee8de4ac3051fce9299578e13afe30af8a0c815c2b44e96/db_mockdata-0.4.5.tar.gz",
"platform": null,
"description": "## Mock data generation\n\nThis is small project for generating artificial / mock data, conforming to the specified DB schema.\nIt can be useful to either generate pseudo-realistic data in the database, or prepare large amounts of mock data for stress testing.\n\n\nThe package allows for generating mock data for specified database schema.\n\n## Simple configuration file schema:\n\n``` \n{\n \"connection\": \"postgresql+psycopg2://admin:test@172.17.0.1:5432/ChmielDB\",\n \"tables\": {\n \"Projects\":{\n \"id\": \"PK serial\",\n \"project_name\": \"first_name\",\n \"project_owner\": \"FK Users.id\"\n },\n \"Users\": {\n \"id\": \"PK serial\",\n \"first_name\": \"first_name\",\n \"last_name\": \"last_name\",\n \"email\": \"email UNIQUE\",\n \"password\": \"password\",\n \"role\": \"OPTION IN (USER, ADMIN)\",\n \"address\": \"address\",\n \"birth_date\": \"timestamp\",\n \"phone_number\": \"phone\"\n },\n \"IntermediaryTable: Projects_Users\": {\n \"project_id\": \"FK Projects.id\",\n \"user_id\": \"FK Users.id\"\n },\n },\n \"objects_count\": {\n \"Users\": 25,\n \"Projects\": 10,\n \"Projects_Users\": 250,\n }\n```\n\n## Advanced configuration file schema:\n\n```\n{\n \"connection\": \"postgresql+psycopg2://admin:test@172.22.0.1:5432/JobMarketDB\",\n \"tables\": {\n \"app_users\": {\n \"user_id\": \"PK UUID\",\n \"company\": \"FK_UUID company.company_id\",\n \"email\": \"email UNIQUE\",\n \"first_name\": \"first_name\",\n \"last_name\": \"last_name\",\n \"phone\": \"first_name\",\n \"role\": \"OPTION IN (USER,ADMIN)\",\n \"is_blocked\": \"bool\",\n \"email_verified\": \"bool\",\n \"employee_verified\": \"bool\",\n \"created_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"password_hash\": \"first_name\"\n },\n \"skills\": {\n \"skill_id\": \"PK UUID\",\n \"profile_id\": \"FK_UUID user_profiles.profile_id\",\n \"skill_name\": \"first_name\",\n \"proficiency_level\": \"first_name\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"chat_messages\": {\n \"message_id\": \"PK UUID\",\n \"chat_id\": \"FK_UUID chats.chat_id\",\n \"content\": \"long_text RANGE(6, 20)\",\n \"created_by\": \"FK_UUID app_users.user_id\",\n \"created_by_display\": \"first_name\",\n \"read_by\": \"first_name\",\n \"deleted_by\": \"first_name\",\n \"created_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"job\": {\n \"job_id\": \"PK UUID\",\n \"company_id\": \"FK_UUID company.company_id\",\n \"job_title\": \"first_name\",\n \"job_description\": \"long_text RANGE(6, 20)\",\n \"required_skills\": \"jsonb:json1\",\n \"required_experience\": \"long_text RANGE(6, 20)\",\n \"location\": \"first_name\",\n \"salary\": \"float RANGE(100,12000) DISTRIBUTION(normal,mean=1,std=1)\",\n \"created_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00) RANGE()\"\n },\n \"experiences\": {\n \"experience_id\": \"PK UUID\",\n \"profile_id\": \"FK_UUID user_profiles.profile_id\",\n \"company_name\": \"FK_UUID company.company_id\",\n \"role\": \"first_name\",\n \"start_date\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"end_date\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"educations\": {\n \"education_id\": \"PK UUID\",\n \"profile_id\": \"first_name\",\n \"institution_name\": \"first_name\",\n \"degree\": \"first_name\",\n \"location\": \"country+city(\\\"en_US\\\",\\\"en_GB\\\",\\\"fr_FR\\\",\\\"de_DE\\\",\\\"it_IT\\\",\\\"es_ES\\\",\\\"pl_PL\\\",\\\"nl_NL\\\",\\\"pt_PT\\\",\\\"sv_SE\\\",\\\"da_DK\\\",\\\"fi_FI\\\",\\\"no_NO\\\",\\\"cs_CZ\\\",\\\"hu_HU\\\",\\\"en_CA\\\",\\\"sk_SK\\\")\",\n \"start_date\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"end_date\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"company\": {\n \"company_id\": \"PK UUID\",\n \"company_name\": \"first_name\",\n \"location\": \"first_name\",\n \"industry\": \"first_name\",\n \"description\": \"first_name\",\n \"verified\": \"bool\",\n \"created_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"chats\": {\n \"chat_id\": \"PK UUID\",\n \"name\": \"first_name\",\n \"created_by\": \"first_name\",\n \"deleted_by\": \"first_name\",\n \"last_message\": \"first_name\",\n \"tags\": \"first_name\",\n \"created_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"IntermediaryTable: user_chats\":{\n \"chat_id\": \"FK_UUID chats.chat_id\",\n \"user_id\": \"FK_UUID app_users.user_id\"\n },\n \"user_profiles\": {\n \"profile_id\": \"PK UUID\",\n \"user_id\": \"FK_UUID app_users.user_id\",\n \"resume_path\": \"first_name\",\n \"profile_picture_path\": \"first_name\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n },\n \"user_settings\": {\n \"settings_id\": \"PK UUID\",\n \"user_id\": \"FK_UUID app_users.user_id\",\n \"offers_notification\": \"bool\",\n \"newsletter_notification\": \"bool\",\n \"recruiter_messages\": \"bool\",\n \"push_notification\": \"bool\",\n \"updated_at\": \"timestamp RANGE(2023-01-01 00:00:00,2024-12-24 22:12:00)\"\n }\n },\n \"json_schemas\": [\n {\n \"json1\": {\n \"fields\": [\n {\n \"skills\": {\n \"type\": \"array\",\n \"item_count\": \"RANGE(1, 5)\",\n \"content\": {\n \"type\": \"object\",\n \"fields\": {\n \"name\": {\n \"type\": \"string\",\n \"options\": [\"Python\", \"JavaScript\", \"Java\", \"C++\", \"Go\", \"Ruby\"]\n },\n \"level\": {\n \"type\": \"integer\",\n \"range\": [1, 5]\n }\n }\n }\n }\n }\n ]\n }\n }\n ],\n \"objects_count\": {\n \"app_users\": 200,\n \"skills\": 500,\n \"chat_messages\": 8000,\n \"job\": 250,\n \"experiences\": 100,\n \"educations\": 200,\n \"company\": 20,\n \"chats\": 50,\n \"user_profiles\": 500,\n \"user_settings\": 500,\n \"user_chats\": 10000\n }\n}\n```\n\n### Allowed column keywords:\n\nTODO\n\n#### Disclaimer:\nThe program only checks for uniqueness and integrity withing itself, there can still be error if there's already existing data in the database.\n",
"bugtrack_url": null,
"license": "MIT License",
"summary": "Simple package for creating mockdata for a live database, according to specified relational schema.",
"version": "0.4.5",
"project_urls": {
"Issues": "https://github.com/Experrior/db-mockdata/issues",
"Repository": "https://github.com/Experrior/db-mockdata.git"
},
"split_keywords": [
"mock",
" database",
" faker"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "f5d9c1e7d0789f9b9a7f24d5b7eb38c3a4b4f1ab493397a41be0eb438b2f7b9b",
"md5": "eb4708ba0f4577bb89375c1a5a4cdf88",
"sha256": "ecc227b6072766fb56bca680cf5eeb020a113c29ba78af6725736c00268d83f8"
},
"downloads": -1,
"filename": "db_mockdata-0.4.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "eb4708ba0f4577bb89375c1a5a4cdf88",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 8661,
"upload_time": "2024-12-09T14:30:54",
"upload_time_iso_8601": "2024-12-09T14:30:54.141895Z",
"url": "https://files.pythonhosted.org/packages/f5/d9/c1e7d0789f9b9a7f24d5b7eb38c3a4b4f1ab493397a41be0eb438b2f7b9b/db_mockdata-0.4.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "9b250a6376bb989e0ee8de4ac3051fce9299578e13afe30af8a0c815c2b44e96",
"md5": "e385f2ab18c3efbdbd653f41fb962b57",
"sha256": "561d88fc4652f5480a10ba368c604b8eb8ebe209d626cd30caa2c59cf21455ed"
},
"downloads": -1,
"filename": "db_mockdata-0.4.5.tar.gz",
"has_sig": false,
"md5_digest": "e385f2ab18c3efbdbd653f41fb962b57",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 10003,
"upload_time": "2024-12-09T14:30:56",
"upload_time_iso_8601": "2024-12-09T14:30:56.466953Z",
"url": "https://files.pythonhosted.org/packages/9b/25/0a6376bb989e0ee8de4ac3051fce9299578e13afe30af8a0c815c2b44e96/db_mockdata-0.4.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-09 14:30:56",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "Experrior",
"github_project": "db-mockdata",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "argparse",
"specs": [
[
">=",
"1.4.0"
]
]
},
{
"name": "networkx",
"specs": [
[
"==",
"3.3"
]
]
},
{
"name": "requests",
"specs": [
[
">=",
"2.31.0"
]
]
},
{
"name": "faker",
"specs": [
[
">=",
"25.2.0"
]
]
},
{
"name": "tqdm",
"specs": [
[
">=",
"4.66.4"
]
]
},
{
"name": "sqlalchemy",
"specs": [
[
">=",
"2.0.30"
]
]
},
{
"name": "psycopg2-binary",
"specs": [
[
">=",
"2.9.9"
]
]
}
],
"lcname": "db-mockdata"
}