
blended.itestsupport.BlendedIntegrationTestSupport.scala Maven / Gradle / Ivy
/*
* Copyright 2014ff, https://github.com/woq-blended
*
* 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 blended.itestsupport
import akka.actor.{ActorRef, Props}
import akka.pattern.ask
import akka.testkit.{TestKit, TestProbe}
import akka.util.Timeout.durationToTimeout
import blended.itestsupport.condition.{Condition, ConditionActor}
import blended.itestsupport.docker.protocol._
import blended.itestsupport.protocol._
import org.apache.camel.CamelContext
import scala.concurrent.Await
import scala.concurrent.duration.FiniteDuration
trait BlendedIntegrationTestSupport {
def testContext(ctProxy: ActorRef)(implicit timeout: FiniteDuration, testKit: TestKit) : CamelContext = {
val probe = new TestProbe(testKit.system)
val cuts = ContainerUnderTest.containerMap(testKit.system.settings.config)
ctProxy.tell(TestContextRequest(cuts), probe.ref)
probe.receiveN(1,timeout).head.asInstanceOf[CamelContext]
}
def containerReady(ctProxy: ActorRef)(implicit timeout: FiniteDuration, testKit : TestKit) : Unit = {
val probe = new TestProbe(testKit.system)
ctProxy.tell(ContainerReady_?, probe.ref)
probe.expectMsg(timeout, ContainerReady(true))
}
def stopContainers(ctProxy: ActorRef)(implicit timeout: FiniteDuration, testKit: TestKit) : Unit = {
val probe = new TestProbe(testKit.system)
testKit.system.log.debug(s"stopProbe [${probe.ref}]")
ctProxy.tell(new StopContainerManager(timeout), probe.ref)
probe.expectMsg(timeout, ContainerManagerStopped)
}
def assertCondition(condition: Condition)(implicit testKit: TestKit) : Boolean = {
implicit val eCtxt = testKit.system.dispatcher
val checker = testKit.system.actorOf(Props(ConditionActor(condition)))
val checkFuture = (checker ? CheckCondition)(condition.timeout).map { result =>
result match {
case cr: ConditionCheckResult => cr.allSatisfied
case _ => false
}
}
Await.result(checkFuture, condition.timeout)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy