Exemple #1
0
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")
Exemple #3
0
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
Exemple #4
0
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()
Exemple #5
0
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
Exemple #6
0
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
Exemple #7
0
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
Exemple #8
0
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)
    )
Exemple #9
0
 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)
Exemple #10
0
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()
Exemple #11
0
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
Exemple #12
0
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
Exemple #13
0
 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)
Exemple #14
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
Exemple #15
0
 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)
Exemple #16
0
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)"
    ))
Exemple #17
0
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)")
    )
Exemple #18
0
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))
Exemple #19
0
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
Exemple #21
0
 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
Exemple #23
0
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
Exemple #24
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
Exemple #25
0
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
Exemple #29
0
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
Exemple #30
0
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