emaile2e-client
Emaile2e provides a simple REST API that lets you create randomized email addresses and fetch the emails sent to them.
Why?
If your application uses emails at any point, Emaile2e makes testing your app's email integration easier.
Say your app sign-up process sends a verification email. During e2e tests you can create a new random email
address for a test user, sign-up, and then fetch the verification email and use the verification code in the next steps of your test.
Getting started
Every API request requires a valid API Key appended as a query parameter. To obtain an API Key visit your account dashboard.
The general flow is as follows:
- Create a new inbox during a test. The email address will be returned in the response.
- Send an email to that address or trigger an action in your test that does so.
- Fetch the email for your new inbox and check if their content is what you expected.
SDK
Legal
The Emaile2e API code is owned by PettmanUG and uses a proprietary software licence. The SDKs are free to use in any project and have an ISC licence.
Bugs, features, support
To report bugs or request features please see the contact page. For help see support.
Installation
npm
To publish the library as a npm,
please follow the procedure in "Publishing npm packages".
Then install it via:
npm install emaile2e-client --save
Local development
To use the library locally without publishing to a remote npm registry, first install the dependencies by changing
into the directory containing package.json
(and this README). Let's call this JAVASCRIPT_CLIENT_DIR
. Then run:
npm install
Next, link it globally in npm with the following, also from JAVASCRIPT_CLIENT_DIR
:
npm link
Finally, switch to the directory you want to use your emaile2e-client from, and run:
npm link /path/to/<JAVASCRIPT_CLIENT_DIR>
You should now be able to require('emaile2e-client')
in javascript files from the directory you ran the last
command above from.
git
If the library is hosted at a git repository, e.g.
https://github.com/GIT_USER_ID/GIT_REPO_ID
then install it via:
npm install GIT_USER_ID/GIT_REPO_ID --save
For browser
The library also works in the browser environment via npm and browserify. After following
the above steps with Node.js and installing browserify with npm install -g browserify
,
perform the following (assuming main.js is your entry file, that's to say your javascript file where you actually
use this library):
browserify main.js > bundle.js
Then include bundle.js in the HTML pages.
Webpack Configuration
Using Webpack you may encounter the following error: "Module not found: Error:
Cannot resolve module", most certainly you should disable AMD loader. Add/merge
the following section to your webpack config:
module: {
rules: [
{
parser: {
amd: false
}
}
]
}
Getting Started
Please follow the installation instruction and execute the following JS code:
var Emaile2eClient = require('emaile2e-client');
var api = new Emaile2eClient.InboxcontrollerApi()
var apiKey = "test";
api.createUsingPOST(apiKey).then(function(data) {
console.log('API called successfully. Returned data: ' + data);
}, function(error) {
console.error(error);
});
Documentation for API Endpoints
All URIs are relative to https://api.emaile2e.com
Class | Method | HTTP request | Description |
---|
Emaile2eClient.InboxcontrollerApi | createUsingPOST | POST /inboxes | Create an inbox |
Emaile2eClient.InboxcontrollerApi | deleteUsingDELETE | DELETE /inboxes/{uuid} | Delete an inbox |
Emaile2eClient.InboxcontrollerApi | indexUsingGET | GET /inboxes | List your inboxes |
Emaile2eClient.InboxcontrollerApi | sendEmailUsingPOST | POST /inboxes/{uuid} | Send an email |
Emaile2eClient.InboxcontrollerApi | viewUsingGET | GET /inboxes/{uuid} | Fetch emails for a given inbox |
Documentation for Models
Documentation for Authorization
All endpoints do not require authorization.