Thank you for wanting to help make readability better!
For outstanding issues, see the issue list in this repo, as well as this bug list.
Any changes to the main code should be reviewed by an appropriate Firefox/toolkit peer, such as @gijsk, since these changes will be merged to mozilla-central and shipped in Firefox.
To test local changes to Readability.js, you can use the automated tests.
This repository is governed by Mozilla's code of conduct and etiquette guidelines. For more details, please read the Mozilla Community Participation Guidelines.
Please run eslint as a first check that your changes are valid JS and adhere to our style guidelines:
$ npm run lint
To run the test suite:
$ npm test
To run a specific test page by its name:
$ npm test -- -g 001
To run the test suite in TDD mode:
$ npm test -- -w
Combo time:
$ npm test -- -w -g 001
There's a node script to help you create new tests. You can run it using:
$ node test/generate-testcase.js slug https://example.com/article
Replacing slug with the identifier the test should use, and providing a URL to an actual article on which the test should be based. If your test case involves dynamic content, you can save the page to disk and pass the file as a file:// URL.
You may need to make the tidy binary executable before that script will succeed. If you see an EACCES error when running that script, try:
# On MacOS $ chmod +x ./node_modules/htmltidy2/bin/darwin/tidy # On Linux, the linuxXX may change depending on your platform # The specific path may change depending on the node tools you use $ chmod +x ./node_modules/htmltidy2/bin/linux64/tidy
We're always happy to see pull requests to improve readability.
Please ensure you run the linter and tests before submitting a PR.
If you‘re changing the algorithm to fix a specific page/article, please add new tests for the case you’re fixing, so we avoid breaking it in future.
git log `npm view . version`...master may help with this.npm run release to create a release, which should:npm version [patch | minor | major], depending on the nature of the changes according to semver. This will bump the version in package.json and package-lock.json and create a commit and Git tag for the release.npm publish to push the release to the npm registry.git push origin head --follow-tags to push the new commit and tag to GitHub.Ensure significant changes are added to CHANGELOG.md. Do not add changes that only affect tests or documentation.