Merge pull request #118 from peter-evans/dev

Assume python3 on PATH when running in a container
This commit is contained in:
Peter Evans 2020-02-14 00:07:03 +09:00 committed by GitHub
commit 87c27ee3eb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 88 additions and 43 deletions

80
dist/index.js vendored
View file

@ -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:

View file

@ -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
View file

@ -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",

View file

@ -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"