Galen is a test framework which allows to test the responsiveness of UI.
Follow the steps below in order to test components:
- Inside your *.test.jsx create a driver so that you can run an instance of the browser (by default Firefox is used as browser, but you can use a different browser like Chrome by modifying the galen.config ). You need to specify the URL of your web page that you want to test, and optionally you can also set resolution, so you can test your UI on different simulated devices (tablet, desktop, mobile...)
- Create a *.gspec file. This is a configuration file where you will define all the elements that you want to check along with the rules (for example visibility, distance between elements, width etc.)
- (Optional) In case you want to perform functional testing and you need to interact with elements on page it is best to use GalenPages. It is a small lightweight framework for working with page object model (check the pages directory)
Example:
Below is an example of how to define rules in the *.gspec file:
@on tablet
tile2:
aligned vertically all tile4
@on desktop, mobile, tablet
tile2:
visible
@on desktop
tile2:
aligned horizontally all tile3
@on mobile
tile2:
aligned vertically all tile3
@on tablet
tile3:
aligned horizontally all tile4
aligned vertically all tile5
@on desktop, mobile, tablet
tile3:
visible
@on desktop
tile3:
aligned horizontally all tile4
@on mobile
tile3:
aligned vertically all tile4
-
Start the instance to test
npm run start
-
Run Gateway service, Discovery service, API Catalog service and Discoverable Client Sample service.
-
From the root of the project, run
npm run test:galen
to run all the tests created inside the tests folder. You will also find reports within the report folder.