Skip to main content

Declarative UI testing with JSON

Project description

Quilla

CodeQL Code Analysis Test pipeline Release pipeline Documentation publish

License Package Version Supported Python Versions Pypi Downloads

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

  1. Run pip install quilla

  2. 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

  3. 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",
        }
      ]
    }
    
  4. 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.

Quilla is available on PyPI, and can be installed by running pip install quilla.

For more information on installation options (such as installing from source) 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] [--debug] [--driver-dir DRIVERS_PATH] [-P] [--no-sandbox] [-d file] 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
  --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
  --no-sandbox          Adds '--no-sandbox' to the Chrome and Edge browsers. Useful for running in docker containers'
  -d file, --definitions file
                        A file with definitions for the 'Definitions' context object

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

quilla-0.3.1.tar.gz (35.3 kB view details)

Uploaded Source

Built Distribution

quilla-0.3.1-py3-none-any.whl (41.8 kB view details)

Uploaded Python 3

File details

Details for the file quilla-0.3.1.tar.gz.

File metadata

  • Download URL: quilla-0.3.1.tar.gz
  • Upload date:
  • Size: 35.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.10

File hashes

Hashes for quilla-0.3.1.tar.gz
Algorithm Hash digest
SHA256 16d0eace6c08a0f1ed6e710933886e30acc0e2d7b4261d7e9e4e5974caf0225a
MD5 6c1b76168422ea73a75fc25b9a3bd3e4
BLAKE2b-256 980f70cdbb3e1b90a48e40b4d7fa4074f27860e2a7466f0f0cb717e3bff613ab

See more details on using hashes here.

File details

Details for the file quilla-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: quilla-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 41.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.10

File hashes

Hashes for quilla-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f014e2a0cfeb2b09fe54c10df3614809b12e68001d6325e2cd5177dc000bfff7
MD5 96edc8a26f879bc53cf6d5e81147ed59
BLAKE2b-256 55a8d4ada84cd75e32993a81f438f2a7aaf88ef4f89d26444dee4ec55c3f9c12

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page