wvlet.airspec.spi.AirSpecContext.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of airspec-light_2.11 Show documentation
Show all versions of airspec-light_2.11 Show documentation
API and and runner for AirSpec test cases
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package wvlet.airspec.spi
import wvlet.airframe.Session
import wvlet.airframe.surface.{MethodSurface, Surface}
import wvlet.airspec.{AirSpecBase, AirSpecMacros, AirSpecSpi}
import scala.language.experimental.macros
/**
* AirSpecContext is an interface to pass the test environment data to individual test methods.
*
*
* Spec: global
* -
*
*/
trait AirSpecContext {
def currentSpec: AirSpecSpi
def parentContext: Option[AirSpecContext]
/**
* Get the current session used for calling the test method
*/
def currentSession: Session
/**
* Get the leaf name of the current spec class.
*
* Note: In Scala.js, this may return weired names especially for inner classes.
*/
def specName: String = currentSpec.leafSpecName
def fullSpecName: String = {
val parent = parentContext.map(x => s"${x.fullSpecName}.").getOrElse("")
s"${parent}${specName}"
}
/**
* Get the test method name currently running.
* For a global context, this will return ''.
*/
def testName: String
lazy val indentLevel: Int = {
parentContext.map(_.indentLevel + 1).getOrElse(0)
}
/**
* Build an instance of type A using Airframe DI, and run the test method within A.
* @return the generated instance of A
*/
def test[A <: AirSpecBase]: A = macro AirSpecMacros.buildAndRunImpl[A]
/**
* Run the test methods in a given AirSpec instance
*/
def run[A <: AirSpecBase](spec: A): A = macro AirSpecMacros.runSpecImpl[A]
protected def runInternal(spec: AirSpecSpi, testMethods: Seq[MethodSurface]): AirSpecSpi
protected def newSpec(specSurface: Surface): AirSpecSpi
}
object AirSpecContext {
implicit class AirSpecContextAccess(val context: AirSpecContext) extends AnyVal {
def callRunInternal(spec: AirSpecSpi, specMethods: Seq[MethodSurface]): AirSpecSpi = {
context.runInternal(spec, AirSpecSpi.collectTestMethods(specMethods))
}
def callNewSpec(specSurface: Surface): AirSpecSpi = context.newSpec(specSurface)
}
}