chore: code formatting

This commit is contained in:
github-actions[bot]
2022-04-23 23:18:43 +00:00
parent 73cd43c18f
commit 4c98629bbc
130 changed files with 1839 additions and 1788 deletions

View File

@@ -1,7 +1,7 @@
//Imports
import fs from "fs/promises"
import ejs from "ejs"
import fss from "fs"
import fs from "fs/promises"
import yaml from "js-yaml"
import paths from "path"
import sgit from "simple-git"
@@ -26,13 +26,13 @@ const __test_secrets = paths.join(paths.join(__metrics, "tests/secrets.json"))
//Git setup
const git = sgit(__metrics)
const staged = new Set()
const secrets = Object.assign(JSON.parse(`${await fs.readFile(__test_secrets)}`), { $regex: /\$\{\{\s*secrets\.(?<secret>\w+)\s*\}\}/ })
const { plugins, templates } = await metadata({ log: false, diff: true })
const secrets = Object.assign(JSON.parse(`${await fs.readFile(__test_secrets)}`), {$regex: /\$\{\{\s*secrets\.(?<secret>\w+)\s*\}\}/})
const {plugins, templates} = await metadata({log: false, diff: true})
const workflow = []
//Plugins
for (const id of Object.keys(plugins)) {
const { examples, options, readme, tests, header, community } = await plugin(id)
const {examples, options, readme, tests, header, community} = await plugin(id)
//Readme
console.log(`Generating source/plugins/${community ? "community/" : ""}${id}/README.md`)
@@ -40,7 +40,7 @@ for (const id of Object.keys(plugins)) {
readme.path,
readme.content
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({ test, prod, ...step }) => ["```yaml", yaml.dump(step, { quotingType: '"', noCompatMode: true }), "```"].join("\n")).join("\n")}\n$2`)
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({test, prod, ...step}) => ["```yaml", yaml.dump(step, {quotingType: '"', noCompatMode: true}), "```"].join("\n")).join("\n")}\n$2`)
.replace(/(<!--options-->)[\s\S]*(<!--\/options-->)/g, `$1\n${options}\n$2`),
)
staged.add(readme.path)
@@ -54,7 +54,7 @@ for (const id of Object.keys(plugins)) {
//Templates
for (const id of Object.keys(templates)) {
const { examples, readme, tests, header } = await template(id)
const {examples, readme, tests, header} = await template(id)
//Readme
console.log(`Generating source/templates/${id}/README.md`)
@@ -62,14 +62,14 @@ for (const id of Object.keys(templates)) {
readme.path,
readme.content
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({ test, prod, ...step }) => ["```yaml", yaml.dump(step, { quotingType: '"', noCompatMode: true }), "```"].join("\n")).join("\n")}\n$2`),
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({test, prod, ...step}) => ["```yaml", yaml.dump(step, {quotingType: '"', noCompatMode: true}), "```"].join("\n")).join("\n")}\n$2`),
)
staged.add(readme.path)
//Tests
console.log(`Generating tests/templates/${id}.yml`)
workflow.push(...examples.map(example => testcase(templates[id].name, "prod", example)).filter(t => t))
await fs.writeFile(tests.path, yaml.dump(examples.map(example => testcase(templates[id].name, "test", example)).filter(t => t), { quotingType: '"', noCompatMode: true }))
await fs.writeFile(tests.path, yaml.dump(examples.map(example => testcase(templates[id].name, "test", example)).filter(t => t), {quotingType: '"', noCompatMode: true}))
staged.add(tests.path)
}
@@ -77,21 +77,21 @@ for (const id of Object.keys(templates)) {
for (const step of ["config", "documentation"]) {
switch (step) {
case "config":
await update({ source: paths.join(__action, "action.yml"), output: "action.yml" })
await update({ source: paths.join(__web, "settings.example.json"), output: "settings.example.json" })
await update({source: paths.join(__action, "action.yml"), output: "action.yml"})
await update({source: paths.join(__web, "settings.example.json"), output: "settings.example.json"})
break
case "documentation":
await update({ source: paths.join(__documentation, "README.md"), output: "README.md", options: { root: __readme } })
await update({ source: paths.join(__documentation, "plugins.md"), output: "source/plugins/README.md" })
await update({ source: paths.join(__documentation, "plugins.community.md"), output: "source/plugins/community/README.md" })
await update({ source: paths.join(__documentation, "templates.md"), output: "source/templates/README.md" })
await update({ source: paths.join(__documentation, "compatibility.md"), output: ".github/readme/partials/documentation/compatibility.md" })
await update({source: paths.join(__documentation, "README.md"), output: "README.md", options: {root: __readme}})
await update({source: paths.join(__documentation, "plugins.md"), output: "source/plugins/README.md"})
await update({source: paths.join(__documentation, "plugins.community.md"), output: "source/plugins/community/README.md"})
await update({source: paths.join(__documentation, "templates.md"), output: "source/templates/README.md"})
await update({source: paths.join(__documentation, "compatibility.md"), output: ".github/readme/partials/documentation/compatibility.md"})
break
}
}
//Example workflows
await update({ source: paths.join(__metrics, ".github/scripts/files/examples.yml"), output: ".github/workflows/examples.yml", context: { steps: yaml.dump(workflow, { quotingType: '"', noCompatMode: true }) } })
await update({source: paths.join(__metrics, ".github/scripts/files/examples.yml"), output: ".github/workflows/examples.yml", context: {steps: yaml.dump(workflow, {quotingType: '"', noCompatMode: true})}})
//Commit and push
if (mode === "publish") {
@@ -109,10 +109,10 @@ console.log("Success!")
//==================================================================================
//Update generated files
async function update({ source, output, context = {}, options = {} }) {
async function update({source, output, context = {}, options = {}}) {
console.log(`Generating ${output}`)
const { plugins, templates, packaged, descriptor } = await metadata({ log: false })
const content = await ejs.renderFile(source, { plugins, templates, packaged, descriptor, ...context }, { async: true, ...options })
const {plugins, templates, packaged, descriptor} = await metadata({log: false})
const content = await ejs.renderFile(source, {plugins, templates, packaged, descriptor, ...context}, {async: true, ...options})
const file = paths.join(__metrics, output)
await fs.writeFile(file, content)
staged.add(file)
@@ -160,15 +160,15 @@ async function template(id) {
//Testcase generator
function testcase(name, env, args) {
const { prod = {}, test = {}, ...step } = JSON.parse(JSON.stringify(args))
const context = { prod, test }[env] ?? {}
const { with: overrides } = context
const {prod = {}, test = {}, ...step} = JSON.parse(JSON.stringify(args))
const context = {prod, test}[env] ?? {}
const {with: overrides} = context
if (context.skip)
return null
Object.assign(step.with, context.with ?? {})
delete context.with
const result = { ...step, ...context, name: `${name} - ${step.name ?? "(unnamed)"}` }
const result = {...step, ...context, name: `${name} - ${step.name ?? "(unnamed)"}`}
for (const [k, v] of Object.entries(result.with)) {
if ((env === "test") && (secrets.$regex.test(v)))
result.with[k] = v.replace(secrets.$regex, secrets[v.match(secrets.$regex)?.groups?.secret])
@@ -177,21 +177,21 @@ function testcase(name, env, args) {
if (env === "prod") {
result.if = "${{ success() || failure() }}"
result.uses = "lowlighter/metrics@master"
Object.assign(result.with, { output_action: "none", delay: 120 })
Object.assign(result.with, {output_action: "none", delay: 120})
for (const { property, value } of [{ property: "user", value: "lowlighter" }, { property: "plugins_errors_fatal", value: "yes" }]) {
for (const {property, value} of [{property: "user", value: "lowlighter"}, {property: "plugins_errors_fatal", value: "yes"}]) {
if (!(property in result.with))
result.with[property] = value
}
if ((overrides?.output_action) && (overrides?.committer_branch === "examples"))
Object.assign(result.with, { output_action: overrides.output_action, committer_branch: "examples" })
Object.assign(result.with, {output_action: overrides.output_action, committer_branch: "examples"})
}
if (env === "test") {
if (!result.with.base)
delete result.with.base
delete result.with.filename
Object.assign(result.with, { use_mocked_data: "yes", verify: "yes" })
Object.assign(result.with, {use_mocked_data: "yes", verify: "yes"})
}
return result