Merge pull request #118 from peter-evans/dev
Assume python3 on PATH when running in a container
This commit is contained in:
commit
87c27ee3eb
4 changed files with 88 additions and 43 deletions
80
dist/index.js
vendored
80
dist/index.js
vendored
|
@ -1001,37 +1001,38 @@ module.exports = require("os");
|
||||||
/***/ (function(__unusedmodule, __unusedexports, __webpack_require__) {
|
/***/ (function(__unusedmodule, __unusedexports, __webpack_require__) {
|
||||||
|
|
||||||
const { inspect } = __webpack_require__(669);
|
const { inspect } = __webpack_require__(669);
|
||||||
const fs = __webpack_require__(747);
|
const isDocker = __webpack_require__(160);
|
||||||
const core = __webpack_require__(470);
|
const core = __webpack_require__(470);
|
||||||
const exec = __webpack_require__(986);
|
const exec = __webpack_require__(986);
|
||||||
const setupPython = __webpack_require__(139);
|
const setupPython = __webpack_require__(139);
|
||||||
|
|
||||||
function fileExists(path) {
|
|
||||||
try {
|
|
||||||
return fs.statSync(path).isFile();
|
|
||||||
} catch (e) {
|
|
||||||
core.debug(`e: ${inspect(e)}`);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
try {
|
try {
|
||||||
// Allows ncc to find assets to be included in the distribution
|
// Allows ncc to find assets to be included in the distribution
|
||||||
const src = __webpack_require__.ab + "src";
|
const src = __webpack_require__.ab + "src";
|
||||||
core.debug(`src: ${src}`);
|
core.debug(`src: ${src}`);
|
||||||
|
|
||||||
// Check if the platfrom is Alpine Linux
|
// Determine how to access python and pip
|
||||||
const alpineLinux = fileExists("/etc/alpine-release");
|
const { pip, python } = (function() {
|
||||||
core.debug(`alpineLinux: ${alpineLinux}`);
|
if (isDocker()) {
|
||||||
|
core.info("Running inside a Docker container");
|
||||||
// Skip Python setup if the platform is Alpine Linux
|
// Python 3 assumed to be installed and on the PATH
|
||||||
if (!alpineLinux)
|
return {
|
||||||
// Setup Python from the tool cache
|
pip: "pip3",
|
||||||
setupPython("3.8.x", "x64");
|
python: "python3"
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
// Setup Python from the tool cache
|
||||||
|
setupPython("3.x", "x64");
|
||||||
|
return {
|
||||||
|
pip: "pip",
|
||||||
|
python: "python"
|
||||||
|
};
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
||||||
// Install requirements
|
// Install requirements
|
||||||
await exec.exec("pip", [
|
await exec.exec(pip, [
|
||||||
"install",
|
"install",
|
||||||
"--requirement",
|
"--requirement",
|
||||||
`${src}/requirements.txt`,
|
`${src}/requirements.txt`,
|
||||||
|
@ -1057,7 +1058,7 @@ async function run() {
|
||||||
projectColumn: core.getInput("project-column"),
|
projectColumn: core.getInput("project-column"),
|
||||||
branch: core.getInput("branch"),
|
branch: core.getInput("branch"),
|
||||||
base: core.getInput("base"),
|
base: core.getInput("base"),
|
||||||
branchSuffix: core.getInput("branch-suffix"),
|
branchSuffix: core.getInput("branch-suffix")
|
||||||
};
|
};
|
||||||
core.debug(`Inputs: ${inspect(inputs)}`);
|
core.debug(`Inputs: ${inspect(inputs)}`);
|
||||||
|
|
||||||
|
@ -1081,7 +1082,7 @@ async function run() {
|
||||||
if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix;
|
if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix;
|
||||||
|
|
||||||
// Execute python script
|
// Execute python script
|
||||||
await exec.exec("python", [`${src}/create_pull_request.py`]);
|
await exec.exec(python, [`${src}/create_pull_request.py`]);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message);
|
core.setFailed(error.message);
|
||||||
}
|
}
|
||||||
|
@ -1411,6 +1412,43 @@ if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
|
||||||
exports.debug = debug; // for test
|
exports.debug = debug; // for test
|
||||||
|
|
||||||
|
|
||||||
|
/***/ }),
|
||||||
|
|
||||||
|
/***/ 160:
|
||||||
|
/***/ (function(module, __unusedexports, __webpack_require__) {
|
||||||
|
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
const fs = __webpack_require__(747);
|
||||||
|
|
||||||
|
let isDocker;
|
||||||
|
|
||||||
|
function hasDockerEnv() {
|
||||||
|
try {
|
||||||
|
fs.statSync('/.dockerenv');
|
||||||
|
return true;
|
||||||
|
} catch (_) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function hasDockerCGroup() {
|
||||||
|
try {
|
||||||
|
return fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');
|
||||||
|
} catch (_) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = () => {
|
||||||
|
if (isDocker === undefined) {
|
||||||
|
isDocker = hasDockerEnv() || hasDockerCGroup();
|
||||||
|
}
|
||||||
|
|
||||||
|
return isDocker;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/***/ }),
|
/***/ }),
|
||||||
|
|
||||||
/***/ 211:
|
/***/ 211:
|
||||||
|
|
43
index.js
43
index.js
|
@ -1,35 +1,36 @@
|
||||||
const { inspect } = require("util");
|
const { inspect } = require("util");
|
||||||
const fs = require("fs");
|
const isDocker = require("is-docker");
|
||||||
const core = require("@actions/core");
|
const core = require("@actions/core");
|
||||||
const exec = require("@actions/exec");
|
const exec = require("@actions/exec");
|
||||||
const setupPython = require("./src/setup-python");
|
const setupPython = require("./src/setup-python");
|
||||||
|
|
||||||
function fileExists(path) {
|
|
||||||
try {
|
|
||||||
return fs.statSync(path).isFile();
|
|
||||||
} catch (e) {
|
|
||||||
core.debug(`e: ${inspect(e)}`);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
try {
|
try {
|
||||||
// Allows ncc to find assets to be included in the distribution
|
// Allows ncc to find assets to be included in the distribution
|
||||||
const src = __dirname + "/src";
|
const src = __dirname + "/src";
|
||||||
core.debug(`src: ${src}`);
|
core.debug(`src: ${src}`);
|
||||||
|
|
||||||
// Check if the platfrom is Alpine Linux
|
// Determine how to access python and pip
|
||||||
const alpineLinux = fileExists("/etc/alpine-release");
|
const { pip, python } = (function() {
|
||||||
core.debug(`alpineLinux: ${alpineLinux}`);
|
if (isDocker()) {
|
||||||
|
core.info("Running inside a Docker container");
|
||||||
// Skip Python setup if the platform is Alpine Linux
|
// Python 3 assumed to be installed and on the PATH
|
||||||
if (!alpineLinux)
|
return {
|
||||||
// Setup Python from the tool cache
|
pip: "pip3",
|
||||||
setupPython("3.8.x", "x64");
|
python: "python3"
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
// Setup Python from the tool cache
|
||||||
|
setupPython("3.x", "x64");
|
||||||
|
return {
|
||||||
|
pip: "pip",
|
||||||
|
python: "python"
|
||||||
|
};
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
||||||
// Install requirements
|
// Install requirements
|
||||||
await exec.exec("pip", [
|
await exec.exec(pip, [
|
||||||
"install",
|
"install",
|
||||||
"--requirement",
|
"--requirement",
|
||||||
`${src}/requirements.txt`,
|
`${src}/requirements.txt`,
|
||||||
|
@ -55,7 +56,7 @@ async function run() {
|
||||||
projectColumn: core.getInput("project-column"),
|
projectColumn: core.getInput("project-column"),
|
||||||
branch: core.getInput("branch"),
|
branch: core.getInput("branch"),
|
||||||
base: core.getInput("base"),
|
base: core.getInput("base"),
|
||||||
branchSuffix: core.getInput("branch-suffix"),
|
branchSuffix: core.getInput("branch-suffix")
|
||||||
};
|
};
|
||||||
core.debug(`Inputs: ${inspect(inputs)}`);
|
core.debug(`Inputs: ${inspect(inputs)}`);
|
||||||
|
|
||||||
|
@ -79,7 +80,7 @@ async function run() {
|
||||||
if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix;
|
if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix;
|
||||||
|
|
||||||
// Execute python script
|
// Execute python script
|
||||||
await exec.exec("python", [`${src}/create_pull_request.py`]);
|
await exec.exec(python, [`${src}/create_pull_request.py`]);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message);
|
core.setFailed(error.message);
|
||||||
}
|
}
|
||||||
|
|
5
package-lock.json
generated
5
package-lock.json
generated
|
@ -41,6 +41,11 @@
|
||||||
"integrity": "sha512-M9WzgquSOt2nsjRkYM9LRylBLmmlwNCwYbm3Up3PDEshfvdmIfqpFNSK8EJvR18NwZjGHE5z2avlDtYQx2JQnw==",
|
"integrity": "sha512-M9WzgquSOt2nsjRkYM9LRylBLmmlwNCwYbm3Up3PDEshfvdmIfqpFNSK8EJvR18NwZjGHE5z2avlDtYQx2JQnw==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"is-docker": {
|
||||||
|
"version": "2.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.0.0.tgz",
|
||||||
|
"integrity": "sha512-pJEdRugimx4fBMra5z2/5iRdZ63OhYV0vr0Dwm5+xtW4D1FvRkB8hamMIhnWfyJeDdyr/aa7BDyNbtG38VxgoQ=="
|
||||||
|
},
|
||||||
"qs": {
|
"qs": {
|
||||||
"version": "6.9.1",
|
"version": "6.9.1",
|
||||||
"resolved": "https://registry.npmjs.org/qs/-/qs-6.9.1.tgz",
|
"resolved": "https://registry.npmjs.org/qs/-/qs-6.9.1.tgz",
|
||||||
|
|
|
@ -23,7 +23,8 @@
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.1.1",
|
"@actions/core": "^1.1.1",
|
||||||
"@actions/exec": "^1.0.1",
|
"@actions/exec": "^1.0.1",
|
||||||
"@actions/tool-cache": "^1.1.2"
|
"@actions/tool-cache": "^1.1.2",
|
||||||
|
"is-docker": "^2.0.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@zeit/ncc": "0.21.1"
|
"@zeit/ncc": "0.21.1"
|
||||||
|
|
Loading…
Reference in a new issue