workaholic 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/.document ADDED
@@ -0,0 +1,5 @@
1
+ lib/**/*.rb
2
+ bin/*
3
+ -
4
+ features/**/*.feature
5
+ LICENSE.txt
data/.rspec ADDED
@@ -0,0 +1 @@
1
+ --color
data/Gemfile ADDED
@@ -0,0 +1,15 @@
1
+ source "http://rubygems.org"
2
+ # Add dependencies required to use your gem here.
3
+ # Example:
4
+ # gem "activesupport", ">= 2.3.5"
5
+
6
+ # Add dependencies to develop your gem here.
7
+ # Include everything needed to run rake, tests, features, etc.
8
+ group :development do
9
+ gem "rspec", "~> 2.8.0"
10
+ gem "yard", "~> 0.7"
11
+ gem "rdoc", "~> 3.12"
12
+ gem "bundler"
13
+ gem "jeweler", "~> 1.8.3"
14
+ gem "simplecov"
15
+ end
data/Gemfile.lock ADDED
@@ -0,0 +1,39 @@
1
+ GEM
2
+ remote: http://rubygems.org/
3
+ specs:
4
+ diff-lcs (1.1.3)
5
+ git (1.2.5)
6
+ jeweler (1.8.3)
7
+ bundler (~> 1.0)
8
+ git (>= 1.2.5)
9
+ rake
10
+ rdoc
11
+ json (1.7.3)
12
+ multi_json (1.3.5)
13
+ rake (0.9.2.2)
14
+ rdoc (3.12)
15
+ json (~> 1.4)
16
+ rspec (2.8.0)
17
+ rspec-core (~> 2.8.0)
18
+ rspec-expectations (~> 2.8.0)
19
+ rspec-mocks (~> 2.8.0)
20
+ rspec-core (2.8.0)
21
+ rspec-expectations (2.8.0)
22
+ diff-lcs (~> 1.1.2)
23
+ rspec-mocks (2.8.0)
24
+ simplecov (0.6.4)
25
+ multi_json (~> 1.0)
26
+ simplecov-html (~> 0.5.3)
27
+ simplecov-html (0.5.3)
28
+ yard (0.8.1)
29
+
30
+ PLATFORMS
31
+ ruby
32
+
33
+ DEPENDENCIES
34
+ bundler
35
+ jeweler (~> 1.8.3)
36
+ rdoc (~> 3.12)
37
+ rspec (~> 2.8.0)
38
+ simplecov
39
+ yard (~> 0.7)
data/LICENSE.txt ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2012 mewlist
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc ADDED
@@ -0,0 +1,31 @@
1
+ = workaholic
2
+
3
+ Parallel job runner.
4
+
5
+ = sample code
6
+
7
+ require 'rubygems'
8
+ require 'workaholic'
9
+
10
+ class TestJob < Workaholic::Job
11
+ attr_reader :count
12
+ def initialize; @count = 0 end
13
+ def run; @count += 1 end
14
+ end
15
+
16
+ worker = Workaholic::Worker.new
17
+ job = TestJob.new
18
+
19
+ worker.start 100 do # 100 threads
20
+ 1000.times do
21
+ worker.push job
22
+ end
23
+ end
24
+
25
+ p job.count # => 1000
26
+
27
+ == Copyright
28
+
29
+ Copyright (c) 2012 mewlist. See LICENSE.txt for
30
+ further details.
31
+
data/Rakefile ADDED
@@ -0,0 +1,42 @@
1
+ # encoding: utf-8
2
+
3
+ require 'rubygems'
4
+ require 'bundler'
5
+ begin
6
+ Bundler.setup(:default, :development)
7
+ rescue Bundler::BundlerError => e
8
+ $stderr.puts e.message
9
+ $stderr.puts "Run `bundle install` to install missing gems"
10
+ exit e.status_code
11
+ end
12
+ require 'rake'
13
+
14
+ require 'jeweler'
15
+ Jeweler::Tasks.new do |gem|
16
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
+ gem.name = "workaholic"
18
+ gem.homepage = "http://github.com/mewlist/workaholic"
19
+ gem.license = "MIT"
20
+ gem.summary = %Q{Parallel job runner}
21
+ gem.description = %Q{Parallel job runner}
22
+ gem.email = "mewlist@mewlist.com"
23
+ gem.authors = ["mewlist"]
24
+ # dependencies defined in Gemfile
25
+ end
26
+ Jeweler::RubygemsDotOrgTasks.new
27
+
28
+ require 'rspec/core'
29
+ require 'rspec/core/rake_task'
30
+ RSpec::Core::RakeTask.new(:spec) do |spec|
31
+ spec.pattern = FileList['spec/**/*_spec.rb']
32
+ end
33
+
34
+ RSpec::Core::RakeTask.new(:rcov) do |spec|
35
+ spec.pattern = 'spec/**/*_spec.rb'
36
+ spec.rcov = true
37
+ end
38
+
39
+ task :default => :spec
40
+
41
+ require 'yard'
42
+ YARD::Rake::YardocTask.new
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.0.0
@@ -0,0 +1,7 @@
1
+ module Workaholic
2
+ class Job
3
+ def run
4
+ # override me
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,60 @@
1
+ require 'thread'
2
+
3
+ module Workaholic
4
+ class RunningError < StandardError; end
5
+ class Worker
6
+ attr_reader :queue
7
+ attr_reader :state
8
+
9
+ def initialize
10
+ @queue = Queue.new
11
+ @state = :stopped
12
+ @threads ||= []
13
+ end
14
+
15
+ def start( thread_count = 2 )
16
+ raise RunningError unless state == :stopped
17
+
18
+ @state = :running
19
+ thread_count.times do |i|
20
+ t = Thread.start do
21
+ while [:running, :stopping].include? @state
22
+ run @queue.pop( true )
23
+ sleep 0.016
24
+ break if @state == :stopping
25
+ end
26
+ end
27
+ @threads.push t
28
+ end
29
+
30
+ if block_given?
31
+ yield self
32
+ sleep 0.1 while queue.size > 0
33
+ stop
34
+ end
35
+ end
36
+
37
+ def stop
38
+ @state = :stopping
39
+ while !@threads.select{ |t| t.alive? }.empty?
40
+ sleep 1
41
+ end
42
+ @state = :stopped
43
+ @threads = []
44
+ end
45
+
46
+ def run( job )
47
+ begin
48
+ job.run
49
+ rescue ThreadError # when queue is empty
50
+ sleep 0.1
51
+ rescue e
52
+ raise e
53
+ end
54
+ end
55
+
56
+ def push( job )
57
+ @queue.push job
58
+ end
59
+ end
60
+ end
data/lib/workaholic.rb ADDED
@@ -0,0 +1,6 @@
1
+ require 'workaholic/job'
2
+ require 'workaholic/worker'
3
+
4
+ module Workaholic
5
+
6
+ end
@@ -0,0 +1,12 @@
1
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
2
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
3
+ require 'rspec'
4
+ require 'workaholic'
5
+
6
+ # Requires supporting files with custom matchers and macros, etc,
7
+ # in ./support/ and its subdirectories.
8
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each {|f| require f}
9
+
10
+ RSpec.configure do |config|
11
+
12
+ end
@@ -0,0 +1,8 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/../spec_helper')
2
+
3
+ describe Workaholic::Job do
4
+ describe '#run' do
5
+ subject { Workaholic::Job.new }
6
+ it { should respond_to :run}
7
+ end
8
+ end
@@ -0,0 +1,45 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/../spec_helper')
2
+
3
+ describe Workaholic do
4
+ let(:worker) { Workaholic::Worker.new }
5
+
6
+ describe '#start' do
7
+ subject { worker.start( 1 ) }
8
+
9
+ it 'should start threads' do
10
+ Thread.should_receive(:start)
11
+ subject
12
+ end
13
+
14
+ it 'should raise error when worker is already running' do
15
+ worker.start 2
16
+ expect { subject }.to raise_error( Workaholic::RunningError )
17
+ end
18
+
19
+ it 'should call stop when block given' do
20
+ worker.should_receive(:stop)
21
+ worker.start 2 do
22
+ worker.push Workaholic::Job.new
23
+ end
24
+ end
25
+ end
26
+
27
+ describe '#run' do
28
+ subject { worker.run job }
29
+ let(:job) { Workaholic::Job.new }
30
+
31
+ it 'should run job' do
32
+ job.should_receive(:run)
33
+ subject
34
+ end
35
+ end
36
+
37
+ describe '#push' do
38
+ subject { worker.push job }
39
+ let(:job) { Workaholic::Job.new }
40
+
41
+ it 'should push job in queue' do
42
+ expect{ subject }.to change( worker.queue, :size ).by(1)
43
+ end
44
+ end
45
+ end
@@ -0,0 +1,33 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
2
+
3
+
4
+ class TestJob < Workaholic::Job
5
+ attr_accessor :counter
6
+ def run
7
+ self.class.count_up!
8
+ end
9
+
10
+ @count = 0
11
+ def self.count; @count end
12
+ def self.count_up!; @count+=1 end
13
+ end
14
+
15
+ describe Workaholic do
16
+ let(:worker) { Workaholic::Worker.new }
17
+ let(:job1) { TestJob.new }
18
+ let(:job2) { TestJob.new }
19
+
20
+ describe 'run parallel job' do
21
+ subject { TestJob.count }
22
+ before do
23
+ worker.start 100 do
24
+ 1000.times do
25
+ worker.push job1
26
+ worker.push job2
27
+ end
28
+ end
29
+ end
30
+
31
+ it { should == 2000 }
32
+ end
33
+ end
@@ -0,0 +1,70 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = "workaholic"
8
+ s.version = "0.0.0"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["mewlist"]
12
+ s.date = "2012-05-15"
13
+ s.description = "Parallel job runner"
14
+ s.email = "mewlist@mewlist.com"
15
+ s.extra_rdoc_files = [
16
+ "LICENSE.txt",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ ".rspec",
22
+ "Gemfile",
23
+ "Gemfile.lock",
24
+ "LICENSE.txt",
25
+ "README.rdoc",
26
+ "Rakefile",
27
+ "VERSION",
28
+ "lib/workaholic.rb",
29
+ "lib/workaholic/job.rb",
30
+ "lib/workaholic/worker.rb",
31
+ "spec/spec_helper.rb",
32
+ "spec/workaholic/job_spec.rb",
33
+ "spec/workaholic/worker_spec.rb",
34
+ "spec/workaholic_spec.rb",
35
+ "workaholic.gemspec"
36
+ ]
37
+ s.homepage = "http://github.com/mewlist/workaholic"
38
+ s.licenses = ["MIT"]
39
+ s.require_paths = ["lib"]
40
+ s.rubygems_version = "1.8.15"
41
+ s.summary = "Parallel job runner"
42
+
43
+ if s.respond_to? :specification_version then
44
+ s.specification_version = 3
45
+
46
+ if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
47
+ s.add_development_dependency(%q<rspec>, ["~> 2.8.0"])
48
+ s.add_development_dependency(%q<yard>, ["~> 0.7"])
49
+ s.add_development_dependency(%q<rdoc>, ["~> 3.12"])
50
+ s.add_development_dependency(%q<bundler>, [">= 0"])
51
+ s.add_development_dependency(%q<jeweler>, ["~> 1.8.3"])
52
+ s.add_development_dependency(%q<simplecov>, [">= 0"])
53
+ else
54
+ s.add_dependency(%q<rspec>, ["~> 2.8.0"])
55
+ s.add_dependency(%q<yard>, ["~> 0.7"])
56
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
57
+ s.add_dependency(%q<bundler>, [">= 0"])
58
+ s.add_dependency(%q<jeweler>, ["~> 1.8.3"])
59
+ s.add_dependency(%q<simplecov>, [">= 0"])
60
+ end
61
+ else
62
+ s.add_dependency(%q<rspec>, ["~> 2.8.0"])
63
+ s.add_dependency(%q<yard>, ["~> 0.7"])
64
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
65
+ s.add_dependency(%q<bundler>, [">= 0"])
66
+ s.add_dependency(%q<jeweler>, ["~> 1.8.3"])
67
+ s.add_dependency(%q<simplecov>, [">= 0"])
68
+ end
69
+ end
70
+
metadata ADDED
@@ -0,0 +1,132 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: workaholic
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - mewlist
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-05-15 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: rspec
16
+ requirement: &70164952939080 !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: 2.8.0
22
+ type: :development
23
+ prerelease: false
24
+ version_requirements: *70164952939080
25
+ - !ruby/object:Gem::Dependency
26
+ name: yard
27
+ requirement: &70164952938000 !ruby/object:Gem::Requirement
28
+ none: false
29
+ requirements:
30
+ - - ~>
31
+ - !ruby/object:Gem::Version
32
+ version: '0.7'
33
+ type: :development
34
+ prerelease: false
35
+ version_requirements: *70164952938000
36
+ - !ruby/object:Gem::Dependency
37
+ name: rdoc
38
+ requirement: &70164952936080 !ruby/object:Gem::Requirement
39
+ none: false
40
+ requirements:
41
+ - - ~>
42
+ - !ruby/object:Gem::Version
43
+ version: '3.12'
44
+ type: :development
45
+ prerelease: false
46
+ version_requirements: *70164952936080
47
+ - !ruby/object:Gem::Dependency
48
+ name: bundler
49
+ requirement: &70164952847480 !ruby/object:Gem::Requirement
50
+ none: false
51
+ requirements:
52
+ - - ! '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ type: :development
56
+ prerelease: false
57
+ version_requirements: *70164952847480
58
+ - !ruby/object:Gem::Dependency
59
+ name: jeweler
60
+ requirement: &70164952846900 !ruby/object:Gem::Requirement
61
+ none: false
62
+ requirements:
63
+ - - ~>
64
+ - !ruby/object:Gem::Version
65
+ version: 1.8.3
66
+ type: :development
67
+ prerelease: false
68
+ version_requirements: *70164952846900
69
+ - !ruby/object:Gem::Dependency
70
+ name: simplecov
71
+ requirement: &70164952846080 !ruby/object:Gem::Requirement
72
+ none: false
73
+ requirements:
74
+ - - ! '>='
75
+ - !ruby/object:Gem::Version
76
+ version: '0'
77
+ type: :development
78
+ prerelease: false
79
+ version_requirements: *70164952846080
80
+ description: Parallel job runner
81
+ email: mewlist@mewlist.com
82
+ executables: []
83
+ extensions: []
84
+ extra_rdoc_files:
85
+ - LICENSE.txt
86
+ - README.rdoc
87
+ files:
88
+ - .document
89
+ - .rspec
90
+ - Gemfile
91
+ - Gemfile.lock
92
+ - LICENSE.txt
93
+ - README.rdoc
94
+ - Rakefile
95
+ - VERSION
96
+ - lib/workaholic.rb
97
+ - lib/workaholic/job.rb
98
+ - lib/workaholic/worker.rb
99
+ - spec/spec_helper.rb
100
+ - spec/workaholic/job_spec.rb
101
+ - spec/workaholic/worker_spec.rb
102
+ - spec/workaholic_spec.rb
103
+ - workaholic.gemspec
104
+ homepage: http://github.com/mewlist/workaholic
105
+ licenses:
106
+ - MIT
107
+ post_install_message:
108
+ rdoc_options: []
109
+ require_paths:
110
+ - lib
111
+ required_ruby_version: !ruby/object:Gem::Requirement
112
+ none: false
113
+ requirements:
114
+ - - ! '>='
115
+ - !ruby/object:Gem::Version
116
+ version: '0'
117
+ segments:
118
+ - 0
119
+ hash: -4376389024857191322
120
+ required_rubygems_version: !ruby/object:Gem::Requirement
121
+ none: false
122
+ requirements:
123
+ - - ! '>='
124
+ - !ruby/object:Gem::Version
125
+ version: '0'
126
+ requirements: []
127
+ rubyforge_project:
128
+ rubygems_version: 1.8.15
129
+ signing_key:
130
+ specification_version: 3
131
+ summary: Parallel job runner
132
+ test_files: []