Declarative UI testing with JSON
Project description
Quilla
Declarative UI Testing with JSON
Quilla is a framework that allows test-writers to perform UI testing using declarative syntax through JSON files. This enables test writers, owners, and maintainers to focus not on how to use code libraries, but on what steps a user would have to take to perform the actions being tested. In turn, this allows for more agile test writing and easier-to-understand test cases.
Quilla was built to be run in CI/CD, in containers, and locally. It also comes with an optional integration with pytest, so you can write your Quilla test cases as part of your regular testing environment for python-based projects. Check out the quilla-pytest docs for more information on how to configure pytest
to auto-discover Quilla files, adding markers, and more.
Check out the features docs for an overview of all quilla can do!
Quickstart
-
Clone the repository
-
cd
into thequilla
directory and runmake install
-
Ensure that you have the correct browser and drivers. Quilla will autodetect drivers that are in your PATH or in the directory it is called
-
Write the following as
Validation.json
, substituting "Edge" for whatever browser you have installed and have the driver for:{ "targetBrowsers": ["Edge"], "path": "https://www.bing.com", "steps": [ { "action": "Validate", "type": "URL", "state": "Contains", "target": "bing", } ] }
-
Run
quilla -f Validation.json
Installation
Note: It is highly recommended that you use a virtual environment whenever you install new python packages. You can install Quilla by cloning the repository and running
make install
.
For more information on installation options and packaging Quilla for remote install, check out the documentation for it here
Usage
This module can be used both as a library, a runnable module, as well as as a command-line tool. The output of quilla --help
is presented below:
usage: quilla [-h] [-f] [-d] [--driver-dir DRIVERS_PATH] [-P] json
Program to provide a report of UI validations given a json representation of the validations or given the filename
containing a json document describing the validations
positional arguments:
json The json file name or raw json string
optional arguments:
-h, --help show this help message and exit
-f, --file Whether to treat the argument as raw json or as a file
-d, --debug Enable debug mode
--driver-dir DRIVERS_PATH
The directory where browser drivers are stored
-P, --pretty Set this flag to have the output be pretty-printed
Writing Validation Files
Check out the documentation for it here
Context Expressions
This package is able to dynamically inject different values, exposed through context objects and expressions whenever the validation JSON would ordinarily require a regular string (instead of an enum). This can be used to grab values specified either at the command-line, or through environment variables.
More discussion of context expressions and how to use them can be found in the documentation file here
Generating Documentation
Documentation can be generated through the make
command make docs
Check out the documentation for it here
Make commands
A Makefile is provided with several convenience commands. You can find usage instructions with make help
, or below:
Usage:
make [target]
Targets:
help Print this help message and exit
package Create release packages
package-deps Create wheel files for all runtime dependencies
docs Build all the docs in the docs/_build directory
clean-python Cleans all the python cache & egg files files
clean-docs Clean the docs build directory
clean-build Cleans all code build and distribution directories
clean Cleans all build, docs, and cache files
install Installs the package
install-docs Install the package and docs dependencies
install-tests Install the package and test dependencies
install-all Install the package, docs, and test dependencies
Contributing
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
Trademarks
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file quilla-0.2.tar.gz
.
File metadata
- Download URL: quilla-0.2.tar.gz
- Upload date:
- Size: 31.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 91d88b59005398d63ba8fe2228afa05aa6c86296078acb5ab3ebd5088eda2af0 |
|
MD5 | 94e82e48a0dd7e53a5d72771417799fc |
|
BLAKE2b-256 | 527d3a6054ab7b4eb187b5382ce2f2fb5b5a0c96ca7c7e1b1f2f6c53b9dd60b7 |
File details
Details for the file quilla-0.2-py3-none-any.whl
.
File metadata
- Download URL: quilla-0.2-py3-none-any.whl
- Upload date:
- Size: 37.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 775d57eabf60c9e581fe43f51b8b9ed4d4f4865fd22b1c223c23f0f9beebe4ac |
|
MD5 | 919b20d464f663b1067b138b33a8c6ef |
|
BLAKE2b-256 | 54d71cd1cec9cb58751ad7fbcc6bdaffeee53be46f9f3ecc03eca4f315288c3d |