1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
|
# Licensed to Elasticsearch B.V. under one or more contributor
# license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright
# ownership. Elasticsearch B.V. licenses this file to you 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.
if ENV['COVERAGE'] && ENV['CI'].nil?
require 'simplecov'
SimpleCov.start { add_filter %r{^/test|spec/} }
end
require 'elasticsearch-transport'
require 'logger'
require 'ansi/code'
require 'hashie/mash'
if defined?(JRUBY_VERSION)
require 'elasticsearch/transport/transport/http/manticore'
require 'pry-nav'
else
require 'pry-byebug'
require 'elasticsearch/transport/transport/http/curb'
require 'curb'
end
# The hosts to use for creating a elasticsearch client.
#
# @since 7.0.0
ELASTICSEARCH_HOSTS = if (hosts = ENV['TEST_ES_SERVER'] || ENV['ELASTICSEARCH_HOSTS'])
hosts.split(',').map do |host|
/(http\:\/\/)?(\S+)/.match(host)[2]
end
else
['localhost:9200']
end.freeze
TEST_HOST, TEST_PORT = ELASTICSEARCH_HOSTS.first.split(':') if ELASTICSEARCH_HOSTS
# Are we testing on JRuby?
#
# @return [ true, false ] Whether JRuby is being used.
#
# @since 7.0.0
def jruby?
RUBY_PLATFORM =~ /\bjava\b/
end
# The names of the connected nodes.
#
# @return [ Array<String> ] The node names.
#
# @since 7.0.0
def node_names
node_stats = default_client.perform_request('GET', '_nodes/stats').body
$node_names ||= node_stats['nodes'].collect do |name, stats|
stats['name']
end
end
# The default client.
#
# @return [ Elasticsearch::Client ] The default client.
#
# @since 7.0.0
def default_client
$client ||= Elasticsearch::Client.new(hosts: ELASTICSEARCH_HOSTS)
end
module Config
def self.included(context)
# Get the hosts to use to connect an elasticsearch client.
#
# @since 7.0.0
context.let(:hosts) { ELASTICSEARCH_HOSTS }
end
end
RSpec.configure do |config|
config.include(Config)
config.formatter = 'documentation'
config.color = true
end
|