summaryrefslogblamecommitdiff
path: root/test/files/scalacheck/quasiquotes/LiftableProps.scala
blob: 2173337edd7935a693ae3308660efcaec761f55e (plain) (tree)
1
2

                                                   











































































                                                               









                                                                          
 
import org.scalacheck._, Prop._, Gen._, Arbitrary._
import scala.reflect.runtime.universe._, Flag._

object LiftableProps extends QuasiquoteProperties("liftable") {
  property("splice byte") = test {
    val c: Byte = 0
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice short") = test {
    val c: Short = 0
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice char") = test {
    val c: Char = 'c'
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice int") = test {
    val c: Int = 0
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice long") = test {
    val c: Long = 0
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice float") = test {
    val c: Float = 0.0f
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice double") = test {
    val c: Double = 0.0
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice boolean") = test {
    val c: Boolean = false
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice string") = test {
    val c: String = "s"
    assert(q"$c"  Literal(Constant(c)))
  }

  property("splice unit") = test {
    val c: Unit = ()
    assert(q"$c"  Literal(Constant(c)))
  }

  property("lift symbol") = test {
    val s = rootMirror.staticClass("scala.Int")
    assert(q"$s"  Ident(s))
  }

  property("lift type") = test {
    val tpe = rootMirror.staticClass("scala.Int").toType
    assert(q"$tpe"  TypeTree(tpe))
  }

  property("lift type tag") = test {
    val tag = TypeTag.Int
    assert(q"$tag"  TypeTree(tag.tpe))
  }

  property("lift weak type tag") = test {
    val tag = WeakTypeTag.Int
    assert(q"$tag"  TypeTree(tag.tpe))
  }

  property("lift constant") = test {
    val const = Constant(0)
    assert(q"$const"  q"0")
  }

  property("lift list variants") = test {
    val lst = List(1, 2)
    val immutable = q"$scalapkg.collection.immutable"
    assert(q"$lst"  q"$immutable.List(1, 2)")
    assert(q"f(..$lst)"  q"f(1, 2)")
    val llst = List(List(1), List(2))
    assert(q"f(..$llst)"  q"f($immutable.List(1), $immutable.List(2))")
    assert(q"f(...$llst)"  q"f(1)(2)")
  }
}