Merge branch 'master' of https://github.com/lowlighter/metrics
This commit is contained in:
23
.github/scripts/presets_examples.mjs
vendored
23
.github/scripts/presets_examples.mjs
vendored
@@ -1,10 +1,10 @@
|
||||
//Imports
|
||||
import fs from "fs/promises"
|
||||
import processes from "child_process"
|
||||
import yaml from "js-yaml"
|
||||
import sgit from "simple-git"
|
||||
import paths from "path"
|
||||
import sgit from "simple-git"
|
||||
import url from "url"
|
||||
import fs from "fs/promises"
|
||||
|
||||
//Mode
|
||||
const [mode = "dryrun"] = process.argv.slice(2)
|
||||
@@ -14,8 +14,8 @@ console.log(`Mode: ${mode}`)
|
||||
const __metrics = paths.join(paths.dirname(url.fileURLToPath(import.meta.url)), "../..")
|
||||
const __presets = paths.join(__metrics, ".presets")
|
||||
|
||||
if ((!await fs.access(__presets).then(_ => true).catch(_ => false))||(!(await fs.lstat(__presets)).isDirectory()))
|
||||
await sgit().clone(`https://github-actions[bot]:${process.env.GITHUB_TOKEN}@github.com/lowlighter/metrics`, __presets, {"--branch":"presets", "--single-branch":true})
|
||||
if ((!await fs.access(__presets).then(_ => true).catch(_ => false)) || (!(await fs.lstat(__presets)).isDirectory()))
|
||||
await sgit().clone(`https://github-actions[bot]:${process.env.GITHUB_TOKEN}@github.com/lowlighter/metrics`, __presets, { "--branch": "presets", "--single-branch": true })
|
||||
const git = sgit(__presets)
|
||||
await git.pull()
|
||||
const staged = new Set()
|
||||
@@ -49,14 +49,16 @@ for (const path of await fs.readdir(__presets)) {
|
||||
|
||||
//Example
|
||||
console.log(`generating: ${preset}/example.svg`)
|
||||
const svg = await action.run({config_presets:`@${preset}`, debug_print: true, plugins_errors_fatal: true, dryrun: true, use_mocked_data: true, verify: true, token:"MOCKED_TOKEN"})
|
||||
const svg = await action.run({ config_presets: `@${preset}`, debug_print: true, plugins_errors_fatal: true, dryrun: true, use_mocked_data: true, verify: true, token: "MOCKED_TOKEN" })
|
||||
await fs.writeFile(paths.join(__presets, path, "example.svg"), svg)
|
||||
staged.add(paths.join(__presets, path, "example.svg"))
|
||||
|
||||
//Readme
|
||||
console.log(`generating: ${preset}/README.svg`)
|
||||
const {name, description} = await yaml.load(await fs.readFile(paths.join(__presets, preset, "preset.yml")))
|
||||
await fs.writeFile(paths.join(__presets, path, "README.md"), `
|
||||
const { name, description } = await yaml.load(await fs.readFile(paths.join(__presets, preset, "preset.yml")))
|
||||
await fs.writeFile(
|
||||
paths.join(__presets, path, "README.md"),
|
||||
`
|
||||
<table>
|
||||
<tr><th><h3>${name}</h3></th></tr>
|
||||
<tr><td align="center"><p>${description}</p></td></tr>
|
||||
@@ -65,7 +67,8 @@ for (const path of await fs.readdir(__presets)) {
|
||||
<img width="900" height="1" alt="">
|
||||
</td></tr>
|
||||
</table>
|
||||
`.trim())
|
||||
`.trim(),
|
||||
)
|
||||
staged.add(paths.join(__presets, path, "README.md"))
|
||||
}
|
||||
|
||||
@@ -78,6 +81,6 @@ if (mode === "publish") {
|
||||
.add([...staged])
|
||||
.commit("ci: auto-regenerate files")
|
||||
.push("origin", "presets")
|
||||
console.log(gitted)
|
||||
console.log(gitted)
|
||||
}
|
||||
console.log("Success!")
|
||||
console.log("Success!")
|
||||
|
||||
@@ -19,7 +19,7 @@ Generate metrics that can be embedded everywhere, including your GitHub profile
|
||||
</tr>
|
||||
<tr>
|
||||
<th colspan="2" align="center">
|
||||
<h3><a href="/README.md#-plugins">🧩 Customizable with 39 plugins and 239 options!</a></h3>
|
||||
<h3><a href="/README.md#-plugins">🧩 Customizable with 39 plugins and 240 options!</a></h3>
|
||||
</th>
|
||||
</tr>
|
||||
<tr>
|
||||
|
||||
@@ -902,6 +902,19 @@ This option has no effects on forks (images will always be rebuilt from Dockerfi
|
||||
<i>(space-separated)</i>
|
||||
<br>
|
||||
<b>allowed values:</b><ul><li>--cakeday</li><li>--hireable</li><li>--halloween</li><li>--error</li></ul></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td nowrap="nowrap"><code>debug_print</code></td>
|
||||
<td rowspan="2"><p>Print output in console</p>
|
||||
<img width="900" height="1" alt=""></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td nowrap="nowrap">⏯️ Cannot be preset<br>
|
||||
🔧 For development<br>
|
||||
✨ On <code>master</code>/<code>main</code><br>
|
||||
<b>type:</b> <code>boolean</code>
|
||||
<br>
|
||||
<b>default:</b> no<br></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td nowrap="nowrap"><code>dryrun</code></td>
|
||||
|
||||
@@ -30,21 +30,21 @@ for (const path of fss.readdirSync(__presets)) {
|
||||
test("syntax is valid", () => expect(true).toBe(true))
|
||||
try {
|
||||
//Load schema
|
||||
const {properties} = yaml.load(fss.readFileSync(paths.join(__presets, "@schema", `${preset.schema}.yml`)))
|
||||
const { properties } = yaml.load(fss.readFileSync(paths.join(__presets, "@schema", `${preset.schema}.yml`)))
|
||||
test("schema is valid", () => expect(preset.schema).toBeDefined())
|
||||
//Test schema
|
||||
for (const [key, {type, required}] of Object.entries(properties)) {
|
||||
for (const [key, { type, required }] of Object.entries(properties)) {
|
||||
if (required)
|
||||
test(`preset.${key} is defined`, () => expect(preset[key]).toBeDefined())
|
||||
test(`preset.${key} type is ${type}`, () => {
|
||||
switch (true) {
|
||||
case /^'.*'$/.test(type):{
|
||||
const value = type.substring(1, type.length-1)
|
||||
case /^'.*'$/.test(type): {
|
||||
const value = type.substring(1, type.length - 1)
|
||||
expect(preset[key]).toBe(value)
|
||||
return
|
||||
}
|
||||
case /\{\}$/.test(type):{
|
||||
const typed = type.substring(0, type.length-2)
|
||||
case /\{\}$/.test(type): {
|
||||
const typed = type.substring(0, type.length - 2)
|
||||
expect(typeof preset[key]).toBe("object")
|
||||
if (typed !== "unknown") {
|
||||
for (const value of Object.values(preset[key]))
|
||||
@@ -52,8 +52,8 @@ for (const path of fss.readdirSync(__presets)) {
|
||||
}
|
||||
return
|
||||
}
|
||||
case /\[\]$/.test(type):{
|
||||
const typed = type.substring(0, type.length-2)
|
||||
case /\[\]$/.test(type): {
|
||||
const typed = type.substring(0, type.length - 2)
|
||||
expect(Array.isArray(preset[key])).toBe(true)
|
||||
if (typed !== "unknown") {
|
||||
for (const value of Object.values(preset[key]))
|
||||
@@ -75,4 +75,4 @@ for (const path of fss.readdirSync(__presets)) {
|
||||
test("syntax is valid", () => expect(false).toBe(true))
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user