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)