refactor: convert project to typescript (#47)

* refactor: convert project to typescript

* fix: image as last argument of docker run

* ci: remove example as the build can act as example

* fix: set tokenEnv to RENOVATE_TOKEN

* fix: add trailing single quite to Docker --env arguments

* fix: mount volume with config file to Docker container

* chore: remove Prettier trailingComma on all

This puts it back at the default, which is es5 style.

* fix: correct package main to dist/indes.js

* fix: use @actions/exec to execute docker child process

* fix: use async/await for exec

Co-authored-by: Michael Kriese <michael.kriese@visualon.de>

* fix: use async/await in the runner

Co-authored-by: Michael Kriese <michael.kriese@visualon.de>
This commit is contained in:
Jeroen de Bruijn 2020-05-04 07:19:15 +01:00 committed by GitHub
parent 47a19ef007
commit ec8a542458
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
14 changed files with 160 additions and 61 deletions

View file

@ -55,10 +55,14 @@ jobs:
steps:
- name: Checkout
uses: actions/checkout@v2.1.0
- name: Install project
run: npm ci
- name: Build
run: npm run build
- name: Renovate test
uses: ./
with:
configurationFile: .github/config.js
configurationFile: example/renovate-config.js
token: ${{ secrets.RENOVATE_TOKEN }}
build:

View file

@ -1,17 +0,0 @@
name: Example
on:
push:
branches:
- master
pull_request:
jobs:
example:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2.1.0
- name: Renovate example
uses: ./
with:
configurationFile: example/config.js
token: ${{ secrets.RENOVATE_TOKEN }}

View file

@ -15,8 +15,5 @@ inputs:
configured using a Secret.
required: true
runs:
using: docker
image: src/Dockerfile
args:
- ${{ inputs.configurationFile }}
- ${{ inputs.token }}
using: node12
main: dist/index.js

View file

@ -1,9 +0,0 @@
module.exports = {
branchPrefix: 'ga-renovate/',
dryRun: true,
gitAuthor: 'Renovate Bot <bot@renovateapp.com>',
logLevel: 'debug',
onboarding: false,
platform: 'github',
repositories: ['renovatebot/github-action'],
};

24
package-lock.json generated
View file

@ -4,6 +4,24 @@
"lockfileVersion": 1,
"requires": true,
"dependencies": {
"@actions/core": {
"version": "1.2.4",
"resolved": "https://registry.npmjs.org/@actions/core/-/core-1.2.4.tgz",
"integrity": "sha512-YJCEq8BE3CdN8+7HPZ/4DxJjk/OkZV2FFIf+DlZTC/4iBlzYCD5yjRR6eiOS5llO11zbRltIRuKAjMKaWTE6cg=="
},
"@actions/exec": {
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.0.4.tgz",
"integrity": "sha512-4DPChWow9yc9W3WqEbUj8Nr86xkpyE29ZzWjXucHItclLbEW6jr80Zx4nqv18QL6KK65+cifiQZXvnqgTV6oHw==",
"requires": {
"@actions/io": "^1.0.1"
}
},
"@actions/io": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/@actions/io/-/io-1.0.2.tgz",
"integrity": "sha512-J8KuFqVPr3p6U8W93DOXlXW6zFvrQAJANdS+vw0YhusLIq+bszW8zmK2Fh1C2kDPX8FMvwIl1OUcFgvJoXLbAg=="
},
"@babel/code-frame": {
"version": "7.8.3",
"resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz",
@ -308,6 +326,12 @@
"integrity": "sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA==",
"dev": true
},
"@types/node": {
"version": "13.13.4",
"resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.4.tgz",
"integrity": "sha512-x26ur3dSXgv5AwKS0lNfbjpCakGIduWU1DU91Zz58ONRWrIKGunmZBNv4P7N+e27sJkiGDsw/3fT4AtsqQBrBA==",
"dev": true
},
"@types/parse-json": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz",

View file

@ -3,6 +3,7 @@
"version": "1.0.5",
"description": "GitHub Action to run Renovate self-hosted.",
"private": true,
"main": "dist/index.js",
"scripts": {
"lint": "concurrently npm:lint-es",
"lint:fix": "concurrently npm:lint-es:fix",
@ -16,7 +17,8 @@
"release:changelog": "standard-version --dry-run --skip.commit=true --skip.tag=true",
"release:commit": "git commit --allow-empty -m \"chore(release): trigger release process [ci release]\"",
"release:message": "chalk -t \"Run {green.bold git push} to publish the release or {red.bold git reset HEAD^} to undo the release.\"",
"release": "run-s release:changelog release:commit release:message"
"release": "run-s release:changelog release:commit release:message",
"build": "tsc"
},
"repository": {
"type": "git",
@ -28,10 +30,14 @@
"url": "https://github.com/renovatebot/github-action/issues"
},
"homepage": "https://github.com/renovatebot/github-action#readme",
"dependencies": {},
"dependencies": {
"@actions/core": "1.2.4",
"@actions/exec": "1.0.4"
},
"devDependencies": {
"@commitlint/cli": "8.3.5",
"@commitlint/config-conventional": "8.3.4",
"@types/node": "13.13.4",
"@typescript-eslint/eslint-plugin": "2.30.0",
"@typescript-eslint/parser": "2.30.0",
"chalk-cli": "4.1.0",

View file

@ -1,5 +0,0 @@
FROM renovate/renovate:19.228.2
COPY entrypoint.sh /usr/entrypoint.sh
ENTRYPOINT ["/usr/entrypoint.sh"]

15
src/docker.ts Normal file
View file

@ -0,0 +1,15 @@
class Docker {
readonly repository = 'renovate/renovate';
// renovate: datasource=docker depName=renovate/renovate versioning=docker
readonly tag = '19.228.1';
image(): string {
return `${this.repository}:${this.tag}`;
}
version(): string {
return this.tag;
}
}
export default Docker;

View file

@ -1,22 +0,0 @@
#!/bin/bash
#
# Entrypoint for Docker.
export RENOVATE_CONFIG_FILE="${GITHUB_WORKSPACE}/${1}"
readonly _RENOVATE_TOKEN="${2}"
# We are running as ubuntu, so no write access to /github/home
export HOME=/home/ubuntu
if [[ ! -f "${RENOVATE_CONFIG_FILE}" ]]; then
echo "ERROR: Couldn't find file ${RENOVATE_CONFIG_FILE}" 1>&2
exit 1
fi
# Run Renovate.
#
# Mimic the original ENTRYPOINT of the renovate/renovate Docker container. See
# the following link for this entry.
# https://github.com/renovatebot/docker-renovate/blob/d3aa0d99931ea7ad7e901a1e538eba0d61268229/Dockerfile#L63
RENOVATE_TOKEN="${_RENOVATE_TOKEN}" /usr/local/bin/docker-entrypoint.sh

17
src/index.ts Normal file
View file

@ -0,0 +1,17 @@
import * as core from '@actions/core';
import Input from './input';
import Renovate from './renovate';
async function run(): Promise<void> {
try {
const input = new Input();
const renovate = new Renovate(input.configurationFile, input.token);
await renovate.runDockerContainer();
} catch (error) {
console.error(error);
core.setFailed(error.message);
}
}
run();

20
src/input.ts Normal file
View file

@ -0,0 +1,20 @@
import * as core from '@actions/core';
class Input {
readonly configurationFile = core.getInput('configurationFile', {
required: true,
});
readonly token = core.getInput('token', { required: true });
constructor() {
this.validate();
}
validate(): void {
if (this.token === '') {
throw new Error('input.token MUST NOT be empty');
}
}
}
export default Input;

55
src/renovate.ts Normal file
View file

@ -0,0 +1,55 @@
import Docker from './docker';
import { exec } from '@actions/exec';
import fs from 'fs';
import path from 'path';
class Renovate {
private configFileEnv = 'RENOVATE_CONFIG_FILE';
private tokenEnv = 'RENOVATE_TOKEN';
private configFileMountDir = '/github-action';
private configFile: string;
private docker: Docker;
constructor(configFile: string, private token: string) {
this.configFile = path.resolve(configFile);
this.validateArguments();
this.docker = new Docker();
}
async runDockerContainer(): Promise<void> {
const commandArguments = [
'--rm',
`--env ${this.configFileEnv}=${this.configFileMountPath()}`,
`--env ${this.tokenEnv}=${this.token}`,
`--volume ${this.configFile}:${this.configFileMountPath()}`,
this.docker.image(),
];
const command = `docker run ${commandArguments.join(' ')}`;
const code = await exec(command);
if (code !== 0) {
new Error(`'docker run' failed with exit code ${code}.`);
}
}
private validateArguments(): void {
if (!fs.existsSync(this.configFile)) {
throw new Error(
`Could not locate configuration file '${this.configFile}'.`
);
}
}
private configFileName(): string {
return path.basename(this.configFile);
}
private configFileMountPath(): string {
return path.join(this.configFileMountDir, this.configFileName());
}
}
export default Renovate;

14
tsconfig.json Normal file
View file

@ -0,0 +1,14 @@
{
"compilerOptions": {
"target": "es2020",
"module": "commonjs",
"moduleResolution": "node",
"declaration": true,
"resolveJsonModule": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"outDir": "dist"
},
"include": ["src/**/*.ts", "bin/**/*.ts"],
"exclude": ["node_modules", "**/*.test.ts"]
}