2017-12-28 11:18:33 +00:00
|
|
|
|
# Testing
|
|
|
|
|
|
|
|
|
|
We aim to keep the code coverage of Electron high. We ask that all pull
|
|
|
|
|
request not only pass all existing tests, but ideally also add new tests
|
|
|
|
|
to cover changed code and new scenarios. Ensuring that we capture as
|
|
|
|
|
many code paths and use cases of Electron as possible ensures that we
|
|
|
|
|
all ship apps with fewer bugs.
|
|
|
|
|
|
|
|
|
|
This repository comes with linting rules for both JavaScript and C++ –
|
|
|
|
|
as well as unit and integration tests. To learn more about Electron's
|
|
|
|
|
coding style, please see the [coding-style(coding-style.md) document.
|
|
|
|
|
|
|
|
|
|
## Linting
|
|
|
|
|
To ensure that your JavaScript is in compliance with the Electron coding
|
|
|
|
|
style, run `npm run lint-js`, which will run `standard` against both
|
|
|
|
|
Electron itself as well as the unit tests. If you are using an editor
|
|
|
|
|
with a plugin/addon system, you might want to use one of the many
|
2018-01-22 22:49:30 +00:00
|
|
|
|
[StandardJS addons][standard-addons] to be informed of coding style
|
2017-12-28 11:18:33 +00:00
|
|
|
|
violations before you ever commit them.
|
|
|
|
|
|
|
|
|
|
To run `standard` with parameters, run `npm run lint-js --` followed by
|
|
|
|
|
arguments you want passed to `standard`.
|
|
|
|
|
|
|
|
|
|
To ensure that your C++ is in compliance with the Electron coding style,
|
|
|
|
|
run `npm run lint-cpp`, which runs a `cpplint` script. We recommend that
|
|
|
|
|
you use `clang-format` and prepared [a short tutorial](clang-format.md).
|
|
|
|
|
|
|
|
|
|
There is not a lot of Python in this repository, but it too is governed
|
|
|
|
|
by coding style rules. `npm run lint-py` will check all Python, using
|
|
|
|
|
`pylint` to do so.
|
|
|
|
|
|
|
|
|
|
## Unit Tests
|
|
|
|
|
|
|
|
|
|
To run all unit tests, run `npm run test`. The unit tests are an Electron
|
|
|
|
|
app (surprise!) that can be found in the `spec` folder. Note that it has
|
|
|
|
|
its own `package.json` and that its dependencies are therefore not defined
|
|
|
|
|
in the top-level `package.json`.
|
|
|
|
|
|
|
|
|
|
To run only a selected number of tests, run `npm run test -match=NAME`,
|
|
|
|
|
replacing the `NAME` with the file name of the test suite you would like
|
|
|
|
|
to run. As an example: If you want to run only IPC suites, you would run
|
|
|
|
|
`npm run test -match=ipc`.
|
|
|
|
|
|
|
|
|
|
[standard-addons]: https://standardjs.com/#are-there-text-editor-plugins
|