def test_return(): random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) tax = api.post_tax(doc) assert tax.is_success assert tax.total_tax > 0 # and return invoice doc = Document.new_return_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=-10.00) doc.add_line(line) tax_date = datetime.date.today() - datetime.timedelta(days=5) doc.add_override(TaxOverrideType=TaxOverride.OVERRIDE_DATE, TaxDate=tax_date, Reason="Tax Date change",) tax = api.post_tax(doc) assert tax.is_success assert float(tax.total_tax) < 0
def test_todict_if_business_identification_no_is_set(self): doc = Document(DocType='SalesInvoice', CustomerCode='123456789', DocCode='12345', CompanyCode='COMPANY_CODE') doc.BusinessIdentificationNo = 'GB999 999' doc.add_from_address(Line1='000 Main Street', City='New York', Region='NY', Country='US', PostalCode='10000') doc.add_to_address(Line1='001 Main Street', Line2='', City='New York', Region='NY', Country='US', PostalCode='10000') doc.add_line(LineNo='1', ItemCode='123456789', Qty=1, Amount=str(100)) dictionary = doc.todict() self.assertIn("BusinessIdentificationNo", dictionary.keys()) self.assertEqual(dictionary.get("BusinessIdentificationNo"), "GB999 999")
def test_timeout(): api = get_api(timeout=0.00001) lat = 47.627935 lng = -122.51702 line = Line(Amount=10.00) doc = Document() doc.add_line(line) try: api.get_tax(lat, lng, doc) except AvalaraServerNotReachableException: assert True else: assert False
def test_override_failure(): try: from pyavatax.models import AvaTaxRecord except ImportError: # no django pytest.mark.xfail('This can only be run inside a django environment') return random_doc_code = uuid.uuid4( ).hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) doc.DocType = 'FooBar' # forcing error tax_date = datetime.date.today() - datetime.timedelta(days=5) doc.add_override( TaxOverrideType=TaxOverride.OVERRIDE_DATE, TaxDate=tax_date, Reason="Tax Date change", ) tax = api.post_tax(doc) assert tax.is_success == False assert 1 == AvaTaxRecord.failures.filter(doc_code=random_doc_code).count() assert 0 == AvaTaxRecord.successes.filter(doc_code=random_doc_code).count()
def test_posttax_commit_cancel(): random_doc_code = uuid.uuid4( ).hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_order(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00, Qty=2) doc.add_line(line) tax = api.post_tax(doc, commit=True) assert doc.Commit assert doc.DocType == Document.DOC_TYPE_SALE_INVOICE # make sure the doc type changes with commit assert tax.is_success is True assert tax.TotalTax > 0 assert tax.total_tax == tax.TotalTax assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 1 assert len(tax.TaxLines[0].TaxDetails) > 0 cancel = api.cancel_tax(doc) assert cancel.is_success is True assert cancel.CancelTaxResult
def test_posttax_commit_exempt(): random_doc_code = uuid.uuid4( ).hex # you can't post/cancel the same doc code over and over api = get_api() # G = resale, which means exempt from tax doc = Document.new_sales_order(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**', CustomerUsageType='G') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00, Qty=2) doc.add_line(line) doc.add_line(TaxCode='FR', Amount='12.00') tax = api.post_tax(doc, commit=True) assert doc.Commit assert doc.DocType == Document.DOC_TYPE_SALE_INVOICE # make sure the doc type changes with commit assert tax.is_success is True assert tax.TotalTax == '0' assert len(tax.TaxAddresses) == 4 assert len(tax.TaxLines) == 2
def test_discount(): api = get_api() # dont pass a doccode amount = 10.00 doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**', Discount=amount) doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_line(Amount=amount, Discounted=True) tax_date = datetime.date.today() - datetime.timedelta(days=5) doc.add_override( TaxOverrideType=TaxOverride.OVERRIDE_DATE, TaxDate=tax_date, Reason="Tax Date change", ) tax = api.post_tax(doc) assert tax.is_success is True assert float(tax.TotalTax) == 0 assert float(tax.TotalAmount) == amount assert float(tax.TotalDiscount) == amount
def test_posttax(): with LogCapture('pyavatax.api') as l: api = get_api() # dont pass a doccode doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) # make sure i don't have a doccode try: doc.DocCode except AttributeError: assert True else: assert False tax = api.post_tax(doc) assert tax.is_success is True assert tax.TotalTax > 0 assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 1 assert len(tax.TaxLines[0].TaxDetails) > 0 assert tax.DocCode assert doc.DocCode # make sure the doccode moved over l.check( ('pyavatax.api', 'DEBUG', 'None setting default from address code'), ('pyavatax.api', 'DEBUG', 'None setting default to address code'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 1'), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'INFO', '"POST", %s, %s%s' % (None, api.url, '/'.join([API.VERSION, 'tax', 'get']))), ('pyavatax.api', 'DEBUG', 'AvaTax assigned %s as DocCode' % doc.DocCode) )
def get_tax(self, lat, lng, doc, sale_amount=None): """Performs a HTTP GET to tax/get/""" if doc is not None: if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document) and sale_amount == None: raise AvalaraTypeException( AvalaraException.CODE_BAD_DOC, 'Please pass a document or a dictionary to create a Document' ) elif sale_amount is None: raise AvalaraException( AvalaraException.CODE_BAD_ARGS, 'Please pass a doc argument, or sale_amount kwarg') try: stem = '/'.join( [self.VERSION, 'tax', '%.6f,%.6f' % (lat, lng), 'get']) except TypeError: raise AvalaraTypeException( AvalaraException.CODE_LATLNG, 'Please pass lat and lng as floats, or Decimal') data = { 'saleamount': sale_amount } if sale_amount else { 'saleamount': doc.total } resp = self._get(stem, data) self.logger.info('"GET" %s%s with: %s' % (self.url, stem, data)) self.recorder.success(doc) return GetTaxResponse(resp)
def test_recorder(): try: from pyavatax.models import AvaTaxRecord except ImportError: # no django pytest.mark.xfail('This can only be run inside a django environment') return random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) setattr(doc, '_testing_ignore_validate', True) # passthrough I put in to allow this test, never actually use this orig_doc_type = doc.DocType doc.DocType = 'DoesntExist' # forcing error tax = api.post_tax(doc) assert tax.is_success == False assert 1 == AvaTaxRecord.failures.filter(doc_code=random_doc_code).count() assert 0 == AvaTaxRecord.successes.filter(doc_code=random_doc_code).count() doc.DocType = orig_doc_type tax = api.post_tax(doc, commit=True) assert tax.is_success == True assert 0 == AvaTaxRecord.failures.filter(doc_code=random_doc_code).count() assert 1 == AvaTaxRecord.successes.filter(doc_code=random_doc_code).count() tax = api.post_tax(doc, commit=True) assert tax.is_success == False assert 1 == AvaTaxRecord.failures.filter(doc_code=random_doc_code).count() assert 1 == AvaTaxRecord.successes.filter(doc_code=random_doc_code).count()
def test_gettax(): api = get_api() # A Lat/Long from Avalara's documentation lat = 47.627935 lng = -122.51702 line = Line(Amount=10.00) doc = Document() doc.add_line(line) tax = api.get_tax(lat, lng, doc) assert tax.is_success is True assert tax.Tax > 0 assert tax.total_tax == tax.Tax tax = api.get_tax(lat, lng, None, sale_amount=10.00) assert tax.is_success is True assert tax.Tax > 0 assert tax.total_tax == tax.Tax
def test_justtozip(): api = get_api() doc = Document.new_sales_order( DocDate=datetime.date.today(), CustomerCode='*****@*****.**') doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="", Line2="", PostalCode="98110") doc.add_line(Amount=10.00) doc.add_line(Amount=10.00) doc.add_line(TaxCode='FR', Amount='10.00') # make sure i don't have a doccode try: doc.DocCode except AttributeError: assert True else: assert False tax = api.post_tax(doc) assert tax.is_success is True assert tax.TotalTax > 0 assert len(tax.TaxAddresses) == 6 assert len(tax.TaxLines) == 3 assert len(tax.TaxLines[0].TaxDetails) > 0 assert tax.DocCode assert doc.DocCode # make sure the doccode moved over
def cancel_tax(self, doc, reason=None, doc_id=None): """Performs a HTTP POST to tax/cancel/""" if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document): raise AvalaraTypeException( AvalaraException.CODE_BAD_DOC, 'Please pass a document or a dictionary to create a Document') if reason and (not reason in Document.CANCEL_CODES): raise AvalaraValidationException( AvalaraException.CODE_BAD_CANCEL, "Please pass a valid cancel code") stem = '/'.join([self.VERSION, 'tax', 'cancel']) data = { 'CompanyCode': doc.CompanyCode, 'DocType': doc.DocType, } if reason: data.update({'CancelCode': reason}) if hasattr(doc, 'DocCode'): data.update({'DocCode': doc.DocCode}) _doc_id = None if hasattr(doc, 'DocId'): _doc_id = doc.DocId if doc_id: _doc_id = doc_id if _doc_id: data.update({'DocId': _doc_id}) resp = self._post(stem, data) self.logger.info('"POST", %s, %s%s with: %s' % (getattr(doc, 'DocCode', None), self.url, stem, data)) self.recorder.success(doc) return CancelTaxResponse(resp)
def post_tax(self, doc, commit=False): """Performs a HTTP POST to tax/get/ If commit=True we will update the document's Commit flag to True, and we will check the document type to make sure it is capable of being Commited. XXXXXOrder is not capable of being commited. We will change it to XXXXXXXInvoice, which is capable of being committed""" if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document): raise AvalaraTypeException(AvalaraException.CODE_BAD_DOC, 'Please pass a document or a dictionary to create a Document') stem = '/'.join([self.VERSION, 'tax', 'get']) doc.update(CompanyCode=self.company_code) if commit: doc.update(Commit=True) self.logger.debug('%s setting Commit=True' % doc.DocCode) # need to change doctype if order, to invoice, otherwise commit does nothing new_doc_type = { Document.DOC_TYPE_SALE_ORDER: Document.DOC_TYPE_SALE_INVOICE, Document.DOC_TYPE_RETURN_ORDER: Document.DOC_TYPE_RETURN_INVOICE, Document.DOC_TYPE_PURCHASE_ORDER: Document.DOC_TYPE_PURCHASE_INVOICE, Document.DOC_TYPE_INVENTORY_ORDER: Document.DOC_TYPE_INVENTORY_INVOICE }.get(doc.DocType, None) if new_doc_type: self.logger.debug('%s updating DocType from %s to %s' % (doc.DocCode, doc.DocType, new_doc_type)) doc.update(DocType=new_doc_type) data = doc.todict() resp = self._post(stem, data) tax_resp = PostTaxResponse(resp) self.logger.info('"POST", %s, %s%s with: %s' % (getattr(doc, 'DocCode', None), self.url, stem, data)) if not hasattr(doc, 'DocCode'): doc.update_doc_code_from_response(tax_resp) self.recorder.success(doc) return tax_resp
def cancel_tax(self, doc, reason=None, doc_id=None): """Performs a HTTP POST to tax/cancel/""" if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document): raise AvalaraTypeException(AvalaraException.CODE_BAD_DOC, 'Please pass a document or a dictionary to create a Document') if reason and (not reason in Document.CANCEL_CODES): raise AvalaraValidationException(AvalaraException.CODE_BAD_CANCEL, "Please pass a valid cancel code") stem = '/'.join([self.VERSION, 'tax', 'cancel']) data = { 'CompanyCode': doc.CompanyCode, 'DocType': doc.DocType, } if reason: data.update({'CancelCode': reason}) if hasattr(doc, 'DocCode'): data.update({'DocCode': doc.DocCode}) _doc_id = None if hasattr(doc, 'DocId'): _doc_id = doc.DocId if doc_id: _doc_id = doc_id if _doc_id: data.update({'DocId': _doc_id}) resp = self._post(stem, data) self.logger.info('"POST", %s, %s%s with: %s' % (getattr(doc, 'DocCode', None), self.url, stem, data)) self.recorder.success(doc) return CancelTaxResponse(resp)
def test_timeout(): with LogCapture('pyavatax.api') as l: api = get_api(timeout=0.00001) lat = 47.627935 lng = -122.51702 line = Line(Amount=10.00) doc = Document() doc.add_line(line) try: api.get_tax(lat, lng, doc) except AvalaraServerNotReachableException: assert True else: assert False l.check(('pyavatax.api', 'DEBUG', 'None inserting LineNo 1'), ( 'pyavatax.api', 'WARNING', "HTTPSConnectionPool(host='development.avalara.net', port=443): Request timed out. (timeout=1e-05)" ))
def test_timeout(): with LogCapture('pyavatax.api') as l: api = get_api(timeout=0.00001) lat = 47.627935 lng = -122.51702 line = Line(Amount=10.00) doc = Document() doc.add_line(line) try: api.get_tax(lat, lng, doc) except AvalaraServerNotReachableException: assert True else: assert False l.check( ('pyavatax.api', 'DEBUG', 'None inserting LineNo 1'), ('pyavatax.api', 'WARNING', "HTTPSConnectionPool(host='development.avalara.net', port=443): Request timed out. (timeout=1e-05)") )
def test_posttax(): with LogCapture('pyavatax.api') as l: api = get_api() # dont pass a doccode doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**') doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_line(Amount=10.00) doc.add_line(Amount=10.00) doc.add_line(TaxCode='FR', Amount='12.00') # make sure i don't have a doccode try: doc.DocCode except AttributeError: assert True else: assert False tax = api.post_tax(doc) assert tax.is_success is True assert tax.TotalTax > 0 assert len(tax.TaxAddresses) == 6 assert len(tax.TaxLines) == 3 assert len(tax.TaxLines[0].TaxDetails) > 0 assert tax.DocCode assert doc.DocCode # make sure the doccode moved over l.check( ('pyavatax.api', 'DEBUG', 'None setting default from address code'), ('pyavatax.api', 'DEBUG', 'None setting default to address code'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 1'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 2'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 3'), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'INFO', '"POST", %s, %s%s' % (None, api.url, '/'.join([API.VERSION, 'tax', 'get']))), ('pyavatax.api', 'DEBUG', 'AvaTax assigned %s as DocCode' % doc.DocCode))
def test_discount(): api = get_api() # dont pass a doccode amount = 10.00 doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**', Discount=amount) doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_line(Amount=amount, Discounted=True) tax = api.post_tax(doc) assert tax.is_success is True assert float(tax.TotalTax) == 0 assert float(tax.TotalAmount) == amount assert float(tax.TotalDiscount) == amount
def test_discount(): api = get_api() # dont pass a doccode amount = 10.00 doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**', Discount=amount) doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_line(Amount=amount, Discounted=True) tax_date = datetime.date.today() - datetime.timedelta(days=5) doc.add_override(TaxOverrideType=TaxOverride.OVERRIDE_DATE, TaxDate=tax_date, Reason="Tax Date change",) tax = api.post_tax(doc) assert tax.is_success is True assert float(tax.TotalTax) == 0 assert float(tax.TotalAmount) == amount assert float(tax.TotalDiscount) == amount
def get_tax(self, lat, lng, doc, sale_amount=None): """Performs a HTTP GET to tax/get/""" if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document) and sale_amount == None: raise AvalaraException('Please pass a document or a dictionary to create a Document') try: stem = '/'.join([self.VERSION, 'tax', '%.6f,%.6f' % (lat, lng), 'get']) except TypeError: raise AvalaraException('Please pass lat and lng as floats, or Decimal') data = {'saleamount': sale_amount} if sale_amount else {'saleamount': doc.total} resp = self._get(stem, data) self.logger.info('"GET" %s%s' % (self.url, stem)) self.recorder.success(doc) return GetTaxResponse(resp)
def test_posttax_commit_exempt(): random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() # G = resale, which means exempt from tax doc = Document.new_sales_order(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**', CustomerUsageType='G') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00, Qty=2) doc.add_line(line) doc.add_line(TaxCode='FR', Amount='12.00') tax = api.post_tax(doc, commit=True) assert doc.Commit assert doc.DocType == Document.DOC_TYPE_SALE_INVOICE # make sure the doc type changes with commit assert tax.is_success is True assert tax.TotalTax == '0' assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 2
def test_override(): import uuid random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) tax = api.post_tax(doc) assert tax.is_success assert tax.total_tax > 0 # now the soap part soap_api = get_soap_api() tax_date = datetime.date.today() - datetime.timedelta(days=5) tax = soap_api.tax_override(doc, tax_date=tax_date, tax_amt=0, reason="Tax Date change", override_type='TaxDate') assert tax.is_success assert tax.total_tax > 0
def post_tax(self, doc, commit=False): """Performs a HTTP POST to tax/get/ If commit=True we will update the document's Commit flag to True, and we will check the document type to make sure it is capable of being Commited. XXXXXOrder is not capable of being commited. We will change it to XXXXXXXInvoice, which is capable of being committed""" if isinstance(doc, dict): doc = Document.from_data(doc) elif not isinstance(doc, Document): raise AvalaraTypeException( AvalaraException.CODE_BAD_DOC, 'Please pass a document or a dictionary to create a Document') stem = '/'.join([self.VERSION, 'tax', 'get']) doc.update(CompanyCode=self.company_code) if commit: doc.update(Commit=True) self.logger.debug('%s setting Commit=True' % doc.DocCode) # need to change doctype if order, to invoice, otherwise commit does nothing new_doc_type = { Document.DOC_TYPE_SALE_ORDER: Document.DOC_TYPE_SALE_INVOICE, Document.DOC_TYPE_RETURN_ORDER: Document.DOC_TYPE_RETURN_INVOICE, Document.DOC_TYPE_PURCHASE_ORDER: Document.DOC_TYPE_PURCHASE_INVOICE, Document.DOC_TYPE_INVENTORY_ORDER: Document.DOC_TYPE_INVENTORY_INVOICE }.get(doc.DocType, None) if new_doc_type: self.logger.debug('%s updating DocType from %s to %s' % (doc.DocCode, doc.DocType, new_doc_type)) doc.update(DocType=new_doc_type) data = doc.todict() resp = self._post(stem, data) tax_resp = PostTaxResponse(resp) self.logger.info('"POST", %s, %s%s with: %s' % (getattr(doc, 'DocCode', None), self.url, stem, data)) if not hasattr(doc, 'DocCode'): doc.update_doc_code_from_response(tax_resp) self.recorder.success(doc) return tax_resp
def test_posttax(): with LogCapture('pyavatax.api') as l: api = get_api() # dont pass a doccode doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**') doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_line(Amount=10.00) doc.add_line(Amount=10.00) doc.add_line(TaxCode='FR', Amount='12.00') # make sure i don't have a doccode try: doc.DocCode except AttributeError: assert True else: assert False tax = api.post_tax(doc) assert tax.is_success is True assert tax.TotalTax > 0 assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 3 assert len(tax.TaxLines[0].TaxDetails) > 0 assert tax.DocCode assert doc.DocCode # make sure the doccode moved over docdate = datetime.date.today().strftime('%Y-%m-%d') l.check( ('pyavatax.api', 'DEBUG', 'None setting default from address code'), ('pyavatax.api', 'DEBUG', 'None setting default to address code'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 1'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 2'), ('pyavatax.api', 'DEBUG', 'None inserting LineNo 3'), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting origin code %s' % Address.DEFAULT_FROM_ADDRESS_CODE), ('pyavatax.api', 'DEBUG', 'None setting destination code %s' % Address.DEFAULT_TO_ADDRESS_CODE), ('pyavatax.api', 'INFO', '"POST", %s, %s%s with: %s' % (None, api.url, '/'.join([API.VERSION, 'tax', 'get']), '{\'Addresses\': [{\'PostalCode\': \'98110\', \'AddressCode\': \'1\', \'Line2\': \'#220\', \'Line1\': \'100 Ravine Lane NE\'}, {\'PostalCode\': \'98110\', \'AddressCode\': \'2\', \'Line2\': \'#250\', \'Line1\': \'435 Ericksen Avenue Northeast\'}], \'DocDate\': \'' + docdate + '\', \'Lines\': [{\'DestinationCode\': \'2\', \'Amount\': 10.0, \'Qty\': 1, \'LineNo\': 1, \'OriginCode\': \'1\'}, {\'DestinationCode\': \'2\', \'Amount\': 10.0, \'Qty\': 1, \'LineNo\': 2, \'OriginCode\': \'1\'}, {\'TaxCode\': \'FR\', \'DestinationCode\': \'2\', \'Qty\': 1, \'Amount\': 12.0, \'LineNo\': 3, \'OriginCode\': \'1\'}], \'DocType\': \'SalesOrder\', \'Discount\': 0, \'CustomerCode\': \'[email protected]\', \'PaymentDate\': None, \'CompanyCode\': \'PYAVATEST\'}')), ('pyavatax.api', 'DEBUG', 'AvaTax assigned %s as DocCode' % doc.DocCode) )
def test_override_failure(): try: from pyavatax.models import AvaTaxRecord except ImportError: # no django pytest.mark.xfail('This can only be run inside a django environment') return random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_invoice(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00) doc.add_line(line) doc.DocType = 'FooBar' # forcing error tax_date = datetime.date.today() - datetime.timedelta(days=5) doc.add_override(TaxOverrideType=TaxOverride.OVERRIDE_DATE, TaxDate=tax_date, Reason="Tax Date change",) tax = api.post_tax(doc) assert tax.is_success == False assert 1 == AvaTaxRecord.failures.filter(doc_code=random_doc_code).count() assert 0 == AvaTaxRecord.successes.filter(doc_code=random_doc_code).count()
def test_posttax_commit_cancel(): random_doc_code = uuid.uuid4().hex # you can't post/cancel the same doc code over and over api = get_api() doc = Document.new_sales_order(DocCode=random_doc_code, DocDate=datetime.date.today(), CustomerCode='*****@*****.**') to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") from_address = Address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) line = Line(Amount=10.00, Qty=2) doc.add_line(line) tax = api.post_tax(doc, commit=True) assert doc.Commit assert doc.DocType == Document.DOC_TYPE_SALE_INVOICE # make sure the doc type changes with commit assert tax.is_success is True assert tax.TotalTax > 0 assert tax.total_tax == tax.TotalTax assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 1 assert len(tax.TaxLines[0].TaxDetails) > 0 cancel = api.cancel_tax(doc) assert cancel.is_success is True assert cancel.CancelTaxResult
def test_justtozip(): api = get_api() doc = Document.new_sales_order(DocDate=datetime.date.today(), CustomerCode='*****@*****.**') doc.add_from_address(Line1="100 Ravine Lane NE", Line2="#220", PostalCode="98110") doc.add_to_address(Line1="", Line2="", PostalCode="98110") doc.add_line(Amount=10.00) doc.add_line(Amount=10.00) # make sure i don't have a doccode try: doc.DocCode except AttributeError: assert True else: assert False tax = api.post_tax(doc) assert tax.is_success is True assert tax.TotalTax > 0 assert len(tax.TaxAddresses) == 2 assert len(tax.TaxLines) == 2 assert len(tax.TaxLines[0].TaxDetails) > 0 assert tax.DocCode assert doc.DocCode # make sure the doccode moved over
def test_validation(): with pytest.raises(AvalaraValidationException) as e: doc = Document(DocDate='foo') # testing date assert e.value.code == AvalaraException.CODE_BAD_DATE with pytest.raises(AvalaraValidationException) as e: line = Line(Qty='foo') # testing int assert e.value.code == AvalaraException.CODE_BAD_FLOAT with pytest.raises(AvalaraValidationException) as e: line = Line(Amount='foo') # testing float assert e.value.code == AvalaraException.CODE_BAD_FLOAT with pytest.raises(AvalaraValidationException) as e: line = Line(ItemCode='this string is longer than fifty characters and should be stopped') # testing length assert e.value.code == AvalaraException.CODE_TOO_LONG doc = Document.new_sales_order(DocCode='1001', DocDate=datetime.date.today(), CustomerCode='*****@*****.**') with pytest.raises(AvalaraValidationException) as e: doc.validate() assert e.value.code == AvalaraException.CODE_BAD_ADDRESS from_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) with pytest.raises(AvalaraValidationException) as e: doc.validate() assert e.value.code == AvalaraException.CODE_BAD_LINE with pytest.raises(AvalaraException) as e: doc.add_from_address(from_address) assert e.value.code == AvalaraException.CODE_HAS_FROM with pytest.raises(AvalaraException) as e: doc.add_to_address(to_address) assert e.value.code == AvalaraException.CODE_HAS_TO line = Line(Amount=10.00) doc.add_line(line) doc.validate() api = get_api() lat = 47.627935 lng = -122.51702 with pytest.raises(AvalaraTypeException) as e: api.get_tax(lat, lng, 'foo', None) assert e.value.code == AvalaraException.CODE_BAD_DOC with pytest.raises(AvalaraException) as e: api.get_tax(lat, lng, None, None) assert e.value.code == AvalaraException.CODE_BAD_ARGS
def test_validation(): try: doc = Document(DocDate='foo') # testing date except AvalaraException: assert True else: assert False try: doc = Line(Qty='foo') # testing int except AvalaraException: assert True else: assert False try: doc = Line(Amount='foo') # testing float except AvalaraException: assert True else: assert False doc = Document.new_sales_order(DocCode='1001', DocDate=datetime.date.today(), CustomerCode='*****@*****.**') try: doc.validate() except AvalaraException: assert True else: assert False from_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") to_address = Address(Line1="435 Ericksen Avenue Northeast", Line2="#250", PostalCode="98110") doc.add_from_address(from_address) doc.add_to_address(to_address) try: doc.validate() except AvalaraException: assert True else: assert False try: doc.add_from_address(from_address) except AvalaraException: assert True else: assert False try: doc.add_to_address(from_address) except AvalaraException: assert True else: assert False line = Line(Amount=10.00) doc.add_line(line) try: doc.validate() except AvalaraException: assert False