To get started working on the project:
-
Install dependencies:
- Install Node.js (LTS version)
npm install -g yarn
yarn install
-
Run all build, lint, and test steps:
yarn precheckin
-
Run the CLI tool with your changes:
yarn build
node dist/cli.js
- Alternately, register a linked global
axe-sarif-converter
command withnpm install && npm link
(yarn doesn't work for this; see yarnpkg/yarn#1585)
For non-trivial changes, we recommend filing an issue before sending a Pull Request (PR) so we can discuss the problem you're trying to solve and make sure there's agreement that the change belongs in this project.
Once you've gotten that agreement, create a Pull Request containing your change and our team will review it. When you create a PR, its description will be automatically filled in with our PR template; be sure to read through and follow the instructions there before submitting your PR!
This section documents how to perform a few less-common development tasks. These serve as documentation for our own team of maintainers; external contributors will not generally need to reference these.
This repo uses semantic release to manage release publishing to NPM. Our Azure Pipelines CI build contains an optional yarn semantic-release
step which only runs in our private CI builds of the repo's main
branch; this step uses commit titles to determine whether a new release is needed (and if so, what the semantic version bump should be), and releases to npm if necessary. See semantic release's documentation for more details of how this works.
This package attempts to maintain backwards compatibility with axe-core versions ^3.2.2. We maintain
test cases using pinned output from multiple axe-core versions under /src/test-resources/
, so updating
the version of axe-core we support involves generating new output for the new versions.
Ideally we'd specify axe-core as a peer dependency; unfortunately, changing this now would be a breaking change, so we're waiting to change this until we would need to make a breaking change anyway.
To update the package and test cases to account for a new axe-core version:
- In
package.json
, update the version numbers of the following components:
devDependencies
entries for@axe-core/cli
and@axe-core/puppeteer
resolutions
entries foraxe-core
- NOT the
dependencies
entry for@axe-core
!
-
Build the repo with:
yarn install yarn build
-
Generate test resource files for the new version with:
yarn generate-test-resources
-
If this fails with an error message saying it cannot find the Chrome binary, run:
yarn generate-chrome-resources
-
If this fails with an error message saying "This version of ChromeDriver only supports Chrome version X", then find a version number that starts with X from this list and then run:
yarn generate-chrome-resources [version-number] yarn generate-test-resources
for example:
yarn generate-chrome-resources 113.0.5672.0 yarn generate-test-resources
This script installs the Chrome binary for the specified version of Chrome in the location that ChromeDriver expects it to be (
C:\Users\[username]\AppData\Local\Google\Chrome\Application
on Windows). This will allow you to successfully run the script to generate test resources.
-
-
Manually compare the diff of
/src/test-resources/basic-axe-vPREVIOUS.sarif
and/src/test-resources/basic-axe-vNEW.sarif
; the only differences should be the version numbers. -
Manually compare the diff of
/src/test-resources/w3citylights-axe-vPREVIOUS.sarif
and/src/test-resources/w3citylights-axe-vNEW.sarif
; in addition to version number differences, you should see some differences based on new/removed rules between the axe versions. -
Add test cases involving the new files to the integration tests in
src/index.test.ts
andsrc/cli.test.ts
-
Update snapshots (
yarn test -u
) -
Update this README's
Version numbers
section to note which versions we've tested against.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For more details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.