spec-change
Computes specs to re-run when files change
Use
CLI
$ npx spec-change --folder "path to folder with specs"
Prints a JSON object with the list of JavaScript files. For each file prints the list of dependent files. For example, if spec.js
imports or requires utils.js
file, then it will print something like:
{
"spec.js": ["spec.js"],
"utils.js": ["spec.js"]
}
You can specify the file mask
# start the search from TS files only
$ npx spec-change --folder "path to folder" --mask '**/*.ts'
You can save detected dependencies into a JSON file
$ npx spec-change --folder "path to folder" --mask '**/*.ts' --save-deps my-deps.json
The saved file will be something like:
{
"folder": "relative path to folder",
"fileMask": "**/*.ts",
"deps": {
"utils/sub/misc.js": ["spec-b.ts"],
"spec-b.ts": ["spec-b.ts"]
}
}
NPM module
All files are found using the import
and require
directives.
getDependentFiles
const { getDependentFiles } = require('spec-change')
const deps = getDependentFiles([
'path/to/spec1.js',
'path/to/spec2.js',
...
], 'path/to/common/directory')
The output will be an object with all files (the initial plus all files they import or require). Each key will be a relative filename to the directory. The values will be arrays, with relative filenames of files dependent on the key file.
{
'path/to/spec1.js': ['path/to/spec1.js'],
'path/to/spec2.js': ['path/to/spec2.js'],
...
'path/to/utils.js': ['path/to/spec2.js', 'path/to/spec3.js'],
...
}
getDependsInFolder
Finds the source files in the given folder and returns the dependencies object (just like above)
const { getDependsInFolder } = require('spec-change')
const deps = getDependsInFolder(
'/absolute/path/to/folder',
(fileMask = '**/*.{js,ts}'),
)
affectedFiles
Takes the dependencies computed using getDependsInFolder
or getDependentFiles
and a list of source files and produces a list of potentially affected files.
const { getDependsInFolder, affectedFiles } = require('spec-change')
const deps = getDependsInFolder(directory)
const changedFiles = ['utils/sub/misc.js']
const affected = affectedFiles(deps, changedFiles)
Debugging
Run this code with environment variable DEBUG=spec-change
Examples
Used to run affected Cypress specs first on CI
Small print
Author: Gleb Bahmutov <gleb.bahmutov@gmail.com> © 2022
License: MIT - do anything with the code, but don't blame me if it does not work.
Support: if you find any problems with this module, email / tweet /
open issue on Github