Once you have Node.js
v8.x on your machine, you can use npx
or install sonarwhal
globally
to use it.
Just run the following command:
npx sonarwhal https://example.com
This will start the wizard to create a .sonarwhalrc
file, and then
analyze https://example.com
.
Windows users: Currently npx
has an issue in this
platform.
npm install -g --engine-strict sonarwhal
Create a .sonarwhalrc
file by running this command and following the
instructions:
sonarwhal --init
Scan a website:
sonarwhal https://example.com
For more in depth information on how to get started, configurations, and more, see the online user guide, or the local version for the most recent (and unstable) content.
To know more about the internals of sonarwhal
, how to create new
rules, collectors, formatters, etc, take a look at the online
contributor guide (or
the local version).
The following are meant only if you are working on sonarwhal
's codebase:
npm run site <url>
will analyze the website with the current configuration and using the latest build available in thedist
directory.npm run site -- --debug <url>
same as above, but will show all the debug information.npm run lint
will lint the code.npm run watch
will start watchmode. This is the recommended task to run in the background while developing. It does the following:- sync all the resources from
src
todist
(basically anything that is not a.ts
file). - compile the typescript files incrementally to
dist
. - run all the tests incrementally.
- sync all the resources from
npm run build
will do the same as thewatch
task but only once and without running the tests.npm test
will run the tests with code coverage using the code available indist
. It is better to run this task afterbuild
.
The initialization of the watch
task is a bit especial: it will
compile and copy the assets before starting to watch for new files
to copy, build, or test. Because of concurrency, it might be that
the tests are run twice initially.
This project adheres to the JS Foundation's code of conduct. By participating in this project you agree to abide by its terms.
The code is available under the Apache 2.0 license.