data:image/s3,"s3://crabby-images/6c789/6c7891ea037149604700324d6e7730869e0bf027" alt="Appium server log example"
If you want, you could even publish a plugin to GitHub, and Appium can fetch its contents for you. You will not need to publish this package to the NPM registry as Appium allows you to directly install a plugin from a local directory. In this short guide, I would like to demonstrate how a user would create an Appium Plugin, how to intercept an Appium server command and to override existing commands in Appium. Appium Plugins allow users to do exactly that. However, this additional logic is completely unrelated to the test itself, and would be better as an external package (which upon installation modifies Appium code). In this case, you will most likely write this logic within the repository that contains test cases. For example, every time you find a particular button you might need to add a custom waiting time.
data:image/s3,"s3://crabby-images/a55fd/a55fd9b6e6679ae9bbf5b8a391464667a1824945" alt="appium server log example appium server log example"
data:image/s3,"s3://crabby-images/1eb17/1eb17479024ba74b7ce3b6d50a350d6d7199b3ce" alt="appium server log example appium server log example"
In order to add customizations, they would need to install Appium first and then write additional logic layered on top. It is a given that users may want to customize the existing Appium functionality available out of the box based on their test scenarios.
data:image/s3,"s3://crabby-images/6c789/6c7891ea037149604700324d6e7730869e0bf027" alt="Appium server log example"