Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
spec-change
Advanced tools
Computes specs to re-run when files change
$ 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:
{
"generatedAt": "2024-01-20T03:38:50.803Z",
"folder": "relative path to folder",
"fileMask": "**/*.ts",
"deps": {
"utils/sub/misc.js": ["spec-b.ts"],
"spec-b.ts": ["spec-b.ts"]
}
}
Note: the file will NOT be written if the folder, file mask, and the dependencies tree is the same.
You can check how long finding files and dependencies takes by adding --time
boolean flag. Note: the info is printed to STDERR
stream
$ npx spec-change --folder "path to folder" --mask '**/*.ts' --time
spec-change took 25ms
If you have JS and TS files in the same project, you should use the flag --allowjs
to make sure TS imports from JS files are detected.
$ npx spec-change --folder "path to folder" --allowjs
You can pass path to tsconfig.json
to use to discover dependencies, even when using import path aliases.
$ npx spec-change --folder "path to folder" --ts-config tsconfig.json
If there is tsconfig.json
file in the current folder, it will be used automatically. You can only specify the --ts-config
option or allowJs
.
All files are found using the import
and require
directives.
const { getDependentFiles } = require('spec-change')
// the input paths should be absolute
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.
{
// input files at least dependent on selves
'path/to/spec1.js': ['path/to/spec1.js'],
'path/to/spec2.js': ['path/to/spec2.js'],
...
// the specs spec2 and spec3 imports something from utils
'path/to/utils.js': ['path/to/spec2.js', 'path/to/spec3.js'],
...
}
Finds the source files in the given folder and returns the dependencies object (just like above)
const { getDependsInFolder } = require('spec-change')
// see the "bin/spec-change.js" for example
const deps = getDependsInFolder({
folder: '/absolute/path/to/folder',
fileMask: '**/*.{js,ts,jsx,tsx}',
allowJs: true,
})
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)
// a list of files that depend on the misc file
Run this code with environment variable DEBUG=spec-change
Used to run affected Cypress specs first on CI
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
FAQs
Computes specs to re-run when files change
The npm package spec-change receives a total of 217,233 weekly downloads. As such, spec-change popularity was classified as popular.
We found that spec-change 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
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.