Skip to content

Commit d3228a1

Browse files
chore: code formatting
1 parent 4fa62aa commit d3228a1

File tree

94 files changed

+3897
-3844
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

94 files changed

+3897
-3844
lines changed

.github/scripts/build.mjs

Lines changed: 49 additions & 45 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,12 @@
11
//Imports
2-
import ejs from "ejs"
32
import fs from "fs/promises"
3+
import ejs from "ejs"
44
import fss from "fs"
5+
import yaml from "js-yaml"
56
import paths from "path"
6-
import url from "url"
77
import sgit from "simple-git"
8+
import url from "url"
89
import metadata from "../../source/app/metrics/metadata.mjs"
9-
import yaml from "js-yaml"
1010

1111
//Mode
1212
const [mode = "dryrun"] = process.argv.slice(2)
@@ -25,34 +25,36 @@ const __test_secrets = paths.join(paths.join(__metrics, "tests/secrets.json"))
2525
//Git setup
2626
const git = sgit(__metrics)
2727
const staged = new Set()
28-
const secrets = Object.assign(JSON.parse(`${await fs.readFile(__test_secrets)}`), {$regex:/\$\{\{\s*secrets\.(?<secret>\w+)\s*\}\}/})
29-
const {plugins, templates} = await metadata({log:false, diff:true})
28+
const secrets = Object.assign(JSON.parse(`${await fs.readFile(__test_secrets)}`), { $regex: /\$\{\{\s*secrets\.(?<secret>\w+)\s*\}\}/ })
29+
const { plugins, templates } = await metadata({ log: false, diff: true })
3030
const workflow = []
3131

3232
//Config and general documentation auto-generation
3333
for (const step of ["config", "documentation"]) {
3434
switch (step) {
3535
case "config":
36-
await update({source:paths.join(__action, "action.yml"), output:"action.yml"})
37-
await update({source:paths.join(__web, "settings.example.json"), output:"settings.example.json"})
36+
await update({ source: paths.join(__action, "action.yml"), output: "action.yml" })
37+
await update({ source: paths.join(__web, "settings.example.json"), output: "settings.example.json" })
3838
break
3939
case "documentation":
40-
await update({source:paths.join(__readme, "README.md"), output:"README.md", options:{root:__readme}})
41-
await update({source:paths.join(__readme, "partials/documentation/plugins.md"), output:"source/plugins/README.md"})
42-
await update({source:paths.join(__readme, "partials/documentation/templates.md"), output:"source/templates/README.md"})
40+
await update({ source: paths.join(__readme, "README.md"), output: "README.md", options: { root: __readme } })
41+
await update({ source: paths.join(__readme, "partials/documentation/plugins.md"), output: "source/plugins/README.md" })
42+
await update({ source: paths.join(__readme, "partials/documentation/templates.md"), output: "source/templates/README.md" })
4343
break
4444
}
4545
}
4646

4747
//Plugins
4848
for (const id of Object.keys(plugins)) {
49-
const {examples, options, readme, tests, header} = await plugin(id)
49+
const { examples, options, readme, tests, header } = await plugin(id)
5050

5151
//Readme
52-
await fs.writeFile(readme.path, readme.content
53-
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
54-
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({test, prod, ...step}) => ["```yaml", yaml.dump(step), "```"].join("\n")).join("\n")}\n$2`)
55-
.replace(/(<!--options-->)[\s\S]*(<!--\/options-->)/g, `$1\n${options}\n$2`)
52+
await fs.writeFile(
53+
readme.path,
54+
readme.content
55+
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
56+
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({ test, prod, ...step }) => ["```yaml", yaml.dump(step), "```"].join("\n")).join("\n")}\n$2`)
57+
.replace(/(<!--options-->)[\s\S]*(<!--\/options-->)/g, `$1\n${options}\n$2`),
5658
)
5759
console.log(`Generating source/plugins/${id}/README.md`)
5860

@@ -64,12 +66,14 @@ for (const id of Object.keys(plugins)) {
6466

6567
//Templates
6668
for (const id of Object.keys(templates)) {
67-
const {examples, readme, tests, header} = await template(id)
69+
const { examples, readme, tests, header } = await template(id)
6870

6971
//Readme
70-
await fs.writeFile(readme.path, readme.content
71-
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
72-
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({test, prod, ...step}) => ["```yaml", yaml.dump(step), "```"].join("\n")).join("\n")}\n$2`)
72+
await fs.writeFile(
73+
readme.path,
74+
readme.content
75+
.replace(/(<!--header-->)[\s\S]*(<!--\/header-->)/g, `$1\n${header}\n$2`)
76+
.replace(/(<!--examples-->)[\s\S]*(<!--\/examples-->)/g, `$1\n${examples.map(({ test, prod, ...step }) => ["```yaml", yaml.dump(step), "```"].join("\n")).join("\n")}\n$2`),
7377
)
7478
console.log(`Generating source/templates/${id}/README.md`)
7579

@@ -80,7 +84,7 @@ for (const id of Object.keys(templates)) {
8084
}
8185

8286
//Example workflows
83-
await update({source:paths.join(__metrics, ".github/scripts/files/examples.yml"), output:".github/workflows/examples.yml", context:{steps:yaml.dump(workflow)}})
87+
await update({ source: paths.join(__metrics, ".github/scripts/files/examples.yml"), output: ".github/workflows/examples.yml", context: { steps: yaml.dump(workflow) } })
8488

8589
//Commit and push
8690
if (mode === "publish") {
@@ -98,10 +102,10 @@ console.log("Success!")
98102
//==================================================================================
99103

100104
//Update generated files
101-
async function update({source, output, context = {}, options = {}}) {
105+
async function update({ source, output, context = {}, options = {} }) {
102106
console.log(`Generating ${output}`)
103-
const {plugins, templates, packaged, descriptor} = await metadata({log:false})
104-
const content = await ejs.renderFile(source, {plugins, templates, packaged, descriptor, ...context}, {async:true, ...options})
107+
const { plugins, templates, packaged, descriptor } = await metadata({ log: false })
108+
const content = await ejs.renderFile(source, { plugins, templates, packaged, descriptor, ...context }, { async: true, ...options })
105109
const file = paths.join(__metrics, output)
106110
await fs.writeFile(file, content)
107111
staged.add(file)
@@ -114,16 +118,16 @@ async function plugin(id) {
114118
const examples = paths.join(path, "examples.yml")
115119
const tests = paths.join(__test_cases, `${id}.plugin.yml`)
116120
return {
117-
readme:{
118-
path:readme,
119-
content:`${await fs.readFile(readme)}`
121+
readme: {
122+
path: readme,
123+
content: `${await fs.readFile(readme)}`,
120124
},
121-
tests:{
122-
path:tests
125+
tests: {
126+
path: tests,
123127
},
124-
examples:fss.existsSync(examples) ? yaml.load(await fs.readFile(examples), "utf8") ?? [] : [],
125-
options:plugins[id].readme.table,
126-
header:plugins[id].readme.header
128+
examples: fss.existsSync(examples) ? yaml.load(await fs.readFile(examples), "utf8") ?? [] : [],
129+
options: plugins[id].readme.table,
130+
header: plugins[id].readme.header,
127131
}
128132
}
129133

@@ -134,45 +138,45 @@ async function template(id) {
134138
const examples = paths.join(path, "examples.yml")
135139
const tests = paths.join(__test_cases, `${id}.template.yml`)
136140
return {
137-
readme:{
138-
path:readme,
139-
content:`${await fs.readFile(readme)}`
141+
readme: {
142+
path: readme,
143+
content: `${await fs.readFile(readme)}`,
140144
},
141-
tests:{
142-
path:tests
145+
tests: {
146+
path: tests,
143147
},
144-
examples:fss.existsSync(examples) ? yaml.load(await fs.readFile(examples), "utf8") ?? [] : [],
145-
header:templates[id].readme.header
148+
examples: fss.existsSync(examples) ? yaml.load(await fs.readFile(examples), "utf8") ?? [] : [],
149+
header: templates[id].readme.header,
146150
}
147151
}
148152

149153
//Testcase generator
150154
function testcase(name, env, args) {
151-
const {prod = {}, test = {}, ...step} = JSON.parse(JSON.stringify(args))
152-
const context = {prod, test}[env] ?? {}
155+
const { prod = {}, test = {}, ...step } = JSON.parse(JSON.stringify(args))
156+
const context = { prod, test }[env] ?? {}
153157
if (context.skip)
154158
return null
155159

156160
Object.assign(step.with, context.with ?? {})
157161
delete context.with
158-
const result = {...step, ...context, name:`${name} - ${step.name ?? "(unnamed)"}`}
162+
const result = { ...step, ...context, name: `${name} - ${step.name ?? "(unnamed)"}` }
159163
for (const [k, v] of Object.entries(result.with)) {
160-
if ((env === "test")&&(secrets.$regex.test(v)))
164+
if ((env === "test") && (secrets.$regex.test(v)))
161165
result.with[k] = v.replace(secrets.$regex, secrets[v.match(secrets.$regex)?.groups?.secret])
162166
}
163167

164168
if (env === "prod") {
165169
result.if = "${{ success() || failure() }}"
166170
result.uses = "lowlighter/metrics@master"
167-
Object.assign(result.with, {plugins_errors_fatal:"yes", output_action:"none", delay:120})
171+
Object.assign(result.with, { plugins_errors_fatal: "yes", output_action: "none", delay: 120 })
168172
}
169173

170174
if (env === "test") {
171175
if (!result.with.base)
172176
delete result.with.base
173177
delete result.with.filename
174-
Object.assign(result.with, {use_mocked_data:"yes", verify:"yes"})
178+
Object.assign(result.with, { use_mocked_data: "yes", verify: "yes" })
175179
}
176180

177181
return result
178-
}
182+
}

.github/scripts/markdown_example.mjs

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -3,19 +3,19 @@ import puppeteer from "puppeteer"
33

44
//Setup browser
55
const browser = await puppeteer.launch({
6-
headless:true,
7-
executablePath:process.env.PUPPETEER_BROWSER_PATH,
8-
args:["--no-sandbox", "--disable-extensions", "--disable-setuid-sandbox", "--disable-dev-shm-usage"],
9-
ignoreDefaultArgs:["--disable-extensions"],
6+
headless: true,
7+
executablePath: process.env.PUPPETEER_BROWSER_PATH,
8+
args: ["--no-sandbox", "--disable-extensions", "--disable-setuid-sandbox", "--disable-dev-shm-usage"],
9+
ignoreDefaultArgs: ["--disable-extensions"],
1010
})
1111
const page = await browser.newPage()
1212

1313
//Select markdown example and take screenshoot
14-
await page.setViewport({width:600, height:600})
14+
await page.setViewport({ width: 600, height: 600 })
1515
await page.goto("https://github.com/lowlighter/metrics/blob/examples/metrics.markdown.md")
1616
const clip = await page.evaluate(() => {
17-
const {x, y, width, height} = document.querySelector("#readme").getBoundingClientRect()
18-
return {x, y, width, height}
17+
const { x, y, width, height } = document.querySelector("#readme").getBoundingClientRect()
18+
return { x, y, width, height }
1919
})
20-
await page.screenshot({type:"png", path:"metrics.markdown.png", clip, omitBackground:true})
20+
await page.screenshot({ type: "png", path: "metrics.markdown.png", clip, omitBackground: true })
2121
await browser.close()

.github/scripts/preview.mjs

Lines changed: 18 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -19,35 +19,36 @@ const __preview_templates_ = paths.join(__preview, ".templates_")
1919
const __preview_about = paths.join(__preview, "about/.statics")
2020

2121
//Extract from web server
22-
const {conf, Templates} = await setup({nosettings:true, log:false})
23-
const templates = Object.entries(Templates).map(([name]) => ({name, enabled:true}))
24-
const metadata = Object.fromEntries(Object.entries(conf.metadata.plugins)
25-
.map(([key, value]) => [key, Object.fromEntries(Object.entries(value).filter(([key]) => ["name", "icon", "category", "web", "supports"].includes(key)))])
26-
.map(([key, value]) => [key, key === "core" ? {...value, web:Object.fromEntries(Object.entries(value.web).filter(([key]) => /^config[.]/.test(key)).map(([key, value]) => [key.replace(/^config[.]/, ""), value]))} : value]))
27-
22+
const { conf, Templates } = await setup({ nosettings: true, log: false })
23+
const templates = Object.entries(Templates).map(([name]) => ({ name, enabled: true }))
24+
const metadata = Object.fromEntries(
25+
Object.entries(conf.metadata.plugins)
26+
.map(([key, value]) => [key, Object.fromEntries(Object.entries(value).filter(([key]) => ["name", "icon", "category", "web", "supports"].includes(key)))])
27+
.map(([key, value]) => [key, key === "core" ? { ...value, web: Object.fromEntries(Object.entries(value.web).filter(([key]) => /^config[.]/.test(key)).map(([key, value]) => [key.replace(/^config[.]/, ""), value])) } : value]),
28+
)
2829

2930
//Directories
30-
await fs.mkdir(__preview, {recursive:true})
31-
await fs.mkdir(__preview_js, {recursive:true})
32-
await fs.mkdir(__preview_css, {recursive:true})
33-
await fs.mkdir(__preview_templates, {recursive:true})
34-
await fs.mkdir(__preview_templates_, {recursive:true})
35-
await fs.mkdir(__preview_about, {recursive:true})
31+
await fs.mkdir(__preview, { recursive: true })
32+
await fs.mkdir(__preview_js, { recursive: true })
33+
await fs.mkdir(__preview_css, { recursive: true })
34+
await fs.mkdir(__preview_templates, { recursive: true })
35+
await fs.mkdir(__preview_templates_, { recursive: true })
36+
await fs.mkdir(__preview_about, { recursive: true })
3637

3738
//Web
3839
fs.copyFile(paths.join(__web, "index.html"), paths.join(__preview, "index.html"))
3940
fs.copyFile(paths.join(__web, "favicon.png"), paths.join(__preview, ".favicon.png"))
4041
fs.copyFile(paths.join(__web, "opengraph.png"), paths.join(__preview, ".opengraph.png"))
4142
//Plugins and templates
42-
fs.writeFile(paths.join(__preview, ".plugins"), JSON.stringify(Object.entries(metadata).filter(([_name, {category}]) => category !== "core").map(([name]) => ({name, enabled:false}))))
43+
fs.writeFile(paths.join(__preview, ".plugins"), JSON.stringify(Object.entries(metadata).filter(([_name, { category }]) => category !== "core").map(([name]) => ({ name, enabled: false }))))
4344
fs.writeFile(paths.join(__preview, ".plugins.base"), JSON.stringify(conf.settings.plugins.base.parts))
4445
fs.writeFile(paths.join(__preview, ".plugins.metadata"), JSON.stringify(metadata))
4546
fs.writeFile(paths.join(__preview, ".templates__"), JSON.stringify(templates))
4647
for (const template in conf.templates) {
4748
fs.writeFile(paths.join(__preview_templates_, template), JSON.stringify(conf.templates[template]))
4849
const __partials = paths.join(__templates, template, "partials")
4950
const __preview_partials = paths.join(__preview_templates, template, "partials")
50-
await fs.mkdir(__preview_partials, {recursive:true})
51+
await fs.mkdir(__preview_partials, { recursive: true })
5152
for (const file of await fs.readdir(__partials))
5253
fs.copyFile(paths.join(__partials, file), paths.join(__preview_partials, file))
5354
}
@@ -71,9 +72,10 @@ fs.copyFile(paths.join(__node_modules, "prismjs/components/prism-markdown.min.js
7172
fs.copyFile(paths.join(__node_modules, "clipboard/dist/clipboard.min.js"), paths.join(__preview_js, "clipboard.min.js"))
7273
//Meta
7374
fs.writeFile(paths.join(__preview, ".version"), JSON.stringify(`${conf.package.version}-preview`))
74-
fs.writeFile(paths.join(__preview, ".hosted"), JSON.stringify({by:"metrics", link:"https://github.com/lowlighter/metrics"}))
75+
fs.writeFile(paths.join(__preview, ".hosted"), JSON.stringify({ by: "metrics", link: "https://github.com/lowlighter/metrics" }))
7576
//About
7677
fs.copyFile(paths.join(__web, "about", "index.html"), paths.join(__preview, "about", "index.html"))
77-
for (const file of await fs.readdir(__web_about))
78+
for (const file of await fs.readdir(__web_about)) {
7879
if (file !== ".statics")
7980
fs.copyFile(paths.join(__web_about, file), paths.join(__preview_about, file))
81+
}

.github/scripts/release.mjs

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
11
//Imports
22
import github from "@actions/github"
33
import paths from "path"
4-
import url from "url"
54
import sgit from "simple-git"
5+
import url from "url"
66

77
//Git setup
88
const __metrics = paths.join(paths.dirname(url.fileURLToPath(import.meta.url)), "../..")
@@ -18,16 +18,16 @@ const repository = process.env.GITHUB_REPOSITORY.match(/^(?<owner>[\s\S]+)[/](?<
1818
const version = process.env.GITHUB_COMMIT_MESSAGE.match(/(?<version>v\d+[.]\d+)/)?.groups?.version ?? null
1919

2020
//Check arguments
21-
if ((!repository)||(!repository.name)||(!repository.owner))
21+
if ((!repository) || (!repository.name) || (!repository.owner))
2222
throw new Error(`Could not parse repository "${process.env.GITHUB_REPOSITORY}"`)
2323
console.log(`Repository: ${repository.owner}/${repository.name}`)
2424
if (!version)
2525
throw new Error(`Could not parse version from "${process.env.GITHUB_COMMIT_MESSAGE}"`)
2626
console.log(`Version: ${version}`)
2727

2828
//Load related pr
29-
const {data:{items:prs}} = await rest.search.issuesAndPullRequests({
30-
q:`repo:${repository.owner}/${repository.name} is:pr is:merged author:${maintainer} assignee:${maintainer} Release ${version} in:title`
29+
const { data: { items: prs } } = await rest.search.issuesAndPullRequests({
30+
q: `repo:${repository.owner}/${repository.name} is:pr is:merged author:${maintainer} assignee:${maintainer} Release ${version} in:title`,
3131
})
3232

3333
//Ensure that there is exactly one pr matching
@@ -40,17 +40,17 @@ console.log(`Using pr#${patchnote.number}: ${patchnote.title}`)
4040

4141
//Check whether release already exists
4242
try {
43-
const {data:{id}} = await rest.repos.getReleaseByTag({owner:repository.owner, repo:repository.name, tag:version})
43+
const { data: { id } } = await rest.repos.getReleaseByTag({ owner: repository.owner, repo: repository.name, tag: version })
4444
console.log(`Release ${version} already exists (#${id}), will replace it`)
45-
await rest.repos.deleteRelease({owner:repository.owner, repo:repository.name, release_id:id})
45+
await rest.repos.deleteRelease({ owner: repository.owner, repo: repository.name, release_id: id })
4646
console.log(`Deleting tag ${version}`)
4747
await git.push(["--delete", "origin", version])
48-
await new Promise(solve => setTimeout(solve, 15*1000))
48+
await new Promise(solve => setTimeout(solve, 15 * 1000))
4949
}
5050
catch {
5151
console.log(`Release ${version} does not exists yet, will create it`)
5252
}
5353

5454
//Publish release
55-
await rest.repos.createRelease({owner:repository.owner, repo:repository.name, tag_name:version, name:`Version ${version.replace(/^v/g, "")}`, body:patchnote.body})
55+
await rest.repos.createRelease({ owner: repository.owner, repo: repository.name, tag_name: version, name: `Version ${version.replace(/^v/g, "")}`, body: patchnote.body })
5656
console.log(`Successfully published`)

source/app/action/index.mjs

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -3,12 +3,12 @@ import core from "@actions/core"
33
import github from "@actions/github"
44
import octokit from "@octokit/graphql"
55
import fs from "fs/promises"
6+
import processes from "child_process"
67
import paths from "path"
78
import sgit from "simple-git"
8-
import processes from "child_process"
9+
import mocks from "../../../tests/mocks/index.mjs"
910
import metrics from "../metrics/index.mjs"
1011
import setup from "../metrics/setup.mjs"
11-
import mocks from "../../../tests/mocks/index.mjs"
1212
process.on("unhandledRejection", error => {
1313
throw error
1414
})
@@ -278,8 +278,8 @@ async function retry(func, {retries = 1, delay = 0} = {}) {
278278
try {
279279
await new Promise(async (solve, reject) => {
280280
let stdout = ""
281-
setTimeout(() => reject("Timeout while waiting for Insights webserver"), 5*60*1000)
282-
const web = await processes.spawn("node", ["/metrics/source/app/web/index.mjs"], {env:{...process.env, NO_SETTINGS: true }})
281+
setTimeout(() => reject("Timeout while waiting for Insights webserver"), 5 * 60 * 1000)
282+
const web = await processes.spawn("node", ["/metrics/source/app/web/index.mjs"], {env:{...process.env, NO_SETTINGS:true}})
283283
web.stdout.on("data", data => (console.debug(`web > ${data}`), stdout += data, /Server ready !/.test(stdout) ? solve() : null))
284284
web.stderr.on("data", data => console.debug(`web > ${data}`))
285285
})
@@ -339,7 +339,7 @@ async function retry(func, {retries = 1, delay = 0} = {}) {
339339
info.break()
340340
info.section("Saving")
341341
info("Output condition", _output_condition)
342-
if ((_output_condition === "data-changed")&&((committer.commit) || (committer.pr))) {
342+
if ((_output_condition === "data-changed") && ((committer.commit) || (committer.pr))) {
343343
const {svg} = await import("../metrics/utils.mjs")
344344
let data = ""
345345
await retry(async () => {
@@ -485,6 +485,7 @@ async function retry(func, {retries = 1, delay = 0} = {}) {
485485
}
486486
else
487487
throw error
488+
488489
}
489490
info("Pull request number", number)
490491
}, {retries:retries_output_action, delay:retries_delay_output_action})
@@ -532,7 +533,7 @@ async function retry(func, {retries = 1, delay = 0} = {}) {
532533
if (delay) {
533534
info.break()
534535
info("Delay before ending job", `${delay}s`)
535-
await new Promise(solve => setTimeout(solve, delay*1000))
536+
await new Promise(solve => setTimeout(solve, delay * 1000))
536537
}
537538

538539
//Success

0 commit comments

Comments
 (0)