
Security News
MCP Community Begins Work on Official MCP Metaregistry
The MCP community is launching an official registry to standardize AI tool discovery and let agents dynamically find and install MCP servers.
A modern, asynchronous Node.js API for c8.
c8 leverages Node.js built-in V8 JavaScript code coverage to produce Istanbul-compatible reports.
c8js offers a usable API to access all c8 commands programmatically in Node.js with JavaScript functions.
c8js is not a wrapper around the command line interface: it calls c8 library functions in the current thread instead of spawning an instrumenter process.
Use npm install
:
npm i -D c8js
c8js exports the functions c8js
(the default export), report
, and checkCoverage
, in place of the commands c8
, c8 report
, and c8 check-coverage
respectively.
Additionally, c8js exports the function exec
that just runs a command and saves V8 coverage data.
While c8 commands accept inline arguments, c8js functions accept in-code options. All c8js options can be used in-code with all functions, but some options are only relevant to some of the functions. In-code options override options defined in .c8rc or another configuration file.
An important difference is that all c8js functions throw exceptions in situations where c8 commands would terminate the process with a nonzero exit code.
For detailed usage information, see the API documentation.
This will run mocha --check-leaks --timeout=10000 test/*.spec.js
and produce html
and text-summary
coverage reports.
async function runMocha()
{
const { default: c8js } = await import('c8js');
await c8js
(
'node_modules/mocha/bin/mocha.js',
['--check-leaks', '--timeout=10000', 'test/*.spec.js'],
{ reporter: ['html', 'text-summary'] },
);
}
npx
Similar to the previous example, but uses npx
to locate and run Mocha.
npx
will download packages from the npm registry if necessary.
async function runMocha()
{
const { default: c8js, commands } = await import('c8js');
await c8js
(
commands.npx,
['mocha', '--check-leaks', '--timeout=10000', 'test/*.spec.js'],
{ reporter: ['html', 'text-summary'] },
);
}
npm test
This will run npm test
with the default coverage options.
async function runTest()
{
const { default: c8js, commands } = await import('c8js');
await c8js(commands.npm, ['test']);
}
node --test
(Node.js ≥ 18.1)Node.js 18.1 introduces the command line flag --test
that launches the built-in Test runner.
The following function shows how to run node --test
with default coverage options.
async function runTest()
{
const { default: c8js } = await import('c8js');
await c8js(process.execPath, ['--test']);
}
NOTE: Some versions of Node.js contain a bug that causes node --test
to crash when run from c8.
The affected Node.js versions are 18.11.0, 18.12.0, 18.12.1, 19.0.0 and 19.0.1.
To use c8js in different build scripts or packages with similar settings, it is useful to export a function that calls c8js with the set of shared options. This function can be imported by each build script and invoked with specific parameters.
// create-coverage.js
export async function createCoverage(options)
{
const { default: c8js, commands } = await import('c8js');
await c8js
(
commands.npm,
['test'],
{
all: true,
src: 'lib',
throwExecError: 'late',
watermarks:
{
branches: [90, 100],
functions: [90, 100],
lines: [90, 100],
statements: [90, 100],
},
...options,
}
);
}
// build.js
import { createCoverage } from './create-coverage.js';
await createCoverage({ src: ['lib', 'src/app'], timeout: 300 * 1000 });
c8js requires Node.js 16 or later. The minimum supported c8 version is 8.0.0.
v0.8.0 (2024-07-25)
Fail
objects of a LowCoverageError
.<a name="v0.7.0"></a>
FAQs
A modern, asynchronous Node.js API for c8
The npm package c8js receives a total of 221 weekly downloads. As such, c8js popularity was classified as not popular.
We found that c8js demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The MCP community is launching an official registry to standardize AI tool discovery and let agents dynamically find and install MCP servers.
Research
Security News
Socket uncovers an npm Trojan stealing crypto wallets and BullX credentials via obfuscated code and Telegram exfiltration.
Research
Security News
Malicious npm packages posing as developer tools target macOS Cursor IDE users, stealing credentials and modifying files to gain persistent backdoor access.