From 371a3bf0be05098a5ced9fb388ce6e465a7dc69f Mon Sep 17 00:00:00 2001 From: Sven-Hendrik Haase Date: Thu, 2 Jul 2020 07:56:14 +0200 Subject: [PATCH] Format code --- __tests__/main.test.ts | 6 +- src/main.ts | 204 ++++++++++++++++++++++++----------------- 2 files changed, 122 insertions(+), 88 deletions(-) diff --git a/__tests__/main.test.ts b/__tests__/main.test.ts index 78e89d7..92e7c18 100644 --- a/__tests__/main.test.ts +++ b/__tests__/main.test.ts @@ -1,6 +1,6 @@ -import * as main from '../src/main'; +import * as main from '../src/main' // Frankly, tests would be entirely useless unless we can mock GitHub somehow. describe('Upload Release Action', () => { - it('', async () => {}); -}); + it('', async () => {}) +}) diff --git a/src/main.ts b/src/main.ts index 37b96ba..6919864 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,104 +1,138 @@ -import * as fs from 'fs'; -import * as core from '@actions/core'; -import * as github from '@actions/github'; -import * as path from 'path'; +import * as fs from 'fs' +import * as core from '@actions/core' +import * as github from '@actions/github' +import * as path from 'path' -const glob = require("glob") +const glob = require('glob') -async function get_release_by_tag(tag: string, octokit: any, context: any): Promise { - try { - core.debug(`Getting release by tag ${tag}.`); - return await octokit.repos.getReleaseByTag({ - ...context.repo, - tag: tag, - }); - } catch (error) { - // If this returns 404, we need to create the release first. - if (error.status === 404) { - core.debug(`Release for tag ${tag} doesn't exist yet so we'll create it now.`) - return await octokit.repos.createRelease({ - ...context.repo, - tag_name: tag, - }) - } else { - throw error; - } +async function get_release_by_tag( + tag: string, + octokit: any, + context: any +): Promise { + try { + core.debug(`Getting release by tag ${tag}.`) + return await octokit.repos.getReleaseByTag({ + ...context.repo, + tag: tag + }) + } catch (error) { + // If this returns 404, we need to create the release first. + if (error.status === 404) { + core.debug( + `Release for tag ${tag} doesn't exist yet so we'll create it now.` + ) + return await octokit.repos.createRelease({ + ...context.repo, + tag_name: tag + }) + } else { + throw error } + } } -async function upload_to_release(release: any, file: string, asset_name: string, tag: string, overwrite: string, octokit: any, context: any) { - const stat = fs.statSync(file); - if (!stat.isFile()) { - core.debug(`Skipping ${file}, since its not a file`); - return; - } - const file_size = stat.size; - const file_bytes = fs.readFileSync(file); +async function upload_to_release( + release: any, + file: string, + asset_name: string, + tag: string, + overwrite: string, + octokit: any, + context: any +) { + const stat = fs.statSync(file) + if (!stat.isFile()) { + core.debug(`Skipping ${file}, since its not a file`) + return + } + const file_size = stat.size + const file_bytes = fs.readFileSync(file) - // Check for duplicates. - const assets = await octokit.repos.listAssetsForRelease({ + // Check for duplicates. + const assets = await octokit.repos.listAssetsForRelease({ + ...context.repo, + release_id: release.data.id + }) + const duplicate_asset = assets.data.find((a: any) => a.name === asset_name) + if (duplicate_asset !== undefined) { + if (overwrite === 'true') { + core.debug( + `An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.` + ) + await octokit.repos.deleteReleaseAsset({ ...context.repo, - release_id: release.data.id, - }); - const duplicate_asset = assets.data.find((a: any) => a.name === asset_name); - if (duplicate_asset !== undefined) { - if (overwrite === "true") { - core.debug(`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`) - await octokit.repos.deleteReleaseAsset({ - ...context.repo, - asset_id: duplicate_asset.id - }) - } else { - core.setFailed(`An asset called ${asset_name} already exists.`) - return; - } + asset_id: duplicate_asset.id + }) } else { - core.debug(`No pre-existing asset called ${asset_name} found in release ${tag}. All good.`); + core.setFailed(`An asset called ${asset_name} already exists.`) + return } + } else { + core.debug( + `No pre-existing asset called ${asset_name} found in release ${tag}. All good.` + ) + } - core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`) - await octokit.repos.uploadReleaseAsset({ - url: release.data.upload_url, - name: asset_name, - file: file_bytes, - headers: { - "content-type": "binary/octet-stream", - "content-length": file_size - }, - }); + core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`) + await octokit.repos.uploadReleaseAsset({ + url: release.data.upload_url, + name: asset_name, + file: file_bytes, + headers: { + 'content-type': 'binary/octet-stream', + 'content-length': file_size + } + }) } async function run() { - try { - const token = core.getInput('repo_token', { required: true }); - const file = core.getInput('file', { required: true }); - const file_glob = core.getInput('file_glob'); - const tag = core.getInput('tag', { required: true }).replace("refs/tags/", ""); - const overwrite = core.getInput('overwrite'); + try { + const token = core.getInput('repo_token', {required: true}) + const file = core.getInput('file', {required: true}) + const file_glob = core.getInput('file_glob') + const tag = core.getInput('tag', {required: true}).replace('refs/tags/', '') + const overwrite = core.getInput('overwrite') - const octokit = github.getOctokit(token); - const context = github.context; - const release = await get_release_by_tag(tag, octokit, context); + const octokit = github.getOctokit(token) + const context = github.context + const release = await get_release_by_tag(tag, octokit, context) - if (file_glob === "true") { - const files = glob.sync(file); - if (files.length > 0) { - for (let file of files) { - const asset_name = path.basename(file); - await upload_to_release(release, file, asset_name, tag, overwrite, octokit, context); - } - } - else { - core.setFailed("No files matching the glob pattern found."); - } + if (file_glob === 'true') { + const files = glob.sync(file) + if (files.length > 0) { + for (let file of files) { + const asset_name = path.basename(file) + await upload_to_release( + release, + file, + asset_name, + tag, + overwrite, + octokit, + context + ) } - else { - const asset_name = core.getInput('asset_name', { required: true }).replace(/\$tag/g, tag); - await upload_to_release(release, file, asset_name, tag, overwrite, octokit, context); - } - } catch (error) { - core.setFailed(error.message); + } else { + core.setFailed('No files matching the glob pattern found.') + } + } else { + const asset_name = core + .getInput('asset_name', {required: true}) + .replace(/\$tag/g, tag) + await upload_to_release( + release, + file, + asset_name, + tag, + overwrite, + octokit, + context + ) } + } catch (error) { + core.setFailed(error.message) + } } -run(); +run()