-
Notifications
You must be signed in to change notification settings - Fork 56
Open
Labels
enhancementNew feature or requestNew feature or requesthelp wantedExtra attention is neededExtra attention is needed
Description
Problem
Our annotations for testing are excellent, and they greatly ease the developer experience. Currently, all the values need to be provided as a string. This is a limitation of java annotation as java annotation members can only be (https://docs.oracle.com/javase/specs/jls/se8/html/jls-9.html#jls-9.6.1):
- A primitive type
- String
- Class or an invocation of Class (§4.5)
- An enum type
- An annotation type
- An array type whose component type is one of the preceding types
Furthermore, annotations can't be generic, nor do they support inheritance.
@Flag(name = "BOOLEAN_FLAG", value = "true")
Goal
Evaluate the feasibility and effort of using meta-annotations or some kind of inheritance.
We should not make the API more complex than it already is.
Maybe we only support those convenience annotations for the simple annotation approach and not in the extended configuration.
like instead of
@Flag(name = "BOOLEAN_FLAG", value = "true")
@Flag(name = "STRING_FLAG", value = "true")
@Flag(name = "Number_FLAG", value = "1")
we would love to use
@BooleanFlag(name = "BOOLEAN_FLAG", value = true)
/* optional boolean improvement
@BooleanFlagTrue(name = "BOOLEAN_FLAG")
@BooleanFlagFalse(name = "BOOLEAN_FLAG")
*/
@StringFlag(name = "STRING_FLAG", value = "true")
@NumberFlag(name = "Number_FLAG", value = 1)
toddbaert
Metadata
Metadata
Assignees
Labels
enhancementNew feature or requestNew feature or requesthelp wantedExtra attention is neededExtra attention is needed
Activity
aepfli commentedon Sep 19, 2024
JUnitPioneer is actually using something like this within their cartesian test approach, which might be worth looking at https://github.com/junit-pioneer/junit-pioneer/blob/main/src/main/java/org/junitpioneer/jupiter/cartesian/CartesianTest.java#L115-L167
toddbaert commentedon Sep 19, 2024
@UtkarshSharma2612 you might like this.
ssharaev commentedon Dec 28, 2024
Hi, @aepfli
I would like to implement this if it’s still free.
I had a look at JUnit CartesianTest and I want to make sure I understand your idea correctly.
I think we can create annotations like this:
And add them in extended configuration annotation like the CartesianTest values:
This way we can support this annotations for both simple and extended configuration, but we need to decide how to solve collisions between different flags.
Does it seem reasonable?
aepfli commentedon Dec 28, 2024
hey seems reasonable to me - i suggest we throw an error, if we see that the same flag key is present in both configurations.
ssharaev commentedon Dec 29, 2024
Great!
I’ll implement it and create a PR in a few days. Could you assign this issue to me?
ssharaev commentedon Jul 6, 2025
Hi @aepfli ,
It takes a bit longer 😅
Please take a look when you have time.