Any contributions to Selenide are both welcomed and appreciated.
It doesn't necessarily have to be code. There are many ways you can help Selenide:
- Answer questions in chats/forums/stackoverflow/etc.
- Write in your blog/twitter/medium about Selenide or its usages in specific situations.
- Discuss ideas in our brainstorms
- Give your feedback on feature requests
- Help to justify or protest requests that we are not sure about
- Help to reproduce an issue that we cannot reproduce
- Make code review for any of pull requests - especially with label "not sure".
- And finally, code!
- Find any issue with label "help wanted"
- Add a comment like "I am working on it" (provide some details what's your plan)
- Send a pull request
Selenide has a very simple branching strategy
- The latest state is always in
master
branch - Every bugfix/feature is developed in a separate branches created from
master
branch - Once bugfix/feature is accepted, someone of maintainers merges it to
master
branch - When we make a release, we make it from
master
branches
- Create a GitHub account
- Fork Selenide repo
- go to https://github.com/selenide/selenide
- click "Fork" link in the right upper corner
- Check out your Selenide copy:
git clone https://github.com/username/selenide
- Create a new branch from
master
branchgit checkout -b remove-duplicate-screenshots-in-allure
(choose any reasonable branch name)
- Make your changes
- it's recommended to add a line to CHANGELOG.md
- Run tests:
- required:
./gradlew check
- optional: some other tests (see below)
- required:
- Commit, say a little prayer and push
- it's recommended to start commit message with issue id, like
#ID remove duplicate screenshots in Allure
- also read a commit message tutorial
- prefer small independent commits to one big commit with many changes
- it's recommended to start commit message with issue id, like
- go to http://github.com/username/selenide/
- you will see an automatic suggestion to create a pull request
- accept it, fill all the required fields.
- wait. Don't worry, we review pull requests often. We will contact you.
git clone https://github.com/selenide/selenide.git
cd selenide
./gradlew (or `gradlew.bat` on Windows)
After build, you'll find Selenide's .jar file under build/libs/
directory as well as in local maven repository at ~/.m2/repository/com/codeborne/selenide/<version>/selenide-<version>.jar
.
Selenide project has two types of tests: unit tests and UI tests.
- Command
./gradlew
already runs unit-tests - To run other types of tests, use the following commands:
./gradlew firefox
./gradlew firefox_headless
./gradlew chrome
./gradlew chrome_headless
./gradlew grid
./gradlew ie
./gradlew edge
./gradlew testng
Note that you typically don't need to run them locally because our Continuous Integration server will run them anyway when you send a pull request.
You can also try to run Selenide tests inside of docker container (sometimes you want to check how Selenide works with Selenoid, for example).
The following is a short instruction how to do it.
-
Syncing browser images from existing configuration file
- Install jq
- Extract image names from JSON and automatically pull them:
cat /config/selenoid/browsers.json | jq -r '..|.image?|strings' | xargs -I{} docker pull {}
-
Start selenoid container
-
Start tests passing
selenide.remote
configuration variable withhttp://localhost:4444/wd/hub
value
Selenide uses Travis CI to automatically build any branches and pull requests, running all the automated tests.
However, you don't need to open Travis in most cases. When you send a pull request, you will see its build status right in the PR.
Feel free to fork, clone, build, run tests and contribute pull requests for Selenide!