Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rdebusscher/grafaces
Arquillian Graphene extension
https://github.com/rdebusscher/grafaces
Last synced: about 2 months ago
JSON representation
Arquillian Graphene extension
- Host: GitHub
- URL: https://github.com/rdebusscher/grafaces
- Owner: rdebusscher
- License: apache-2.0
- Created: 2014-04-23T12:06:32.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2015-04-14T20:14:36.000Z (over 9 years ago)
- Last Synced: 2023-04-03T18:53:33.219Z (almost 2 years ago)
- Language: Java
- Size: 320 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Grafaces
========Arquillian Graphene extension.
### What do I want to solve with this Extension?
1. Allow Page fragments with multiple 'root' elements, like radio button group. See also [Testing Radio button group with Arquillian Graphene](http://statelessprime.blogspot.be/2014/03/testing-radio-button-group-with.html)
2. Injecting utility classes which don't have a root but need the WebDriver, like utility class for handling alert's.
3. Detecting mechanism to see if the DOM element selected by _@FindBy()_ correspond with the Page Fragment class. Some validation to see if we didn't make any assignment mistakes.
4. 1 set of Page Fragments which are capable of testing any Web framework, as long as they generate HTML and CSS. Like, but not limited to, PrimeFaces, AngularPrime, AngularJS, jQuery UI, ...##### Multiple roots
You can annotate a no argument method with __javax.annotation.PostConstruct__ and this method will then be executed the first time the proxy to the WebElement is accessed.
This can be used to do some initialization, like in the radio button group scenario to detect all radio button belonging to the same group.
See for example _be.rubus.web.testing.widget.extension.angularprime.PuiRadiobuttonGroup_
#### Injecting utility classes
You can inject any POJO class into the test class (class with the __RunWith(Arquillian.class)__ annotation) and any enhancement will be performed in this utility class. For example the property with __@Drone__ will be initialized.
You need to annotate the property in the test class with __@Graphene__.
Another use case for the __@Graphene__ is to inject the GrapheneContext instance into a page fragment. It has some very useful methods like _initializePageFragment_ used in the PuiRadioButtonGroup to initialize Page Fragment's for each radio button.
#### Detecting widget
You can apply the __@WidgetValidation__ annotation to a method which will verify if the Page Fragment root points to a compatible DOM element.
This is very useful to verify the correct assignment of the element id (using @FindBy) to a certain type of DOM element.
The following code will lead maybe to some strange errors
@FindBy("saveBtn")
private PuiButton saveButton;When _saveBtn_ points to textarea for some reason.
2 types of methods are supported :
1. No argument method which returns a boolean (return false means the Page fragment can't work with the supplied element in the root.
2. No argument method wich return an instance of Detector. This is an interface with one single method which also returns a boolean.The second type of methods, with the interface, is created to allow a clear separation between the validation code and the real Page Fragment code.
#### Single set of Page Fragments
A lot of frameworks, like PrimeFaces, AngularPrime, AngularJS and so on generate HTML, JavaScript and CSS. The HTML DOM structure of a the widget is sometimes very similar.
The idea was then to have one testing framework which handles the HTML generated by these frameworks to maximize the reusability of the Page Fragments.
Of course there will be specific widgets and extensions are foreseen for each framework.
### Proof of concept
This is version 0.1 of the framework to verify if the concepts could work. Not all widgets of mentioned frameworks are created nor is the code complete for those widgets which are provided.
This will be handled in future versions.
### Feedback
Of course, any feedback on the approach, issues or improvements are welcome of course.