padrino-response 0.0.1

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 340112ce19798bc835b91a04a1d96fab55b38419
4
+ data.tar.gz: 6cd6de2f37d5ff9c56f0a5fc3a3362010c685d5d
5
+ SHA512:
6
+ metadata.gz: c128575feb849a70d38cc1920e220946ca0d78d35d8a727f021aa45095232909a030a0818fe2bf3ed67d40fa1f1559c6d2bba99f75b0f00824751efd29c9a039
7
+ data.tar.gz: 70cae9051a7be7e27f7da5a3fa83bca631fa839a198d518df7101b4149d4272b18a98b1b88c93231a8601576e30e6bf8dd5d8415c67d517036b3dcc42f81699b
@@ -0,0 +1,4 @@
1
+ *.gem
2
+ .bundle
3
+ Gemfile.lock
4
+ pkg/*
@@ -0,0 +1,12 @@
1
+ lang: ruby
2
+ before_install: gem install bundler --pre
3
+ install:
4
+ - gem update --system
5
+ - bundle update
6
+ rvm:
7
+ - 1.9.3
8
+ - 2.0.0
9
+ - jruby-19mode-1.7.4
10
+ branches:
11
+ only:
12
+ - master
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source "https://rubygems.org"
2
+
3
+ gemspec
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2013 K-2052
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy of
6
+ this software and associated documentation files (the "Software"), to deal in
7
+ the Software without restriction, including without limitation the rights to
8
+ use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
9
+ the Software, and to permit persons to whom the Software is furnished to do so,
10
+ subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
17
+ FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
18
+ COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
19
+ IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,84 @@
1
+ # padrino-response
2
+
3
+ Eliminates the repetitive response code in your [Padrino](http://www.padrinorb.com/) controllers
4
+
5
+ ## Installation
6
+
7
+ Via rubygems:
8
+
9
+ $ gem install padrino-responders
10
+
11
+ Or add add the following to your Gemfile:
12
+
13
+ gem 'padrino-response'
14
+
15
+ Now register it in your application:
16
+
17
+ ```ruby
18
+ class App < Padrino::Application
19
+ register Padrino::Response
20
+ end
21
+ ```
22
+
23
+ ## Usage Examples
24
+
25
+ Basic:
26
+
27
+ ```ruby
28
+ get :user, map: '/user' do
29
+ respond @user
30
+ end
31
+ ```
32
+
33
+ With a status code:
34
+
35
+ ```ruby
36
+ post :unauthorized_user, map: => '/unauthurized-user' do
37
+ respond :unauthorized
38
+ end
39
+ ```
40
+
41
+ Skip the object:
42
+
43
+ ```ruby
44
+ get :not_found, map: '/not-found' do
45
+ respond :not_found
46
+ end
47
+ ```
48
+
49
+ ### Customizing the responder:
50
+
51
+ Via options:
52
+
53
+ ```ruby
54
+ class CustomResponder < Padrino::Responders::Default
55
+ end
56
+
57
+ get :custom_responder, map: '/custom-responder' do
58
+ respond responder: "CustomResponder"
59
+ end
60
+ ```
61
+
62
+ Specify a responder for the controller:
63
+
64
+ ```ruby
65
+ class Padrino::Responders::Main < Padrino::Responders::Default
66
+ end
67
+ ```
68
+
69
+ # Five Second Contributions Guide
70
+
71
+ - Fork
72
+ - Make changes in a branch
73
+ - Write tests
74
+ - Commit
75
+ - Pull Request
76
+
77
+ # Copyright
78
+
79
+ This started out as a fork of nu7hatch's [padrino-responders](https://github.com/k2052/padrino-responders); my fork
80
+ diverged enough that I felt it was best to make an entirely new gem. I cant thank nu7hatch enough for the original code
81
+ .
82
+
83
+ Licensed under MIT
84
+
@@ -0,0 +1,5 @@
1
+ require "bundler/gem_tasks"
2
+ require 'padrino-core/cli/rake'
3
+
4
+ PadrinoTasks.use(:database)
5
+ PadrinoTasks.init
@@ -0,0 +1,34 @@
1
+ require 'padrino-core'
2
+ require 'padrino-gen'
3
+
4
+ FileSet.glob_require('padrino-response/*.rb', __FILE__)
5
+ FileSet.glob_require('padrino-response/{helpers,notifiers,responders}/*.rb', __FILE__)
6
+
7
+ module Padrino
8
+ ##
9
+ # This component is used to create slim controllers without unnecessery
10
+ # and repetitive code.
11
+ #
12
+ module Response
13
+ ##
14
+ # Method used by Padrino::Application when we register the extension
15
+ #
16
+ class << self
17
+ def registered(app)
18
+ app.enable :sessions
19
+ app.enable :flash
20
+ app.helpers Padrino::Response::Helpers::Controller
21
+ app.helpers Padrino::Response::Helpers::Simple
22
+ app.set :notifier, Padrino::Response::Notifiers::FlashNotifier
23
+ app.send :include, Padrino::Response::Respond
24
+ end
25
+ alias :included :registered
26
+ end
27
+ end
28
+ end
29
+
30
+ ##
31
+ # Load our Padrino::Response locales
32
+ #
33
+ I18n.load_path += Dir["#{File.dirname(__FILE__)}/padrino-response/locale/**/*.yml"]
34
+
@@ -0,0 +1,92 @@
1
+ module Padrino
2
+ module Response
3
+ module Helpers
4
+ module Controller
5
+ ##
6
+ # A request from a non-browser user. Could be ajax, via curl etc.
7
+ #
8
+ def api_request
9
+ (request.xhr? or content_type == :json or mime_type(:json) == request.preferred_type.to_s)
10
+ end
11
+
12
+ ##
13
+ # Shortcut for <code>notifier.say</code> method.
14
+ #
15
+ def notify(kind, message, *args, &block)
16
+ settings.notifier.say(self, kind, message, *args, &block) if settings.notifier
17
+ end
18
+
19
+ ##
20
+ # Trys to render and then falls back to to_format
21
+ #
22
+ def try_render(object, detour_name=nil, responder)
23
+ begin
24
+ if responder.layout
25
+ render "#{controller_name}/#{detour_name || action_name}", :layout => responder.layout, :strict_format => true
26
+ else
27
+ render "#{controller_name}/#{detour_name || action_name}", :strict_format => true
28
+ end
29
+ rescue Exception => e
30
+ if api_request
31
+ if responder.jsend? && object.respond_to?(:attributes)
32
+ {:status => (responder.options.include?(:status) ? responder.options[:status] : 200),
33
+ :data => {responder.human_model_name.to_sym => object.attributes}}.to_json
34
+ else
35
+ return object.to_json if object.respond_to?(:to_json)
36
+ end
37
+ end
38
+
39
+ if content_type == :xml or mime_type(:xml) == request.preferred_type
40
+ return object.to_xml if object.respond_to?(:to_xml)
41
+ end
42
+
43
+ # raise ::Padrino::Responder::ResponderError, e.message
44
+ end
45
+ end
46
+
47
+ ##
48
+ # Returns name of current action
49
+ #
50
+ def action_name
51
+ if request.respond_to? :action
52
+ action = request.action
53
+ else
54
+ action, parameters = Padrino.mounted_apps[0].app_obj.recognize_path request.path_info
55
+ action = action.to_s
56
+ action.gsub!(/^#{controller_name}_?/, '')
57
+ end
58
+ action = 'index' if action == ''
59
+ action
60
+ end
61
+
62
+ ##
63
+ # Returns name of current controller
64
+ #
65
+ def controller_name
66
+ request.controller
67
+ end
68
+
69
+ ##
70
+ # Returns translated, human readable name for specified model.
71
+ #
72
+ def human_model_name(object)
73
+ if object.class.respond_to?(:human)
74
+ object.class.human
75
+ elsif object.class.respond_to?(:human_name)
76
+ object.class.human_name
77
+ else
78
+ I18n.translate("models.#{object.class.to_s.underscore}", :default => object.class.to_s.humanize)
79
+ end
80
+ end
81
+
82
+ ##
83
+ # Returns url
84
+ #
85
+ def back_or_default(default)
86
+ return_to = session.delete(:return_to)
87
+ return_to || default
88
+ end
89
+ end
90
+ end
91
+ end
92
+ end
@@ -0,0 +1,34 @@
1
+ module Padrino
2
+ module Response
3
+ module Helpers
4
+ module Simple
5
+ def error_resp(obj, message=nil)
6
+ status 400
7
+ if api_request
8
+ content_type 'application/json'
9
+ @resp ||= {}
10
+ @resp[:success] = false
11
+ @resp[:errors] = obj.errors if message == nil
12
+ @resp[:message] = message if message
13
+ halt 400, @resp.to_json
14
+ else
15
+ flash[:warning] = obj.errors.full_messages if message == nil
16
+ flash[:warning] = message if message
17
+ end
18
+ end
19
+
20
+ def success_resp(obj, message=nil)
21
+ if api_request
22
+ content_type 'application/json'
23
+ @resp ||= {}
24
+ @resp[:success] = true
25
+ @resp[:message] = message if message
26
+ halt 200, @resp.to_json
27
+ else
28
+ flash[:notice] = message
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end
@@ -0,0 +1,7 @@
1
+ en:
2
+ responder:
3
+ messages:
4
+ default:
5
+ destroy: "%{model} has been successfully deleted."
6
+ create: "%{model} has been successfully created."
7
+ update: "%{model} has been successfully updated."
@@ -0,0 +1,7 @@
1
+ en:
2
+ responder:
3
+ messages:
4
+ default:
5
+ destroy: "%{model} został poprawnie usunięty."
6
+ create: "%{model} został poprawnie dodany."
7
+ update: "%{model} został poprawnie zapisany."
@@ -0,0 +1,20 @@
1
+ module Padrino
2
+ module Response
3
+ module Notifiers
4
+ module FlashNotifier
5
+ ##
6
+ # Saves specified message as flash notification with specified type.
7
+ #
8
+ # ==== Examples
9
+ #
10
+ # notifier.say(self, :error, "Something went wrong")
11
+ #
12
+ # ... will save message to <code>flash[:notice]</code>
13
+ #
14
+ def self.say(app, kind, message, *args, &block)
15
+ app.flash[kind.to_sym] = message
16
+ end
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,25 @@
1
+ module Padrino
2
+ module Response
3
+ module Respond
4
+ def respond(*options)
5
+ if ::Padrino::Responders.constants.include?("#{controller_name.capitalize}")
6
+ responder = ::Padrino::Responders.const_get("#{controller_name.capitalize}").new
7
+ elsif options.include?(:responder)
8
+ responder = ::Padrino::Responders.const_get("#{options[:responder]}").new
9
+ else
10
+ responder = Padrino::Responders::Default.new
11
+ end
12
+
13
+ responder.object = options.shift if !options.first.is_a?(Hash)
14
+ options = options.extract_options!
15
+ responder.object = options.delete(:object) if options.include?(:object)
16
+ responder.object ||= {}
17
+ responder.options[:location] = options.shift if options.first.is_a?(String)
18
+ responder.options.merge!(options)
19
+ responder.class = self
20
+ return responder.respond
21
+ end
22
+ alias :resp :respond
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,165 @@
1
+ module Padrino
2
+ module Responders
3
+ class ResponderError < RuntimeError
4
+ end
5
+ class Default
6
+ include Padrino::Response::StatusCodes
7
+ attr_accessor :options, :object, :class
8
+
9
+ def initialize
10
+ @options = {}
11
+ end
12
+
13
+ # Jsend format?
14
+ def jsend?
15
+ return false
16
+ end
17
+
18
+ def respond
19
+ set_status
20
+
21
+ if self.class.request.put?
22
+ put
23
+ elsif self.class.request.post?
24
+ post
25
+ elsif self.class.request.delete?
26
+ delete
27
+ else
28
+ default
29
+ end
30
+ end
31
+
32
+ def put_or_post(message_type, error_detour)
33
+ message = message(message_type)
34
+
35
+ if valid?
36
+ if location
37
+ if api_request
38
+ content = try_render
39
+ redirect location, content
40
+ else
41
+ notify(:notice, message)
42
+ redirect location
43
+ end
44
+ end
45
+ else
46
+ set_status 400
47
+ if api_request
48
+ return object.errors.to_json
49
+ else
50
+ notify(:error, message)
51
+ try_render error_detour
52
+ end
53
+ end
54
+ end
55
+
56
+ def put
57
+ put_or_post :update, 'edit'
58
+ end
59
+
60
+ def post
61
+ put_or_post :create, 'new'
62
+ end
63
+
64
+ def delete
65
+ message = message(:destroy)
66
+
67
+ if location
68
+ if api_request
69
+ redirect location, {:message => message}.to_json
70
+ else
71
+ notify(:notice, message)
72
+ redirect location
73
+ end
74
+ else
75
+ try_render
76
+ end
77
+ end
78
+
79
+ def default
80
+ if location
81
+ redirect location
82
+ else
83
+ try_render
84
+ end
85
+ end
86
+
87
+ def message(type)
88
+ return @options[:message] if @options[:message]
89
+ return @options[:error_message] if @options[:error_message] and !valid
90
+ return @options[:success_message] if @options[:success_message] and valid
91
+
92
+ return object.errors.full_messages if !valid?
93
+
94
+ object_notice = "responder.messages.#{controller_name}.#{type}"
95
+ alternative_notice = "responder.messages.default.#{type}"
96
+
97
+ object_notice = I18n.translate(object_notice, :model => human_model_name)
98
+ alternative_notice = I18n.translate(alternative_notice, :model => human_model_name)
99
+
100
+ return object_notice unless object_notice.blank?
101
+ return alternative_notice unless alternative_notice.blank?
102
+
103
+ return 'No message found in locale'
104
+ end
105
+
106
+ def valid?
107
+ valid = true
108
+ # `valid?` method may override existing errors, so check for those first
109
+ valid &&= object.valid? if object.respond_to?(:valid?)
110
+ valid &&= (object.errors.count == 0) if object.respond_to?(:errors)
111
+ return valid
112
+ end
113
+
114
+ def request
115
+ self.class.request
116
+ end
117
+
118
+ def notify(kind, message, *args, &block)
119
+ self.class.notify(kind, message, *args, &block)
120
+ end
121
+
122
+ def try_render(detour_name=nil)
123
+ self.class.try_render(object, detour_name, self)
124
+ end
125
+
126
+ def redirect(*args)
127
+ self.class.redirect(*args)
128
+ end
129
+
130
+ def api_request
131
+ self.class.api_request
132
+ end
133
+
134
+ def human_model_name
135
+ self.class.human_model_name(object)
136
+ end
137
+
138
+ def controller_name
139
+ self.class.controller_name
140
+ end
141
+
142
+ def action_name
143
+ self.class.action_name
144
+ end
145
+
146
+ def location
147
+ @options[:location]
148
+ end
149
+
150
+ def layout
151
+ return @options[:layout] if @options.include?(:layout)
152
+ end
153
+
154
+ def set_status(status=nil)
155
+ if status.is_a?(Integer)
156
+ self.class.status status
157
+ elsif status.is_a?(String)
158
+ self.class.status SYMBOL_TO_STATUS_CODE[status]
159
+ else
160
+ self.class.status SYMBOL_TO_STATUS_CODE[@options[:status]] if @options[:status]
161
+ end
162
+ end
163
+ end
164
+ end
165
+ end
@@ -0,0 +1,92 @@
1
+ module Padrino
2
+ module Responders
3
+ class Jsend < Default
4
+ include Padrino::Response::StatusCodes
5
+ attr_accessor :options, :object, :class
6
+
7
+ def initialize
8
+ @options = {}
9
+ end
10
+
11
+ def jsend?
12
+ return true
13
+ end
14
+
15
+ def put_or_post(message_type, error_detour)
16
+ message = message( message_type )
17
+ if valid?
18
+ if request.xhr?
19
+ ajax_obj = {
20
+ :status => :success,
21
+ :data => {
22
+ object.class.to_s.singularize.downcase => object
23
+ }
24
+ }
25
+ end
26
+ if location
27
+ if request.xhr?
28
+ ajax_obj[:data][:redirect] = location
29
+ return ajax_obj.to_json
30
+ else
31
+ notify(:notice, message)
32
+ redirect location
33
+ end
34
+ else
35
+ try_render
36
+ end
37
+ else
38
+ if request.xhr?
39
+ ajax_obj = {
40
+ :status => :fail,
41
+ :data => {
42
+ :errors => object.errors
43
+ }
44
+ }
45
+ ajax_obj[:data][:redirect] = location if location
46
+ return ajax_obj.to_json
47
+ else
48
+ notify(:error, message)
49
+ try_render error_detour
50
+ end
51
+ end
52
+ end
53
+
54
+ def delete
55
+ message = message(:destroy)
56
+
57
+ if request.xhr?
58
+ ajax_obj = {
59
+ :status => :success,
60
+ :data => {
61
+ :message => message
62
+ }
63
+ }
64
+ end
65
+
66
+ if location
67
+ if request.xhr?
68
+ ajax_obj[:data][:redirect] = location
69
+ return ajax_obj.to_json
70
+ else
71
+ notify(:notice, message)
72
+ redirect location
73
+ end
74
+ else
75
+ try_render
76
+ end
77
+ end
78
+
79
+ def default
80
+ if location
81
+ if request.xhr?
82
+ {:status => :success, :data => { :redirect => location } }.to_json
83
+ else
84
+ redirect location
85
+ end
86
+ else
87
+ try_render
88
+ end
89
+ end
90
+ end
91
+ end
92
+ end
@@ -0,0 +1,88 @@
1
+ module Padrino
2
+ module Response
3
+ module StatusCodes
4
+ # Defines the standard HTTP status codes, by integer, with their
5
+ # corresponding default message texts.
6
+ # Source: http://www.iana.org/assignments/http-status-codes
7
+ STATUS_CODES = {
8
+ 100 => "Continue",
9
+ 101 => "Switching Protocols",
10
+ 102 => "Processing",
11
+
12
+ 200 => "OK",
13
+ 201 => "Created",
14
+ 202 => "Accepted",
15
+ 203 => "Non-Authoritative Information",
16
+ 204 => "No Content",
17
+ 205 => "Reset Content",
18
+ 206 => "Partial Content",
19
+ 207 => "Multi-Status",
20
+ 226 => "IM Used",
21
+
22
+ 300 => "Multiple Choices",
23
+ 301 => "Moved Permanently",
24
+ 302 => "Found",
25
+ 303 => "See Other",
26
+ 304 => "Not Modified",
27
+ 305 => "Use Proxy",
28
+ 307 => "Temporary Redirect",
29
+
30
+ 400 => "Bad Request",
31
+ 401 => "Unauthorized",
32
+ 402 => "Payment Required",
33
+ 403 => "Forbidden",
34
+ 404 => "Not Found",
35
+ 405 => "Method Not Allowed",
36
+ 406 => "Not Acceptable",
37
+ 407 => "Proxy Authentication Required",
38
+ 408 => "Request Timeout",
39
+ 409 => "Conflict",
40
+ 410 => "Gone",
41
+ 411 => "Length Required",
42
+ 412 => "Precondition Failed",
43
+ 413 => "Request Entity Too Large",
44
+ 414 => "Request-URI Too Long",
45
+ 415 => "Unsupported Media Type",
46
+ 416 => "Requested Range Not Satisfiable",
47
+ 417 => "Expectation Failed",
48
+ 422 => "Unprocessable Entity",
49
+ 423 => "Locked",
50
+ 424 => "Failed Dependency",
51
+ 426 => "Upgrade Required",
52
+
53
+ 500 => "Internal Server Error",
54
+ 501 => "Not Implemented",
55
+ 502 => "Bad Gateway",
56
+ 503 => "Service Unavailable",
57
+ 504 => "Gateway Timeout",
58
+ 505 => "HTTP Version Not Supported",
59
+ 507 => "Insufficient Storage",
60
+ 510 => "Not Extended"
61
+ }
62
+
63
+ # Provides a symbol-to-fixnum lookup for converting a symbol (like
64
+ # :created or :not_implemented) into its corresponding HTTP status
65
+ # code (like 200 or 501).
66
+ SYMBOL_TO_STATUS_CODE = STATUS_CODES.inject({}) do |hash, (code, message)|
67
+ hash[message.gsub(/ /, "").underscore.to_sym] = code
68
+ hash
69
+ end
70
+
71
+ # Given a status parameter, determine whether it needs to be converted
72
+ # to a string. If it is a fixnum, use the STATUS_CODES hash to lookup
73
+ # the default message. If it is a symbol, use the SYMBOL_TO_STATUS_CODE
74
+ # hash to convert it.
75
+ def interpret_status(status)
76
+ case status
77
+ when Fixnum then
78
+ STATUS_CODES[status]
79
+ when Symbol then
80
+ interpret_status(SYMBOL_TO_STATUS_CODE[status] ||
81
+ "500 Unknown Status #{status.inspect}")
82
+ else
83
+ status.to_s
84
+ end
85
+ end
86
+ end
87
+ end
88
+ end
@@ -0,0 +1,5 @@
1
+ module Padrino
2
+ module Response
3
+ VERSION = "0.0.1"
4
+ end
5
+ end
@@ -0,0 +1,29 @@
1
+ # -*- encoding: utf-8 -*-
2
+ $:.push File.expand_path("../lib", __FILE__)
3
+ require "padrino-response/version"
4
+
5
+ Gem::Specification.new do |s|
6
+ s.name = "padrino-response"
7
+ s.version = Padrino::Response::VERSION
8
+ s.authors = ["K-2052"]
9
+ s.email = ["k@2052.me"]
10
+ s.homepage = "https://github.com/k2052/padrino-response"
11
+ s.summary = %q{Eliminates the repetitive response code in your Padrino controllers}
12
+ s.description = %q{Eliminates the repetitive response code in your Padrino controllers}
13
+
14
+ s.rubyforge_project = "padrino-response"
15
+
16
+ s.files = `git ls-files`.split("\n")
17
+ s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
18
+ s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
19
+ s.require_paths = ["lib"]
20
+
21
+ # specify any dependencies here; for example:
22
+ s.add_development_dependency "rspec"
23
+ s.add_development_dependency "adapter"
24
+ s.add_development_dependency "toystore"
25
+ s.add_development_dependency "rack-test"
26
+ s.add_dependency "padrino", ">= 0.10.7"
27
+ s.add_dependency "rake"
28
+ s.add_dependency "sinatra-flash", ">= 0.3.0"
29
+ end
@@ -0,0 +1,49 @@
1
+ require File.expand_path(File.dirname(__FILE__) + '/spec_helper.rb')
2
+
3
+ describe 'Main Controller' do
4
+ before do
5
+ header 'Accept', 'application/json'
6
+ end
7
+
8
+ it 'should return an error resp' do
9
+ get '/error'
10
+ last_response.status.should eq 400
11
+ resp = MultiJson.load last_response.body
12
+ resp['success'].should eq false
13
+ resp['message'].should eq 'Error'
14
+ end
15
+
16
+ it 'should return a success resp' do
17
+ get '/success'
18
+ last_response.status.should eq 200
19
+ resp = MultiJson.load last_response.body
20
+ resp['success'].should eq true
21
+ end
22
+
23
+ it 'should return a 404' do
24
+ get '/not-found'
25
+ last_response.status.should eq 404
26
+ end
27
+
28
+ it 'should return no-content' do
29
+ get '/no-content'
30
+ last_response.status.should eq 204
31
+ end
32
+
33
+ it 'should create a new human' do
34
+ post '/new', human: {name: 'Bob'}
35
+ last_response.status.should eq 302
36
+ resp = MultiJson.load last_response.body
37
+ resp['human']['name'].should eq 'Bob'
38
+ end
39
+
40
+ it 'should fail to update a human' do
41
+ put '/fail-update', human: {name: 'Bob'}
42
+ last_response.status.should eq 400
43
+ end
44
+
45
+ it 'should fail to create a human' do
46
+ post '/fail-create', human: {name: 'Bob'}
47
+ last_response.status.should eq 400
48
+ end
49
+ end
@@ -0,0 +1,62 @@
1
+ require 'i18n'
2
+ require 'padrino'
3
+ require 'padrino-response'
4
+ require 'adapter/memory'
5
+ require 'toystore'
6
+
7
+ class Human
8
+ include Toy::Store
9
+ adapter :memory, {}
10
+
11
+ attribute :name, String
12
+ attribute :dont_set, String
13
+ validate :dont_set_should_be_blank
14
+
15
+ def dont_set_should_be_blank
16
+ unless self[:dont_set].blank?
17
+ errors.add :base, "Don't set that!"
18
+ end
19
+ end
20
+ end
21
+
22
+ class App < Padrino::Application
23
+ register Padrino::Response
24
+ register Padrino::Helpers::TranslationHelpers
25
+
26
+ controllers :main do
27
+ get :error, map: '/error' do
28
+ error_resp Human.new, 'Error'
29
+ end
30
+
31
+ get :success, map: '/success' do
32
+ success_resp Human.new name: 'Bob'
33
+ end
34
+
35
+ get :not_found, map: '/not-found' do
36
+ resp status: :not_found
37
+ end
38
+
39
+ get :no_content, map: '/no-content' do
40
+ resp status: :no_content
41
+ end
42
+
43
+ post :create, map: '/new' do
44
+ @human = Human.create name: 'Bob'
45
+ resp @human, location: '/success'
46
+ end
47
+
48
+ put :fail_update, map: '/fail-update' do
49
+ @human = Human.create name: 'Bob'
50
+ @human.update_attributes dont_set: 'Cats'
51
+ resp @human
52
+ end
53
+
54
+ post :fail_create, map: '/fail-create' do
55
+ @human = Human.create name: 'Bob', dont_set: 'Cats'
56
+ resp @human
57
+ end
58
+ end
59
+ end
60
+
61
+ Padrino.load!
62
+ Padrino.mount(App).to('/')
@@ -0,0 +1,17 @@
1
+ begin
2
+ require 'rspec/core/rake_task'
3
+
4
+ spec_tasks = Dir['spec/*/'].map { |d| File.basename(d) }
5
+
6
+ spec_tasks.each do |folder|
7
+ RSpec::Core::RakeTask.new("spec:#{folder}") do |t|
8
+ t.pattern = "./spec/#{folder}/**/*_spec.rb"
9
+ t.rspec_opts = %w(-fs --color)
10
+ end
11
+ end
12
+
13
+ desc "Run complete application spec suite"
14
+ task 'spec' => spec_tasks.map { |f| "spec:#{f}" }
15
+ rescue LoadError
16
+ puts "RSpec is not part of this bundle, skip specs."
17
+ end
@@ -0,0 +1,12 @@
1
+ PADRINO_ENV = 'test' unless defined?(PADRINO_ENV)
2
+ require File.expand_path(File.dirname(__FILE__) + "/fixtures/app.rb")
3
+ require 'rack/test'
4
+
5
+ RSpec.configure do |conf|
6
+ conf.include Rack::Test::Methods
7
+ end
8
+
9
+ def app(app = nil, &blk)
10
+ @app ||= block_given? ? app.instance_eval(&blk) : app
11
+ @app ||= Padrino.application
12
+ end
metadata ADDED
@@ -0,0 +1,163 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: padrino-response
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - K-2052
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2013-11-07 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rspec
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '>='
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
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: adapter
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
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: toystore
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
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: rack-test
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
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: padrino
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - '>='
74
+ - !ruby/object:Gem::Version
75
+ version: 0.10.7
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - '>='
81
+ - !ruby/object:Gem::Version
82
+ version: 0.10.7
83
+ - !ruby/object:Gem::Dependency
84
+ name: rake
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: sinatra-flash
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - '>='
102
+ - !ruby/object:Gem::Version
103
+ version: 0.3.0
104
+ type: :runtime
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - '>='
109
+ - !ruby/object:Gem::Version
110
+ version: 0.3.0
111
+ description: Eliminates the repetitive response code in your Padrino controllers
112
+ email:
113
+ - k@2052.me
114
+ executables: []
115
+ extensions: []
116
+ extra_rdoc_files: []
117
+ files:
118
+ - .gitignore
119
+ - .travis.yml
120
+ - Gemfile
121
+ - LICENSE
122
+ - README.md
123
+ - Rakefile
124
+ - lib/padrino-response.rb
125
+ - lib/padrino-response/helpers/controller.rb
126
+ - lib/padrino-response/helpers/simple.rb
127
+ - lib/padrino-response/locale/en.yml
128
+ - lib/padrino-response/locale/pl.yml
129
+ - lib/padrino-response/notifiers/flash_notifier.rb
130
+ - lib/padrino-response/respond.rb
131
+ - lib/padrino-response/responders/default.rb
132
+ - lib/padrino-response/responders/jsend.rb
133
+ - lib/padrino-response/status_codes.rb
134
+ - lib/padrino-response/version.rb
135
+ - padrino-response.gemspec
136
+ - spec/all_spec.rb
137
+ - spec/fixtures/app.rb
138
+ - spec/spec.rake
139
+ - spec/spec_helper.rb
140
+ homepage: https://github.com/k2052/padrino-response
141
+ licenses: []
142
+ metadata: {}
143
+ post_install_message:
144
+ rdoc_options: []
145
+ require_paths:
146
+ - lib
147
+ required_ruby_version: !ruby/object:Gem::Requirement
148
+ requirements:
149
+ - - '>='
150
+ - !ruby/object:Gem::Version
151
+ version: '0'
152
+ required_rubygems_version: !ruby/object:Gem::Requirement
153
+ requirements:
154
+ - - '>='
155
+ - !ruby/object:Gem::Version
156
+ version: '0'
157
+ requirements: []
158
+ rubyforge_project: padrino-response
159
+ rubygems_version: 2.0.3
160
+ signing_key:
161
+ specification_version: 4
162
+ summary: Eliminates the repetitive response code in your Padrino controllers
163
+ test_files: []