[logback-user] can't understand cast error

pedro rijo pedrorijo91 at gmail.com
Sun Aug 2 19:42:14 CEST 2015


Hey,

I'm not sure if this is a logback or slf4j issue, so sorry if it's a slf4j
issue.

My question is posted on stackoverflow (
http://stackoverflow.com/questions/31772577/org-slf4j-helpers-substitutelogger-cannot-be-cast-to-ch-qos-logback-classic-logg
) but I will paste it here:

I've seen some questions very similar to this one (
http://stackoverflow.com/questions/15483309/org-slf4j-helpers-noploggerfactory-cannot-be-cast-to-ch-qos-logback-classic-logg)),
but none of them received a good answer, or at least one that explained or
solved this problem

I was able to create a very small project (basically 2 Scala classes - each
with a logger - and 2 test classes) with a similar structure to my real
project where I found the problem. The example is available here:
https://bitbucket.org/pedrorijo91/logger-exp

The problem happens when I run `sbt test`, resulting in the following error:

    {14:43:41} (#47) ~/Desktop/logger-exp/log-exp at pedrorijo(master) $ sbt
test
    Java HotSpot(TM) 64-Bit Server VM warning: ignoring option
MaxPermSize=384m; support was removed in 8.0
    [info] Loading global plugins from /Users/pedrorijo/.sbt/0.13/plugins
    [info] Loading project definition from
/Users/pedrorijo/Desktop/git/scala/logger-exp/log-exp/project
    [info] Set current project to log-exp (in build
file:/Users/pedrorijo/Desktop/git/scala/logger-exp/log-exp/)
    [info] HelloTest:
    [info] Exception encountered when attempting to run a suite with class
name: HelloTest *** ABORTED ***
    [info]   java.lang.ExceptionInInitializerError:
    [info]   at HelloTest$$anonfun$1.apply$mcV$sp(HelloTest.scala:8)
    [info]   at HelloTest$$anonfun$1.apply(HelloTest.scala:8)
    [info]   at HelloTest$$anonfun$1.apply(HelloTest.scala:8)
    [info]   at
org.scalatest.Transformer$$anonfun$apply$1.apply$mcV$sp(Transformer.scala:22)
    [info]   at org.scalatest.OutcomeOf$class.outcomeOf(OutcomeOf.scala:85)
    [info]   at org.scalatest.OutcomeOf$.outcomeOf(OutcomeOf.scala:104)
    [info]   at org.scalatest.Transformer.apply(Transformer.scala:22)
    [info]   at org.scalatest.Transformer.apply(Transformer.scala:20)
    [info]   at
org.scalatest.FunSuiteLike$$anon$1.apply(FunSuiteLike.scala:166)
    [info]   at org.scalatest.Suite$class.withFixture(Suite.scala:1122)
    [info]   ...
    [info]   Cause: java.lang.ClassCastException:
org.slf4j.helpers.SubstituteLogger cannot be cast to
ch.qos.logback.classic.Logger
    [info]   at com.example.Hello$.<init>(Hello.scala:8)
    [info]   at com.example.Hello$.<clinit>(Hello.scala)
    [info]   at HelloTest$$anonfun$1.apply$mcV$sp(HelloTest.scala:8)
    [info]   at HelloTest$$anonfun$1.apply(HelloTest.scala:8)
    [info]   at HelloTest$$anonfun$1.apply(HelloTest.scala:8)
    [info]   at
org.scalatest.Transformer$$anonfun$apply$1.apply$mcV$sp(Transformer.scala:22)
    [info]   at org.scalatest.OutcomeOf$class.outcomeOf(OutcomeOf.scala:85)
    [info]   at org.scalatest.OutcomeOf$.outcomeOf(OutcomeOf.scala:104)
    [info]   at org.scalatest.Transformer.apply(Transformer.scala:22)
    [info]   at org.scalatest.Transformer.apply(Transformer.scala:20)
    [info]   ...
    SLF4J: The following set of substitute loggers may have been accessed
    SLF4J: during the initialization phase. Logging calls during this
    SLF4J: phase were not honored. However, subsequent logging calls to
these
    SLF4J: loggers will work as normally expected.
    SLF4J: See also http://www.slf4j.org/codes.html#substituteLogger
    SLF4J: com.example.Hello$
    14:43:52.846 [pool-6-thread-4-ScalaTest-running-WorldTest] INFO
 com.example.World$ - LOGGING
    [info] WorldTest:
    [info] - test
    [info] Run completed in 456 milliseconds.
    [info] Total number of tests run: 1
    [info] Suites: completed 1, aborted 1
    [info] Tests: succeeded 1, failed 0, canceled 0, ignored 0, pending 0
    [info] *** 1 SUITE ABORTED ***
    [error] Error during tests:
    [error]  HelloTest
    [error] (test:test) sbt.TestsFailedException: Tests unsuccessful
    [error] Total time: 1 s, completed Aug 2, 2015 2:43:52 PM


but if I run each of the tests individually through:

`sbt "testOnly HelloTest"` and `sbt "testOnly WorlTest"` I get no error.

As far as I've seen this is not just a Scala issue, it seems that in Java
is also possible to happen. Furthermore, I've read that during
initialization the loggers are substituted by a  Substitute Logger (
http://www.slf4j.org/codes.html#substituteLogger).

But I can't understand:

 1. why it only happens in tests, and when running both tests?
 2. why it happens?
 3. how to debug/solve this problem?

 As I said before, I've created a repository with a working example
(working, meaning with the error happening) here:
https://bitbucket.org/pedrorijo91/logger-exp



-- 
Kind Regards,

Pedro Rijo
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mailman.qos.ch/pipermail/logback-user/attachments/20150802/004d3c4b/attachment.html>


More information about the Logback-user mailing list