pd-blender 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (62) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +22 -0
  3. data/.rubocop.yml +2 -0
  4. data/.travis.yml +10 -0
  5. data/Gemfile +6 -0
  6. data/LICENSE.txt +14 -0
  7. data/README.md +342 -0
  8. data/Rakefile +21 -0
  9. data/bin/blend +20 -0
  10. data/blender.gemspec +36 -0
  11. data/lib/blender.rb +67 -0
  12. data/lib/blender/cli.rb +71 -0
  13. data/lib/blender/configuration.rb +45 -0
  14. data/lib/blender/discovery.rb +41 -0
  15. data/lib/blender/drivers/base.rb +40 -0
  16. data/lib/blender/drivers/compound.rb +29 -0
  17. data/lib/blender/drivers/ruby.rb +55 -0
  18. data/lib/blender/drivers/shellout.rb +63 -0
  19. data/lib/blender/drivers/ssh.rb +93 -0
  20. data/lib/blender/drivers/ssh_multi.rb +102 -0
  21. data/lib/blender/event_dispatcher.rb +45 -0
  22. data/lib/blender/exceptions.rb +26 -0
  23. data/lib/blender/handlers/base.rb +39 -0
  24. data/lib/blender/handlers/doc.rb +73 -0
  25. data/lib/blender/job.rb +73 -0
  26. data/lib/blender/lock/flock.rb +64 -0
  27. data/lib/blender/log.rb +24 -0
  28. data/lib/blender/rspec.rb +68 -0
  29. data/lib/blender/rspec/stub_registry.rb +45 -0
  30. data/lib/blender/scheduled_job.rb +66 -0
  31. data/lib/blender/scheduler.rb +114 -0
  32. data/lib/blender/scheduler/dsl.rb +160 -0
  33. data/lib/blender/scheduling_strategies/base.rb +30 -0
  34. data/lib/blender/scheduling_strategies/default.rb +37 -0
  35. data/lib/blender/scheduling_strategies/per_host.rb +38 -0
  36. data/lib/blender/scheduling_strategies/per_task.rb +37 -0
  37. data/lib/blender/tasks/base.rb +72 -0
  38. data/lib/blender/tasks/ruby.rb +31 -0
  39. data/lib/blender/tasks/shell_out.rb +30 -0
  40. data/lib/blender/tasks/ssh.rb +25 -0
  41. data/lib/blender/timer.rb +54 -0
  42. data/lib/blender/utils/refinements.rb +45 -0
  43. data/lib/blender/utils/thread_pool.rb +54 -0
  44. data/lib/blender/utils/ui.rb +51 -0
  45. data/lib/blender/version.rb +20 -0
  46. data/spec/blender/blender_rspec.rb +31 -0
  47. data/spec/blender/discovery_spec.rb +16 -0
  48. data/spec/blender/drivers/ssh_multi_spec.rb +16 -0
  49. data/spec/blender/drivers/ssh_spec.rb +17 -0
  50. data/spec/blender/dsl_spec.rb +19 -0
  51. data/spec/blender/event_dispatcher_spec.rb +17 -0
  52. data/spec/blender/job_spec.rb +42 -0
  53. data/spec/blender/lock_spec.rb +129 -0
  54. data/spec/blender/scheduled_job_spec.rb +30 -0
  55. data/spec/blender/scheduler_spec.rb +140 -0
  56. data/spec/blender/scheduling_strategies/default_spec.rb +75 -0
  57. data/spec/blender/utils/refinements_spec.rb +16 -0
  58. data/spec/blender/utils/thread_pool_spec.rb +16 -0
  59. data/spec/blender_spec.rb +37 -0
  60. data/spec/data/example.rb +12 -0
  61. data/spec/spec_helper.rb +35 -0
  62. metadata +304 -0
@@ -0,0 +1,75 @@
1
+ require 'spec_helper'
2
+ describe Blender::SchedulingStrategy do
3
+ let(:hosts){ %w{ h1 h2 h3 } }
4
+ let(:tasks){ Array.new(4){ |n| create_task("t#{n}") } }
5
+ let(:driver){ Object.new }
6
+ subject(:jobs) do
7
+ described_class.new.compute_jobs(tasks)
8
+ end
9
+ describe Blender::SchedulingStrategy::Default do
10
+ before do
11
+ tasks.each{|t| t.members(hosts)}
12
+ end
13
+ it 'number of jobs' do
14
+ expect(jobs.size).to eq(hosts.size * tasks.size)
15
+ end
16
+ it 'fist job should be first task on first host' do
17
+ expect(jobs.first.tasks).to eq([tasks.first])
18
+ expect(jobs.first.hosts).to eq([hosts.first])
19
+ end
20
+ it 'last job should be last task on last host' do
21
+ expect(jobs[-1].tasks).to eq([tasks.last])
22
+ expect(jobs[-1].hosts).to eq([hosts.last])
23
+ end
24
+ it 'all jobs should have one host' do
25
+ expect(jobs.map(&:hosts).map(&:size).uniq).to eq([1])
26
+ end
27
+ it 'all jobs should have one task' do
28
+ expect(jobs.map(&:tasks).map(&:size).uniq).to eq([1])
29
+ end
30
+ end
31
+ describe Blender::SchedulingStrategy::PerHost do
32
+ before do
33
+ tasks.each{|t| t.members(hosts)}
34
+ end
35
+ it 'number of jobs' do
36
+ expect(jobs.size).to eq(hosts.size)
37
+ end
38
+ it 'fist job should be all tasks on first host' do
39
+ expect(jobs.first.tasks).to eq(tasks)
40
+ expect(jobs.first.hosts).to eq([hosts.first])
41
+ end
42
+ it 'last job should be all tasks on last host' do
43
+ expect(jobs[-1].tasks).to eq(tasks)
44
+ expect(jobs[-1].hosts).to eq([hosts.last])
45
+ end
46
+ it 'all jobs should have one host' do
47
+ expect(jobs.map(&:hosts).map(&:size).uniq).to eq([1])
48
+ end
49
+ it 'all jobs should have all task' do
50
+ expect(jobs.map(&:tasks).map(&:size).uniq).to eq([tasks.size])
51
+ end
52
+ end
53
+ describe Blender::SchedulingStrategy::PerTask do
54
+ before do
55
+ tasks.each{|t| t.members(hosts)}
56
+ end
57
+ it 'number of jobs' do
58
+ expect(jobs.size).to eq(tasks.size)
59
+ end
60
+ it 'fist job should be first task on all hosts' do
61
+ expect(jobs.first.tasks).to eq([tasks.first])
62
+ expect(jobs.first.hosts).to eq(hosts)
63
+ end
64
+ it 'last job should be last task on all hosts' do
65
+ expect(jobs[-1].tasks).to eq([tasks.last])
66
+ expect(jobs[-1].hosts).to eq(hosts)
67
+ end
68
+ it 'all jobs should have all hosts' do
69
+ expect(jobs.map(&:hosts).map(&:size).uniq).to eq([hosts.size])
70
+ end
71
+ it 'all jobs should have one task' do
72
+ expect(jobs.map(&:tasks).map(&:size).uniq).to eq([1])
73
+ end
74
+ end
75
+ end
@@ -0,0 +1,16 @@
1
+ require 'spec_helper'
2
+ require 'blender/utils/refinements'
3
+
4
+ describe Blender::Utils::Refinements do
5
+ let(:util) do
6
+ Object.new.extend described_class
7
+ end
8
+ it '#camelcase' do
9
+ expect(util.camelcase('one')).to eq('One')
10
+ expect(util.camelcase('one_two')).to eq('OneTwo')
11
+ expect(util.camelcase('one_two_three')).to eq('OneTwoThree')
12
+ expect(util.camelcase('o_n_e')).to eq('ONE')
13
+ expect(util.camelcase('One')).to eq('One')
14
+ expect(util.camelcase('onE')).to eq('One')
15
+ end
16
+ end
@@ -0,0 +1,16 @@
1
+ require 'spec_helper'
2
+
3
+ describe Blender::Utils::ThreadPool do
4
+ let(:pool) { described_class.new(5)}
5
+ it 'should parallelize works' do
6
+ 10.times do
7
+ pool.add_job do
8
+ sleep 1
9
+ end
10
+ end
11
+ t1 = Time.now
12
+ pool.run_till_done
13
+ t2 = Time.now
14
+ expect(t2 - t1).to be < 4
15
+ end
16
+ end
@@ -0,0 +1,37 @@
1
+ #
2
+ # Author:: Ranjib Dey (<ranjib@pagerduty.com>)
3
+ # Copyright:: Copyright (c) 2014 PagerDuty, Inc.
4
+ # License:: Apache License, Version 2.0
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+
18
+ require 'spec_helper'
19
+
20
+ describe Blender do
21
+ describe '#blend' do
22
+ it 'should invoke a local command is no block is given' do
23
+ cmd = double(Mixlib::ShellOut, exitstatus: 0).as_null_object
24
+ expect(Mixlib::ShellOut).to receive(:new).with('foo', {}).and_return(cmd)
25
+ described_class.blend('foo')
26
+ end
27
+ it 'should yield a scheduler object when block passed' do
28
+ x = 1
29
+ described_class.blend('test') do |sched|
30
+ sched.ruby_task 'foo' do
31
+ x = 100
32
+ end
33
+ end
34
+ expect(x).to eq(100)
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,12 @@
1
+ members ['h1', 'h2', 'h3']
2
+
3
+ ruby_task 'task2' do
4
+ execute do |h|
5
+ puts 'HelloWorld'
6
+ end
7
+ driver_options(stdout: $stdout)
8
+ end
9
+ shell_task 'task3' do
10
+ execute 'does not exist'
11
+ ignore_failure true
12
+ end
@@ -0,0 +1,35 @@
1
+ require 'simplecov'
2
+ SimpleCov.formatter = SimpleCov::Formatter::HTMLFormatter
3
+ SimpleCov.start do
4
+ add_filter '/spec/'
5
+ add_filter '.bundle'
6
+ end
7
+
8
+ require 'rspec'
9
+ require 'rspec/mocks'
10
+ require 'rspec/expectations'
11
+ require 'blender'
12
+ require 'blender/scheduling_strategies/per_host'
13
+ require 'blender/scheduling_strategies/per_task'
14
+
15
+ module SpecHelper
16
+ def create_task(name, driver = nil)
17
+ t = Blender::Task::Base.new(name)
18
+ if driver
19
+ t.use_driver(driver)
20
+ end
21
+ t
22
+ end
23
+ end
24
+
25
+ RSpec.configure do |config|
26
+ config.include SpecHelper
27
+ config.mock_with :rspec do |mocks|
28
+ mocks.verify_doubled_constant_names = true
29
+ end
30
+ config.before(:each) do
31
+ doc = double(Blender::Handlers::Doc).as_null_object
32
+ allow(Blender::Handlers::Doc).to receive(:new).and_return(doc)
33
+ end
34
+ config.backtrace_exclusion_patterns = []
35
+ end
metadata ADDED
@@ -0,0 +1,304 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: pd-blender
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Ranjib Dey
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2014-09-10 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: highline
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: thor
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: mixlib-shellout
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: mixlib-log
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: net-ssh
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rufus-scheduler
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :runtime
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: bundler
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rake
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: rspec
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: rubocop
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: simplecov
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - ">="
158
+ - !ruby/object:Gem::Version
159
+ version: '0'
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - ">="
165
+ - !ruby/object:Gem::Version
166
+ version: '0'
167
+ - !ruby/object:Gem::Dependency
168
+ name: yard
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - ">="
172
+ - !ruby/object:Gem::Version
173
+ version: '0'
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - ">="
179
+ - !ruby/object:Gem::Version
180
+ version: '0'
181
+ - !ruby/object:Gem::Dependency
182
+ name: pry
183
+ requirement: !ruby/object:Gem::Requirement
184
+ requirements:
185
+ - - ">="
186
+ - !ruby/object:Gem::Version
187
+ version: '0'
188
+ type: :development
189
+ prerelease: false
190
+ version_requirements: !ruby/object:Gem::Requirement
191
+ requirements:
192
+ - - ">="
193
+ - !ruby/object:Gem::Version
194
+ version: '0'
195
+ description: Discover hosts, run tasks against them and control their execution order
196
+ email:
197
+ - ranjib@pagerduty.com
198
+ executables:
199
+ - blend
200
+ extensions: []
201
+ extra_rdoc_files: []
202
+ files:
203
+ - ".gitignore"
204
+ - ".rubocop.yml"
205
+ - ".travis.yml"
206
+ - Gemfile
207
+ - LICENSE.txt
208
+ - README.md
209
+ - Rakefile
210
+ - bin/blend
211
+ - blender.gemspec
212
+ - lib/blender.rb
213
+ - lib/blender/cli.rb
214
+ - lib/blender/configuration.rb
215
+ - lib/blender/discovery.rb
216
+ - lib/blender/drivers/base.rb
217
+ - lib/blender/drivers/compound.rb
218
+ - lib/blender/drivers/ruby.rb
219
+ - lib/blender/drivers/shellout.rb
220
+ - lib/blender/drivers/ssh.rb
221
+ - lib/blender/drivers/ssh_multi.rb
222
+ - lib/blender/event_dispatcher.rb
223
+ - lib/blender/exceptions.rb
224
+ - lib/blender/handlers/base.rb
225
+ - lib/blender/handlers/doc.rb
226
+ - lib/blender/job.rb
227
+ - lib/blender/lock/flock.rb
228
+ - lib/blender/log.rb
229
+ - lib/blender/rspec.rb
230
+ - lib/blender/rspec/stub_registry.rb
231
+ - lib/blender/scheduled_job.rb
232
+ - lib/blender/scheduler.rb
233
+ - lib/blender/scheduler/dsl.rb
234
+ - lib/blender/scheduling_strategies/base.rb
235
+ - lib/blender/scheduling_strategies/default.rb
236
+ - lib/blender/scheduling_strategies/per_host.rb
237
+ - lib/blender/scheduling_strategies/per_task.rb
238
+ - lib/blender/tasks/base.rb
239
+ - lib/blender/tasks/ruby.rb
240
+ - lib/blender/tasks/shell_out.rb
241
+ - lib/blender/tasks/ssh.rb
242
+ - lib/blender/timer.rb
243
+ - lib/blender/utils/refinements.rb
244
+ - lib/blender/utils/thread_pool.rb
245
+ - lib/blender/utils/ui.rb
246
+ - lib/blender/version.rb
247
+ - spec/blender/blender_rspec.rb
248
+ - spec/blender/discovery_spec.rb
249
+ - spec/blender/drivers/ssh_multi_spec.rb
250
+ - spec/blender/drivers/ssh_spec.rb
251
+ - spec/blender/dsl_spec.rb
252
+ - spec/blender/event_dispatcher_spec.rb
253
+ - spec/blender/job_spec.rb
254
+ - spec/blender/lock_spec.rb
255
+ - spec/blender/scheduled_job_spec.rb
256
+ - spec/blender/scheduler_spec.rb
257
+ - spec/blender/scheduling_strategies/default_spec.rb
258
+ - spec/blender/utils/refinements_spec.rb
259
+ - spec/blender/utils/thread_pool_spec.rb
260
+ - spec/blender_spec.rb
261
+ - spec/data/example.rb
262
+ - spec/spec_helper.rb
263
+ homepage: http://github.com/PagerDuty/blender
264
+ licenses:
265
+ - Apache 2
266
+ metadata: {}
267
+ post_install_message:
268
+ rdoc_options: []
269
+ require_paths:
270
+ - lib
271
+ required_ruby_version: !ruby/object:Gem::Requirement
272
+ requirements:
273
+ - - ">="
274
+ - !ruby/object:Gem::Version
275
+ version: '0'
276
+ required_rubygems_version: !ruby/object:Gem::Requirement
277
+ requirements:
278
+ - - ">="
279
+ - !ruby/object:Gem::Version
280
+ version: '0'
281
+ requirements: []
282
+ rubyforge_project:
283
+ rubygems_version: 2.2.2
284
+ signing_key:
285
+ specification_version: 4
286
+ summary: A modular orchestration engine
287
+ test_files:
288
+ - spec/blender/blender_rspec.rb
289
+ - spec/blender/discovery_spec.rb
290
+ - spec/blender/drivers/ssh_multi_spec.rb
291
+ - spec/blender/drivers/ssh_spec.rb
292
+ - spec/blender/dsl_spec.rb
293
+ - spec/blender/event_dispatcher_spec.rb
294
+ - spec/blender/job_spec.rb
295
+ - spec/blender/lock_spec.rb
296
+ - spec/blender/scheduled_job_spec.rb
297
+ - spec/blender/scheduler_spec.rb
298
+ - spec/blender/scheduling_strategies/default_spec.rb
299
+ - spec/blender/utils/refinements_spec.rb
300
+ - spec/blender/utils/thread_pool_spec.rb
301
+ - spec/blender_spec.rb
302
+ - spec/data/example.rb
303
+ - spec/spec_helper.rb
304
+ has_rdoc: