From 330d4997403c9464636959a43bc4687163763c27 Mon Sep 17 00:00:00 2001 From: Matej Novotny Date: Mon, 13 Sep 2021 23:52:49 +0200 Subject: [PATCH] Allow using @Priority within stereotypes. --- .../main/asciidoc/core/definition.asciidoc | 27 ++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/spec/src/main/asciidoc/core/definition.asciidoc b/spec/src/main/asciidoc/core/definition.asciidoc index e3eeee15..f4244b98 100644 --- a/spec/src/main/asciidoc/core/definition.asciidoc +++ b/spec/src/main/asciidoc/core/definition.asciidoc @@ -731,13 +731,12 @@ A stereotype encapsulates any combination of: A stereotype may also specify that: * all beans with the stereotype have defaulted bean names, or that -* all beans with the stereotype are alternatives. +* all beans with the stereotype are alternatives, or that +* all beans with the stereotype have predefined `@Priority`. A bean may declare zero, one or multiple stereotypes. -// TODO how about we finally allowed declaring `@Priority` on stereotypes? - [[defining_new_stereotype]] ==== Defining new stereotypes @@ -839,6 +838,28 @@ We may specify that all mock objects are alternatives: public @interface Mock {} ---- +[[priority_stereotype]] + +===== Declaring stereotype with `@Priority` + +A stereotype may declare a `@Priority` annotation which functions as a means of enabling and ordering affected alternatives, interceptors and decorators. + +If there are two different stereotypes declared by the bean that declare different priority values, then there is no default priority and the bean must explicitly declare a `@Priority` annotation. If it does not explicitly declare priority, the container automatically detects the problem and treats it as a definition error. + +If a bean explicitly declares priority, any priority values declared by stereotypes are ignored. + +Following sample shows a stereotype that can be used to mark bean as globally enabled alternative: + +[source, java] +---- +@Alternative +@Priority(Interceptor.Priority.APPLICATION + 5) +@Stereotype +@Target(TYPE) +@Retention(RUNTIME) +public @interface TestReplacementStereotype {} +---- + [[stereotypes_with_additional_stereotypes]] ===== Stereotypes with additional stereotypes