forked from JakePartusch/wait-for-netlify-action
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
52 lines (49 loc) · 1.64 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
const core = require("@actions/core");
const github = require("@actions/github");
const axios = require("axios");
const waitForUrl = async (url, MAX_TIMEOUT, statusCodes, { headers }) => {
const iterations = MAX_TIMEOUT / 2;
for (let i = 0; i < iterations; i++) {
try {
await axios.get(url, {
headers,
validateStatus: function(status) {
return statusCodes.includes(status);
},
});
return;
} catch (e) {
console.log("Url unavailable, retrying...");
await new Promise((r) => setTimeout(r, 2000));
}
}
core.setFailed(`Timeout reached: Unable to connect to ${url}`);
};
const run = async () => {
try {
const PR_NUMBER = github.context.payload.number;
if (!PR_NUMBER) {
core.setFailed(
"Action must be run in conjunction with the `pull_request` event"
);
}
const MAX_TIMEOUT = Number(core.getInput("max_timeout")) || 60;
const statusCodes = core.getMultilineInput("status_codes").map(code => Number(code)) || [200];
const siteName = core.getInput("site_name");
const basePath = core.getInput("base_path");
if (!siteName) {
core.setFailed("Required field `site_name` was not provided");
}
const url = `https://deploy-preview-${PR_NUMBER}--${siteName}.netlify.app${basePath}`;
const extraHeaders = core.getInput("request_headers");
const headers = !extraHeaders ? {} : JSON.parse(extraHeaders)
console.log(`Waiting for a 200 from: ${url}`);
await waitForUrl(url, MAX_TIMEOUT, statusCodes, {
headers,
});
core.setOutput("url", url);
} catch (error) {
core.setFailed(error.message);
}
};
run();