A utility to check whether a directory is an exact clone of another directory. This might be useful, if you have some source code in your repository, that is created by a template. For example, if you have a create-react-app template, and an instance of that template in the same repo. This is helpful for testing purposes, because you don't need to re-create a new app from the template every time you want to test something. The problem in this case is that you have to make sure to keep the test app and the template in sync. In this scenario the clone-check utility will come in handy: It will check whether your test app and template are the same, by running just a single script command.
yarn add --dev clone-checkAdd a script to your package.json to run the clone check:
"scripts": {
"test": "...",
"build": "...",
"template:check": "clone-check -m \"The template is not up-to-date!\" src template tmp test"
},Usage: clone-check [options] <sourceDir> <cloneDir> [ignorePatterns...]
Arguments:
sourceDir The source directory
cloneDir The clone directory to check
ignorePatterns Files and directories to ignore when checking the clone (glob syntax)
Options:
--verbose Increase the console output
-m, --message <message> An optional error message to show when the clone does not match the source
-h, --help display help for command
Basic usage:
clone-check src cloneUse custom error message:
clone-check -m "The clone directory does not have the same contents as the src directory!" src cloneRelative source and clone directories:
clone-check . ../otherAbsolute source and clone directories:
clone-check C:/git/my-app/src C:/git/my-app/cloneIgnore node_modules directory (in all subdirectories):
clone-check src clone **/node_modules/**Ignore test directory (only in root):
clone-check src clone test/**Ignore config.js file (only in root):
clone-check src clone config.jsIgnore test files (in all subdirectories):
clone-check src clone **/*.test.jsMultiple ignore patterns:
clone-check src clone **/*.test.js **/*rc.js config.js **/node_modules/**