elasticsearch-drain 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,42 @@
1
+ require 'test_helper'
2
+ require 'pp'
3
+
4
+ class TestNodes < Minitest::Test
5
+ def setup
6
+ VCR.insert_cassette 'nodes', record: :new_episodes
7
+ @drain = ::Elasticsearch::Drain.new(
8
+ 'localhost:9250',
9
+ 'esuilogs-razor-d0prod-r01-v000',
10
+ 'us-west-2'
11
+ )
12
+ @nodes = ::Elasticsearch::Drain::Nodes.new(@drain.client, @drain.asg)
13
+ end
14
+
15
+ def teardown
16
+ VCR.eject_cassette
17
+ end
18
+
19
+ def test_has_nodes
20
+ assert_respond_to @nodes, :client
21
+ end
22
+
23
+ def test_nodes_is_array
24
+ assert_respond_to @nodes.nodes, :each
25
+ end
26
+
27
+ def test_has_info
28
+ assert_respond_to @nodes, :info
29
+ end
30
+
31
+ def test_info_has_value
32
+ assert_respond_to @nodes.info, :each
33
+ end
34
+
35
+ def test_has_stats
36
+ assert_respond_to @nodes, :stats
37
+ end
38
+
39
+ def test_stats_has_value
40
+ assert_respond_to @nodes.stats, :each
41
+ end
42
+ end
@@ -0,0 +1,44 @@
1
+ require 'test_helper'
2
+
3
+ class TestDrain < Minitest::Test
4
+ def setup
5
+ VCR.insert_cassette 'drain', record: :new_episodes
6
+ @drain = ::Elasticsearch::Drain.new(
7
+ 'localhost:9250',
8
+ 'esuilogs-razor-d0prod-r01-v000',
9
+ 'us-west-2'
10
+ )
11
+ end
12
+
13
+ def teardown
14
+ VCR.eject_cassette
15
+ end
16
+
17
+ def test_nodes_method
18
+ assert_respond_to @drain, :nodes
19
+ end
20
+
21
+ def test_has_hosts_attribute
22
+ assert_respond_to @drain, :hosts
23
+ end
24
+
25
+ def test_has_asg
26
+ assert_equal 'esuilogs-razor-d0prod-r01-v000', @drain.asg.asg
27
+ end
28
+
29
+ def test_has_region
30
+ assert_equal 'us-west-2', @drain.region
31
+ end
32
+
33
+ def test_has_cluster
34
+ assert_respond_to @drain, :cluster
35
+ end
36
+
37
+ def test_cluster_health_is_valid
38
+ assert (@drain.cluster.healthy? || %w(red yellow green).include?(@drain.cluster.health['status']))
39
+ end
40
+
41
+ def test_es_cluster_hosts_match
42
+ assert_equal 'localhost:9250', @drain.hosts
43
+ end
44
+ end
@@ -0,0 +1,26 @@
1
+ require 'vcr'
2
+ require 'ipaddr'
3
+ require 'webmock'
4
+ require 'simplecov'
5
+ require 'minitest/spec'
6
+ require 'minitest/autorun'
7
+ require 'elasticsearch/extensions/test/cluster'
8
+
9
+ gem 'minitest'
10
+ SimpleCov.start
11
+
12
+ require_relative '../lib/elasticsearch/drain'
13
+
14
+ VCR.configure do |c|
15
+ c.cassette_library_dir = 'test/cassettes'
16
+ c.hook_into :webmock
17
+ # c.debug_logger = $stderr
18
+ # c.default_cassette_options = { allow_playback_repeats: true }
19
+ end
20
+
21
+ def private_ipaddress?(ip)
22
+ class_a = IPAddr.new('10.0.0.0/8')
23
+ class_b = IPAddr.new('172.16.0.0/12')
24
+ class_c = IPAddr.new('192.168.0.0/16')
25
+ [class_a, class_b, class_c].any? { |i| i.include?(ip) }
26
+ end
metadata ADDED
@@ -0,0 +1,160 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: elasticsearch-drain
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Andrew Thompson
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-11-09 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.7'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.7'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: elasticsearch
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: aws-sdk
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '2'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '2'
69
+ - !ruby/object:Gem::Dependency
70
+ name: thor
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '0.19'
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '0.19'
83
+ description: The purpose of this utility is to drain documents from Elasticsearch
84
+ nodes in an AutoScaling Group
85
+ email:
86
+ - Andrew_Thompson@rapid7.com
87
+ executables:
88
+ - drain
89
+ extensions: []
90
+ extra_rdoc_files: []
91
+ files:
92
+ - ".gitignore"
93
+ - ".rubocop.yml"
94
+ - ".rubocop_todo.yml"
95
+ - ".travis.yml"
96
+ - Gemfile
97
+ - Gemfile.lock
98
+ - Guardfile
99
+ - LICENSE
100
+ - README.md
101
+ - Rakefile
102
+ - Thorfile
103
+ - bin/drain
104
+ - elasticsearch-drain.gemspec
105
+ - lib/elasticsearch/drain.rb
106
+ - lib/elasticsearch/drain/autoscaling.rb
107
+ - lib/elasticsearch/drain/base.rb
108
+ - lib/elasticsearch/drain/cli.rb
109
+ - lib/elasticsearch/drain/cluster.rb
110
+ - lib/elasticsearch/drain/node.rb
111
+ - lib/elasticsearch/drain/nodes.rb
112
+ - lib/elasticsearch/drain/version.rb
113
+ - test/cassettes/autoscaling.yml
114
+ - test/cassettes/cluster.yml
115
+ - test/cassettes/drain.yml
116
+ - test/cassettes/node.yml
117
+ - test/cassettes/nodes.yml
118
+ - test/elasticsearch/drain/test_autoscaling.rb
119
+ - test/elasticsearch/drain/test_cluster.rb
120
+ - test/elasticsearch/drain/test_node.rb
121
+ - test/elasticsearch/drain/test_nodes.rb
122
+ - test/elasticsearch/test_drain.rb
123
+ - test/test_helper.rb
124
+ homepage: ''
125
+ licenses:
126
+ - MIT
127
+ metadata: {}
128
+ post_install_message:
129
+ rdoc_options: []
130
+ require_paths:
131
+ - lib
132
+ required_ruby_version: !ruby/object:Gem::Requirement
133
+ requirements:
134
+ - - ">="
135
+ - !ruby/object:Gem::Version
136
+ version: '0'
137
+ required_rubygems_version: !ruby/object:Gem::Requirement
138
+ requirements:
139
+ - - ">="
140
+ - !ruby/object:Gem::Version
141
+ version: '0'
142
+ requirements: []
143
+ rubyforge_project:
144
+ rubygems_version: 2.4.4
145
+ signing_key:
146
+ specification_version: 4
147
+ summary: Elasticsearch node replacement utility that tries to keep the cluster healthy
148
+ test_files:
149
+ - test/cassettes/autoscaling.yml
150
+ - test/cassettes/cluster.yml
151
+ - test/cassettes/drain.yml
152
+ - test/cassettes/node.yml
153
+ - test/cassettes/nodes.yml
154
+ - test/elasticsearch/drain/test_autoscaling.rb
155
+ - test/elasticsearch/drain/test_cluster.rb
156
+ - test/elasticsearch/drain/test_node.rb
157
+ - test/elasticsearch/drain/test_nodes.rb
158
+ - test/elasticsearch/test_drain.rb
159
+ - test/test_helper.rb
160
+ has_rdoc: