backgrounded 0.3.1

Sign up to get free protection for your applications and to get access to all the features.
data/.document ADDED
@@ -0,0 +1,5 @@
1
+ README.rdoc
2
+ lib/**/*.rb
3
+ bin/*
4
+ features/**/*.feature
5
+ LICENSE
data/.gitignore ADDED
@@ -0,0 +1,5 @@
1
+ *.sw?
2
+ .DS_Store
3
+ coverage
4
+ rdoc
5
+ pkg
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2009 Ryan Sonnek
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,68 @@
1
+ = Backgrounded
2
+
3
+ Background processing done right.
4
+
5
+ = Features
6
+ * clean and concise API
7
+ * testable
8
+ * integrates with any background processing framework (DelayedJob, JobFu, Workling, etc)
9
+
10
+ = Usage
11
+
12
+ #declaration
13
+ class User
14
+ backgrounded :do_stuff
15
+ def do_stuff
16
+ # do all your work here
17
+ end
18
+ end
19
+
20
+ #usage
21
+ user = User.new
22
+ user.do_stuff_backgrounded
23
+
24
+ = Installation
25
+
26
+ Command line installation
27
+
28
+ sudo gem install wireframe-backgrounded
29
+
30
+ Rails environment.rb configuration
31
+
32
+ config.gem 'wireframe-backgrounded', :source => 'http://gems.github.com', :lib => 'backgrounded'
33
+
34
+ = Configuration
35
+
36
+ Backgrounded provides a thin wrapper around any background processing framework that implements the Backgrounded handler API. This makes it trivial to swap out processing frameworks with no impact on your code.
37
+
38
+ = DelayedJob
39
+
40
+ An implementation for DelayedJob is packaged directly with Backgrounded for a slick out of the box experience.
41
+ see http://github.com/tobi/delayed_job/tree/master
42
+
43
+ # rails config/initializers/backgrounded.rb
44
+ Backgrounded.handler = Backgrounded::Handler::DelayedJobHandler.new
45
+
46
+ = JobFu
47
+
48
+ Developers using the JobFu library have it easy as well!
49
+ see http://github.com/jnstq/job_fu/tree
50
+
51
+ # rails config/initializers/backgrounded.rb
52
+ Backgrounded.handler = JobFu::Backgrounded::Handler.new
53
+
54
+ = Custom Handlers
55
+
56
+ It's trivial to write your own plugin for processing Backgrounded events!
57
+
58
+ # rails config/initializers/backgrounded.rb
59
+ class MyHandler
60
+ def request(object, method, *args)
61
+ #process the call however you want!
62
+ end
63
+ end
64
+ Backgrounded.handler = MyHandler.new
65
+
66
+ == Copyright
67
+
68
+ Copyright (c) 2009 Ryan Sonnek. See LICENSE for details.
data/Rakefile ADDED
@@ -0,0 +1,56 @@
1
+ require 'rubygems'
2
+ require 'rake'
3
+
4
+ begin
5
+ require 'jeweler'
6
+ Jeweler::Tasks.new do |gem|
7
+ gem.name = "backgrounded"
8
+ gem.summary = %Q{Simple API to run Model methods in the background}
9
+ gem.email = "ryan.sonnek@gmail.com"
10
+ gem.homepage = "http://github.com/wireframe/backgrounded"
11
+ gem.authors = ["Ryan Sonnek"]
12
+ # gem is a Gem::Specification... see http://www.rubygems.org/read/chapter/20 for additional settings
13
+ end
14
+ Jeweler::GemcutterTasks.new
15
+ rescue LoadError
16
+ puts "Jeweler (or a dependency) not available. Install it with: sudo gem install jeweler"
17
+ end
18
+
19
+ require 'rake/testtask'
20
+ Rake::TestTask.new(:test) do |test|
21
+ test.libs << 'lib' << 'test'
22
+ test.pattern = 'test/**/*_test.rb'
23
+ test.verbose = true
24
+ end
25
+
26
+ begin
27
+ require 'rcov/rcovtask'
28
+ Rcov::RcovTask.new do |test|
29
+ test.libs << 'test'
30
+ test.pattern = 'test/**/*_test.rb'
31
+ test.verbose = true
32
+ end
33
+ rescue LoadError
34
+ task :rcov do
35
+ abort "RCov is not available. In order to run rcov, you must: sudo gem install spicycode-rcov"
36
+ end
37
+ end
38
+
39
+
40
+ task :default => :test
41
+
42
+ require 'rake/rdoctask'
43
+ Rake::RDocTask.new do |rdoc|
44
+ if File.exist?('VERSION.yml')
45
+ config = YAML.load(File.read('VERSION.yml'))
46
+ version = "#{config[:major]}.#{config[:minor]}.#{config[:patch]}"
47
+ else
48
+ version = ""
49
+ end
50
+
51
+ rdoc.rdoc_dir = 'rdoc'
52
+ rdoc.title = "backgrounded #{version}"
53
+ rdoc.rdoc_files.include('README*')
54
+ rdoc.rdoc_files.include('lib/**/*.rb')
55
+ end
56
+
data/VERSION.yml ADDED
@@ -0,0 +1,5 @@
1
+ ---
2
+ :major: 0
3
+ :build:
4
+ :minor: 3
5
+ :patch: 1
@@ -0,0 +1,53 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run the gemspec command
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = %q{backgrounded}
8
+ s.version = "0.3.1"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Ryan Sonnek"]
12
+ s.date = %q{2009-10-26}
13
+ s.email = %q{ryan.sonnek@gmail.com}
14
+ s.extra_rdoc_files = [
15
+ "LICENSE",
16
+ "README.rdoc"
17
+ ]
18
+ s.files = [
19
+ ".document",
20
+ ".gitignore",
21
+ "LICENSE",
22
+ "README.rdoc",
23
+ "Rakefile",
24
+ "VERSION.yml",
25
+ "backgrounded.gemspec",
26
+ "lib/backgrounded.rb",
27
+ "lib/handler.rb",
28
+ "lib/handler/delayed_job_handler.rb",
29
+ "lib/handler/inprocess_handler.rb",
30
+ "test/backgrounded_test.rb",
31
+ "test/test_helper.rb"
32
+ ]
33
+ s.homepage = %q{http://github.com/wireframe/backgrounded}
34
+ s.rdoc_options = ["--charset=UTF-8"]
35
+ s.require_paths = ["lib"]
36
+ s.rubygems_version = %q{1.3.5}
37
+ s.summary = %q{Simple API to run Model methods in the background}
38
+ s.test_files = [
39
+ "test/backgrounded_test.rb",
40
+ "test/test_helper.rb"
41
+ ]
42
+
43
+ if s.respond_to? :specification_version then
44
+ current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
45
+ s.specification_version = 3
46
+
47
+ if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
48
+ else
49
+ end
50
+ else
51
+ end
52
+ end
53
+
@@ -0,0 +1,37 @@
1
+ require 'activesupport'
2
+
3
+ module Backgrounded
4
+ mattr_accessor :handler
5
+ def self.handler
6
+ @@handler ||= Backgrounded::Handler::InprocessHandler.new
7
+ end
8
+
9
+ autoload :Handler, 'handler'
10
+
11
+ module Model
12
+ def self.included(base)
13
+ base.extend(ClassMethods)
14
+ end
15
+
16
+ module ClassMethods
17
+ def backgrounded(*methods)
18
+ methods.each do |method|
19
+ method_basename, punctuation = method.to_s.sub(/([?!=])$/, ''), $1
20
+ define_method :"#{method_basename}_backgrounded#{punctuation}" do |*args|
21
+ Backgrounded.handler.request(self, method, *args)
22
+ end
23
+ end
24
+ include Backgrounded::Model::InstanceMethods
25
+ extend Backgrounded::Model::SingletonMethods
26
+ end
27
+ end
28
+
29
+ module SingletonMethods
30
+ end
31
+
32
+ module InstanceMethods
33
+ end
34
+ end
35
+ end
36
+
37
+ Object.send(:include, Backgrounded::Model)
data/lib/handler.rb ADDED
@@ -0,0 +1,10 @@
1
+ require 'activesupport'
2
+
3
+ module Backgrounded
4
+ module Handler
5
+ Dir["#{File.dirname(__FILE__)}/#{name.demodulize.underscore}/*.rb"].each do |handler_file|
6
+ handler_name = File.basename(handler_file, '.rb').camelize.to_sym
7
+ autoload handler_name, File.expand_path(handler_file)
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,13 @@
1
+ require 'delayed_job'
2
+
3
+ module Backgrounded
4
+ module Handler
5
+ # invoke the operation in the background using delayed job
6
+ # see http://github.com/tobi/delayed_job/tree/master
7
+ class DelayedJobHandler
8
+ def request(object, method, *args)
9
+ object.send_later(method.to_sym, *args)
10
+ end
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,11 @@
1
+ module Backgrounded
2
+ module Handler
3
+ #simple handler to process synchronously and not actually in the background
4
+ #useful for testing
5
+ class InprocessHandler
6
+ def request(object, method, *args)
7
+ object.send method, *args
8
+ end
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,75 @@
1
+ require 'test_helper'
2
+
3
+ class User
4
+ backgrounded :do_stuff
5
+
6
+ def do_stuff
7
+ end
8
+ end
9
+
10
+ class Person
11
+ backgrounded :do_stuff
12
+
13
+ def do_stuff(name, place, location)
14
+ end
15
+ end
16
+
17
+ class Post
18
+ backgrounded :do_stuff, :notify_users
19
+
20
+ def do_stuff
21
+ end
22
+ def notify_users
23
+ end
24
+ end
25
+
26
+ class Comment
27
+ backgrounded :delete_spam!
28
+
29
+ def delete_spam!
30
+ end
31
+ end
32
+
33
+ class BackgroundedTest < Test::Unit::TestCase
34
+ context 'an object with a single backgrounded method' do
35
+ setup do
36
+ @user = User.new
37
+ end
38
+ should "execute method in background" do
39
+ @user.expects(:do_stuff)
40
+ @user.do_stuff_backgrounded
41
+ end
42
+ end
43
+
44
+ context 'an object with a backgrounded method that accepts parameters' do
45
+ setup do
46
+ @person = Person.new
47
+ end
48
+ should 'forward them' do
49
+ @person.expects(:do_stuff).with('ryan', 2, 3)
50
+ @person.do_stuff_backgrounded('ryan', 2, 3)
51
+ end
52
+ end
53
+
54
+ context 'an object with a backgrounded method included punctuation' do
55
+ setup do
56
+ @comment = Comment.new
57
+ end
58
+ should 'move punctuation to the end of the new method' do
59
+ assert @comment.respond_to?(:'delete_spam_backgrounded!')
60
+ end
61
+ end
62
+
63
+ context 'an object with multiple backgrounded methods' do
64
+ setup do
65
+ @post = Post.new
66
+ end
67
+ should "execute method either method in background" do
68
+ @post.expects(:do_stuff)
69
+ @post.do_stuff_backgrounded
70
+
71
+ @post.expects(:notify_users)
72
+ @post.notify_users_backgrounded
73
+ end
74
+ end
75
+ end
@@ -0,0 +1,11 @@
1
+ require 'rubygems'
2
+ require 'test/unit'
3
+ require 'shoulda'
4
+ require 'mocha'
5
+
6
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
7
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
8
+ require 'backgrounded'
9
+
10
+ class Test::Unit::TestCase
11
+ end
metadata ADDED
@@ -0,0 +1,69 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: backgrounded
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.3.1
5
+ platform: ruby
6
+ authors:
7
+ - Ryan Sonnek
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+
12
+ date: 2009-10-26 00:00:00 -05:00
13
+ default_executable:
14
+ dependencies: []
15
+
16
+ description:
17
+ email: ryan.sonnek@gmail.com
18
+ executables: []
19
+
20
+ extensions: []
21
+
22
+ extra_rdoc_files:
23
+ - LICENSE
24
+ - README.rdoc
25
+ files:
26
+ - .document
27
+ - .gitignore
28
+ - LICENSE
29
+ - README.rdoc
30
+ - Rakefile
31
+ - VERSION.yml
32
+ - backgrounded.gemspec
33
+ - lib/backgrounded.rb
34
+ - lib/handler.rb
35
+ - lib/handler/delayed_job_handler.rb
36
+ - lib/handler/inprocess_handler.rb
37
+ - test/backgrounded_test.rb
38
+ - test/test_helper.rb
39
+ has_rdoc: true
40
+ homepage: http://github.com/wireframe/backgrounded
41
+ licenses: []
42
+
43
+ post_install_message:
44
+ rdoc_options:
45
+ - --charset=UTF-8
46
+ require_paths:
47
+ - lib
48
+ required_ruby_version: !ruby/object:Gem::Requirement
49
+ requirements:
50
+ - - ">="
51
+ - !ruby/object:Gem::Version
52
+ version: "0"
53
+ version:
54
+ required_rubygems_version: !ruby/object:Gem::Requirement
55
+ requirements:
56
+ - - ">="
57
+ - !ruby/object:Gem::Version
58
+ version: "0"
59
+ version:
60
+ requirements: []
61
+
62
+ rubyforge_project:
63
+ rubygems_version: 1.3.5
64
+ signing_key:
65
+ specification_version: 3
66
+ summary: Simple API to run Model methods in the background
67
+ test_files:
68
+ - test/backgrounded_test.rb
69
+ - test/test_helper.rb