Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 1 | # Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors |
| 2 | # License: GNU General Public License v3. See license.txt |
| 3 | |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 4 | |
Chillar Anand | 915b343 | 2021-09-02 16:44:59 +0530 | [diff] [blame] | 5 | import json |
| 6 | import random |
| 7 | |
| 8 | import frappe |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 9 | from frappe.desk import query_report |
Chillar Anand | 915b343 | 2021-09-02 16:44:59 +0530 | [diff] [blame] | 10 | from frappe.utils.make_random import get_random, how_many |
| 11 | |
| 12 | import erpnext |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 13 | from erpnext.accounts.party import get_party_account_currency |
Chillar Anand | 915b343 | 2021-09-02 16:44:59 +0530 | [diff] [blame] | 14 | from erpnext.buying.doctype.request_for_quotation.request_for_quotation import ( |
| 15 | make_supplier_quotation_from_rfq, |
| 16 | ) |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 17 | from erpnext.exceptions import InvalidCurrency |
Chillar Anand | 915b343 | 2021-09-02 16:44:59 +0530 | [diff] [blame] | 18 | from erpnext.setup.utils import get_exchange_rate |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 19 | from erpnext.stock.doctype.material_request.material_request import make_request_for_quotation |
Chillar Anand | 915b343 | 2021-09-02 16:44:59 +0530 | [diff] [blame] | 20 | |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 21 | |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 22 | def work(): |
| 23 | frappe.set_user(frappe.db.get_global('demo_purchase_user')) |
| 24 | |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 25 | if random.random() < 0.6: |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 26 | report = "Items To Be Requested" |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 27 | for row in query_report.run(report)["result"][:random.randint(1, 5)]: |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 28 | item_code, qty = row[0], abs(row[-1]) |
| 29 | |
| 30 | mr = make_material_request(item_code, qty) |
| 31 | |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 32 | if random.random() < 0.6: |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 33 | for mr in frappe.get_all('Material Request', |
| 34 | filters={'material_request_type': 'Purchase', 'status': 'Open'}, |
| 35 | limit=random.randint(1,6)): |
| 36 | if not frappe.get_all('Request for Quotation', |
| 37 | filters={'material_request': mr.name}, limit=1): |
| 38 | rfq = make_request_for_quotation(mr.name) |
| 39 | rfq.transaction_date = frappe.flags.current_date |
| 40 | add_suppliers(rfq) |
| 41 | rfq.save() |
| 42 | rfq.submit() |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 43 | |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 44 | # Make suppier quotation from RFQ against each supplier. |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 45 | if random.random() < 0.6: |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 46 | for rfq in frappe.get_all('Request for Quotation', |
| 47 | filters={'status': 'Open'}, limit=random.randint(1, 6)): |
| 48 | if not frappe.get_all('Supplier Quotation', |
| 49 | filters={'request_for_quotation': rfq.name}, limit=1): |
| 50 | rfq = frappe.get_doc('Request for Quotation', rfq.name) |
| 51 | |
| 52 | for supplier in rfq.suppliers: |
Marica | c5e139a | 2020-10-13 16:53:10 +0530 | [diff] [blame] | 53 | supplier_quotation = make_supplier_quotation_from_rfq(rfq.name, for_supplier=supplier.supplier) |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 54 | supplier_quotation.save() |
| 55 | supplier_quotation.submit() |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 56 | |
| 57 | # get supplier details |
| 58 | supplier = get_random("Supplier") |
| 59 | |
Zlash65 | fd9c451 | 2018-10-10 14:27:07 +0530 | [diff] [blame] | 60 | company_currency = frappe.get_cached_value('Company', erpnext.get_default_company(), "default_currency") |
| 61 | party_account_currency = get_party_account_currency("Supplier", supplier, erpnext.get_default_company()) |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 62 | if company_currency == party_account_currency: |
| 63 | exchange_rate = 1 |
| 64 | else: |
Shreya | 3f77852 | 2018-05-15 16:59:20 +0530 | [diff] [blame] | 65 | exchange_rate = get_exchange_rate(party_account_currency, company_currency, args="for_buying") |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 66 | |
| 67 | # make supplier quotations |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 68 | if random.random() < 0.5: |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 69 | from erpnext.stock.doctype.material_request.material_request import make_supplier_quotation |
| 70 | |
| 71 | report = "Material Requests for which Supplier Quotations are not created" |
Rushabh Mehta | cca33b2 | 2016-07-08 18:24:46 +0530 | [diff] [blame] | 72 | for row in query_report.run(report)["result"][:random.randint(1, 3)]: |
Aditya Hase | 41d189a | 2019-01-07 14:25:58 +0530 | [diff] [blame] | 73 | if row[0] != "Total": |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 74 | sq = frappe.get_doc(make_supplier_quotation(row[0])) |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 75 | sq.transaction_date = frappe.flags.current_date |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 76 | sq.supplier = supplier |
| 77 | sq.currency = party_account_currency or company_currency |
| 78 | sq.conversion_rate = exchange_rate |
| 79 | sq.insert() |
| 80 | sq.submit() |
| 81 | frappe.db.commit() |
| 82 | |
| 83 | # make purchase orders |
Rushabh Mehta | 99c814b | 2016-12-19 11:51:02 +0530 | [diff] [blame] | 84 | if random.random() < 0.5: |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 85 | from erpnext.stock.doctype.material_request.material_request import make_purchase_order |
| 86 | report = "Requested Items To Be Ordered" |
| 87 | for row in query_report.run(report)["result"][:how_many("Purchase Order")]: |
Aditya Hase | 41d189a | 2019-01-07 14:25:58 +0530 | [diff] [blame] | 88 | if row[0] != "Total": |
Zlash65 | 8b1133c | 2018-10-01 12:55:07 +0530 | [diff] [blame] | 89 | try: |
| 90 | po = frappe.get_doc(make_purchase_order(row[0])) |
| 91 | po.supplier = supplier |
| 92 | po.currency = party_account_currency or company_currency |
| 93 | po.conversion_rate = exchange_rate |
| 94 | po.transaction_date = frappe.flags.current_date |
| 95 | po.insert() |
| 96 | po.submit() |
| 97 | except Exception: |
| 98 | pass |
| 99 | else: |
| 100 | frappe.db.commit() |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 101 | |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 102 | if random.random() < 0.5: |
Rushabh Mehta | ea0ff23 | 2016-07-07 14:02:26 +0530 | [diff] [blame] | 103 | make_subcontract() |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 104 | |
| 105 | def make_material_request(item_code, qty): |
| 106 | mr = frappe.new_doc("Material Request") |
| 107 | |
Rushabh Mehta | cca33b2 | 2016-07-08 18:24:46 +0530 | [diff] [blame] | 108 | variant_of = frappe.db.get_value('Item', item_code, 'variant_of') or item_code |
| 109 | |
| 110 | if frappe.db.get_value('BOM', {'item': variant_of, 'is_default': 1, 'is_active': 1}): |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 111 | mr.material_request_type = 'Manufacture' |
| 112 | else: |
| 113 | mr.material_request_type = "Purchase" |
| 114 | |
| 115 | mr.transaction_date = frappe.flags.current_date |
Sunny | 0d91d3f | 2017-09-26 10:56:31 +0800 | [diff] [blame] | 116 | mr.schedule_date = frappe.utils.add_days(mr.transaction_date, 7) |
Rushabh Mehta | 99c814b | 2016-12-19 11:51:02 +0530 | [diff] [blame] | 117 | |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 118 | mr.append("items", { |
| 119 | "doctype": "Material Request Item", |
| 120 | "schedule_date": frappe.utils.add_days(mr.transaction_date, 7), |
| 121 | "item_code": item_code, |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 122 | "qty": qty |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 123 | }) |
| 124 | mr.insert() |
| 125 | mr.submit() |
| 126 | return mr |
| 127 | |
| 128 | def add_suppliers(rfq): |
Achilles Rasquinha | 96698c9 | 2018-02-28 16:12:51 +0530 | [diff] [blame] | 129 | for i in range(2): |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 130 | supplier = get_random("Supplier") |
| 131 | if supplier not in [d.supplier for d in rfq.get('suppliers')]: |
| 132 | rfq.append("suppliers", { "supplier": supplier }) |
| 133 | |
| 134 | def make_subcontract(): |
Zlash65 | 796bffb | 2018-09-26 12:27:09 +0530 | [diff] [blame] | 135 | from erpnext.buying.doctype.purchase_order.purchase_order import make_rm_stock_entry |
Rushabh Mehta | 92d1b8c | 2016-07-14 15:46:12 +0530 | [diff] [blame] | 136 | item_code = get_random("Item", {"is_sub_contracted_item": 1}) |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 137 | if item_code: |
| 138 | # make sub-contract PO |
| 139 | po = frappe.new_doc("Purchase Order") |
| 140 | po.is_subcontracted = "Yes" |
| 141 | po.supplier = get_random("Supplier") |
Zlash65 | dcf7401 | 2018-09-27 18:51:18 +0530 | [diff] [blame] | 142 | po.transaction_date = frappe.flags.current_date # added |
Sunny | 3a22fd1 | 2017-09-26 12:21:41 +0800 | [diff] [blame] | 143 | po.schedule_date = frappe.utils.add_days(frappe.flags.current_date, 7) |
Rushabh Mehta | 92d1b8c | 2016-07-14 15:46:12 +0530 | [diff] [blame] | 144 | |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 145 | item_code = get_random("Item", {"is_sub_contracted_item": 1}) |
Rushabh Mehta | 99c814b | 2016-12-19 11:51:02 +0530 | [diff] [blame] | 146 | |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 147 | po.append("items", { |
| 148 | "item_code": item_code, |
| 149 | "schedule_date": frappe.utils.add_days(frappe.flags.current_date, 7), |
| 150 | "qty": random.randint(10, 30) |
| 151 | }) |
| 152 | po.set_missing_values() |
| 153 | try: |
| 154 | po.insert() |
| 155 | except InvalidCurrency: |
| 156 | return |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 157 | |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 158 | po.submit() |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 159 | |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 160 | # make material request for |
| 161 | make_material_request(po.items[0].item_code, po.items[0].qty) |
Rushabh Mehta | dc8067e | 2016-06-29 18:38:32 +0530 | [diff] [blame] | 162 | |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 163 | # transfer material for sub-contract |
Zlash65 | 523f77e | 2018-09-28 13:59:09 +0530 | [diff] [blame] | 164 | rm_items = get_rm_item(po.items[0], po.supplied_items[0]) |
| 165 | stock_entry = frappe.get_doc(make_rm_stock_entry(po.name, json.dumps([rm_items]))) |
Neil Trini Lasrado | 0672459 | 2016-08-22 12:57:09 +0530 | [diff] [blame] | 166 | stock_entry.from_warehouse = "Stores - WPL" |
| 167 | stock_entry.to_warehouse = "Supplier - WPL" |
| 168 | stock_entry.insert() |
Zlash65 | 523f77e | 2018-09-28 13:59:09 +0530 | [diff] [blame] | 169 | |
| 170 | def get_rm_item(items, supplied_items): |
| 171 | return { |
| 172 | "item_code": items.get("item_code"), |
| 173 | "rm_item_code": supplied_items.get("rm_item_code"), |
| 174 | "item_name": supplied_items.get("rm_item_code"), |
Zlash65 | d080a17 | 2018-10-01 10:49:06 +0530 | [diff] [blame] | 175 | "qty": supplied_items.get("required_qty") + random.randint(3,10), |
Zlash65 | 523f77e | 2018-09-28 13:59:09 +0530 | [diff] [blame] | 176 | "amount": supplied_items.get("amount"), |
| 177 | "warehouse": supplied_items.get("reserve_warehouse"), |
| 178 | "rate": supplied_items.get("rate"), |
| 179 | "stock_uom": supplied_items.get("stock_uom") |
| 180 | } |