Purpose
This eslint
plugin automatically updates numeric id’s in unit test descriptions:
data:image/s3,"s3://crabby-images/8eb56/8eb565111aa0639cb85365002db1c32963f6c4cc" alt="Fig 1. Automatically-updated test numbers"
so that you don’t need to rely on row numbers, or worse, search by unit test’s description label.
For example, here’s a real-life terminal output, codsen-parser
unit tests, tap unit test runner:
data:image/s3,"s3://crabby-images/3e733/3e733f5de97147a59ffd70f8f3b08c6f466deb88" alt="Fig 2. Unit tests with numbers"
Notice, there were 104 tests above and tap didn’t report any row numbers for “todo” tests.
Or, here’s the uvu reporting that assert 07.01
is failing:
data:image/s3,"s3://crabby-images/ccc69/ccc69324a6ef390313f042fb2a579a480ae355a6" alt="Fig 3. uvu test 07.01 failing"
This program updates both test names and assert messages:
data:image/s3,"s3://crabby-images/d4c3b/d4c3bf710acbf2a9db6a7b7dd43715d0e5c6d21f" alt="Fig 4. Bunch of numbers to maintain"
As a result, it becomes easier to locate the failing tests. In the long run, everything adds up, every small thing like this — we write hundreds (if not thousands) of unit tests per month, so every second counts.
Features
Supports:
- ava
- uvu
- tap
Codsen monorepo has been using all these unit test runners above; currently we’re on uvu
, and it’s been using this plugin on every one of them.
Install
npm i -D eslint-plugin-test-num
Configuration
Use our preset:
"extends": [
"eslint:recommended",
"plugin:test-num/recommended"
]
If you do not use a preset you will need to specify individual rules and add extra configuration.
Add "test-num"
to the plugins section:
{
"plugins": ["test-num"]
}
Enable the rule:
"rules": {
"test-num/correct-test-num": "error",
}
Also
Check out: eslint-plugin-row-num
— it updates console.log
row numbers so you know where exactly did that console.log
came from. It’s especially relevant when you Rollup your programs and tests are ran against a file different from source from which console.log
originate.