Skip to content

Commit

Permalink
chore: Minor Markdown tweaks (istanbuljs#1256)
Browse files Browse the repository at this point in the history
  • Loading branch information
XhmikosR authored and coreyfarrell committed Dec 27, 2019
1 parent fcacc46 commit bed4729
Show file tree
Hide file tree
Showing 5 changed files with 58 additions and 47 deletions.
33 changes: 22 additions & 11 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Istanbul's state of the art command line interface, with support for:

Use your package manager to add it as a dev dependency: `npm i -D nyc` or `yarn add -D nyc`.
You can use nyc to call npm scripts (assuming they don't already have nyc executed in them), like so (replace `mocha` with your test runner everywhere you see it):

```json
{
"scripts": {
Expand Down Expand Up @@ -67,6 +68,7 @@ Please start with the pre-configured [`@istanbuljs/nyc-config-typescript`](https

nyc allows you to inherit other configurations using the key `extends` in the `package.json` stanza, `.nycrc`, or YAML files.
You can then add the specific configuration options you want that aren't in that particular shared config, e.g.

```json
{
"nyc": {
Expand Down Expand Up @@ -108,8 +110,10 @@ This table is a quick TLDR for the rest of this readme and there are more advanc
| `temp-dir` | Directory to output raw coverage information to | `String` | `./.nyc_output` |

Configuration can also be provided by `nyc.config.js` if programmed logic is required:

```js
'use strict';

const defaultExclude = require('@istanbuljs/schema/default-exclude');
const isWindows = require('is-windows');

Expand All @@ -127,7 +131,10 @@ module.exports = {
To publish and reuse your own `nyc` configuration, simply create an npm module that exports your JSON config (via [`index.json`](https://github.com/istanbuljs/istanbuljs/blob/master/packages/nyc-config-typescript/) or a CJS [`index.js`](https://github.com/istanbuljs/istanbuljs/blob/master/packages/nyc-config-hook-run-in-this-context/)).

A more advanced use case would be to combine multiple shared configs in a `nyc.config.js` file:

```js
'use strict';

const babelConfig = require('@istanbuljs/nyc-config-babel');
const hookRunInThisContextConfig = require('@istanbuljs/nyc-config-hook-run-in-this-context');

Expand Down Expand Up @@ -158,9 +165,10 @@ The `exclude` array may also use exclude negated glob patterns, these are specif
Globs are matched using [minimatch](https://www.npmjs.com/package/minimatch).

We use the following process to remove files from consideration:
1. Limit the set of instrumented files to those files in paths listed in the `include` array.
2. Remove any files that are found in the `exclude` array.
3. Restore any exclude negated files that have been excluded in step 2.

1. Limit the set of instrumented files to those files in paths listed in the `include` array.
2. Remove any files that are found in the `exclude` array.
3. Restore any exclude negated files that have been excluded in step 2.

### Using include and exclude arrays

Expand Down Expand Up @@ -231,20 +239,22 @@ If nyc fails to find a directory containing a `package.json` file, it will use t
You can change the project root directory with the `--cwd` option.

nyc uses the project root directory when:
* looking for source files to instrument
* creating globs for include and exclude rules during file selection
* loading custom require hooks from the `require` array

nyc may create artefact directories within the project root, with these defaults:
* the report directory, `<project-root>/coverage`
* the cache directory, `<project-root>/node_modules/.cache/nyc`
* the temp directory, `<project-root>/.nyc_output`
* looking for source files to instrument
* creating globs for include and exclude rules during file selection
* loading custom require hooks from the `require` array

nyc may create artifact directories within the project root, with these defaults:

* the report directory, `<project-root>/coverage`
* the cache directory, `<project-root>/node_modules/.cache/nyc`
* the temp directory, `<project-root>/.nyc_output`

## Require additional modules

The `--require` flag can be provided to `nyc` to indicate that additional modules should be required in the subprocess collecting coverage:

```
```shell
nyc --require esm mocha
```

Expand Down Expand Up @@ -328,6 +338,7 @@ rather than having to ignore every instance of that method:
```

## Combining reports from multiple runs

If for whatever reason you have different test runners in your project or a different series of test runs for different kinds of tests, nyc will automatically combine the coverage report for you if configured correctly with the `--no-clean` flag and the `report` command.
Originally inspired by @janiukjf in #1001, here's an example, where the `test:*` scripts (not shown) invoke only your test runner(s) and not nyc:

Expand Down
6 changes: 3 additions & 3 deletions docs/instrument.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ These files are suitable for client side deployment during end to end testing.
You can either pre-instrument your source, or write instrumented source to a stream.

Run `nyc instrument --help` to display a full list of available command options.
## Pre-instrumented source

## Pre-instrumented source

You can create pre-instrumented source code by running:

```bash
Expand Down
59 changes: 29 additions & 30 deletions docs/profiling.md
Original file line number Diff line number Diff line change
@@ -1,80 +1,79 @@

## Profiling:
# Profiling:

The self-coverage tool can provide a [fairly interesting information on how nyc performs](https://github.com/bcoe/nyc/pull/101#issuecomment-165337057) in real world test suites. Doing this is a bit involved, detailed steps follow.

*Note:* This assumes your locally cloned development version of `nyc` is in `/user/dev/nyc`, and that you are profiling against the AVA test suite in `/user/dev/ava`. Adapt as required.

### Initial Setup (NYC)
## Initial Setup (NYC)

We must use `npm link`, and ensure we have fresh "self-coverage" scripts generated.

```sh
# Go to the local clone of nyc
$ cd /user/dev/nyc
cd /user/dev/nyc

# Link the local clone globally
$ npm link
npm link

# Create the self-coverage instrumented files
$ node ./build-self-coverage
node ./build-self-coverage
```

### Initial Setup (Test Project)
## Initial Setup (Test Project)

```sh
# CD to the real world test suite you want to profile against
$ cd /user/dev/ava
cd /user/dev/ava

# Link the globally linked nyc into your local node_modules
$ npm link nyc
npm link nyc
```

This will likely not work with `tap --coverage`, since tap will try to use it's own older copy of nyc instead of your globally linked one. Modify the test script in your test project so it uses the `nyc` binary directly, and disable `tap`s version with the `--no-cov` flag:

`package.json`:
`package.json`:

```json
{
"scripts" : {
"test": "nyc tap --no-cov test/*.js"
}
}
```

```json
{
"scripts" : {
"test": "nyc tap --no-cov test/*.js"
}
}
```
### Each Run
## Each Run

```sh
# Clear existing self coverage (`trash` ~== `rm -rf`)
$ cd /user/dev/nyc
$ trash ./.self_coverage
cd /user/dev/nyc
trash ./.self_coverage

# Clear the `.nyc_cache` folder in your test project
$ cd /user/dev/ava
$ trash ./.nyc_cache
cd /user/dev/ava
trash ./.nyc_cache

# Run your test suite
$ npm test
npm test

# Go back to the `nyc` folder and create a self-coverage report
$ cd /user/dev/nyc
$ npm run report
cd /user/dev/nyc
npm run report
```

A detailed profile of your test run now exists in `/user/dev/nyc/coverage/lcov-report`

*Note: * `trash` is a safer version of `rm -rf`. Install via `npm i -g trash-cli`. [More info](https://github.com/sindresorhus/guides/blob/master/how-not-to-rm-yourself.md).
*Note:* `trash` is a safer version of `rm -rf`. Install via `npm i -g trash-cli`. [More info](https://github.com/sindresorhus/guides/blob/master/how-not-to-rm-yourself.md).

### WARNING: Self coverage can cause some confusing problems.
## WARNING: Self coverage can cause some confusing problems.

If `index.covered.js` exists, it will be used instead of the normal file. This means your changes to `index.js` will not have an effect until you recreate or delete the self coverage files. Unless you are trying to do some profiling, you should probably delete them so the regular files are used.

You can delete the self coverage scripts and use the regular ones as follows:

```sh
# Go to nyc directory and remove the self coverage scripts
$ cd /user/dev/nyc
$ npm run clean
cd /user/dev/nyc
npm run clean
```

You can rerun `node ./build-self-coverage` scripts as desired to re-enable self-coverage.

5 changes: 3 additions & 2 deletions docs/setup-codecov.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,12 @@
## Quick start

Assuming your `npm test` does not run `nyc` and you have the `npx` executable (npm v5.2+), have your CI runner execute the following:

```shell
npx nyc --reporter=lcov npm test && npx codecov
```

## Without `npx` - TravisCI example using npm scripts
## Without `npx` - Travis CI example using npm scripts

1. add the codecov and nyc dependencies:

Expand All @@ -28,7 +29,7 @@ npx nyc --reporter=lcov npm test && npx codecov
}
```

3. For private repos, add the environment variable `CODECOV_TOKEN` to travis.
3. For private repos, add the environment variable `CODECOV_TOKEN` to Travis CI.

4. add the following to your `.travis.yml`:

Expand Down
2 changes: 1 addition & 1 deletion docs/setup-coveralls.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ integrated with coveralls and travis-ci.org:
}
```

3. For private repos, add the environment variable `COVERALLS_REPO_TOKEN` to travis.
3. For private repos, add the environment variable `COVERALLS_REPO_TOKEN` to Travis CI.

4. add the following to your `.travis.yml`:

Expand Down

0 comments on commit bed4729

Please sign in to comment.