Skip to content

Commit

Permalink
refactor: badge
Browse files Browse the repository at this point in the history
  • Loading branch information
stopsopa committed Sep 6, 2023
1 parent 676749a commit a00e581
Show file tree
Hide file tree
Showing 5 changed files with 355 additions and 12 deletions.
10 changes: 8 additions & 2 deletions .github/workflows/playwright.yml
Original file line number Diff line number Diff line change
Expand Up @@ -76,13 +76,19 @@ jobs:

- name: UNIT TESTS
run: |
/bin/bash jest.sh
mkdir -p coverage
/bin/bash jest.sh | tee coverage/for-coverage-badge.log
- name: JASMINE TESTS
if: matrix.version == 18
run: |
NODE_API_PORT=4273 /bin/bash jasmine/test.sh --env .env -- --target docker
- name: generate coverage badge
if: matrix.version == 18
run: |
cat coverage/for-coverage-badge.log | node bash/node/coverage-badge.js --output coverage/coverage-badge.svg
- name: IIFE TEST # https://esbuild.github.io/api/#format-iife
if: matrix.version == 18
run: |
Expand Down
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
[![npm version](https://badge.fury.io/js/%40stopsopa%2Fvalidator.svg)](https://badge.fury.io/js/%40stopsopa%2Fvalidator)
[![npm version](https://shields.io/npm/v/%40stopsopa%2Fvalidator)](https://www.npmjs.com/package/%40stopsopa%2Fvalidator)
[![NpmLicense](https://img.shields.io/npm/l/@stopsopa/validator.svg)](https://github.com/stopsopa/validator/blob/master/LICENSE)
![jest coverage](https://stopsopa.github.io/validator/coverage/coverage-badge.svg)


## Table of Contents

Expand Down
56 changes: 56 additions & 0 deletions bash/node/coverage-badge-clean.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
# remove all from coverage/* directory, except to file coverage/coverage-badge.svg

cat <<EEE
No need for this one really, I will not remove content of directory coverage before publishing to github actions
but it's still interesting script to remove everything from directory except SOMETHING
EEE

exit 1

_SHELL="$(ps "${$}" | grep "${$} " | grep -v grep | sed -rn "s/.*[-\/]+(bash|z?sh) .*/\1/p")"; # bash || sh || zsh
case ${_SHELL} in
zsh)
_DIR="$( cd "$( dirname "${(%):-%N}" )" && pwd -P )"
_0="$( basename "${(%):-%N}" )"
_SCRIPT="${(%):-%N}"
_BINARY="/bin/zsh"
_PWD="$(pwd)"
;;
sh)
_DIR="$( cd "$( dirname "${0}" )" && pwd -P )"
_0="$( basename "${0}" )"
_SCRIPT="${0}"
_BINARY="/bin/sh"
_PWD="$(pwd)"
;;
*)
_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd -P )"
_0="$( basename "${BASH_SOURCE[0]}" )"
_SCRIPT="${BASH_SOURCE[0]}"
_BINARY="/bin/bash"
_PWD="$(pwd)"
;;
esac

set -e
set -x

cd "${_DIR}/../../coverage"

set +x

LIST="$(find . -mindepth 1 -maxdepth 1 | grep -v -i -E '^\./coverage-badge\.svg$' || true)"

if [ "${LIST}" = "" ]; then
echo nothing found to remove
else
cat <<EEE
deleting:
${LIST}
EEE
fi

cat <<EEE | xargs -I % rm -rf "%"
${LIST}
EEE
269 changes: 269 additions & 0 deletions bash/node/coverage-badge.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,269 @@
/**
* badge svg taken from: https://github.com/jpb06/jest-badges-action
*
* to generate use jest.config.js:
{
...
coverageReporters: ["html", "text"],
}
// more about https://github.com/stopsopa/nlab
gather text report from jest:
/bin/bash jest.sh | tee coverage/for-coverage-badge.log
then you generate svg badge file:
cat coverage/for-coverage-badge.log | node bash/node/coverage-badge.js --output coverage/coverage-badge.svg
and then you add badge to README.md:
![jest coverage](https://stopsopa.github.io/nlab/coverage/coverage-badge.svg)
# NOTICE: there is script bash/node/coverage-badge-clean.sh for cleaning directory coverage/*
-----------------
coverage badge tresholds:
95 up to and including 100% - good ( #4c1 )
90 up to 95% - acceptable ( #a3c51c )
75 up to 90% - medium ( #dfb317 )
0 up to 75% - low ( #e05d44 )
no coverage - unknown ( #9f9f9f )
from: https://docs.gitlab.com/ee/user/project/badges.html#test-coverage-report-badge-colors-and-limits
g(gitlab Test coverage report badge colors and limits)
or from: https://labs.etsi.org/rep/help/user/project/badges.md#test-coverage-report-badge-colors-and-limits
*/

const fs = require("fs");

const script = "coverage-badge.js";

const th = (msg) => new Error(`${script} error: ${msg}`);

const args = (function (obj, tmp) {
process.argv.slice(2).map((a) => {
if (a.indexOf("--") === 0) {
tmp = a.substring(2).replace(/^\s*(\S*(\s+\S+)*)\s*$/, "$1");

if (tmp) {
obj[tmp] = typeof obj[tmp] === "undefined" ? true : obj[tmp];
}

return;
}

if (a === "true") {
a = true;
}

if (a === "false") {
a = false;
}

if (tmp !== null) {
if (obj[tmp] === true) {
return (obj[tmp] = [a]);
}

try {
obj[tmp].push(a);
} catch (e) {}
}
});

Object.keys(obj).map((k) => {
obj[k] !== true && obj[k].length === 1 && (obj[k] = obj[k][0]);
obj[k] === "false" && (obj[k] = false);
});

return {
count: () => Object.keys(obj).length,
all: () => JSON.parse(JSON.stringify(obj)),
get: (key, def) => {
var t = JSON.parse(JSON.stringify(obj));

if (typeof def === "undefined") return t[key];

return typeof t[key] === "undefined" ? def : t[key];
},
string: (key, def) => {
var t = JSON.parse(JSON.stringify(obj));

return typeof t[key] === "string" ? t[key] : def;
},
};
})({});

const file = args.get("output");

if (typeof file !== "string") {
throw th(`--output argument is not specified`);
}

const rl = require("readline").createInterface({
input: process.stdin,
output: process.stdout,
terminal: false, // This allows reading without echoing input
});

const p = [];

function add(...args) {
args.forEach((d) => p.push(parseFloat(d)));
}

const reg = /^.*?\|\s*([\d\.]+)\s*\|\s*([\d\.]+)\s*\|\s*([\d\.]+)\s*\|\s*([\d\.]+).*$/;

let lines = [];

// (87.47 + 93.27 + 90.34 + 87.58) / 4
// 89.665
rl.on("line", (line) => {
if (lines.length < 4) {
if (lines.length > 1) {
lines.push(line);
}

if (line.includes("Uncovered Line #s")) {
lines.push(line);
} else if (lines.length < 2) {
lines[0] = line;
}
} else {
const foundLine = lines.at(-1);

let foundNumbers;

let math;

let m = foundLine.match(reg);

if (Array.isArray(m) && m.length === 5) {
const [_, a, b, c, d] = m;

foundNumbers = `${script} found numbers: ${a} ${b} ${c} ${d}`;

math = `(${a} + ${b} + ${c} + ${d}) / 4 = `;

add(a, b, c, d);
}

let result = 0;

if (p.length > 0) {
const sum = p.reduce((acc, x) => acc + x, 0);

result = (sum / p.length).toFixed(2);

const t = result.split(".");

t[1] = trim(t[1], "0", "r");

result = t[0];

if (t[1]) {
result += "." + t[1];
}
}

math += String(result);

let color = "#9f9f9f";

if (typeof result === "string") {
if (result >= 0) {
color = "#e05d44";
}

if (result >= 75) {
color = "#dfb317";
}

if (result >= 90) {
color = "#a3c51c";
}

if (result >= 95) {
color = "#4c1";
}
}

if (typeof result === "string") {
if (result.length === 1) {
result = `0${result}.0`;
}

if (result.length < 4) {
result += ".0";
}
}

console.log(`
${script} report:
foundLine : ${foundLine}
foundNumbers : ${foundNumbers}
math : ${math}
result:
coverage percentage : ${result}%
color : ${color}
url encoded : data:image/svg+xml;base64,${Buffer.from(
`<svg xmlns='http://www.w3.org/2000/svg'><rect x='0' y='0' width='300' height='200' fill='${color}' /></svg>`,
).toString("base64")}
file: >${file}< generated
`);

fs.writeFileSync(
file,
`<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="155" height="20" role="img" aria-label="jest coverage: ${result}%"><title>jest coverage: ${result}%</title><linearGradient id="s" x2="0" y2="100%"><stop offset="0" stop-color="#bbb" stop-opacity=".1"/><stop offset="1" stop-opacity=".1"/></linearGradient><clipPath id="r"><rect width="155" height="20" rx="3" fill="#fff"/></clipPath><g clip-path="url(#r)"><rect width="102" height="20" fill="#555"/><rect x="102" width="53" height="20" fill="${color}"/><rect width="155" height="20" fill="url(#s)"/></g><g fill="#fff" text-anchor="middle" font-family="Verdana,Geneva,DejaVu Sans,sans-serif" text-rendering="geometricPrecision" font-size="110"><image x="5" y="3" width="14" height="14" xlink:href=""/><text aria-hidden="true" x="605" y="150" fill="#010101" fill-opacity=".3" transform="scale(.1)" textLength="750">jest coverage</text><text x="605" y="140" transform="scale(.1)" fill="#fff" textLength="750">jest coverage</text><text aria-hidden="true" x="1275" y="150" fill="#010101" fill-opacity=".3" transform="scale(.1)" textLength="430">${result}%</text><text x="1275" y="140" transform="scale(.1)" fill="#fff" textLength="430">${result}%</text></g></svg>`,
);

process.exit(0);
}
});

rl.on("close", () => {
console.log(`
${script} report:
line with stats not found
`);

process.exit(1);
});

var matchOperatorsRe = /[\^\$\.\*\+\-\?\=\!\:\|\\\/\(\)\[\]\{\}\,]/g;

function pregQuote(str) {
if (typeof str !== "string") {
return false;
}

return str.replace(matchOperatorsRe, "\\$&");
}

function trim(string, charlist, direction) {
if (typeof string !== "string") {
return false;
}

direction = direction || "rl";
charlist = pregQuote(charlist || "");
charlist = charlist || " \\n";
direction.indexOf("r") + 1 && (string = string.replace(new RegExp("^(.*?)[" + charlist + "]*$", "gm"), "$1"));
direction.indexOf("l") + 1 && (string = string.replace(new RegExp("^[" + charlist + "]*(.*)$", "gm"), "$1"));
return string;
}
Loading

0 comments on commit a00e581

Please sign in to comment.