2019-01-20 09:55:44 -05:00
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-20 09:55:44 -05:00
|
|
|
import unittest
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-20 09:55:44 -05:00
|
|
|
import frappe
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-20 09:55:44 -05:00
|
|
|
from erpnext.regional.report.irs_1099.irs_1099 import execute as execute_1099_report
|
|
|
|
|
|
|
|
|
|
|
|
class TestUnitedStates(unittest.TestCase):
|
|
|
|
def test_irs_1099_custom_field(self):
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-03-04 13:22:51 +05:30
|
|
|
if not frappe.db.exists("Supplier", "_US 1099 Test Supplier"):
|
|
|
|
doc = frappe.new_doc("Supplier")
|
|
|
|
doc.supplier_name = "_US 1099 Test Supplier"
|
|
|
|
doc.supplier_group = "Services"
|
|
|
|
doc.supplier_type = "Company"
|
|
|
|
doc.country = "United States"
|
|
|
|
doc.tax_id = "04-1234567"
|
|
|
|
doc.irs_1099 = 1
|
|
|
|
doc.save()
|
|
|
|
frappe.db.commit()
|
|
|
|
supplier = frappe.get_doc("Supplier", "_US 1099 Test Supplier")
|
|
|
|
self.assertEqual(supplier.irs_1099, 1)
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-01-20 09:55:44 -05:00
|
|
|
def test_irs_1099_report(self):
|
|
|
|
make_payment_entry_to_irs_1099_supplier()
|
2020-08-28 12:56:37 +05:30
|
|
|
filters = frappe._dict({"fiscal_year": "_Test Fiscal Year 2016", "company": "_Test Company 1"})
|
2019-01-20 09:55:44 -05:00
|
|
|
columns, data = execute_1099_report(filters)
|
|
|
|
expected_row = {
|
|
|
|
"supplier": "_US 1099 Test Supplier",
|
|
|
|
"supplier_group": "Services",
|
|
|
|
"payments": 100.0,
|
|
|
|
"tax_id": "04-1234567",
|
|
|
|
}
|
2019-03-04 13:22:51 +05:30
|
|
|
self.assertEqual(data[0], expected_row)
|
2019-01-20 09:55:44 -05:00
|
|
|
|
|
|
|
|
|
|
|
def make_payment_entry_to_irs_1099_supplier():
|
2019-03-04 13:25:39 +05:30
|
|
|
|
|
|
|
frappe.db.sql("delete from `tabGL Entry` where party='_US 1099 Test Supplier'")
|
|
|
|
frappe.db.sql("delete from `tabGL Entry` where against='_US 1099 Test Supplier'")
|
|
|
|
frappe.db.sql("delete from `tabPayment Entry` where party='_US 1099 Test Supplier'")
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-01-20 09:55:44 -05:00
|
|
|
pe = frappe.new_doc("Payment Entry")
|
|
|
|
pe.payment_type = "Pay"
|
2020-08-28 12:56:37 +05:30
|
|
|
pe.company = "_Test Company 1"
|
2019-01-20 09:55:44 -05:00
|
|
|
pe.posting_date = "2016-01-10"
|
2020-08-28 13:40:48 +05:30
|
|
|
pe.paid_from = "_Test Bank USD - _TC1"
|
|
|
|
pe.paid_to = "_Test Payable USD - _TC1"
|
2019-01-20 09:55:44 -05:00
|
|
|
pe.paid_amount = 100
|
|
|
|
pe.received_amount = 100
|
|
|
|
pe.reference_no = "For IRS 1099 testing"
|
|
|
|
pe.reference_date = "2016-01-10"
|
|
|
|
pe.party_type = "Supplier"
|
|
|
|
pe.party = "_US 1099 Test Supplier"
|
2019-03-04 13:22:51 +05:30
|
|
|
pe.insert()
|
|
|
|
pe.submit()
|