mirror of
https://github.com/pacnpal/django-anymail.git
synced 2025-12-20 20:01:05 -05:00
Reformat code with automated tools
Apply standardized code style
This commit is contained in:
@@ -9,20 +9,24 @@ from anymail.message import AnymailMessage
|
||||
|
||||
from .utils import AnymailTestMixin
|
||||
|
||||
|
||||
ANYMAIL_TEST_POSTAL_API_KEY = os.getenv('ANYMAIL_TEST_POSTAL_API_KEY')
|
||||
ANYMAIL_TEST_POSTAL_API_URL = os.getenv('ANYMAIL_TEST_POSTAL_API_URL')
|
||||
ANYMAIL_TEST_POSTAL_DOMAIN = os.getenv('ANYMAIL_TEST_POSTAL_DOMAIN')
|
||||
ANYMAIL_TEST_POSTAL_API_KEY = os.getenv("ANYMAIL_TEST_POSTAL_API_KEY")
|
||||
ANYMAIL_TEST_POSTAL_API_URL = os.getenv("ANYMAIL_TEST_POSTAL_API_URL")
|
||||
ANYMAIL_TEST_POSTAL_DOMAIN = os.getenv("ANYMAIL_TEST_POSTAL_DOMAIN")
|
||||
|
||||
|
||||
@tag('postal', 'live')
|
||||
@tag("postal", "live")
|
||||
@unittest.skipUnless(
|
||||
ANYMAIL_TEST_POSTAL_API_KEY and ANYMAIL_TEST_POSTAL_API_URL and ANYMAIL_TEST_POSTAL_DOMAIN,
|
||||
"Set ANYMAIL_TEST_POSTAL_API_KEY and ANYMAIL_TEST_POSTAL_API_URL and ANYMAIL_TEST_POSTAL_DOMAIN "
|
||||
"environment variables to run Postal integration tests")
|
||||
@override_settings(ANYMAIL_POSTAL_API_KEY=ANYMAIL_TEST_POSTAL_API_KEY,
|
||||
ANYMAIL_POSTAL_API_URL=ANYMAIL_TEST_POSTAL_API_URL,
|
||||
EMAIL_BACKEND="anymail.backends.postal.EmailBackend")
|
||||
ANYMAIL_TEST_POSTAL_API_KEY
|
||||
and ANYMAIL_TEST_POSTAL_API_URL
|
||||
and ANYMAIL_TEST_POSTAL_DOMAIN,
|
||||
"Set ANYMAIL_TEST_POSTAL_API_KEY and ANYMAIL_TEST_POSTAL_API_URL and"
|
||||
" ANYMAIL_TEST_POSTAL_DOMAIN environment variables to run Postal integration tests",
|
||||
)
|
||||
@override_settings(
|
||||
ANYMAIL_POSTAL_API_KEY=ANYMAIL_TEST_POSTAL_API_KEY,
|
||||
ANYMAIL_POSTAL_API_URL=ANYMAIL_TEST_POSTAL_API_URL,
|
||||
EMAIL_BACKEND="anymail.backends.postal.EmailBackend",
|
||||
)
|
||||
class PostalBackendIntegrationTests(AnymailTestMixin, SimpleTestCase):
|
||||
"""Postal API integration tests
|
||||
|
||||
@@ -34,10 +38,14 @@ class PostalBackendIntegrationTests(AnymailTestMixin, SimpleTestCase):
|
||||
|
||||
def setUp(self):
|
||||
super().setUp()
|
||||
self.from_email = 'from@%s' % ANYMAIL_TEST_POSTAL_DOMAIN
|
||||
self.message = AnymailMessage('Anymail Postal integration test', 'Text content',
|
||||
self.from_email, ['test+to1@anymail.dev'])
|
||||
self.message.attach_alternative('<p>HTML content</p>', "text/html")
|
||||
self.from_email = "from@%s" % ANYMAIL_TEST_POSTAL_DOMAIN
|
||||
self.message = AnymailMessage(
|
||||
"Anymail Postal integration test",
|
||||
"Text content",
|
||||
self.from_email,
|
||||
["test+to1@anymail.dev"],
|
||||
)
|
||||
self.message.attach_alternative("<p>HTML content</p>", "text/html")
|
||||
|
||||
def test_simple_send(self):
|
||||
# Example of getting the Postal send status and message id from the message
|
||||
@@ -45,12 +53,13 @@ class PostalBackendIntegrationTests(AnymailTestMixin, SimpleTestCase):
|
||||
self.assertEqual(sent_count, 1)
|
||||
|
||||
anymail_status = self.message.anymail_status
|
||||
sent_status = anymail_status.recipients['test+to1@anymail.dev'].status
|
||||
message_id = anymail_status.recipients['test+to1@anymail.dev'].message_id
|
||||
sent_status = anymail_status.recipients["test+to1@anymail.dev"].status
|
||||
message_id = anymail_status.recipients["test+to1@anymail.dev"].message_id
|
||||
|
||||
self.assertEqual(sent_status, 'queued')
|
||||
self.assertEqual(sent_status, "queued")
|
||||
self.assertGreater(len(message_id), 0) # non-empty string
|
||||
self.assertEqual(anymail_status.status, {sent_status}) # set of all recipient statuses
|
||||
# set of all recipient statuses:
|
||||
self.assertEqual(anymail_status.status, {sent_status})
|
||||
self.assertEqual(anymail_status.message_id, message_id)
|
||||
|
||||
def test_all_options(self):
|
||||
@@ -70,23 +79,32 @@ class PostalBackendIntegrationTests(AnymailTestMixin, SimpleTestCase):
|
||||
message.attach("attachment2.csv", "ID,Name\n1,Amy Lina", "text/csv")
|
||||
|
||||
message.send()
|
||||
self.assertEqual(message.anymail_status.status, {'queued'})
|
||||
self.assertEqual(message.anymail_status.recipients['test+to1@anymail.dev'].status, 'queued')
|
||||
self.assertEqual(message.anymail_status.recipients['test+to2@anymail.dev'].status, 'queued')
|
||||
self.assertEqual(message.anymail_status.status, {"queued"})
|
||||
self.assertEqual(
|
||||
message.anymail_status.recipients["test+to1@anymail.dev"].status, "queued"
|
||||
)
|
||||
self.assertEqual(
|
||||
message.anymail_status.recipients["test+to2@anymail.dev"].status, "queued"
|
||||
)
|
||||
# distinct messages should have different message_ids:
|
||||
self.assertNotEqual(message.anymail_status.recipients['test+to1@anymail.dev'].message_id,
|
||||
message.anymail_status.recipients['teset+to2@anymail.dev'].message_id)
|
||||
self.assertNotEqual(
|
||||
message.anymail_status.recipients["test+to1@anymail.dev"].message_id,
|
||||
message.anymail_status.recipients["teset+to2@anymail.dev"].message_id,
|
||||
)
|
||||
|
||||
def test_invalid_from(self):
|
||||
self.message.from_email = 'webmaster@localhost' # Django's default From
|
||||
self.message.from_email = "webmaster@localhost" # Django's default From
|
||||
with self.assertRaises(AnymailAPIError) as cm:
|
||||
self.message.send()
|
||||
err = cm.exception
|
||||
response = err.response.json()
|
||||
self.assertEqual(err.status_code, 200)
|
||||
self.assertEqual(response['status'], 'error')
|
||||
self.assertIn("The From address is not authorised to send mail from this server", response['data']['message'])
|
||||
self.assertIn("UnauthenticatedFromAddress", response['data']['code'])
|
||||
self.assertEqual(response["status"], "error")
|
||||
self.assertIn(
|
||||
"The From address is not authorised to send mail from this server",
|
||||
response["data"]["message"],
|
||||
)
|
||||
self.assertIn("UnauthenticatedFromAddress", response["data"]["code"])
|
||||
|
||||
@override_settings(ANYMAIL_POSTAL_API_KEY="Hey, that's not an API key!")
|
||||
def test_invalid_server_token(self):
|
||||
@@ -95,6 +113,9 @@ class PostalBackendIntegrationTests(AnymailTestMixin, SimpleTestCase):
|
||||
err = cm.exception
|
||||
response = err.response.json()
|
||||
self.assertEqual(err.status_code, 200)
|
||||
self.assertEqual(response['status'], 'error')
|
||||
self.assertIn("The API token provided in X-Server-API-Key was not valid.", response['data']['message'])
|
||||
self.assertIn("InvalidServerAPIKey", response['data']['code'])
|
||||
self.assertEqual(response["status"], "error")
|
||||
self.assertIn(
|
||||
"The API token provided in X-Server-API-Key was not valid.",
|
||||
response["data"]["message"],
|
||||
)
|
||||
self.assertIn("InvalidServerAPIKey", response["data"]["code"])
|
||||
|
||||
Reference in New Issue
Block a user