-
Notifications
You must be signed in to change notification settings - Fork 47
Maven
Maven is used the build and run the generator component. This page explains the maven configurations that are shipped with Getaviz. They are availabel as Eclipse Launch files.
This configuration builds every project, including the xtext projects (org.svis.xtext), the generator itself, and the test cases. For the initial biuld build everything is executed automatically. During development usually you would not want to run this configuration.
This configuration executes the test cases for the generator. This config you use during generator development.
There exist several workflows for specific metaphors and input formats:
- Dynamix2RD
- Famix2City
- Famix2MultiSphere
- Famix2Plant
- Famix2RD
- JQA2City
- JQA2Multisphere
- ...
This configurations are thought only for productive use, not for testing purposes. To run them you need a suitable input file in a subdirectory of org.svis.generator.run/input. For example if you want to run Famix2RD put a .famix file in org.svis.generator.run/input/famix. The output is created in org.svis.generator.run/output.
When using a JQAssisstant compatible database as input, put database folder in directory databases. Change value of DATABASE_NAME in FAMIXSettings.java (famix.database_name in settings.properties) to your database and use one of the maven builds named as JQA2City, JQA2Plant, ...
In case you just want to rebuild e.g. the famix metamodel simply right click on the corresponding project and select Run As → Maven install
The project report can be generated by launching "Project Report". Among others it contains an overview over all external dependencies and their licenses. It can be found in the releng project under target/staging/index.html
After running the test cases, per test case a test report is createt in target/surfire-reports wtihin the project org.svis.generator.tests. Open the xml files to view the reports in the familiar junit view.
The JavaDoc documentation is still very incomplete, so please extend it whenever possible. The documentation is created automatically. It is available within eclipse, e.g. when hovering over a documented class. The html documentation is generated in target/site within the corresponding project.
For very big systems you may have to increase RAM to visualize them. If you change settings via eclipse launch file this will only affect the maven process but not the separate java execution. Instead open the pom.xml of org.svis.generator.run and add the following line to the arguments part of the exec-maven-plugin to use 5 gigabyte ram:
<argument>-Xmx5g</argument>
If you want to use breakpoints, right click on a junit test and choose Debug As → JUnit Test
The integration from maven into eclipse is not optimal. From time to time this can occur
- eclipse shows hunrets of compilation errors although things were fine a second ago
- Tests will fail due to compilation errors (especially when running the "Build everything" workflow"
In this case do the following:
- Select a project and press Alt + F5
- Click "Select all", then on "Ok"
- Run "Test Generator" workflow