summaryrefslogblamecommitdiff
path: root/test/scaladoc/run/implicits-known-type-classes.scala
blob: 471a1a219dcaa2182ab1a2fbbd8a16d62994a618 (plain) (tree)

























                                                                                                                         
                                                                         





                                                                                                                 
import scala.tools.nsc.doc.model._
import scala.tools.partest.ScaladocModelTest
import language._

object Test extends ScaladocModelTest {

  // test a file instead of a piece of code
  override def resourceFile = "implicits-known-type-classes-res.scala"

  // start implicits
  def scaladocSettings = "-implicits"

  def testModel(root: Package) = {
    // get the quick access implicit defs in scope (_package(s), _class(es), _trait(s), object(s) _method(s), _value(s))
    import access._

    /** Tests the "known type classes" feature of scaladoc implicits
     *  if the test fails, please update the correct qualified name of
     *  the type class in src/compiler/scala/tools/nsc/doc/Settings.scala
     *  in the knownTypeClasses map. Thank you! */

    val base = root._package("scala")._package("test")._package("scaladoc")._package("implicits")._package("typeclasses")
    var conv: ImplicitConversion = null

    val A = base._class("A")

    for (conversion <- A.conversions if !conversion.isHiddenConversion) {
      assert(conversion.constraints.length == 1, conversion.constraints.length + " == 1 (in " + conversion + ")")
      assert(conversion.constraints.head.isInstanceOf[KnownTypeClassConstraint],
             conversion.constraints.head + " is not a known type class constraint!")
    }
  }
}