EvoAvalla is an automated tool that uses evosuite to generate test scenarios in Avalla language for an Abstract State Machine (ASM).
To achieve this, EvoAvalla is divided into three microservices:
-
asmetal2java:
This microservice converts the input.asm
file into a corresponding Java application. -
evoservice:
This microservice uses EvoSuite, a test generation tool that automatically generates JUnit test suites for Java classes. EvoSuite therfore generates a test suite based on the Java application that was produced by theasmetal2java
service. Since we are testing an ASM, the tests we are interested in are operating scenarios, which we will call scenarios. -
javaToAvalla:
Once the scenarios are generated, this microservice converts the Java-based scenarios into the Avalla language. The Avalla format is a specialized language used for defining test scenarios for ASMs, and this conversion ensures the generated test cases can be executed in an Avalla-based testing environment.
To start using EvoAvalla, you need to have Docker Desktop installed on your machine.
Make sure you have it installed and then clone the repository:
git clone https://github.com/isaacmaffeis/evoAvalla.git
Note: Currently, this project only works on Windows machines because it uses a batch file (
exec.bat
) that can only be executed in a Command Prompt (CMD).
Follow these steps to run the project:
-
Open Docker Desktop:
Open and run Docker Desktop.
-
Prepare Your Input File:
Place the .asm file you want to process in the input folder of the cloned repository.
-
Run the Project:
Open a CDM terminal and navigate to the root of the cloned repository folder:
cd path/to/cloned/repository
Run the following command to execute the project:
exec.bat
At this point the application will run and provide the output in the
./output
folder.
EvoAvalla is structured as a series of microservices built on Docker:
- asmetal2java: Converts the .asm input file into a Java application.
- evoservice: Generates a Junit test suite (scenarios) for the newly created Java application using EvoSuite.
- javaToAvalla: Converts the Junit test scenarios into the Avalla format.
These projects are built and integrated into EvoAvalla using a GitHub Action CI pipeline.
This pipeline automates the building of Docker images for each project,
making them available for use in EvoAvalla via the docker-compose
file.
The project repository is organized into the following folders:
-
input/
: The application expects.asm
input files to be placed here before execution. -
output/
: The output.avalla
files generated by the services will be located here. -
example/
: This folder contains a collection of example.asm
files that you can use to test the application. -
services/
: This folder contains subfolders for each microservice that the application uses. It stores Docker volumes, which are needed for the services to communicate with each other and persist data between containers.