All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sksamuel.elastic4s.testkit.providers.scala Maven / Gradle / Ivy

There is a newer version: 8.15.4
Show newest version
//package com.sksamuel.elastic4s.testkit
//
//import java.nio.file.{Path, Paths}
//import java.util.UUID
//import java.util.concurrent.atomic.AtomicLong
//
//import com.sksamuel.elastic4s.embedded.{LocalNode, RemoteLocalNode}
//import com.sksamuel.elastic4s.http.ElasticClient
//
//import scala.util.control.NonFatal
//import scala.util.{Failure, Random, Success, Try}
//
//// LocalNodeProvider provides helper methods to create a local (embedded) node
//trait LocalNodeProvider {
//  // returns an embedded, started, node
//  def getNode: LocalNode
//  def node: LocalNode = getNode
//
//  implicit lazy val client: ElasticClient  = getNode.client(false)
//}
//
//// implementation of LocalNodeProvider that uses a single
//// node instance for all classes in the same thread classloader.
//trait ClassloaderLocalNodeProvider extends LocalNodeProvider {
//
//  private lazy val dir: Path  = Paths get System.getProperty("java.io.tmpdir")
//  private lazy val home: Path = dir resolve UUID.randomUUID().toString
//
//  override lazy val getNode: LocalNode = localNode(0)
//
//  private def localNode(timesTried: Int): LocalNode =
//    Try(LocalNode("node_" + ClassLocalNodeProvider.counter.getAndIncrement(), home.toAbsolutePath.toString)) match {
//      case Failure(ex: IllegalStateException) if timesTried < 5 =>
//        ex.printStackTrace()
//        localNode(timesTried + 1)
//      case Success(okNode) => okNode
//      case Failure(other)  => throw other
//    }
//}
//
//// implementation of LocalNodeProvider that attempts to find local nodes already started
//// and then connects to that, or creates a new one if one cannot be found
//trait DiscoveryLocalNodeProvider extends LocalNodeProvider {
//
//  override def getNode: LocalNode =
//    try {
//
//      // assume the local node is running on 39227
//      val client = ElasticClient("elasticsearch://localhost:39227")
//      import com.sksamuel.elastic4s.http.ElasticDsl._
//      val nodeinfo   = client.execute(nodeInfo()).await.result
//      val (id, node) = nodeinfo.nodes.head
//      println(s"Found local node $id")
//
//      val paths    = node.settingsAsMap("path").asInstanceOf[Map[String, AnyRef]]
//      val pathData = Paths get paths("data").toString
//      val pathHome = Paths get paths("home").toString
//      val pathRepo = Paths get paths("repo").toString
//      new RemoteLocalNode(nodeinfo.clusterName,
//                          id,
//                          node.ip,
//                          node.http.publishAddress,
//                          node.transport.publishAddress,
//                          pathData,
//                          pathHome,
//                          pathRepo)
//
//    } catch {
//      case NonFatal(e) =>
//        def tempDirectoryPath: Path = Paths get System.getProperty("java.io.tmpdir")
//        def pathHome: Path          = tempDirectoryPath resolve UUID.randomUUID().toString
//
//        def createLocalNode(timesTried: Int): LocalNode = {
//          println(s"Creating new local node")
//          Try(LocalNode("localnode-cluster", pathHome.toAbsolutePath.toString)) match {
//            case Failure(_: IllegalStateException) if timesTried < 5 => createLocalNode(timesTried + 1)
//            case Success(okNode)                                     => okNode
//            case Failure(other)                                      => throw other
//          }
//        }
//
//        val node = createLocalNode(0)
//        // allow time for the node to start up
//        Thread.sleep(3000)
//        node
//    }
//}
//
//// implementation of LocalNodeProvider that uses a single
//// node instance for each class that mixes in this trait.
//trait ClassLocalNodeProvider extends LocalNodeProvider {
//
//  private lazy val tempDirectoryPath: Path = Paths get System.getProperty("java.io.tmpdir")
//  private lazy val pathHome: Path          = tempDirectoryPath resolve UUID.randomUUID().toString
//
//  override lazy val getNode = LocalNode(
//    "node_" + ClassLocalNodeProvider.counter.getAndIncrement(),
//    pathHome.toAbsolutePath.toString
//  )
//}
//
//object ClassLocalNodeProvider {
//  val counter = new AtomicLong(1)
//}
//
//trait AlwaysNewLocalNodeProvider extends LocalNodeProvider {
//
//  private def tempDirectoryPath: Path = Paths get System.getProperty("java.io.tmpdir")
//  private def pathHome: Path          = tempDirectoryPath resolve UUID.randomUUID().toString
//
//  override def getNode: LocalNode =
//    LocalNode(
//      "node_" + Random.nextInt(),
//      pathHome.toAbsolutePath.toString
//    )
//}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy