Skip to content

Instantly share code, notes, and snippets.

What would you like to do?
Environment Health Check - Test Plutora APIs
The following scripts executes a plain JS Test script.
The script accepts a URL and API Credentials as parameters passed in from the UI, generates a Oauth token and makes a simple API call
The paramaters entered into the UI need to be named as follows and are case sensitive:
- url = <The API oauth url of your Plutora Instance>
- clientId = <The API clientId for your instance of Plutora>
- clientSecret = <The API clientSecret for your instance of Plutora>
- username = <The email address for your user>
- password = <The password address for your user>
- apiUrl = <The API url of your Plutora Instance>
- failureEmails = <email addresses of selected email recipients if the test fails>
The outcome of the test will return a true or false result via Promise.Resolve();
- resolve(true) = your environment is ONLINE
- resolve(false) = your environment is OFFLINE
Any thrown errors during script execution or a call to Reject will be treated as a result of Unknown
- ie - reject(true) = the status of your environment is UNKNOWN
The script will trigger an email notification if the test fails to the email address entered in the failureEmails parameter value
const https = require("https");
const querystring = require('querystring');
var parameters;
let run = function (args) {
//Destructure paramaters for local use.
parameters = args.arguments;
return new Promise(async function (resolve, reject) {
console.log('Beginning EnvironmentCheck test');
//Execute the test
let testResult;
getBearerToken().then(token => makeRequest(token, "Releases"))
.then(async result => {
if (result.length > 0) {
console.log("Call successfully completed");
testResult = true;
} else {
console.log("Call did not return a 200 response");
testResult = false;
console.log('Completed EnvironmentCheck test');
//Optional clause to send emails if a test fails to pass.
if (testResult = false) {
await sendFailureEmail(parameters.failureEmails, "Test completed but the result was a fail.");
return resolve(testResult);
.catch(async err => {
console.log("Critical error making call");
//Optional clause to send emails if a test fails to complete.
await sendFailureEmail(parameters.failureEmails, `Test did not complete due to error: ${err}`);
//return resolve(testResult); //This is considered a failed scenario as the API was not accessible.
const getBearerToken = function () {
console.log('Starting Authorisation');
return new Promise(function (resolve, reject) {
let body = "";
const data = querystring.stringify({
client_id: parameters.clientId,
client_secret: parameters.clientSecret,
grant_type: "password",
username: parameters.username,
password: parameters.password
const options = {
method: "POST",
"rejectUnauthorized": false,
port: 443,
hostname: parameters.url,
path: "/oauth/token",
headers: {
"Content-Type": 'x-www-form-urlencoded; charset=urf-8',
'Accept': "application/json"
const req = https.request(options, function (res) {
res.on('data', function (chunk) {
body += chunk;
res.on('end', function () {
try {
console.log("end request");
result = JSON.parse(body);
if (result.access_token) {
console.log("Received token");
} else {
} catch (e) {
console.log("end request catch");
req.on('error', (e) => {
const makeRequest = function (bearerToken, entity) {
return new Promise(function (resolve, reject) {
console.log(`Making GET request to endpoint: ${entity}`);
const req = https.request({
method: "GET",
hostname: parameters.apiUrl,
port: 443,
path: "/" + entity,
"rejectUnauthorized": false,
headers: {
Authorization: "bearer " + bearerToken
}, function (res) {
let body = "";
res.on("data", data => {
body += data;
res.on("end", () => {
body = JSON.parse(body);
req.on('error', (e) => {
const sendFailureEmail = async function (emails, message = null) {
mailData = {
to: emails, // Required - Address data can be passed as a single string with commas separating addresses or an array of single address strings. ie: ['', '']
//cc: '', //optional
//bcc: '', //optional
subject: 'Environment Health Check Failure - SSO_Login', //Required
body: `A failure occured during the execution of this script. <b> Bold Text </b> <i>Italicized text</i> \n\n + ${message}` //Required - This accepts HTML or standard text input.
//signature: '\n\n\nCustom email signature.' //Optional. If excluded a default Plutora signature will be appended.
await mailer.send(mailData);
module.exports = {
run: run
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.