Skip to main content

Kwola makes an AI powered tooling for finding bugs in software

Project description

Kwola

Kwola is an AI user that helps you find bugs in your software. Unlike conventional Selenium or Cypress tests, Kwola will learn to use your user-interface completely automatically, with no configuration.

Please go to https://kwola.io/ or https://kwolatesting.com/ to learn more.

![Screenshot of debug video generated by Kwola](https://raw.githubusercontent.com/Kwola/kwola/master/docs/debug_video.png “Screenshot of debug video generated by Kwola”)

Installation

Dependencies

  1. Python

Please go to https://www.python.org/downloads/ to download and install Python. You should also install the Python development headers, as some of our Python dependencies compile C / C++ code into Python modules.

  1. NodeJS

Please go to https://nodejs.org/en/ to install NodeJS or install it through a package manager appropriate for your distribution.

  1. Chromium / Google Chrome

Please go to https://www.chromium.org/ to install Chromium (the open source version of Chrome), or go to https://chrome.google.com to install Google Chrome (you may have it installed already).

  1. Chromedriver

Install chromedriver globally to your operating system. Go here: https://chromedriver.chromium.org/getting-started and install the binary appropriate for your operating system and which Chrome version you have installed.

For example, I run the following on Linux with Chrome 80:

[user@localhost]$ wget https://chromedriver.storage.googleapis.com/80.0.3987.106/chromedriver_linux64.zip

[user@localhost]$ unzip chromedriver_linux64.zip

[user@localhost]$ sudo cp chromedriver /usr/bin/

Alternatively you can also install chromedriver just to your Python virtual environment.

  1. Ffmpeg

You must install ffmpeg as it is used to compress the videos of Kwola interacting with the client program.

Please go to this url: https://www.ffmpeg.org/download.html to get instructions on how to install ffmpeg.

  1. [linux / macOS] C & C++ Compiler

You need to install a c++ compiler, as it is used by some of the Python dependencies to compile highly efficient code.

On Ubuntu, you can run:

[user@localhost]$ sudo apt-get install build-essential

On Fedora, you can run:

[user@localhost]$ sudo dnf install gcc-c++

On macOS, you must install XCode to get the compiler.

  1. [windows] Visual Studio

Install visual studio community edition (or basically any version of visual studio) if you are using Windows.

Visual Studio is needed for the C++ compiler, used by some of our Python dependencies. Go here for the download instructions: https://visualstudio.microsoft.com/downloads/

  1. [optional] Nvidia Drivers & Cuda

How you install NVIDIA Drivers depends on your operating system. You only need to install NVIDIA drivers if you are using GPUs. Using GPUs is recommended but optional, and you can do test runs with just the CPU.

Windows: Go here for instructions: https://docs.nvidia.com/cuda/cuda-installation-guide-microsoft-windows/index.html

MacOS: https://docs.nvidia.com/cuda/cuda-installation-guide-mac-os-x/index.html

Ubuntu: https://linuxconfig.org/how-to-install-the-nvidia-drivers-on-ubuntu-18-04-bionic-beaver-linux * Its recommended to stick to LTS releases for Ubuntu when doing high performance computing.

Fedora: https://www.if-not-true-then-false.com/2015/fedora-nvidia-guide/

  1. [optional] Docker

Go here and follow the instructions to install Docker: https://docs.docker.com/install/

Docker not required for Kwola to operate but is used in some of the examples.

Installation Instructions

Create a virtual environment. Doing this is not 100% necessary, you can install Kwola globally, but there is a much higher likelihood of a package version conflict. Installing inside the virtual environment is the most reliable way to run Kwola.

[user@localhost]$ python3 -m venv venv

[user@localhost]$ source venv/bin/activate

Install Kwola using pip.

[user@localhost]$ pip3 install kwola

Install babel-cli and the Kwola babel plugin globally. This makes it easier for the code to access the babel binary.

[user@localhost]$ sudo npm install @babel/cli -g

[user@localhost]$ sudo npm install babel-plugin-kwola -g

If you have any issues, particularly issues with running testing sequences, try installing the babel plugin locally as well, in the same folder that you run the Kwola executable. We are still sorting out precisely how all of this is done.

[user@localhost]$ npm install babel-plugin-kwola

That’s it! Kwola should now be installed.

Usage

Running Kwola is very straightforward. First activate your virtual environment:

[user@localhost]$ source venv/bin/activate

To initiate a Kwola testing session, run the following command. Make sure to replace the URL with the url pointing to the website you want to start testing. The URL must be a complete, fully validated url containing the http:// part and everything.

[user@localhost]$ kwola http://yoururl.com/

Kwola will now start testing your application! Its that easy. Kwola will create a directory to hold all of its results in your current directory. You can cancel the run simply using Ctrl-C or Cmd-C in your terminal. If you want to restart the run, simply run kwola with no arguments:

[user@localhost]$ kwola

Or alternatively, you can run Kwola and give it a specific directory containing a Kwola run. This allows you to restart specific runs.

[user@localhost]$ kwola kwola_run_0

For example, you can use Kwola with one of our example codebases if you have Docker installed:

[user@localhost]$ docker run docker.io/kwola/kros-1

[user@localhost]$ kwola http://172.17.0.2:3000/

You will then see Kwola running on our restaraunt backend sample codebase.

Support

Kwola is maintained by Kwola Software Testing Inc, a Canadian company. You can contact the authors at any of the following emails: quinn@kwola.io, brad@kwola.io or daniel@kwola.io

Roadmap

Oh boy there is a lot of stuff on the roadmap for Kwola. Too much to write down today.

Contributing

We are absolutely open to contributors. If you are interested in Kwola, please reach out to brad@kwola.io via email and we will get in touch. We will accept any contributions so long as the copyrights are transferred to the Kwola Software Testing company.

Or alternatively just throw up a pull-request. That always gets peoples attention ;)

Authors and acknowledgment

The project was founded by Quinn Lawson, Bradley Arsenault and Daniel Shakmundes.

License

The project is licensed GPLv3 Affero.

Project status

As of February 2020, the project is just getting started. We are open to anyone who wants to join!

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kwola-0.0.23.tar.gz (60.8 kB view hashes)

Uploaded Source

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