mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
[WEB-983] chore: dummy data script (#4173)
* chore: dummy data script * fix: lint issues * chore: removed print statment
This commit is contained in:
parent
cd395fa3d2
commit
b90ca97461
@ -1,9 +1,8 @@
|
|||||||
# Django imports
|
# Django imports
|
||||||
from django.db import IntegrityError
|
from django.db import IntegrityError
|
||||||
from django.db.models import Q
|
|
||||||
from rest_framework import status
|
|
||||||
|
|
||||||
# Third party imports
|
# Third party imports
|
||||||
|
from rest_framework import status
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
|
|
||||||
from plane.api.serializers import StateSerializer
|
from plane.api.serializers import StateSerializer
|
||||||
|
@ -3,7 +3,7 @@ import json
|
|||||||
|
|
||||||
# Django import
|
# Django import
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.db.models import Q, Count, OuterRef, Func, F, Prefetch, Exists
|
from django.db.models import Q, Count, OuterRef, Func, F, Prefetch
|
||||||
from django.core.serializers.json import DjangoJSONEncoder
|
from django.core.serializers.json import DjangoJSONEncoder
|
||||||
from django.contrib.postgres.aggregates import ArrayAgg
|
from django.contrib.postgres.aggregates import ArrayAgg
|
||||||
from django.contrib.postgres.fields import ArrayField
|
from django.contrib.postgres.fields import ArrayField
|
||||||
@ -22,7 +22,6 @@ from plane.db.models import (
|
|||||||
InboxIssue,
|
InboxIssue,
|
||||||
Issue,
|
Issue,
|
||||||
State,
|
State,
|
||||||
Workspace,
|
|
||||||
IssueLink,
|
IssueLink,
|
||||||
IssueAttachment,
|
IssueAttachment,
|
||||||
ProjectMember,
|
ProjectMember,
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
# Python imports
|
# Python imports
|
||||||
from itertools import groupby
|
from itertools import groupby
|
||||||
|
|
||||||
# Django imports
|
|
||||||
from django.db.models import Q
|
|
||||||
|
|
||||||
# Third party imports
|
# Third party imports
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
|
578
apiserver/plane/bgtasks/dummy_data_task.py
Normal file
578
apiserver/plane/bgtasks/dummy_data_task.py
Normal file
@ -0,0 +1,578 @@
|
|||||||
|
# Python imports
|
||||||
|
import random
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
# Django imports
|
||||||
|
from django.db.models import Max
|
||||||
|
|
||||||
|
# Third party imports
|
||||||
|
from celery import shared_task
|
||||||
|
from faker import Faker
|
||||||
|
|
||||||
|
# Module imports
|
||||||
|
from plane.db.models import (
|
||||||
|
Workspace,
|
||||||
|
WorkspaceMember,
|
||||||
|
User,
|
||||||
|
Project,
|
||||||
|
ProjectMember,
|
||||||
|
State,
|
||||||
|
Label,
|
||||||
|
Cycle,
|
||||||
|
Module,
|
||||||
|
Issue,
|
||||||
|
IssueSequence,
|
||||||
|
IssueAssignee,
|
||||||
|
IssueLabel,
|
||||||
|
IssueActivity,
|
||||||
|
CycleIssue,
|
||||||
|
ModuleIssue,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def create_workspace_members(workspace, members):
|
||||||
|
members = User.objects.filter(email__in=members)
|
||||||
|
|
||||||
|
_ = WorkspaceMember.objects.bulk_create(
|
||||||
|
[
|
||||||
|
WorkspaceMember(
|
||||||
|
workspace=workspace,
|
||||||
|
member=member,
|
||||||
|
role=20,
|
||||||
|
)
|
||||||
|
for member in members
|
||||||
|
],
|
||||||
|
ignore_conflicts=True,
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
def create_project(workspace, user_id):
|
||||||
|
fake = Faker()
|
||||||
|
name = fake.name()
|
||||||
|
project = Project.objects.create(
|
||||||
|
workspace=workspace,
|
||||||
|
name=name,
|
||||||
|
identifier=name[
|
||||||
|
: random.randint(2, 12 if len(name) - 1 >= 12 else len(name) - 1)
|
||||||
|
].upper(),
|
||||||
|
created_by_id=user_id,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Add current member as project member
|
||||||
|
_ = ProjectMember.objects.create(
|
||||||
|
project=project,
|
||||||
|
member_id=user_id,
|
||||||
|
role=20,
|
||||||
|
)
|
||||||
|
|
||||||
|
return project
|
||||||
|
|
||||||
|
|
||||||
|
def create_project_members(workspace, project, members):
|
||||||
|
members = User.objects.filter(email__in=members)
|
||||||
|
|
||||||
|
_ = ProjectMember.objects.bulk_create(
|
||||||
|
[
|
||||||
|
ProjectMember(
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
member=member,
|
||||||
|
role=20,
|
||||||
|
sort_order=random.randint(0, 65535),
|
||||||
|
)
|
||||||
|
for member in members
|
||||||
|
],
|
||||||
|
ignore_conflicts=True,
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
def create_states(workspace, project, user_id):
|
||||||
|
states = [
|
||||||
|
{
|
||||||
|
"name": "Backlog",
|
||||||
|
"color": "#A3A3A3",
|
||||||
|
"sequence": 15000,
|
||||||
|
"group": "backlog",
|
||||||
|
"default": True,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Todo",
|
||||||
|
"color": "#3A3A3A",
|
||||||
|
"sequence": 25000,
|
||||||
|
"group": "unstarted",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "In Progress",
|
||||||
|
"color": "#F59E0B",
|
||||||
|
"sequence": 35000,
|
||||||
|
"group": "started",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Done",
|
||||||
|
"color": "#16A34A",
|
||||||
|
"sequence": 45000,
|
||||||
|
"group": "completed",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Cancelled",
|
||||||
|
"color": "#EF4444",
|
||||||
|
"sequence": 55000,
|
||||||
|
"group": "cancelled",
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
states = State.objects.bulk_create(
|
||||||
|
[
|
||||||
|
State(
|
||||||
|
name=state["name"],
|
||||||
|
color=state["color"],
|
||||||
|
project=project,
|
||||||
|
sequence=state["sequence"],
|
||||||
|
workspace=workspace,
|
||||||
|
group=state["group"],
|
||||||
|
default=state.get("default", False),
|
||||||
|
created_by_id=user_id,
|
||||||
|
)
|
||||||
|
for state in states
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
return states
|
||||||
|
|
||||||
|
|
||||||
|
def create_labels(workspace, project, user_id):
|
||||||
|
fake = Faker()
|
||||||
|
Faker.seed(0)
|
||||||
|
|
||||||
|
return Label.objects.bulk_create(
|
||||||
|
[
|
||||||
|
Label(
|
||||||
|
name=fake.color_name(),
|
||||||
|
color=fake.hex_color(),
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
created_by_id=user_id,
|
||||||
|
sort_order=random.randint(0, 65535),
|
||||||
|
)
|
||||||
|
for _ in range(0, 50)
|
||||||
|
],
|
||||||
|
ignore_conflicts=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def create_cycles(workspace, project, user_id, cycle_count):
|
||||||
|
fake = Faker()
|
||||||
|
Faker.seed(0)
|
||||||
|
|
||||||
|
cycles = []
|
||||||
|
used_date_ranges = set() # Track used date ranges
|
||||||
|
|
||||||
|
while len(cycles) <= cycle_count:
|
||||||
|
# Generate a start date, allowing for None
|
||||||
|
start_date_option = [None, fake.date_this_year()]
|
||||||
|
start_date = start_date_option[random.randint(0, 1)]
|
||||||
|
|
||||||
|
# Initialize end_date based on start_date
|
||||||
|
end_date = (
|
||||||
|
None
|
||||||
|
if start_date is None
|
||||||
|
else fake.date_between_dates(
|
||||||
|
date_start=start_date,
|
||||||
|
date_end=datetime.now().date().replace(month=12, day=31),
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Ensure end_date is strictly after start_date if start_date is not None
|
||||||
|
while start_date is not None and (
|
||||||
|
end_date <= start_date
|
||||||
|
or (start_date, end_date) in used_date_ranges
|
||||||
|
):
|
||||||
|
end_date = fake.date_this_year()
|
||||||
|
|
||||||
|
# Add the unique date range to the set
|
||||||
|
(
|
||||||
|
used_date_ranges.add((start_date, end_date))
|
||||||
|
if (end_date is not None and start_date is not None)
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
|
# Append the cycle with unique date range
|
||||||
|
cycles.append(
|
||||||
|
Cycle(
|
||||||
|
name=fake.name(),
|
||||||
|
owned_by_id=user_id,
|
||||||
|
sort_order=random.randint(0, 65535),
|
||||||
|
start_date=start_date,
|
||||||
|
end_date=end_date,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
return Cycle.objects.bulk_create(cycles, ignore_conflicts=True)
|
||||||
|
|
||||||
|
|
||||||
|
def create_modules(workspace, project, user_id, module_count):
|
||||||
|
fake = Faker()
|
||||||
|
Faker.seed(0)
|
||||||
|
|
||||||
|
modules = []
|
||||||
|
for _ in range(0, module_count):
|
||||||
|
start_date = [None, fake.date_this_year()][random.randint(0, 1)]
|
||||||
|
end_date = (
|
||||||
|
None
|
||||||
|
if start_date is None
|
||||||
|
else fake.date_between_dates(
|
||||||
|
date_start=start_date,
|
||||||
|
date_end=datetime.now().date().replace(month=12, day=31),
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
modules.append(
|
||||||
|
Module(
|
||||||
|
name=fake.name(),
|
||||||
|
sort_order=random.randint(0, 65535),
|
||||||
|
start_date=start_date,
|
||||||
|
target_date=end_date,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
return Module.objects.bulk_create(modules, ignore_conflicts=True)
|
||||||
|
|
||||||
|
|
||||||
|
def create_issues(workspace, project, user_id, issue_count):
|
||||||
|
fake = Faker()
|
||||||
|
Faker.seed(0)
|
||||||
|
|
||||||
|
states = State.objects.values_list("id", flat=True)
|
||||||
|
creators = ProjectMember.objects.values_list("member_id", flat=True)
|
||||||
|
|
||||||
|
issues = []
|
||||||
|
|
||||||
|
# Get the maximum sequence_id
|
||||||
|
last_id = IssueSequence.objects.filter(
|
||||||
|
project=project,
|
||||||
|
).aggregate(
|
||||||
|
largest=Max("sequence")
|
||||||
|
)["largest"]
|
||||||
|
|
||||||
|
last_id = 1 if last_id is None else last_id + 1
|
||||||
|
|
||||||
|
# Get the maximum sort order
|
||||||
|
largest_sort_order = Issue.objects.filter(
|
||||||
|
project=project,
|
||||||
|
state_id=states[random.randint(0, len(states) - 1)],
|
||||||
|
).aggregate(largest=Max("sort_order"))["largest"]
|
||||||
|
|
||||||
|
largest_sort_order = (
|
||||||
|
65535 if largest_sort_order is None else largest_sort_order + 10000
|
||||||
|
)
|
||||||
|
|
||||||
|
for _ in range(0, issue_count):
|
||||||
|
start_date = [None, fake.date_this_year()][random.randint(0, 1)]
|
||||||
|
end_date = (
|
||||||
|
None
|
||||||
|
if start_date is None
|
||||||
|
else fake.date_between_dates(
|
||||||
|
date_start=start_date,
|
||||||
|
date_end=datetime.now().date().replace(month=12, day=31),
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
sentence = fake.sentence()
|
||||||
|
issues.append(
|
||||||
|
Issue(
|
||||||
|
state_id=states[random.randint(0, len(states) - 1)],
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
name=sentence[:254],
|
||||||
|
description_html=f"<p>{sentence}</p>",
|
||||||
|
description_stripped=sentence,
|
||||||
|
sequence_id=last_id,
|
||||||
|
sort_order=largest_sort_order,
|
||||||
|
start_date=start_date,
|
||||||
|
target_date=end_date,
|
||||||
|
priority=["urgent", "high", "medium", "low", "none"][
|
||||||
|
random.randint(0, 4)
|
||||||
|
],
|
||||||
|
created_by_id=creators[random.randint(0, len(creators) - 1)],
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
largest_sort_order = largest_sort_order + random.randint(0, 1000)
|
||||||
|
last_id = last_id + 1
|
||||||
|
|
||||||
|
issues = Issue.objects.bulk_create(
|
||||||
|
issues, ignore_conflicts=True, batch_size=1000
|
||||||
|
)
|
||||||
|
# Sequences
|
||||||
|
_ = IssueSequence.objects.bulk_create(
|
||||||
|
[
|
||||||
|
IssueSequence(
|
||||||
|
issue=issue,
|
||||||
|
sequence=issue.sequence_id,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
for issue in issues
|
||||||
|
],
|
||||||
|
batch_size=100,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Track the issue activities
|
||||||
|
IssueActivity.objects.bulk_create(
|
||||||
|
[
|
||||||
|
IssueActivity(
|
||||||
|
issue=issue,
|
||||||
|
actor_id=user_id,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
comment="created the issue",
|
||||||
|
verb="created",
|
||||||
|
created_by_id=user_id,
|
||||||
|
)
|
||||||
|
for issue in issues
|
||||||
|
],
|
||||||
|
batch_size=100,
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
def create_issue_parent(workspace, project, user_id, issue_count):
|
||||||
|
|
||||||
|
parent_count = issue_count / 4
|
||||||
|
|
||||||
|
parent_issues = Issue.objects.filter(project=project).values_list(
|
||||||
|
"id", flat=True
|
||||||
|
)[: int(parent_count)]
|
||||||
|
sub_issues = Issue.objects.filter(project=project).exclude(
|
||||||
|
pk__in=parent_issues
|
||||||
|
)[: int(issue_count / 2)]
|
||||||
|
|
||||||
|
bulk_sub_issues = []
|
||||||
|
for sub_issue in sub_issues:
|
||||||
|
sub_issue.parent_id = parent_issues[
|
||||||
|
random.randint(0, int(parent_count - 1))
|
||||||
|
]
|
||||||
|
|
||||||
|
Issue.objects.bulk_update(bulk_sub_issues, ["parent"], batch_size=1000)
|
||||||
|
|
||||||
|
|
||||||
|
def create_issue_assignees(workspace, project, user_id, issue_count):
|
||||||
|
# assignees
|
||||||
|
assignees = ProjectMember.objects.filter(project=project).values_list(
|
||||||
|
"member_id", flat=True
|
||||||
|
)
|
||||||
|
issues = random.sample(
|
||||||
|
list(
|
||||||
|
Issue.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
),
|
||||||
|
int(issue_count / 2),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Bulk issue
|
||||||
|
bulk_issue_assignees = []
|
||||||
|
for issue in issues:
|
||||||
|
for assignee in random.sample(
|
||||||
|
list(assignees), random.randint(0, len(assignees) - 1)
|
||||||
|
):
|
||||||
|
bulk_issue_assignees.append(
|
||||||
|
IssueAssignee(
|
||||||
|
issue_id=issue,
|
||||||
|
assignee_id=assignee,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Issue assignees
|
||||||
|
IssueAssignee.objects.bulk_create(
|
||||||
|
bulk_issue_assignees, batch_size=1000, ignore_conflicts=True
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def create_issue_labels(workspace, project, user_id, issue_count):
|
||||||
|
# assignees
|
||||||
|
labels = Label.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
issues = random.sample(
|
||||||
|
list(
|
||||||
|
Issue.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
),
|
||||||
|
int(issue_count / 2),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Bulk issue
|
||||||
|
bulk_issue_labels = []
|
||||||
|
for issue in issues:
|
||||||
|
for label in random.sample(
|
||||||
|
list(labels), random.randint(0, len(labels) - 1)
|
||||||
|
):
|
||||||
|
bulk_issue_labels.append(
|
||||||
|
IssueLabel(
|
||||||
|
issue_id=issue,
|
||||||
|
label_id=label,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Issue assignees
|
||||||
|
IssueLabel.objects.bulk_create(
|
||||||
|
bulk_issue_labels, batch_size=1000, ignore_conflicts=True
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def create_cycle_issues(workspace, project, user_id, issue_count):
|
||||||
|
# assignees
|
||||||
|
cycles = Cycle.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
issues = random.sample(
|
||||||
|
list(
|
||||||
|
Issue.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
),
|
||||||
|
int(issue_count / 2),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Bulk issue
|
||||||
|
bulk_cycle_issues = []
|
||||||
|
for issue in issues:
|
||||||
|
cycle = cycles[random.randint(0, len(cycles) - 1)]
|
||||||
|
bulk_cycle_issues.append(
|
||||||
|
CycleIssue(
|
||||||
|
cycle_id=cycle,
|
||||||
|
issue_id=issue,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Issue assignees
|
||||||
|
CycleIssue.objects.bulk_create(
|
||||||
|
bulk_cycle_issues, batch_size=1000, ignore_conflicts=True
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def create_module_issues(workspace, project, user_id, issue_count):
|
||||||
|
# assignees
|
||||||
|
modules = Module.objects.filter(project=project).values_list(
|
||||||
|
"id", flat=True
|
||||||
|
)
|
||||||
|
issues = random.sample(
|
||||||
|
list(
|
||||||
|
Issue.objects.filter(project=project).values_list("id", flat=True)
|
||||||
|
),
|
||||||
|
int(issue_count / 2),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Bulk issue
|
||||||
|
bulk_module_issues = []
|
||||||
|
for issue in issues:
|
||||||
|
module = modules[random.randint(0, len(modules) - 1)]
|
||||||
|
bulk_module_issues.append(
|
||||||
|
ModuleIssue(
|
||||||
|
module_id=module,
|
||||||
|
issue_id=issue,
|
||||||
|
project=project,
|
||||||
|
workspace=workspace,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
# Issue assignees
|
||||||
|
ModuleIssue.objects.bulk_create(
|
||||||
|
bulk_module_issues, batch_size=1000, ignore_conflicts=True
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@shared_task
|
||||||
|
def create_dummy_data(
|
||||||
|
slug, email, members, issue_count, cycle_count, module_count
|
||||||
|
):
|
||||||
|
workspace = Workspace.objects.get(slug=slug)
|
||||||
|
|
||||||
|
user = User.objects.get(email=email)
|
||||||
|
user_id = user.id
|
||||||
|
|
||||||
|
# create workspace members
|
||||||
|
create_workspace_members(workspace=workspace, members=members)
|
||||||
|
|
||||||
|
# Create a project
|
||||||
|
project = create_project(workspace=workspace, user_id=user_id)
|
||||||
|
|
||||||
|
# create project members
|
||||||
|
create_project_members(
|
||||||
|
workspace=workspace, project=project, members=members
|
||||||
|
)
|
||||||
|
|
||||||
|
# Create states
|
||||||
|
create_states(workspace=workspace, project=project, user_id=user_id)
|
||||||
|
|
||||||
|
# Create labels
|
||||||
|
create_labels(workspace=workspace, project=project, user_id=user_id)
|
||||||
|
|
||||||
|
# create cycles
|
||||||
|
create_cycles(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
cycle_count=cycle_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create modules
|
||||||
|
create_modules(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
module_count=module_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create issues
|
||||||
|
create_issues(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create issue parent
|
||||||
|
create_issue_parent(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create issue assignees
|
||||||
|
create_issue_assignees(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create issue labels
|
||||||
|
create_issue_labels(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create cycle issues
|
||||||
|
create_cycle_issues(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
# create module issues
|
||||||
|
create_module_issues(
|
||||||
|
workspace=workspace,
|
||||||
|
project=project,
|
||||||
|
user_id=user_id,
|
||||||
|
issue_count=issue_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
return
|
79
apiserver/plane/db/management/commands/create_dummy_data.py
Normal file
79
apiserver/plane/db/management/commands/create_dummy_data.py
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
# Django imports
|
||||||
|
from typing import Any
|
||||||
|
from django.core.management.base import BaseCommand, CommandError
|
||||||
|
|
||||||
|
# Module imports
|
||||||
|
from plane.db.models import User, Workspace, WorkspaceMember
|
||||||
|
|
||||||
|
|
||||||
|
class Command(BaseCommand):
|
||||||
|
help = "Create dump issues, cycles etc. for a project in a given workspace"
|
||||||
|
|
||||||
|
def handle(self, *args: Any, **options: Any) -> str | None:
|
||||||
|
|
||||||
|
try:
|
||||||
|
workspace_name = input("Workspace Name: ")
|
||||||
|
workspace_slug = input("Workspace slug: ")
|
||||||
|
|
||||||
|
if workspace_slug == "":
|
||||||
|
raise CommandError("Workspace slug is required")
|
||||||
|
|
||||||
|
if Workspace.objects.filter(slug=workspace_slug).exists():
|
||||||
|
raise CommandError("Workspace already exists")
|
||||||
|
|
||||||
|
creator = input("Your email: ")
|
||||||
|
|
||||||
|
if (
|
||||||
|
creator == ""
|
||||||
|
or not User.objects.filter(email=creator).exists()
|
||||||
|
):
|
||||||
|
raise CommandError(
|
||||||
|
"User email is required and should have signed in plane"
|
||||||
|
)
|
||||||
|
|
||||||
|
user = User.objects.get(email=creator)
|
||||||
|
|
||||||
|
members = input("Enter Member emails (comma separated): ")
|
||||||
|
members = members.split(",") if members != "" else []
|
||||||
|
|
||||||
|
issue_count = int(
|
||||||
|
input("Number of issues to be created: ")
|
||||||
|
)
|
||||||
|
cycle_count = int(
|
||||||
|
input("Number of cycles to be created: ")
|
||||||
|
)
|
||||||
|
module_count = int(
|
||||||
|
input("Number of modules to be created: ")
|
||||||
|
)
|
||||||
|
|
||||||
|
# Create workspace
|
||||||
|
workspace = Workspace.objects.create(
|
||||||
|
slug=workspace_slug,
|
||||||
|
name=workspace_name,
|
||||||
|
owner=user,
|
||||||
|
)
|
||||||
|
# Create workspace member
|
||||||
|
WorkspaceMember.objects.create(
|
||||||
|
workspace=workspace, role=20, member=user
|
||||||
|
)
|
||||||
|
|
||||||
|
from plane.bgtasks.dummy_data_task import create_dummy_data
|
||||||
|
|
||||||
|
create_dummy_data.delay(
|
||||||
|
slug=workspace_slug,
|
||||||
|
email=creator,
|
||||||
|
members=members,
|
||||||
|
issue_count=issue_count,
|
||||||
|
cycle_count=cycle_count,
|
||||||
|
module_count=module_count,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.stdout.write(
|
||||||
|
self.style.SUCCESS("Data is pushed to the queue")
|
||||||
|
)
|
||||||
|
return
|
||||||
|
except Exception as e:
|
||||||
|
self.stdout.write(
|
||||||
|
self.style.ERROR(f"Command errored out {str(e)}")
|
||||||
|
)
|
||||||
|
return
|
@ -288,10 +288,13 @@ else:
|
|||||||
CELERY_BROKER_URL = REDIS_URL
|
CELERY_BROKER_URL = REDIS_URL
|
||||||
|
|
||||||
CELERY_IMPORTS = (
|
CELERY_IMPORTS = (
|
||||||
|
# scheduled tasks
|
||||||
"plane.bgtasks.issue_automation_task",
|
"plane.bgtasks.issue_automation_task",
|
||||||
"plane.bgtasks.exporter_expired_task",
|
"plane.bgtasks.exporter_expired_task",
|
||||||
"plane.bgtasks.file_asset_task",
|
"plane.bgtasks.file_asset_task",
|
||||||
"plane.bgtasks.email_notification_task",
|
"plane.bgtasks.email_notification_task",
|
||||||
|
# management tasks
|
||||||
|
"plane.bgtasks.dummy_data_task",
|
||||||
)
|
)
|
||||||
|
|
||||||
# Sentry Settings
|
# Sentry Settings
|
||||||
|
Loading…
Reference in New Issue
Block a user