From 4beea725d361a3a2bdf0aa2938f46ce8c7dae36e Mon Sep 17 00:00:00 2001 From: Peter Evans Date: Thu, 13 Feb 2020 17:36:57 +0900 Subject: [PATCH] Call python3 when running in a container --- dist/index.js | 31 +++++++++++++++++++++---------- index.js | 33 ++++++++++++++++++++++----------- 2 files changed, 43 insertions(+), 21 deletions(-) diff --git a/dist/index.js b/dist/index.js index 5bd8357..4fcff7f 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1002,7 +1002,6 @@ module.exports = require("os"); const { inspect } = __webpack_require__(669); const isDocker = __webpack_require__(160); -const fs = __webpack_require__(747); const core = __webpack_require__(470); const exec = __webpack_require__(986); const setupPython = __webpack_require__(139); @@ -1013,15 +1012,27 @@ async function run() { const src = __webpack_require__.ab + "src"; core.debug(`src: ${src}`); - if (isDocker()) { - core.info('Running inside a Docker container'); - } else { - // Setup Python from the tool cache - setupPython("3.8.x", "x64"); - } + // Determine how to access python and pip + const { pip, python } = (function() { + if (isDocker()) { + core.info("Running inside a Docker container"); + // Python 3 assumed to be installed and on the PATH + return { + pip: "pip3", + python: "python3" + }; + } else { + // Setup Python from the tool cache + setupPython("3.x", "x64"); + return { + pip: "pip", + python: "python" + }; + } + })(); // Install requirements - await exec.exec("pip", [ + await exec.exec(pip, [ "install", "--requirement", `${src}/requirements.txt`, @@ -1047,7 +1058,7 @@ async function run() { projectColumn: core.getInput("project-column"), branch: core.getInput("branch"), base: core.getInput("base"), - branchSuffix: core.getInput("branch-suffix"), + branchSuffix: core.getInput("branch-suffix") }; core.debug(`Inputs: ${inspect(inputs)}`); @@ -1071,7 +1082,7 @@ async function run() { if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix; // Execute python script - await exec.exec("python", [`${src}/create_pull_request.py`]); + await exec.exec(python, [`${src}/create_pull_request.py`]); } catch (error) { core.setFailed(error.message); } diff --git a/index.js b/index.js index c4575ea..3dce607 100644 --- a/index.js +++ b/index.js @@ -1,6 +1,5 @@ const { inspect } = require("util"); -const isDocker = require('is-docker'); -const fs = require("fs"); +const isDocker = require("is-docker"); const core = require("@actions/core"); const exec = require("@actions/exec"); const setupPython = require("./src/setup-python"); @@ -11,15 +10,27 @@ async function run() { const src = __dirname + "/src"; core.debug(`src: ${src}`); - if (isDocker()) { - core.info('Running inside a Docker container'); - } else { - // Setup Python from the tool cache - setupPython("3.8.x", "x64"); - } + // Determine how to access python and pip + const { pip, python } = (function() { + if (isDocker()) { + core.info("Running inside a Docker container"); + // Python 3 assumed to be installed and on the PATH + return { + pip: "pip3", + python: "python3" + }; + } else { + // Setup Python from the tool cache + setupPython("3.x", "x64"); + return { + pip: "pip", + python: "python" + }; + } + })(); // Install requirements - await exec.exec("pip", [ + await exec.exec(pip, [ "install", "--requirement", `${src}/requirements.txt`, @@ -45,7 +56,7 @@ async function run() { projectColumn: core.getInput("project-column"), branch: core.getInput("branch"), base: core.getInput("base"), - branchSuffix: core.getInput("branch-suffix"), + branchSuffix: core.getInput("branch-suffix") }; core.debug(`Inputs: ${inspect(inputs)}`); @@ -69,7 +80,7 @@ async function run() { if (inputs.branchSuffix) process.env.CPR_BRANCH_SUFFIX = inputs.branchSuffix; // Execute python script - await exec.exec("python", [`${src}/create_pull_request.py`]); + await exec.exec(python, [`${src}/create_pull_request.py`]); } catch (error) { core.setFailed(error.message); }