This is a mistake, namely SI-10405 , which I discovered a while ago.
For some reason Predef, implicit search fails. If you compile your code with a flag -Yno-predef, you will succeed.
The symptom is that you see typer trying to resolve implicit using Predef.conforms[A]compilation in -Xlog-implicits:
λ scalac -Xlog-implicits Bar.scala
Bar.scala:16: listImplicitConversion is not a valid implicit value for List[yuval.tests.ImplicitTest.CaseClassA] => List[yuval.tests.ImplicitTest.CaseClassB] because:
incompatible: (l: List[yuval.tests.ImplicitTest.CaseClassA])(implicit conv: yuval.tests.ImplicitTest.CaseClassA => yuval.tests.ImplicitTest.CaseClassA)List[yuval.tests.ImplicitTest.CaseClassA] does not match expected type List[yuval.tests.ImplicitTest.CaseClassA] => List[yuval.tests.ImplicitTest.CaseClassB]
val listOfB: List[CaseClassB] = listOfA
And ignores further search, although earlier he managed to match:
|-- List[CaseClassB] TYPEmode (site: value listOfB in ImplicitTest)
| | | | | |-- scala.`package` EXPRmode-POLYmode-QUALmode (site: value listOfB in ImplicitTest)
| | | | | | \-> scala.type
| | | | | |-- CaseClassB TYPEmode (site: value listOfB in ImplicitTest)
| | | | | | \-> yuval.tests.ImplicitTest.CaseClassB
| | | | | \-> List[yuval.tests.ImplicitTest.CaseClassB]
| | | | |-- listOfA : pt=List[yuval.tests.ImplicitTest.CaseClassB] BYVALmode-EXPRmode (site: value listOfB in ImplicitTest)
| | | | | [search
| | | | | [search #2] considering listImplicitConversion
| | | | | |-- listImplicitConversion BYVALmode-EXPRmode-FUNmode-POLYmode (silent: value listOfB in ImplicitTest) implicits disabled
| | | | | | [adapt] [A, B](l: List[A])(implicit conv: A => B)List[B] adapted to [A, B](l: List[A])(implicit conv: A => B)List[B]
| | | | | | \-> (l: List[A])(implicit conv: A => B)List[B]
| | | | | solving for (A: ?A, B: ?B)
| | | | | [search #3] start `[A, B](l: List[A])(implicit conv: A => B)List[B]` inferring type B, searching for adaptation to pt=yuval.tests.ImplicitTest.CaseClassA => B (silent: value listOfB in ImplicitTest) implicits disabled
| | | | | [search
| | | | | |-- { ((a: yuval.tests.ImplicitTest.CaseClassA) => ImplicitTe... : pt=yuval.tests.ImplicitTest.CaseClassA => ? EXPRmode (silent: value listOfB in ImplicitTest) implicits disabled
| | | | | | |-- ((a: yuval.tests.ImplicitTest.CaseClassA) => ImplicitTest... : pt=yuval.tests.ImplicitTest.CaseClassA => ? EXPRmode (silent: value listOfB in ImplicitTest) implicits disabled
| | | | | | | |-- ImplicitTest.this.a2b(a) EXPRmode (silent: value $anonfun in ImplicitTest) implicits disabled
| | | | | | | | |-- ImplicitTest.this.a2b BYVALmode-EXPRmode-FUNmode-POLYmode (silent: value $anonfun in ImplicitTest) implicits disabled
| | | | | | | | | \-> (a: yuval.tests.ImplicitTest.CaseClassA)yuval.tests.ImplicitTest.CaseClassB
| | | | | | | | |-- a : pt=yuval.tests.ImplicitTest.CaseClassA BYVALmode-EXPRmode (silent: value $anonfun in ImplicitTest) implicits disabled
| | | | | | | | | \-> yuval.tests.ImplicitTest.CaseClassA
| | | | | | | | \-> yuval.tests.ImplicitTest.CaseClassB
| | | | | | | \-> yuval.tests.ImplicitTest.CaseClassA => yuval.tests.ImplicitTest.CaseClassB
| | | | | | \-> yuval.tests.ImplicitTest.CaseClassA => yuval.tests.ImplicitTest.CaseClassB
| | | | | [adapt] a2b adapted to { ((a: yuval.tests.ImplicitTest.CaseClassA) => ImplicitTe... based on pt yuval.tests.ImplicitTest.CaseClassA => B
| | | | | [search
| | | | | solving for (B: ?B)
| | | | | [search
| | | | | ((a: yuval.tests.ImplicitTest.CaseClassA) => ImplicitTest.this.a2b(a))
| | | | | }, TreeTypeSubstituter(List(type B),List(yuval.tests.ImplicitTest.CaseClassB)))
, :
[search
((a: yuval.tests.ImplicitTest.CaseClassA) => ImplicitTest.this.a2b(a))
}, TreeTypeSubstituter(List(type B),List(yuval.tests.ImplicitTest.CaseClassB)))