Create Email Test
This call creates a new email test and submits it to our system for processing.
All requests must contain a “subject” property and one source property (either “html” or “url”). Customers on a user-based reseller package must provide the “customer_id” as well. All other properties are optional. In the following table, each property and its default value is shown.
The response will include an “id” property that should be used to request the results or run processes on the email content.
If the seed list method of spam testing was used, the response will also include a spam property with the spam key which contains an object with an “address_list” property that contains the list of email addresses to send a copy of the email for spam testing purposes.
Enterprise customers’ responses will also include the customer_id and reference_id that were submitted with the test.
URL:
POST https://api.emailonacid.com/v5/email/tests
Example Request Body:
{
"subject": "My Email Subject",
"html": "",
"transfer_encoding": "8bit",
"charset": "utf-8",
"reference_id": "123ABC",
"customer_id": "1",
"clients": [
"outlook16",
"gmail_chr26_win",
"iphone6p_9"
],
"image_blocking": true,
"spam": {
"test_method": "seed",
"from_address": "my.test@example.com"
}
}
Example Response:
{
"id": "<UNIQUE ID>",
"reference_id": "123ABC",
"customer_id": "1",
"spam": {
"key": "<UNIQUE SPAM ID>",
"address_list": [
"spam_address1@example.com",
"spam_address2@example.com"
]
}
}
Request Details
Element | Type | Description | Default |
---|---|---|---|
subject |
String | The subject line of your email, encoded as declared in transfer_encoding . |
None; Required |
html |
String | The email source of your email, encoded as declared in transfer_encoding . |
None; Required if no url |
url |
String | A URL pointing to the email source of your email. | None; Required if no html |
transfer_encoding |
String | One of base64 , quoted-printable , 7bit , or 8bit . |
8bit ; subject and html should be encoded as described by this field. |
charset |
String | The character set your HTML is encoded in. | utf-8 ; subject and html should be encoded as described by this field. |
free_test |
Boolean | If true, run as a free test with limited features. | false |
sandbox |
Boolean | If true, run without creating any actual content. | false |
reference_id |
String | Enterprise customers can set this value for searching and internal reporting. | None; Enterprise only |
customer_id |
String | Enterprise customers can set this value for searching and internal reporting. | None; Enterprise only |
headers |
Object | Enterprise customers can populate this object with X-Header style key/value pairs whose keys begin with "X-" , but not with the reserved "X-EOA" prefix, to assist in test retrieval.ie: { "X-Cake":"Best123", "X-Fun":"Yes456" } |
None; Enterprise only |
clients |
Array of String | An array of string IDs as returned from client list functions. | Default list as returned from email/clients/default |
image_blocking |
Boolean | If true, run a test with images blocked in clients that support it. | false |
spam |
Object | As below. | None; if set, a Spam Test will be run with the Email Test |
spam->test_method |
String | One of "eoa", "smtp", or "seed". The meanings of these values are explained in the Spam Test section. | "eoa" |
spam->smtp_info |
Object | An object containing the SMTP Authentication info. | None; Required if test_method is "smtp" |
spam->smtp_info->host |
String | The SMTP host. | None; Required |
spam->smtp_info->port |
Integer | The SMTP port. | 25 |
spam->smtp_info->secure |
String | One of "ssl", "tls", or "". | "" |
spam->smtp_info->username |
String | The SMTP username. | None |
spam->smtp_info->password |
String | The SMTP password. | None |
spam->from_address |
String | Address to send the email from. | None |
spam->key |
String | Seedlist Key to use. Generated ahead of time using Reserve Seed List. | None; Optional if test_method is "seed" |
Get Tests
This call returns a list of all available Email Tests and some metadata about them. Email Tests are stored for 90 days.
URL:
GET https://api.emailonacid.com/v5/email/tests
Example Response:
[
{
"id": "<test_id>",
"date": 1737665360,
"type": "email-test",
"headers": {
"X-EXAMPLE": "My Header"
}
},
{
"id": "<test_id>",
"date": 1737665360,
"type": "spam-test",
"headers": {}
}
]
Search Tests
This call returns a list of Email Tests that match the criteria in the query string and some metadata about them. Its structure is identical to the above call.
The query string is a standard URL parameterized version containing any or all of the following parameters.
URL:
GET https://api.emailonacid.com/v5/email/tests?<query_string>
Query String Details
Name | Description | Example |
---|---|---|
from |
The starting point of your test date range. | from=2025-01-23 20:49:20 , from=1737665360 , from=yesterday |
to |
The ending point of your test date range. | to=2025-01-23 20:49:20 , to=1737665360 , to=yesterday |
subject |
The "subject" field of returned tests must contain the exact string. This search is case-insensitive. | subject=My+example+test , subject=Another%20example , subject=A%2B tests |
headers |
Enterprise users can use this field in a KV array of x-headers submitted with the test. This is an AND match, meaning all headers must be present to return. | headers[x-fun]=most+fun&headers[x-cake]=best+cake |
results |
The number of results to return. Must be between 1 and 200. The default value is 50 | results=50 |
page |
The page number. If you submit a number higher than the number of pages in the data, an empty array will be returned. The default value is 1 | page=2 |
Get Test Info
This call returns the subject and submission time in UNIX timestamp format. It will also contain one to three properties containing an array of clients. The “completed” property shows clients that have completed screenshots uploaded. The “processing” property contains clients which are still being processed by our system. The “bounced” property contains clients that were bounced by the destination and cannot be retried.
This call will automatically requeue screenshots if they stay in processing for more than three minutes.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>
Example Response:
{
"subject": "Test Subject",
"date": 1470034800,
"completed": [
"outlook13",
"iphone6p_9"
],
"processing": [
"cc_chr26_win"
],
"bounced": [
"ffr_chr26_win"
]
}
Delete Test
This call marks an Email Test as deleted. Once it is deleted, it cannot be recovered.
URL:
DELETE https://api.emailonacid.com/v5/email/tests/<test_id>
Example Response:
{
"success": true
}
Get Results
This call returns detailed results for screenshots including their upload locations, send times, completion times, and information about bounces, if any. <test_id> is a test ID returned from test creation or the get test list functions. The <client_id> is optional and restricts the returned data to a single client if present. If the client is not present in the test or is invalid, an error will be returned.
Any reprocessing that is done will replace the images in these locations. The image locations are generated programmatically before the screenshots are complete, so the presence of a URL in the call is not a guarantee that the file will be present. Use the “status” property to determine whether or not the file is present in the location, or you can manually test the URL provided. If the file is not present, you will receive a 403 Forbidden response from the endpoint.
SCREENSHOT URLS
Screenshot URLs contain direct access to screenshot images, and remain valid throughout the life of the test (90 days from test creation). Access to screenshot URLs are done through either Basic Authentication or Presigned URLs.
Basic Authentication
Screenshot URLs are accessed using the same authentication credentials used on all other API requests. When Basic Authentication is used, the temporary nature of presigned URLs are overridden and the same URL can be used through the life of a test (90 days), provided basic auth credentials are sent along with the request.
Presigned URLs
If no basic authentication credentials are sent along with the request, the default authentication scheme is a form of presigned URLs that provide a time-limited URL (24 hours) for accessing screenshot images. With that in mind, it's important to note that screenshot URLs are dynamic, and it is strongly recommended that an API call to Get Results is made each time to retrieve a fresh set of screenshot URLs.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/results[/<client_id>]
Example Response:
{
"outlook03": {
"id": "outlook03",
"display_name": "Outlook 2003",
"client": "Outlook 2003",
"os": "Windows",
"category": "Application",
"screenshots": {
"default": "<url>",
"no_images": "<url>"
},
"thumbnail": "<url>",
"full_thumbnail": "<url>",
"status": "Processing",
"status_details": {
"submitted": 1468789495,
"attempts": 1
}
},
"iphone6p_9": {
"id": "iphone6p_9",
"display_name": "iPhone 6+ (iOS 9)",
"client": "iPhone 6+",
"os": "iOS9",
"category": "Mobile",
"screenshots": {
"default": "<url>",
"no_images": "<url>",
"horizontal": "<url>",
"horizontal_no_images": "<url>"
},
"thumbnail": "<url>",
"full_thumbnail": "<url>",
"status": "Complete",
"status_details": {
"submitted": 1468789495,
"completed": 1468789503,
"attempts": 1
}
},
"ffr_chr26_win": {
"id": "ffr_chr26_win",
"display_name": "Free.fr Chrome (Windows)",
"client": "Free.fr",
"os": "Windows",
"category": "Web",
"browser": "Chrome",
"screenshots": {
"default": "<url>",
"no_images": "<url>"
},
"thumbnail": "<url>",
"full_thumbnail": "<url>",
"status": "Bounced",
"status_details": {
"submitted": 1468789495,
"bounce_code": "550 5.5.0",
"bounce_message": "<message>"
}
}
}
Response Details
Element | Description |
---|---|
id |
Our unique identifier for the email client. This code can be used when creating new Email Tests. |
display_name |
A presentable name of the email client. |
client |
Name of the email client. |
os |
The name of the OS that this client is running on. |
category |
The type of client this is: one of "Application", "Mobile", or "Web" |
browser |
If this is client is in a browser, the name of the browser the client is running in. |
screenshots |
An object of all screenshots available for this client. Possible properties of this object are default , no_images if image_blocking is true on both the test and the client, horizontal if rotate is true for the client, and horizontal_no_images if both no_images and horizontal exist. |
thumbnail |
The URL to the cropped result thumbnail. |
full_thumbnail |
The URL to the full result thumbnail. Available in API V5.0.1 and later |
status |
A string describing the current status. One of Complete , Processing , Bounced , or Pending . |
status_details |
An object with properties depending on the status. |
status_details->submitted |
UNIX timestamp the screenshot was sent. |
status_details->completed |
UNIX timestamp the screenshot was completed. |
status_details->bounce_code |
If bounced, the code the remote server returned. |
status_details->bounce_message |
If bounced, the message the remote server returned. |
Reprocess Screenshots
Sometimes strange things happen on the internet. If a strange result has come back in your screenshot, use this function to tell us to retake your screenshot free of charge.
The request should contain an object with a property of “clients” that contains a list of clients in the <test_id>
provided.
The object returned will have a “success” value indicating if the attempt was successful. If it is false, there will be a “reason” value describing the failure reason.
URL:
PUT https://api.emailonacid.com/v5/email/tests/<test_id>/results/reprocess
Example Request Body:
{
"clients": [
"iphone6p_9",
"gmail_chr26_win",
"outlook16"
]
}
Example Response:
{
"iphone6p_9": {
"success": true,
"remaining_reprocesses": 19,
"regional": false
}
}
Get Test Content
Each of these calls will return an object with a single property “content” that contains the desired format of content. <test_id> is a test ID returned from test creation or the get test list functions.
Example Response:
{
"content": <html>
}
HTML Content
This call returns the HTML associated with your Email Test. This is what is sent to our servers.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/content
Inlined CSS Content
This call returns HTML with all stylesheets inlined into the HTML.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/content/inlinecss
Text Only Content
This call returns a plain text version of your HTML. This approximates what will be displayed on devices that do not support HTML content. Our system does not currently support multipart emails, so if you send a separate text/plain section when you send your email, this may not be accurate to what users see. Additionally, devices may differ in their plain text renderings, so this function should be used more as a guide than as an exact preview.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/content/textonly
Spam Results
This call returns an object containing the status of your spam result, if you submitted your test with spam processing. If you did not submit with spam processing, you will receive an error. The object will be identical to that received from the Spam Testing version of the function.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/spam/results
Example Response:
[
{
"client": "SPAM CLIENT 1",
"type": "b2c",
"spam": 1,
"details": "SPAM DETAILS"
},
{
"client": "SPAM CLIENT 2",
"type": "b2b",
"spam": -1,
"details": ""
}
]
Spam Seed List
This call returns a list of email addresses to send to for your seed list type spam test. If your spam test was not a seed list type or you did not run the test with spam processing, you will receive an error.
URL:
GET https://api.emailonacid.com/v5/email/tests/<test_id>/spam/seedlist
Example Response:
[
"address1@example.com",
"address2@example.com"
]