Contributions welcome, please raise a pull request.
If you want to help and want to get more familiar with the codebase, try starting with the "good for beginners" issues. Feel free to request more guidance in the issue comments.
You will need a recent version of Node and npm installed:
$ node -v
v7.10.0
$ npm -v
v5.0.0
If you want to run the selenium tests, you will also need a local copy of the Java Development Kit:
$ java -version
java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)
To install Node (with npm) and Java locally on macOS, you can use brew:
brew install node
brew cask install java
$ ls
coverage/ # Gets outputted by the tests, `open html/src/index.html` to see latest coverage reports.
dist/ # The compiled and ready to distribute build artefacts.
screenshots/ # Gets outputted by the end to end tests when something goes wrong.
examples/ # GitHub pages examples of using the autocomplete.
scripts/ # Build scripts that don't fit in `package.json`.
src/ # The source code for the library.
test/ # The tests for the library.
To develop locally:
npm install
npm run dev
Contributions will need to pass the linter and tests. To run everything once:
npm test
To run the linter on its own:
npm run standard
To run the functional tests in dev mode (automatically reruns when a file changes):
npm run karma:dev
To run the integration tests locally with Chrome (specified in wdio.config.js):
npm run wdio
To run the integration tests on Sauce Labs, create a .env
file with the following:
SAUCE_ENABLED="true"
SAUCE_USERNAME="XXXXXXXX"
SAUCE_ACCESS_KEY="YYYYYYYY"
And run the same command:
npm run wdio
Failed integration tests should output screenshots to the ./screenshots/
folder.
To build the project for distribution:
npm run build
You should do this and commit it before you attempt to git push
, otherwise the prepush checks will prevent you from pushing.
When you push to a branch, git will run a npm run prepush
script that will compile the build on your behalf to the dist/
folder. If it then finds unstaged files in dist/
, it will fail your push.
The solution is to commit the files, preferably as part of a separate commit:
npm run build
git add dist/
git commit -m "Rebuild dist"
git push
If you want to ignore the checks and push regardless:
git push --no-verify
- Tests for your feature or fix
- Updates to the README.md when necessary
- A 1 line update in CHANGELOG.md describing your changes
git pull --rebase
and then run:
git checkout -b "v1.2.3"
vim CHANGELOG.md # Update CHANGELOG, put all unreleased changes under new heading.
git commit -am "Update CHANGELOG"
npm version <major|minor|patch> -m "## 1.2.3 - 2017-01-13
- Change included in this release
- Another change included in this release"
Then run:
git push --tags --set-upstream origin refs/heads/v1.2.3:refs/heads/v1.2.3
Create a pull request for the release.
To actually publish, you will need access to an npm
account that owns accessible-autocomplete
. Merge the version PR and then run:
git checkout master
git pull --rebase
npm publish
Create a new release on GitHub.
- Select the latest tag version.
- Set "v[VERSION-NUMBER]" as the title.
- Add the release notes from the changelog.
- Add a summary of highlights.
- Publish the release.
You don't need to manually attach source code files to the release on GitHub.
Post a short summary of the release in the cross-government and GDS #govuk-design-system Slack channels. For example:
🚀 We’ve just released Accessible Autocomplete v2.0.1. You can now use the acccessible autocomplete multiple times on one page. Thanks to @ and @ for helping with this release. https://github.com/alphagov/accessible-autocomplete/releases/tag/v2.0.1