Contributing
The Appium project would not exist without the many contributions of code, documentation, maintenance, and support from companies and volunteers. As such, we welcome contributions!
There are a lot of different ways to help the project - see below for everything you can do and the processes to follow for each contribution method. Note that no matter how you contribute, your participation is governed by our Code of Conduct.
Join the Discussion Forum¶
You don't need to know the internals of Appium to be able to contribute! If you have experience with using Appium and feel like sharing your knowledge with others, consider helping out users on the Appium forums at discuss.appium.io. Hop on over and see if there are any questions that you can answer.
Report Bugs or Feature Requests¶
If you've encountered a bug, or have a cool feature in mind that you think Appium should support, make sure to let us know at our GitHub issue tracker. Please use the appropriate issue form template when creating your issue.
Triage Issues¶
In addition to creating issues, you can also help us investigate already reported issues. All you need is enough familiarity with Appium to try and reproduce bugs.
You can get started by checking our GitHub issue tracker
for issues with labels such as Needs Triage
or Needs Info
, and leaving relevant comments:
- If the issue is a duplicate, drop a link to the original issue
- If the user has not provided enough information (such as Appium logs), ask them for more details
- If you can reproduce the problem on your own environment, provide all the information that you think would help us track down the cause of the issue
For further information on triaging Appium issues (for any Appium project repository), please contact any member of the Technical Committee.
Contribute Code¶
We are always open to pull requests for improving the Appium code or documentation!
Info
Developer information may not be kept up to date as frequently as user-facing information, or it may be most relevant in its current form on the online repository, not in this published version. Make sure to check the repo or discuss with maintainers. We would be glad to help new contributors get started!
Start by cloning the repository (we recommend forking it first):
Info
If you are VS Code user, you can easily check out the project using Runme.
Install dependencies:
From here on there are several things you can do.
Build the project:
Build the project and watch for changes:
Start the locally built Appium server:
Run various tests:
npm run lint
npm run test:unit
npm run test:types
npm run test:smoke
npm run test:e2e
npm run test:quick # unit and types
npm run test:slow # everything
You can also run tests for specific workspaces, e.g.:
Documentation¶
The documentation for this project is available in the project repository itself.
It is contained in Markdown files, which are built by our documentation system in the
@appium/docutils
module. This module is based on MkDocs and therefore
requires Python to be installed on your system.
Install Python dependencies:
After making your changes, you can run the documentation server in dev mode:
You can then view the documentation at http://127.0.0.1:8000/docs/en
.
Translating Appium Documentation¶
The process of Appium documents localization into languages other than English is automated and is done via the Crowdin Translations Management System. Do not edit any translated documents directly in the GitHub Appium repository as they are going to be replaced with ones exported from Crowdin during an upcoming sync.
Where To Start¶
If you would like to contribute to the translation of Appium documents into your language then simply join the translators group for the Appium Documentation Crowdin project, and start translating documents there. If you see that your language is missing from the list of available Crowdin languages then simply let us know by creating an issue.
Source Language Updates¶
Changes in documents are synchronized to Crowdin automatically via the Update Crowdin English Docs
GitHub action.
This action is triggered automatically as soon as there are any changes under packages/appium/docs/en/**.md
or packages/appium/docs/mkdocs-en.yml
.
Fetching Translated Documents¶
In order to fetch translated files from Crowdin to the GitHub repository it is necessary to trigger
the Sync Crowdin Docs Translations
action. This action should also automatically create a PR with
corresponding translated resources included.