crystal_ext 0.0.7 → 0.0.11
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +70 -7
- data/lib/crystal/controller.rb +28 -0
- data/lib/crystal/controller/abstract_controller.rb +60 -0
- data/lib/crystal/controller/abstract_controller/micelaneous.rb +31 -0
- data/lib/crystal/controller/abstract_controller/render.rb +133 -0
- data/lib/crystal/controller/abstract_controller/responder.rb +17 -0
- data/lib/crystal/controller/controller_context.rb +7 -0
- data/lib/crystal/controller/http_controller.rb +43 -0
- data/lib/crystal/controller/processors/controller_caller.rb +40 -0
- data/lib/crystal/controller/processors/controller_error_handling.rb +53 -0
- data/lib/crystal/controller/processors/controller_logger.rb +13 -0
- data/lib/crystal/conveyor.rb +29 -0
- data/lib/crystal/conveyor/conveyor.rb +74 -0
- data/lib/crystal/conveyor/conveyors.rb +20 -0
- data/lib/crystal/conveyor/params.rb +22 -0
- data/lib/crystal/conveyor/processor.rb +68 -0
- data/lib/crystal/conveyor/processors/conveyor_logger.rb +24 -0
- data/lib/crystal/conveyor/workspace.rb +36 -0
- data/lib/crystal/environment.rb +52 -0
- data/lib/crystal/environment/config.rb +118 -0
- data/lib/crystal/environment/dependency_resolver.rb +107 -0
- data/lib/crystal/environment/environment.rb +5 -0
- data/lib/crystal/environment/files_helper.rb +42 -0
- data/lib/crystal/environment/logger.rb +21 -0
- data/lib/crystal/html.rb +28 -0
- data/lib/crystal/html/controller_helpers/controller_url_helper.rb +52 -0
- data/lib/crystal/html/controller_helpers/flash_helper.rb +5 -0
- data/lib/crystal/html/flash.rb +40 -0
- data/lib/crystal/html/include_into_controller.rb +24 -0
- data/lib/crystal/html/processors/prepare_flash.rb +26 -0
- data/lib/crystal/html/processors/scoped_params.rb +30 -0
- data/lib/crystal/html/view_helpers/basic_html_helper.rb +83 -0
- data/lib/crystal/html/view_helpers/form_helper.rb +104 -0
- data/lib/crystal/html/view_helpers/javascript_helper.rb +18 -0
- data/lib/crystal/html/view_helpers/model_helper.rb +119 -0
- data/lib/crystal/html/view_helpers/view_url_helper.rb +66 -0
- data/lib/crystal/http.rb +47 -0
- data/lib/crystal/http/http.rb +18 -0
- data/lib/crystal/http/http_adapter.rb +30 -0
- data/lib/crystal/http/middleware/static_files.rb +20 -0
- data/lib/crystal/http/processors/evaluate_format.rb +22 -0
- data/lib/crystal/http/processors/http_logger.rb +15 -0
- data/lib/crystal/http/processors/http_writer.rb +48 -0
- data/lib/crystal/http/processors/prepare_params.rb +24 -0
- data/lib/crystal/http/rack_config.rb +15 -0
- data/lib/crystal/http/support/rack/rack_adapter.rb +65 -0
- data/lib/crystal/http/support/rack/request.rb +12 -0
- data/lib/crystal/http/support/rack/response.rb +39 -0
- data/lib/crystal/mailer.rb +13 -0
- data/lib/crystal/mailer/mail.rb +7 -0
- data/lib/{crystal_ext/profiles/web_ext.rb → crystal/profiles/web.rb} +9 -15
- data/lib/crystal/profiles/web_require.rb +5 -0
- data/lib/crystal/remote.rb +9 -0
- data/lib/crystal/remote/processors/remote_caller.rb +54 -0
- data/lib/crystal/remote/processors/remote_logger.rb +13 -0
- data/lib/crystal/remote/remote.rb +15 -0
- data/lib/crystal/router.rb +19 -0
- data/lib/crystal/router/configurator.rb +23 -0
- data/lib/crystal/router/default_format_processor.rb +12 -0
- data/lib/crystal/router/default_router.rb +23 -0
- data/lib/crystal/router/named_router.rb +63 -0
- data/lib/crystal/router/processors/router.rb +22 -0
- data/lib/crystal/router/router.rb +218 -0
- data/lib/crystal/router/routing_helper.rb +17 -0
- data/lib/crystal/spec.rb +8 -0
- data/lib/crystal/spec/controller.rb +15 -0
- data/lib/crystal/spec/environment.rb +41 -0
- data/lib/crystal/spec/http.rb +67 -0
- data/lib/crystal/spec/mail.rb +20 -0
- data/lib/crystal/spec/remote.rb +9 -0
- data/lib/crystal/spec/view.rb +10 -0
- data/lib/crystal/spec/xhtml.rb +33 -0
- data/lib/crystal/support.rb +46 -0
- data/lib/crystal/support/active_support.rb +39 -0
- data/lib/crystal/support/active_support/micelaneous.rb +2 -0
- data/lib/crystal/support/addressable.rb +45 -0
- data/lib/crystal/support/buffered_logger.rb +38 -0
- data/lib/crystal/support/callbacks.rb +155 -0
- data/lib/crystal/support/exception.rb +20 -0
- data/lib/crystal/support/filters.rb +34 -0
- data/lib/crystal/support/format.rb +9 -0
- data/lib/crystal/support/gems.rb +8 -0
- data/lib/crystal/support/micon.rb +13 -0
- data/lib/crystal/support/mime.rb +11 -0
- data/lib/crystal/support/module.rb +44 -0
- data/lib/crystal/support/rson.rb +53 -0
- data/lib/crystal/support/ruby_ext_with_active_support.rb +4 -0
- data/lib/crystal/support/safe_hash.rb +135 -0
- data/lib/crystal/support/string.rb +26 -0
- data/lib/crystal/template.rb +21 -0
- data/lib/crystal/template/support/tilt.rb +68 -0
- data/lib/crystal/template/template.rb +244 -0
- data/lib/crystal/template/template_context.rb +57 -0
- data/lib/views/crystal_default_templates/development/error.html.erb +11 -0
- data/lib/views/crystal_default_templates/development/error.js.erb +1 -0
- data/readme.md +8 -11
- data/spec/_mailer/basic_spec.rb +110 -0
- data/spec/_mailer/helper.rb +7 -0
- data/spec/controller/abstract_controller_spec.rb +137 -0
- data/spec/controller/abstract_controller_spec/views/OperationsOrderSpec/action.erb +1 -0
- data/spec/controller/abstract_controller_spec/views/ViewVariablesSpec/action.erb +10 -0
- data/spec/controller/controller_context_spec.rb +122 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/actions.erb +4 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/ItemSpec/update.erb +0 -0
- data/spec/controller/controller_context_spec/views/NamespaceSpec/ClassSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/PageSpec/actions.erb +3 -0
- data/spec/controller/controller_context_spec/views/PageSpec/show.erb +0 -0
- data/spec/controller/controller_context_spec/views/namespace_spec/class_spec/update.erb +0 -0
- data/spec/controller/controller_helper_spec.rb +57 -0
- data/spec/controller/controller_helper_spec/views/HelperMethodSpec/action.erb +1 -0
- data/spec/controller/controller_helper_spec/views/HelperSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec.rb +191 -0
- data/spec/controller/controller_render_spec/views/AlreadyRenderedSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/AlreadyRenderedSpec/custom_template.erb +1 -0
- data/spec/controller/controller_render_spec/views/AnotherActionSpec/another_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/AnotherLayout/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ExplicitRenderSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ExplicitRenderSpec/another_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/ForbidPartialAsActionSpec/_action.erb +1 -0
- data/spec/controller/controller_render_spec/views/FormatSpec/action.html.erb +1 -0
- data/spec/controller/controller_render_spec/views/FormatSpec/action.js.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutFiltersSpec/action_with_layout.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutFiltersSpec/action_without_layout.erb +1 -0
- data/spec/controller/controller_render_spec/views/LayoutSpec/action.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/admin.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/app.html.erb +1 -0
- data/spec/controller/controller_render_spec/views/layouts/app.js.erb +1 -0
- data/spec/controller/controller_render_spec/views/some_template.erb +1 -0
- data/spec/controller/controller_render_spec/views/standalone.html.erb +1 -0
- data/spec/controller/error_handling_spec.rb +96 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/a.erb +1 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/b.erb +1 -0
- data/spec/controller/error_handling_spec/views/diferrent_error_handling_spec/c.erb +1 -0
- data/spec/controller/helper.rb +21 -0
- data/spec/controller/http_controller_spec.rb +89 -0
- data/spec/conveyor/conveyor_spec.rb +124 -0
- data/spec/conveyor/helper.rb +8 -0
- data/spec/environment/_dependency_resolver_spec.rb +50 -0
- data/spec/environment/environment_spec.rb +85 -0
- data/spec/environment/environment_spec/app/app_plugin/config/ec_layout +1 -0
- data/spec/environment/environment_spec/app/app_plugin/ec_some_file +1 -0
- data/spec/environment/environment_spec/app/config/config.test.yml +1 -0
- data/spec/environment/environment_spec/app/config/config.yml +2 -0
- data/spec/environment/environment_spec/gem_plugin/config/ec_layout +1 -0
- data/spec/environment/helper.rb +6 -0
- data/spec/environment/logger_spec.rb +18 -0
- data/spec/environment/minimal_app_spec.rb +27 -0
- data/spec/environment/minimal_app_spec/app.rb +3 -0
- data/spec/environment/standard_app_spec.rb +63 -0
- data/spec/environment/standard_app_spec_data/config/init.rb +18 -0
- data/spec/environment/standard_app_spec_data/plugin_a/plugin_a.rb +7 -0
- data/spec/html/basic_html_helper_spec.rb +28 -0
- data/spec/html/flash_spec.rb +184 -0
- data/spec/html/form_helper_spec.rb +56 -0
- data/spec/html/helper.rb +31 -0
- data/spec/html/javascript_helper_spec.rb +15 -0
- data/spec/html/model_helper_spec.rb +65 -0
- data/spec/html/scoped_params_spec.rb +17 -0
- data/spec/html/url_helper_spec.rb +151 -0
- data/spec/http/helper.rb +9 -0
- data/spec/http/http_spec.rb +56 -0
- data/spec/http/http_spec_data/config/init.rb +7 -0
- data/spec/http/http_spec_data/plugin_b/plugin_b.rb +6 -0
- data/spec/integration/basic_spec.rb +82 -0
- data/spec/integration/basic_spec/views/smoke_test_spec/action.erb +1 -0
- data/spec/integration/helper.rb +10 -0
- data/spec/remote/helper.rb +20 -0
- data/spec/remote/remote_spec.rb +75 -0
- data/spec/router/basic_spec.rb +130 -0
- data/spec/router/configurator_spec.rb +29 -0
- data/spec/router/helper.rb +24 -0
- data/spec/router/integration_spec.rb +42 -0
- data/spec/spec.opts +4 -0
- data/spec/support/callbacks_spec.rb +153 -0
- data/spec/support/filters_spec.rb +59 -0
- data/spec/support/helper.rb +7 -0
- data/spec/support/safe_hash_spec.rb +82 -0
- data/spec/template/helper.rb +8 -0
- data/spec/template/template_spec.rb +189 -0
- data/spec/template/template_spec/file.erb +1 -0
- data/spec/template/template_spec/views/basic/custom_context.erb +1 -0
- data/spec/template/template_spec/views/basic/extension.erb +1 -0
- data/spec/template/template_spec/views/basic/general.html.erb +5 -0
- data/spec/template/template_spec/views/basic/non_existing_format.html.erb +0 -0
- data/spec/template/template_spec/views/format/format.erb +1 -0
- data/spec/template/template_spec/views/format/format.html.erb +1 -0
- data/spec/template/template_spec/views/format/format.js.erb +1 -0
- data/spec/template/template_spec/views/layout/basic/content.erb +1 -0
- data/spec/template/template_spec/views/layout/basic/layout.erb +1 -0
- data/spec/template/template_spec/views/layout/content_for/content.erb +3 -0
- data/spec/template/template_spec/views/layout/content_for/layout.erb +3 -0
- data/spec/template/template_spec/views/layout/format/content.html.erb +1 -0
- data/spec/template/template_spec/views/layout/format/content.js.erb +1 -0
- data/spec/template/template_spec/views/layout/format/layout.html.erb +1 -0
- data/spec/template/template_spec/views/layout/format/layout.js.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/a.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/layout.erb +1 -0
- data/spec/template/template_spec/views/layout/nested_yield/layout_b.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/a.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/b.erb +1 -0
- data/spec/template/template_spec/views/layout/same_context/layout.erb +1 -0
- data/spec/template/template_spec/views/nested/format/a.erb +1 -0
- data/spec/template/template_spec/views/nested/format/b.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/a.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/b.erb +1 -0
- data/spec/template/template_spec/views/nested/relative/c.erb +1 -0
- data/spec/template/template_spec/views/nested/shared/c.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/_dialog.html.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/_form.html.erb +1 -0
- data/spec/template/template_spec/views/nesting_format/dialog.js.erb +1 -0
- data/spec/template/template_spec/views/other/template.erb +1 -0
- data/spec/template/template_spec/views/prefixes/_underscored.erb +1 -0
- data/spec/template/template_spec/views/prefixes/without_prefix.erb +1 -0
- data/spec/template/tilt_spec.rb +96 -0
- data/spec/template/tilt_spec/views/concat_and_capture.erb +1 -0
- data/spec/template/tilt_spec/views/concat_and_capture.haml +3 -0
- data/spec/template/tilt_spec/views/errors.erb +3 -0
- data/spec/template/tilt_spec/views/errors.haml +3 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_erb_concat_erb.erb +4 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_erb_concat_haml.haml +1 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_haml_concat_erb.erb +1 -0
- data/spec/template/tilt_spec/views/mixed_templates/broken_haml_concat_haml.haml +2 -0
- data/spec/template/tilt_spec/views/nested_capture_and_concat.haml +3 -0
- data/spec/template/tilt_spec/views/ugly.haml +3 -0
- data/spec/template/tilt_spec/views/yield.erb +1 -0
- metadata +303 -33
- data/lib/crystal_ext/defer_js.rb +0 -75
- data/lib/crystal_ext/ensure_no_www.rb +0 -39
- data/lib/crystal_ext/gems.rb +0 -2
- data/lib/crystal_ext/i18n.rb +0 -25
- data/lib/crystal_ext/i18n/locales/ru/pluralization.rb +0 -62
- data/lib/crystal_ext/plugin.rb +0 -23
- data/lib/crystal_ext/plugin/app.rb +0 -19
- data/lib/crystal_ext/plugin/web.rb +0 -44
- data/lib/crystal_ext/prepare_model.rb +0 -20
- data/lib/crystal_ext/profiles/web_ext_require.rb +0 -13
- data/lib/crystal_ext/protect_from_forgery.rb +0 -66
- data/lib/crystal_ext/user_error.rb +0 -14
- data/spec/controller_spec_helper.rb +0 -19
- data/spec/defer_js_spec.rb +0 -33
- data/spec/i18n_spec.rb +0 -31
- data/spec/i18n_spec/locales/en/general.yml +0 -5
- data/spec/i18n_spec/locales/ru/general.yml +0 -7
- data/spec/prepare_model_spec.rb +0 -43
- data/spec/protect_from_forgery_spec.rb +0 -169
- data/spec/spec_helper.rb +0 -4
- data/spec/user_error_spec.rb +0 -41
data/spec/i18n_spec.rb
DELETED
@@ -1,31 +0,0 @@
|
|
1
|
-
require "spec_helper"
|
2
|
-
|
3
|
-
require 'crystal/support' # to check that i18n will correctly works with ActiveSupport
|
4
|
-
require 'crystal_ext/i18n'
|
5
|
-
|
6
|
-
describe 'I18n' do
|
7
|
-
before :all do
|
8
|
-
dir = File.expand_path(File.dirname(__FILE__))
|
9
|
-
I18n.load_path += Dir["#{dir}/i18n_spec/locales/*/*.{rb,yml}"]
|
10
|
-
end
|
11
|
-
|
12
|
-
def t *args
|
13
|
-
I18n.t *args
|
14
|
-
end
|
15
|
-
|
16
|
-
it "basic" do
|
17
|
-
I18n.locale = 'en'
|
18
|
-
t(:name).should == "Name"
|
19
|
-
t(:name).is_a?(String).should be_true
|
20
|
-
|
21
|
-
I18n.locale = 'ru'
|
22
|
-
t(:name).should == "Имя"
|
23
|
-
end
|
24
|
-
|
25
|
-
it "pluggable pluralization" do
|
26
|
-
I18n.locale = 'ru'
|
27
|
-
t(:comments_count, :count => 1).should == "1 комментарий"
|
28
|
-
t(:comments_count, :count => 2).should == "2 комментария"
|
29
|
-
t(:comments_count, :count => 5).should == "5 комментариев"
|
30
|
-
end
|
31
|
-
end
|
data/spec/prepare_model_spec.rb
DELETED
@@ -1,43 +0,0 @@
|
|
1
|
-
require "controller_spec_helper"
|
2
|
-
|
3
|
-
require 'crystal_ext/prepare_model'
|
4
|
-
|
5
|
-
describe "User Error" do
|
6
|
-
with_environment :test
|
7
|
-
with_controller_ext_spec
|
8
|
-
|
9
|
-
before :all do
|
10
|
-
class ::SomeModel
|
11
|
-
def self.find! id
|
12
|
-
id.should == 'some id'
|
13
|
-
SomeModel.new
|
14
|
-
end
|
15
|
-
end
|
16
|
-
|
17
|
-
# crystal[:config].environment = :test
|
18
|
-
# crystal[:environment] = Crystal::Environment.new
|
19
|
-
# crystal[:environment].load :controller_ext_spec
|
20
|
-
end
|
21
|
-
|
22
|
-
after :all do
|
23
|
-
remove_constants %w(SomeModel ControllerSpec)
|
24
|
-
|
25
|
-
# Micon.clear
|
26
|
-
end
|
27
|
-
|
28
|
-
it "user error" do
|
29
|
-
class ::ControllerSpec
|
30
|
-
inherit Crystal::HttpController
|
31
|
-
|
32
|
-
prepare_model SomeModel, :id => :some_model, :variable => 'some_model'
|
33
|
-
|
34
|
-
def action
|
35
|
-
@some_model.should_not == nil
|
36
|
-
render :inline => 'ok'
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
ccall(ControllerSpec, :action, :some_model => 'some id').content.should == 'ok'
|
41
|
-
# workspace.response.should == [200, {"Content-Type"=>"application/json"}, %({"result":true})]
|
42
|
-
end
|
43
|
-
end
|
@@ -1,169 +0,0 @@
|
|
1
|
-
require "spec_helper"
|
2
|
-
|
3
|
-
require 'crystal/profiles/web_require'
|
4
|
-
require 'crystal_ext/protect_from_forgery'
|
5
|
-
|
6
|
-
require 'crystal/spec/environment'
|
7
|
-
|
8
|
-
describe "Forgery protection" do
|
9
|
-
with_environment :test
|
10
|
-
|
11
|
-
before :all do
|
12
|
-
class ForgerySpecHelper < Crystal::Processor
|
13
|
-
def call
|
14
|
-
block = workspace.check_forgery.before_request
|
15
|
-
block.call workspace if block
|
16
|
-
workspace.before_request_done = true
|
17
|
-
|
18
|
-
next_processor.call
|
19
|
-
|
20
|
-
block = workspace.check_forgery.after_request
|
21
|
-
block.call workspace if block
|
22
|
-
workspace.after_request_done = true
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
class ::AnRemote
|
27
|
-
inherit Crystal::HttpController
|
28
|
-
|
29
|
-
protect_from_forgery :only => :protected_method
|
30
|
-
|
31
|
-
def protected_method
|
32
|
-
render :inline => 'protected result'
|
33
|
-
end
|
34
|
-
|
35
|
-
def method_without_protection
|
36
|
-
render :inline => 'result'
|
37
|
-
end
|
38
|
-
|
39
|
-
def dumb_method; end
|
40
|
-
end
|
41
|
-
|
42
|
-
crystal.after :environment do
|
43
|
-
crystal.conveyors.web do |web|
|
44
|
-
web.use Crystal::Processors::PrepareParams
|
45
|
-
web.use Crystal::Processors::EvaluateFormat
|
46
|
-
web.use ForgerySpecHelper
|
47
|
-
web.use Crystal::Processors::PrepareAutenticityToken
|
48
|
-
web.use Crystal::Processors::ControllerCaller, :content
|
49
|
-
end
|
50
|
-
|
51
|
-
crystal.config.session = {'key' => 'session_id'}
|
52
|
-
end
|
53
|
-
end
|
54
|
-
|
55
|
-
after :all do
|
56
|
-
remove_constants %w(AnRemote ForgerySpecHelper)
|
57
|
-
end
|
58
|
-
|
59
|
-
def check_forgery opt
|
60
|
-
workspace = nil
|
61
|
-
result = Crystal::HTTPAdapter.mock_call({}, :check_forgery => opt.to_openobject) do |&block|
|
62
|
-
block.call
|
63
|
-
workspace = crystal[:workspace]
|
64
|
-
end
|
65
|
-
|
66
|
-
workspace.before_request_done.should be_true
|
67
|
-
workspace.after_request_done.should be_true
|
68
|
-
workspace
|
69
|
-
end
|
70
|
-
|
71
|
-
it "should set :authenticity_token only for :get and :html request" do
|
72
|
-
check_forgery(
|
73
|
-
:before_request => lambda{|workspace|
|
74
|
-
workspace.env['REQUEST_METHOD'] = 'GET'
|
75
|
-
workspace.env['CONTENT_TYPE'] = 'html'
|
76
|
-
workspace.class = AnRemote
|
77
|
-
workspace.method_name = 'dumb_method'
|
78
|
-
},
|
79
|
-
:after_request => lambda{|workspace|
|
80
|
-
workspace.request.session['authenticity_token'].should_not be_blank
|
81
|
-
}
|
82
|
-
)
|
83
|
-
|
84
|
-
# post
|
85
|
-
check_forgery(
|
86
|
-
:before_request => lambda{|workspace|
|
87
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
88
|
-
workspace.env['CONTENT_TYPE'] = 'html'
|
89
|
-
workspace.class = AnRemote
|
90
|
-
workspace.method_name = 'dumb_method'
|
91
|
-
},
|
92
|
-
:after_request => lambda{|workspace|
|
93
|
-
workspace.request.session['authenticity_token'].should be_blank
|
94
|
-
}
|
95
|
-
)
|
96
|
-
end
|
97
|
-
|
98
|
-
it "should check any non :get request with browser's formats for :authenticity_token" do
|
99
|
-
lambda{
|
100
|
-
check_forgery(
|
101
|
-
:before_request => lambda{|workspace|
|
102
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
103
|
-
workspace.env['CONTENT_TYPE'] = 'html'
|
104
|
-
workspace.class = AnRemote
|
105
|
-
workspace.method_name = 'protected_method'
|
106
|
-
}
|
107
|
-
)
|
108
|
-
}.should raise_error(/Invalid authenticity token/)
|
109
|
-
|
110
|
-
# with correct :authenticity_token
|
111
|
-
check_forgery(
|
112
|
-
:before_request => lambda{|workspace|
|
113
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
114
|
-
workspace.env['CONTENT_TYPE'] = 'html'
|
115
|
-
workspace.request.session['authenticity_token'] = 'secure token'
|
116
|
-
workspace.params['authenticity_token'] = 'secure token'
|
117
|
-
workspace.class = AnRemote
|
118
|
-
workspace.method_name = 'protected_method'
|
119
|
-
},
|
120
|
-
:after_request => lambda{|workspace|
|
121
|
-
workspace.content.should == "protected result"
|
122
|
-
}
|
123
|
-
)
|
124
|
-
|
125
|
-
# non-browser format
|
126
|
-
check_forgery(
|
127
|
-
:before_request => lambda{|workspace|
|
128
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
129
|
-
workspace.env['CONTENT_TYPE'] = 'non-browser-format'
|
130
|
-
workspace.class = AnRemote
|
131
|
-
workspace.method_name = 'protected_method'
|
132
|
-
},
|
133
|
-
:after_request => lambda{|workspace|
|
134
|
-
workspace.content.should == "protected result"
|
135
|
-
}
|
136
|
-
)
|
137
|
-
end
|
138
|
-
|
139
|
-
it "should not protect non protected methods" do
|
140
|
-
check_forgery(
|
141
|
-
:before_request => lambda{|workspace|
|
142
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
143
|
-
workspace.env['CONTENT_TYPE'] = 'html'
|
144
|
-
workspace.class = AnRemote
|
145
|
-
workspace.method_name = 'method_without_protection'
|
146
|
-
},
|
147
|
-
:after_request => lambda{|workspace|
|
148
|
-
workspace.content.should == "result"
|
149
|
-
}
|
150
|
-
)
|
151
|
-
end
|
152
|
-
|
153
|
-
it "should use :session_authenticity_token from params (for flash support)" do
|
154
|
-
check_forgery(
|
155
|
-
:before_request => lambda{|workspace|
|
156
|
-
workspace.env['REQUEST_METHOD'] = 'POST'
|
157
|
-
workspace.params.format = 'html'
|
158
|
-
workspace.params['session_authenticity_token'] = 'secure token'
|
159
|
-
workspace.params['authenticity_token'] = 'secure token'
|
160
|
-
workspace.class = AnRemote
|
161
|
-
workspace.method_name = 'protected_method'
|
162
|
-
},
|
163
|
-
:after_request => lambda{|workspace|
|
164
|
-
workspace.content.should == "protected result"
|
165
|
-
}
|
166
|
-
)
|
167
|
-
end
|
168
|
-
|
169
|
-
end
|
data/spec/spec_helper.rb
DELETED
data/spec/user_error_spec.rb
DELETED
@@ -1,41 +0,0 @@
|
|
1
|
-
require "controller_spec_helper"
|
2
|
-
|
3
|
-
require 'crystal_ext/user_error'
|
4
|
-
|
5
|
-
describe "User Error" do
|
6
|
-
with_environment :test
|
7
|
-
with_controller_ext_spec
|
8
|
-
|
9
|
-
# before :all do
|
10
|
-
# crystal[:config].environment = :test
|
11
|
-
# crystal[:environment] = Crystal::Environment.new
|
12
|
-
# crystal[:environment].load :controller_ext_spec
|
13
|
-
# end
|
14
|
-
|
15
|
-
after :all do
|
16
|
-
# Micon.clear
|
17
|
-
remove_constants %w(UserErrorSpec)
|
18
|
-
end
|
19
|
-
|
20
|
-
it "user error" do
|
21
|
-
class ::UserErrorSpec
|
22
|
-
inherit Crystal::HttpController
|
23
|
-
|
24
|
-
def call
|
25
|
-
raise_user_error "some error"
|
26
|
-
end
|
27
|
-
|
28
|
-
protected
|
29
|
-
def catch_user_error
|
30
|
-
begin
|
31
|
-
yield
|
32
|
-
rescue UserError => ue
|
33
|
-
render :inline => "Catched #{ue.message}"
|
34
|
-
end
|
35
|
-
end
|
36
|
-
around :catch_user_error
|
37
|
-
end
|
38
|
-
|
39
|
-
ccall(UserErrorSpec, :call).content.should == "Catched some error"
|
40
|
-
end
|
41
|
-
end
|