First of all, Welcome! 👋 and thank you for your interest in contributing to our UI testing framework.
Have you a question? Have you found a problem 🚫 you would like to see fixed? Is there something you would like to see improved or features 🚀 added?
Then we'd like to hear from you. Hop on to the issue tracker and create an issue. If you would check if a similar issue already exists beforehand, it would be much appreciated ❤️.
If you happen to find an existing issue or a pull request that interests you, feel free to comment or upvote 👍 / downvote 👎 to give us your opinion (we do prefer comments over votes).
If submitting issues just doesn't cut it for you, we are always happy to see code contributions. Here are a few steps to get your code in as fast as possible:
The first step is to fork this repository and clone your new fork. We also recommend adding the upstream as a new remote so you can easily get updates.
git clone https://github.com/<your user name>/vscode-extension-tester
cd vscode-extension-tester
git remote add upstream https://github.com/redhat-developer/vscode-extension-tester
Now that you have the code, you will need to build the project. First, we need to install all modules dependencies:
npm install
When you make a change, make sure the tests are passing. In the tests/test-project
directory there is a dummy VS Code extension we use to test the framework itself.
For that, you can use the following script and launch the tests:
npm run test:build
If you are adding a new feature, be sure to write new tests for it. If you navigate to the tests/test-project/src/test
folder, you will find a test file structure that mirrors the source files. Put your new test into the appropriate existing file, or create a new one that follows the same structure.
Having made and tested your changes, we recommend committing them into a new branch:
git checkout -b <my-new-branch>
git add <changed files>
git commit -m <type>(optional scope): <description> # see https://www.conventionalcommits.org/en/v1.0.0/#summary
git push origin <my-new-branch>
Now the changes are in a new branch in your fork, you can submit a new pull request. If your pull request is intended to fix an issue in the tracker, make sure to link the two together.
Lastly, a pull request check on Github Actions is going to kick in whenever a change is pushed. Please make sure it ends up green. Otherwise it might need a change on your part. Or maybe it also needs a change on our part - in that case opening a new issue is the best way to go.
- Check all related PR's were merged and the
Main CI
is green
- Execute
npm run version
- commit changes and open new PR
- wait for PR is approved and merged
- after merge, wait until
Main CI
is green
- Execute
npm run publish
- create and push new
vX.X.X
tag - create a new GitHub release from a new
vX.X.X
tag (with generated release notes)
- create and push new
- Close published version milestone and update ExTester project board
- Update
examples/helloworld-extester
project- Bump
vscode-extension-tester
version to recently released one - Run tests and check everything is working properly
- Bump
- (optional) Spread a message about new release using IM tools, mailing lists and social media
By contributing to this project you agree to the Developer Certificate of Origin (DCO). This document was created by the Linux Kernel community and is a simple statement that you, as a contributor, have the legal right to make the contribution.
See the DCO file for the details.