Это, кажется, ошибка. @Lazy
не работает в значении. Вы должны создать билет с ошибкой с Groovy, чтобы это было исправлено.
Для доказательства этого вопроса, я продлил свой код, чтобы создать тест (запускать как простой заводной скрипт), который показывает, что @Lazy
работает для Class
, но терпит неудачу утверждения, когда используется на trait
:
class MyBase{
@Lazy String test = { 'test' }()
}
class TestBaseClass extends MyBase{}
def tb = new TestBaseClass();
//Dump the current state to output an assert test hasn't been initialized
println "Testing @Lazy on a Class.."
println tb.dump()
assert tb.dump().contains('test=null') //FOR A CLASS, THIS WILL SUCCEED
//Access the test property causing initialization
println "Accessing the test property."
assert tb.test
//Dump the current state to output an assert test has now been initialized
println tb.dump()
assert tb.test == 'test'
trait MyTrait{
@Lazy String test = { 'test' }()
}
class TestClass implements MyTrait{}
def t = new TestClass();
//Dump the current state to output an assert test hasn't been initialized
println "\nTesting @Lazy on a Trait.."
println t.dump()
assert t.dump().contains('test=null') //FOR A TRAIT, THIS WILL FAIL THE ASSERTION - A BUG?
//Access the test property causing initialization
println "Accessing the test property."
assert t.test
//Dump the current state to output an assert test has now been initialized
println t.dump()
assert t.test == 'test'
Это неудивительно. Во всех разговорах, которые я слышал о «Чертах» в G2One, Седрик сказал: «Если документация ГОВОРИТ, что она будет работать с« Чертами », большинство аннотаций НЕ будут работать с« Чертами ». – billjamesdev
Вы можете сделать это вручную в качестве обходного пути, проверив существующее значение в пользовательском getter –