@k03mad/actual-versions 1.0.2 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,11 +1,13 @@
1
1
  # Get tool actual version string
2
2
 
3
- ## Global
3
+ ## CLI
4
4
 
5
5
  ```bash
6
- npm i @k03mad/acver -g
6
+ npm i @k03mad/actual-versions -g
7
7
  acver
8
8
  # ╔════════╤════════════════╗
9
+ # ║ aria │ 1.37.0 ║
10
+ # ╟────────┼────────────────╢
9
11
  # ║ chrome │ 126.0.6478.182 ║
10
12
  # ╟────────┼────────────────╢
11
13
  # ║ curl │ 8.8.0 ║
@@ -15,15 +17,22 @@ acver
15
17
  ## API
16
18
 
17
19
  ```bash
18
- npm i @k03mad/acver
20
+ npm i @k03mad/actual-versions
19
21
  ```
20
22
 
21
23
  ```js
22
- import {getChromeVersion, getCurlVersion} from '@k03mad/acver';
24
+ import {
25
+ getAriaVersion
26
+ getChromeVersion,
27
+ getCurlVersion
28
+ } from '@k03mad/actual-versions';
29
+
30
+ const ariaVersion = await getAriaVersion();
31
+ // '1.37.0'
23
32
 
24
- const chrome = await getChromeVersion();
33
+ const chromeVersion = await getChromeVersion();
25
34
  // '126.0.6478.182'
26
35
 
27
- const curl = await getCurlVersion();
36
+ const curlVersion = await getCurlVersion();
28
37
  // '8.8.0'
29
38
  ```
package/app/cli.js CHANGED
@@ -2,18 +2,30 @@
2
2
 
3
3
  import {log} from '@k03mad/simple-log';
4
4
  import chalk from 'chalk';
5
- import {table} from 'table';
5
+ import {getBorderCharacters, table} from 'table';
6
+
7
+ import config from '../config.js';
6
8
 
7
9
  import * as api from './api.js';
8
10
 
9
- const {blue, bold, green} = chalk;
11
+ const {blue, bold, green, red} = chalk;
12
+
13
+ const TOOL_NAME_RE = /get(.+)Version/;
10
14
 
11
15
  const output = await Promise.all(
12
16
  Object.entries(api).map(async ([key, value]) => {
13
17
  const version = await value();
14
- const tool = key.replaceAll(/Version|get/g, '').toLowerCase();
15
- return [blue(bold(tool)), green(version)];
18
+ const tool = key.match(TOOL_NAME_RE)[1].toLowerCase();
19
+
20
+ return [
21
+ blue(bold(tool)),
22
+ version ? green(version) : red('———'),
23
+ ];
16
24
  }),
17
25
  );
18
26
 
19
- log(table(output));
27
+ const formattedTable = table(output, {
28
+ border: getBorderCharacters(config.table.border),
29
+ });
30
+
31
+ log(formattedTable);
package/app/tools/aria.js CHANGED
@@ -8,5 +8,5 @@ const ARIA_VERSION_RE = /href=".+\/releases\/tag\/release-([\d.]+)"/;
8
8
  */
9
9
  export default async () => {
10
10
  const {body} = await requestCache(ARIA_VERSIONS_URL);
11
- return body.match(ARIA_VERSION_RE)[1];
11
+ return body.match(ARIA_VERSION_RE)?.[1];
12
12
  };
@@ -7,5 +7,5 @@ const CHROME_VERSIONS_URL = 'https://googlechromelabs.github.io/chrome-for-testi
7
7
  */
8
8
  export default async () => {
9
9
  const {body} = await requestCache(CHROME_VERSIONS_URL);
10
- return body.channels.Stable.version;
10
+ return body?.channels?.Stable?.version;
11
11
  };
package/app/tools/curl.js CHANGED
@@ -8,5 +8,5 @@ const CURL_VERSION_RE = /href="\/download\/curl-([\d.]+).tar.gz"/;
8
8
  */
9
9
  export default async () => {
10
10
  const {body} = await requestCache(CURL_VERSIONS_URL);
11
- return body.match(CURL_VERSION_RE)[1];
11
+ return body.match(CURL_VERSION_RE)?.[1];
12
12
  };
package/config.js ADDED
@@ -0,0 +1,9 @@
1
+ export default {
2
+ version: {
3
+ re: String.raw`\d[\d.]+$`,
4
+ },
5
+ table: {
6
+ // https://www.npmjs.com/package/table#getbordercharacters
7
+ border: 'honeywell',
8
+ },
9
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@k03mad/actual-versions",
3
- "version": "1.0.2",
3
+ "version": "1.1.1",
4
4
  "description": "Get tool actual version string",
5
5
  "maintainers": [
6
6
  "Kirill Molchanov <k03.mad@gmail.com"
@@ -19,7 +19,7 @@
19
19
  "node": ">=20"
20
20
  },
21
21
  "dependencies": {
22
- "@k03mad/request": "5.8.1",
22
+ "@k03mad/request": "6.0.1",
23
23
  "@k03mad/simple-log": "2.2.1",
24
24
  "chalk": "5.3.0",
25
25
  "table": "6.8.2"
package/tests/api.js CHANGED
@@ -2,24 +2,25 @@ import assert from 'node:assert/strict';
2
2
  import {describe, it} from 'node:test';
3
3
 
4
4
  import * as api from '../app/api.js';
5
+ import config from '../config.js';
5
6
 
6
- const TESTS = {
7
- getAriaVersion: /^\d\.\d+\.\d$/,
8
- getChromeVersion: /^\d{3}(?:\.\d+){3}$/,
9
- getCurlVersion: /^\d\.\d\.\d$/,
10
- };
7
+ const API_FUNCTIONS = [
8
+ 'getAriaVersion',
9
+ 'getChromeVersion',
10
+ 'getCurlVersion',
11
+ ];
11
12
 
12
- describe('api', () => {
13
- const steps = Object.entries(TESTS);
13
+ const versionRe = new RegExp(`^${config.version.re}`);
14
14
 
15
- it('coverage', () => {
16
- assert.equal(steps.length, Object.keys(api).length);
15
+ describe('api', () => {
16
+ it('check tests count', () => {
17
+ assert.equal(API_FUNCTIONS.length, Object.keys(api).length);
17
18
  });
18
19
 
19
- Object.entries(TESTS).forEach(([key, value]) => {
20
- it(key, async () => {
21
- const version = await api[key]();
22
- assert.match(version, value);
20
+ API_FUNCTIONS.forEach(fn => {
21
+ it(`check fn output: ${fn}()`, async () => {
22
+ const version = await api[fn]();
23
+ assert.match(version, versionRe);
23
24
  });
24
25
  });
25
26
  });
package/tests/cli.js CHANGED
@@ -4,17 +4,23 @@ import {before, describe, it} from 'node:test';
4
4
  import {promisify} from 'node:util';
5
5
 
6
6
  import stripAnsi from 'strip-ansi';
7
+ import {getBorderCharacters} from 'table';
8
+
9
+ import config from '../config.js';
7
10
 
8
11
  const cliFile = process.env.npm_package_bin_acver;
9
12
  const exec = promisify(cp.exec);
10
13
 
11
- const TESTS = [
12
- /^aria\s+\d\.\d+\.\d$/,
13
- /^chrome\s+\d{3}(?:\.\d+){3}$/,
14
- /^curl\s+\d\.\d\.\d$/,
14
+ const tableBorderChars = Object.values(getBorderCharacters(config.table.border));
15
+ const tableBorderCharsRe = new RegExp(tableBorderChars.join('|'), 'g');
16
+
17
+ const STDOUT_TOOLS = [
18
+ 'aria',
19
+ 'chrome',
20
+ 'curl',
15
21
  ];
16
22
 
17
- const TABLE_CHARS_RE = /[─│┼═║╔╗╚╝╟╢╤╧]+/g;
23
+ const versionRe = tool => new RegExp(`^${tool}\\s+${config.version.re}`);
18
24
 
19
25
  describe('cli', () => {
20
26
  let versions;
@@ -25,17 +31,19 @@ describe('cli', () => {
25
31
  versions = stdout
26
32
  .split('\n')
27
33
  .map(elem => stripAnsi(elem)
28
- .replaceAll(TABLE_CHARS_RE, '')
34
+ .replaceAll(tableBorderCharsRe, '')
29
35
  .trim(),
30
36
  )
31
37
  .filter(Boolean);
32
38
  });
33
39
 
34
- it('coverage', () => {
35
- assert.equal(TESTS.length, versions.length);
40
+ it('check tests count', () => {
41
+ assert.equal(STDOUT_TOOLS.length, versions.length);
36
42
  });
37
43
 
38
- TESTS.forEach((re, i) => {
39
- it(String(re), () => assert.match(versions[i], re));
44
+ STDOUT_TOOLS.forEach((tool, i) => {
45
+ it(`check stdout output: #${i + 1} tool: ${tool}`, () => {
46
+ assert.match(versions[i], versionRe(tool));
47
+ });
40
48
  });
41
49
  });