seitime-frappe/frappe/utils/make_random.py
Suraj Shetty c0c5b2ebdd
style: format all python files using black (#16453)
Co-authored-by: Frappe Bot <developers@frappe.io>
2022-04-12 10:59:25 +05:30

66 lines
1.4 KiB
Python

import random
import frappe
settings = frappe._dict(
prob={
"default": {"make": 0.6, "qty": (1, 5)},
}
)
def add_random_children(doc, fieldname, rows, randomize, unique=None):
nrows = rows
if rows > 1:
nrows = random.randrange(1, rows)
for i in range(nrows):
d = {}
for key, val in randomize.items():
if isinstance(val[0], str):
d[key] = get_random(*val)
else:
d[key] = random.randrange(*val)
if unique:
if not doc.get(fieldname, {unique: d[unique]}):
doc.append(fieldname, d)
else:
doc.append(fieldname, d)
def get_random(doctype, filters=None, doc=False):
condition = []
if filters:
for key, val in filters.items():
condition.append("%s='%s'" % (key, str(val).replace("'", "'")))
if condition:
condition = " where " + " and ".join(condition)
else:
condition = ""
out = frappe.db.multisql(
{
"mariadb": """select name from `tab%s` %s
order by RAND() limit 1 offset 0"""
% (doctype, condition),
"postgres": """select name from `tab%s` %s
order by RANDOM() limit 1 offset 0"""
% (doctype, condition),
}
)
out = out and out[0][0] or None
if doc and out:
return frappe.get_doc(doctype, out)
else:
return out
def can_make(doctype):
return random.random() < settings.prob.get(doctype, settings.prob["default"])["make"]
def how_many(doctype):
return random.randrange(*settings.prob.get(doctype, settings.prob["default"])["qty"])