You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@groovy.apache.org by "Paul King (JIRA)" <ji...@apache.org> on 2017/01/26 05:19:26 UTC
[jira] [Resolved] (GROOVY-8060) @Log annotation does not check
logging enablement inside closures which are arguments to methods
[ https://issues.apache.org/jira/browse/GROOVY-8060?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Paul King resolved GROOVY-8060.
-------------------------------
Resolution: Fixed
Fix Version/s: 2.4.9
Proposed PR merged.
> @Log annotation does not check logging enablement inside closures which are arguments to methods
> ------------------------------------------------------------------------------------------------
>
> Key: GROOVY-8060
> URL: https://issues.apache.org/jira/browse/GROOVY-8060
> Project: Groovy
> Issue Type: Bug
> Components: groovy-runtime
> Affects Versions: 2.3.3, 2.4.8
> Environment: Windows 7, Groovy 2.3.3, JDK 1.8.0_05
> Reporter: Shorn
> Assignee: Paul King
> Priority: Minor
> Fix For: 2.4.9
>
>
> From cloned issue for an additional case:
> {code}
> import groovy.util.logging.Slf4j
> import spock.lang.Specification
> @Slf4j
> class LoggingSpec extends Specification {
> def "makes sure groovy isn't building the string inside inactive log levels"() {
> assert log.isDebugEnabled() == false, "set the log level for this class to INFO to see the horror"
> assert log.isInfoEnabled() == true, "set the log level for this class to INFO to see the horror"
> CountingDoIt counter = new CountingDoIt()
> //http://docs.groovy-lang.org/docs/groovy-2.4.5/html/documentation/#_logging_improvements
> when: "we shouldn't evaluate"
> log.debug("this shouldn't happen ${counter.call()}".toString())
> then:
> counter.count == 0
> when: "we should evaluate"
> counter = new CountingDoIt()
> log.info("this should happen ${counter.call()}".toString())
> then:
> counter.count == 1
> when: "we're inside a closure and groovy is failing..so beware"
> counter = new CountingDoIt()
> 1.times({ ignore ->
> log.debug(counter.call())
> })
> then:
> counter.count == 0 //debug isn't enabled so this string should never be evaluated but it is
> when: "we're inside a closure that calls a method. it's OK"
> counter = new CountingDoIt()
> 1.times({ ignore ->
> log.debug("this shouldn't happen ${doIt(counter)}".toString())
> })
> then:
> counter.count == 0
> }
> String doIt(CountingDoIt countingDoIt) {
> log.debug("this shouldn't happen ${countingDoIt.call()}".toString())
> "blah"
> }
> static class CountingDoIt {
> int count = 0
> String call() {
> count = count + 1
> "doneDidIt"
> }
> }
> }
> {code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)