pager-resource_controller 1.0.20080513
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/LICENSE +22 -0
- data/README +276 -0
- data/Rakefile +55 -0
- data/TODO +1 -0
- data/generators/scaffold_resource/USAGE +29 -0
- data/generators/scaffold_resource/scaffold_resource_generator.rb +101 -0
- data/generators/scaffold_resource/templates/controller.rb +2 -0
- data/generators/scaffold_resource/templates/fixtures.yml +10 -0
- data/generators/scaffold_resource/templates/functional_test.rb +57 -0
- data/generators/scaffold_resource/templates/helper.rb +2 -0
- data/generators/scaffold_resource/templates/migration.rb +15 -0
- data/generators/scaffold_resource/templates/model.rb +2 -0
- data/generators/scaffold_resource/templates/old_migration.rb +13 -0
- data/generators/scaffold_resource/templates/shoulda_functional_test.rb +19 -0
- data/generators/scaffold_resource/templates/unit_test.rb +7 -0
- data/generators/scaffold_resource/templates/view__form.erb +6 -0
- data/generators/scaffold_resource/templates/view__form.haml +5 -0
- data/generators/scaffold_resource/templates/view_edit.erb +16 -0
- data/generators/scaffold_resource/templates/view_edit.haml +11 -0
- data/generators/scaffold_resource/templates/view_index.erb +22 -0
- data/generators/scaffold_resource/templates/view_index.haml +19 -0
- data/generators/scaffold_resource/templates/view_new.erb +12 -0
- data/generators/scaffold_resource/templates/view_new.haml +9 -0
- data/generators/scaffold_resource/templates/view_show.erb +9 -0
- data/generators/scaffold_resource/templates/view_show.haml +9 -0
- data/init.rb +6 -0
- data/install.rb +1 -0
- data/lib/resource_controller.rb +11 -0
- data/lib/resource_controller/accessors.rb +76 -0
- data/lib/resource_controller/action_options.rb +28 -0
- data/lib/resource_controller/actions.rb +75 -0
- data/lib/resource_controller/base.rb +15 -0
- data/lib/resource_controller/class_methods.rb +22 -0
- data/lib/resource_controller/controller.rb +63 -0
- data/lib/resource_controller/failable_action_options.rb +17 -0
- data/lib/resource_controller/helpers.rb +28 -0
- data/lib/resource_controller/helpers/current_objects.rb +69 -0
- data/lib/resource_controller/helpers/internal.rb +59 -0
- data/lib/resource_controller/helpers/nested.rb +45 -0
- data/lib/resource_controller/helpers/urls.rb +124 -0
- data/lib/resource_controller/response_collector.rb +21 -0
- data/lib/urligence.rb +50 -0
- data/rails/init.rb +1 -0
- data/test/Rakefile +10 -0
- data/test/app/controllers/application.rb +7 -0
- data/test/app/controllers/cms/options_controller.rb +3 -0
- data/test/app/controllers/cms/products_controller.rb +2 -0
- data/test/app/controllers/comments_controller.rb +3 -0
- data/test/app/controllers/people_controller.rb +9 -0
- data/test/app/controllers/photos_controller.rb +10 -0
- data/test/app/controllers/posts_controller.rb +10 -0
- data/test/app/controllers/projects_controller.rb +3 -0
- data/test/app/controllers/somethings_controller.rb +3 -0
- data/test/app/controllers/tags_controller.rb +13 -0
- data/test/app/controllers/users_controller.rb +12 -0
- data/test/app/helpers/application_helper.rb +3 -0
- data/test/app/helpers/cms/products_helper.rb +2 -0
- data/test/app/helpers/comments_helper.rb +2 -0
- data/test/app/helpers/options_helper.rb +2 -0
- data/test/app/helpers/people_helper.rb +2 -0
- data/test/app/helpers/photos_helper.rb +2 -0
- data/test/app/helpers/posts_helper.rb +2 -0
- data/test/app/helpers/projects_helper.rb +2 -0
- data/test/app/helpers/somethings_helper.rb +2 -0
- data/test/app/helpers/tags_helper.rb +2 -0
- data/test/app/helpers/users_helper.rb +2 -0
- data/test/app/models/account.rb +3 -0
- data/test/app/models/comment.rb +3 -0
- data/test/app/models/option.rb +3 -0
- data/test/app/models/photo.rb +4 -0
- data/test/app/models/post.rb +3 -0
- data/test/app/models/product.rb +3 -0
- data/test/app/models/project.rb +2 -0
- data/test/app/models/something.rb +2 -0
- data/test/app/models/tag.rb +3 -0
- data/test/app/views/cms/options/edit.rhtml +17 -0
- data/test/app/views/cms/options/index.rhtml +20 -0
- data/test/app/views/cms/options/new.rhtml +16 -0
- data/test/app/views/cms/options/show.rhtml +8 -0
- data/test/app/views/cms/products/edit.rhtml +17 -0
- data/test/app/views/cms/products/index.rhtml +20 -0
- data/test/app/views/cms/products/new.rhtml +16 -0
- data/test/app/views/cms/products/show.rhtml +8 -0
- data/test/app/views/comments/edit.rhtml +27 -0
- data/test/app/views/comments/index.rhtml +24 -0
- data/test/app/views/comments/new.rhtml +26 -0
- data/test/app/views/comments/show.rhtml +18 -0
- data/test/app/views/layouts/application.rhtml +17 -0
- data/test/app/views/layouts/comments.rhtml +17 -0
- data/test/app/views/layouts/options.rhtml +17 -0
- data/test/app/views/layouts/people.rhtml +17 -0
- data/test/app/views/layouts/photos.rhtml +17 -0
- data/test/app/views/layouts/projects.rhtml +17 -0
- data/test/app/views/layouts/somethings.rhtml +17 -0
- data/test/app/views/layouts/tags.rhtml +17 -0
- data/test/app/views/people/edit.rhtml +17 -0
- data/test/app/views/people/index.rhtml +20 -0
- data/test/app/views/people/new.rhtml +16 -0
- data/test/app/views/people/show.rhtml +8 -0
- data/test/app/views/photos/edit.rhtml +17 -0
- data/test/app/views/photos/index.rhtml +20 -0
- data/test/app/views/photos/new.rhtml +16 -0
- data/test/app/views/photos/show.rhtml +8 -0
- data/test/app/views/posts/edit.rhtml +22 -0
- data/test/app/views/posts/index.rhtml +22 -0
- data/test/app/views/posts/new.rhtml +21 -0
- data/test/app/views/posts/show.rhtml +13 -0
- data/test/app/views/projects/edit.rhtml +17 -0
- data/test/app/views/projects/index.rhtml +20 -0
- data/test/app/views/projects/new.rhtml +16 -0
- data/test/app/views/projects/show.rhtml +8 -0
- data/test/app/views/somethings/edit.rhtml +17 -0
- data/test/app/views/somethings/index.rhtml +20 -0
- data/test/app/views/somethings/new.rhtml +16 -0
- data/test/app/views/somethings/show.rhtml +8 -0
- data/test/app/views/tags/edit.rhtml +17 -0
- data/test/app/views/tags/index.rhtml +20 -0
- data/test/app/views/tags/index.rjs +0 -0
- data/test/app/views/tags/new.rhtml +16 -0
- data/test/app/views/tags/show.rhtml +8 -0
- data/test/app/views/users/edit.rhtml +17 -0
- data/test/app/views/users/index.rhtml +20 -0
- data/test/app/views/users/new.rhtml +16 -0
- data/test/app/views/users/show.rhtml +8 -0
- data/test/config/boot.rb +45 -0
- data/test/config/database.yml +16 -0
- data/test/config/environment.rb +64 -0
- data/test/config/environments/development.rb +21 -0
- data/test/config/environments/test.rb +19 -0
- data/test/config/routes.rb +51 -0
- data/test/db/migrate/001_create_posts.rb +12 -0
- data/test/db/migrate/002_create_products.rb +11 -0
- data/test/db/migrate/003_create_comments.rb +13 -0
- data/test/db/migrate/004_create_options.rb +12 -0
- data/test/db/migrate/005_create_photos.rb +11 -0
- data/test/db/migrate/006_create_tags.rb +17 -0
- data/test/db/migrate/007_create_somethings.rb +11 -0
- data/test/db/migrate/008_create_accounts.rb +11 -0
- data/test/db/migrate/009_add_account_id_to_photos.rb +9 -0
- data/test/db/migrate/010_create_projects.rb +11 -0
- data/test/db/schema.rb +65 -0
- data/test/script/console +3 -0
- data/test/script/destroy +3 -0
- data/test/script/generate +3 -0
- data/test/script/server +3 -0
- data/test/test/fixtures/accounts.yml +7 -0
- data/test/test/fixtures/comments.yml +11 -0
- data/test/test/fixtures/options.yml +9 -0
- data/test/test/fixtures/photos.yml +9 -0
- data/test/test/fixtures/photos_tags.yml +3 -0
- data/test/test/fixtures/posts.yml +9 -0
- data/test/test/fixtures/products.yml +7 -0
- data/test/test/fixtures/projects.yml +7 -0
- data/test/test/fixtures/somethings.yml +7 -0
- data/test/test/fixtures/tags.yml +7 -0
- data/test/test/functional/cms/options_controller_test.rb +20 -0
- data/test/test/functional/cms/products_controller_test.rb +18 -0
- data/test/test/functional/comments_controller_test.rb +26 -0
- data/test/test/functional/people_controller_test.rb +34 -0
- data/test/test/functional/photos_controller_test.rb +128 -0
- data/test/test/functional/posts_controller_test.rb +34 -0
- data/test/test/functional/projects_controller_test.rb +18 -0
- data/test/test/functional/somethings_controller_test.rb +28 -0
- data/test/test/functional/tags_controller_test.rb +64 -0
- data/test/test/functional/users_controller_test.rb +24 -0
- data/test/test/test_helper.rb +12 -0
- data/test/test/unit/accessors_test.rb +91 -0
- data/test/test/unit/account_test.rb +7 -0
- data/test/test/unit/action_options_test.rb +66 -0
- data/test/test/unit/base_test.rb +11 -0
- data/test/test/unit/comment_test.rb +10 -0
- data/test/test/unit/failable_action_options_test.rb +50 -0
- data/test/test/unit/helpers/current_objects_test.rb +127 -0
- data/test/test/unit/helpers/internal_test.rb +88 -0
- data/test/test/unit/helpers/nested_test.rb +82 -0
- data/test/test/unit/helpers/urls_test.rb +71 -0
- data/test/test/unit/helpers_test.rb +25 -0
- data/test/test/unit/option_test.rb +10 -0
- data/test/test/unit/photo_test.rb +10 -0
- data/test/test/unit/post_test.rb +10 -0
- data/test/test/unit/project_test.rb +10 -0
- data/test/test/unit/response_collector_test.rb +31 -0
- data/test/test/unit/something_test.rb +10 -0
- data/test/test/unit/tag_test.rb +10 -0
- data/test/test/unit/urligence_test.rb +203 -0
- data/test/vendor/plugins/shoulda/README +123 -0
- data/test/vendor/plugins/shoulda/Rakefile +29 -0
- data/test/vendor/plugins/shoulda/bin/convert_to_should_syntax +40 -0
- data/test/vendor/plugins/shoulda/init.rb +3 -0
- data/test/vendor/plugins/shoulda/lib/shoulda.rb +47 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/active_record_helpers.rb +338 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/color.rb +77 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/context.rb +143 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/controller_tests/controller_tests.rb +470 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/controller_tests/formats/html.rb +192 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/controller_tests/formats/xml.rb +162 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/general.rb +119 -0
- data/test/vendor/plugins/shoulda/lib/shoulda/private_helpers.rb +17 -0
- data/test/vendor/plugins/shoulda/tasks/list_tests.rake +40 -0
- data/uninstall.rb +1 -0
- metadata +410 -0
@@ -0,0 +1,34 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
require 'posts_controller'
|
3
|
+
|
4
|
+
# Re-raise errors caught by the controller.
|
5
|
+
class PostsController; def rescue_action(e) raise e end; end
|
6
|
+
|
7
|
+
class PostsControllerTest < Test::Unit::TestCase
|
8
|
+
def setup
|
9
|
+
@controller = PostsController.new
|
10
|
+
@request = ActionController::TestRequest.new
|
11
|
+
@response = ActionController::TestResponse.new
|
12
|
+
@post = Post.find 1
|
13
|
+
end
|
14
|
+
|
15
|
+
should_be_restful do |resource|
|
16
|
+
resource.formats = [:html]
|
17
|
+
|
18
|
+
resource.actions = :all
|
19
|
+
end
|
20
|
+
|
21
|
+
context "on post to :create" do
|
22
|
+
setup do
|
23
|
+
post :create, :post => {}
|
24
|
+
end
|
25
|
+
|
26
|
+
should "name the post 'a great post'" do
|
27
|
+
assert_equal 'a great post', assigns(:post).title
|
28
|
+
end
|
29
|
+
|
30
|
+
should "give the post a body of '...'" do
|
31
|
+
assert_equal '...', assigns(:post).body
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
require 'projects_controller'
|
3
|
+
|
4
|
+
# Re-raise errors caught by the controller.
|
5
|
+
class ProjectsController; def rescue_action(e) raise e end; end
|
6
|
+
|
7
|
+
class ProjectsControllerTest < Test::Unit::TestCase
|
8
|
+
def setup
|
9
|
+
@controller = ProjectsController.new
|
10
|
+
@request = ActionController::TestRequest.new
|
11
|
+
@response = ActionController::TestResponse.new
|
12
|
+
@project = projects :one
|
13
|
+
end
|
14
|
+
|
15
|
+
should_be_restful do |resource|
|
16
|
+
resource.formats = [:html]
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
require 'somethings_controller'
|
3
|
+
|
4
|
+
# Re-raise errors caught by the controller.
|
5
|
+
class SomethingsController; def rescue_action(e) raise e end; end
|
6
|
+
|
7
|
+
class SomethingsControllerTest < Test::Unit::TestCase
|
8
|
+
def setup
|
9
|
+
@controller = SomethingsController.new
|
10
|
+
@request = ActionController::TestRequest.new
|
11
|
+
@response = ActionController::TestResponse.new
|
12
|
+
@something = somethings :one
|
13
|
+
end
|
14
|
+
|
15
|
+
context "actions specified" do
|
16
|
+
[:create, :edit, :update, :destroy, :new].each do |action|
|
17
|
+
should "not respond to #{action}" do
|
18
|
+
assert !@controller.respond_to?(action)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
should_be_restful do |resource|
|
24
|
+
resource.formats = [:html]
|
25
|
+
|
26
|
+
resource.actions = [:index, :show]
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,64 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
require 'tags_controller'
|
3
|
+
|
4
|
+
# Re-raise errors caught by the controller.
|
5
|
+
class TagsController; def rescue_action(e) raise e end; end
|
6
|
+
|
7
|
+
class TagsControllerTest < Test::Unit::TestCase
|
8
|
+
def setup
|
9
|
+
@controller = TagsController.new
|
10
|
+
@request = ActionController::TestRequest.new
|
11
|
+
@response = ActionController::TestResponse.new
|
12
|
+
@tag = Tag.find 1
|
13
|
+
end
|
14
|
+
|
15
|
+
context "with photo as parent" do
|
16
|
+
context "get to :index" do
|
17
|
+
setup do
|
18
|
+
get :index, :photo_id => 1
|
19
|
+
end
|
20
|
+
|
21
|
+
should_assign_to :products
|
22
|
+
should_render_template "index"
|
23
|
+
should_respond_with :success
|
24
|
+
|
25
|
+
should "respond with html" do
|
26
|
+
assert_equal 'text/html', @response.content_type
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
context "xhr to :index" do
|
31
|
+
setup do
|
32
|
+
xhr :get, :index, :photo_id => 1
|
33
|
+
end
|
34
|
+
|
35
|
+
should_assign_to :products
|
36
|
+
should_respond_with :success
|
37
|
+
|
38
|
+
should "respond with rjs" do
|
39
|
+
assert_equal 'text/javascript', @response.content_type
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
context "post to create" do
|
44
|
+
setup do
|
45
|
+
post :create, :photo_id => 1, :tag => {:name => "Hello!"}
|
46
|
+
end
|
47
|
+
|
48
|
+
should "add tag to photo" do
|
49
|
+
assert assigns(:photo).tags.include?(assigns(:tag)), "photo does not include new tag"
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
context "without photo as parent" do
|
55
|
+
should_be_restful do |resource|
|
56
|
+
resource.formats = [:html]
|
57
|
+
end
|
58
|
+
|
59
|
+
should "render text for a missing object" do
|
60
|
+
get :show, :id => 50000
|
61
|
+
assert @response.body.match(/not found/i), @response.body
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
require 'users_controller'
|
3
|
+
|
4
|
+
# Re-raise errors caught by the controller.
|
5
|
+
class UsersController; def rescue_action(e) raise e end; end
|
6
|
+
|
7
|
+
class UsersControllerTest < Test::Unit::TestCase
|
8
|
+
def setup
|
9
|
+
@controller = UsersController.new
|
10
|
+
@request = ActionController::TestRequest.new
|
11
|
+
@response = ActionController::TestResponse.new
|
12
|
+
@dude = accounts :one
|
13
|
+
end
|
14
|
+
|
15
|
+
should_be_restful do |resource|
|
16
|
+
resource.formats = [:html]
|
17
|
+
resource.klass = Account
|
18
|
+
resource.object = :dude
|
19
|
+
|
20
|
+
resource.create.redirect = 'dude_url(@dude)'
|
21
|
+
resource.update.redirect = 'dude_url(@dude)'
|
22
|
+
resource.destroy.redirect = 'dudes_url'
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
$:.reject! { |path| path.include? 'TextMate' }
|
2
|
+
ENV["RAILS_ENV"] = "test"
|
3
|
+
require File.expand_path(File.dirname(__FILE__) + "/../config/environment")
|
4
|
+
require 'test_help'
|
5
|
+
require 'mocha'
|
6
|
+
|
7
|
+
class Test::Unit::TestCase
|
8
|
+
self.use_transactional_fixtures = true
|
9
|
+
self.use_instantiated_fixtures = false
|
10
|
+
|
11
|
+
load_all_fixtures
|
12
|
+
end
|
@@ -0,0 +1,91 @@
|
|
1
|
+
require File.dirname(__FILE__)+'/../test_helper'
|
2
|
+
|
3
|
+
class AccessorsTest < Test::Unit::TestCase
|
4
|
+
def setup
|
5
|
+
PostsController.class_eval do
|
6
|
+
extend ResourceController::Accessors
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
context "scoping reader" do
|
11
|
+
setup do
|
12
|
+
PostsController.class_eval do
|
13
|
+
class_scoping_reader :create, ResourceController::ActionOptions.new
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
should "access create as usual" do
|
18
|
+
PostsController.class_eval do
|
19
|
+
create.flash "asdf"
|
20
|
+
end
|
21
|
+
|
22
|
+
assert_equal "asdf", PostsController.create.flash
|
23
|
+
end
|
24
|
+
|
25
|
+
should "scope to create object in a block" do
|
26
|
+
PostsController.class_eval do
|
27
|
+
create do
|
28
|
+
flash "asdf"
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
assert_equal "asdf", PostsController.create.flash
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
context "reader/writer method" do
|
37
|
+
setup do
|
38
|
+
PostsController.class_eval do
|
39
|
+
reader_writer :flash
|
40
|
+
end
|
41
|
+
|
42
|
+
@controller = PostsController.new
|
43
|
+
end
|
44
|
+
|
45
|
+
should "set and get var" do
|
46
|
+
@controller.flash "something"
|
47
|
+
assert_equal "something", @controller.flash
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
context "class reader/writer method" do
|
52
|
+
setup do
|
53
|
+
PostsController.class_eval do
|
54
|
+
class_reader_writer :flash
|
55
|
+
end
|
56
|
+
|
57
|
+
@controller = PostsController.new
|
58
|
+
end
|
59
|
+
|
60
|
+
should "initialize var" do
|
61
|
+
assert_nil PostsController.flash
|
62
|
+
assert_nil @controller.flash
|
63
|
+
end
|
64
|
+
|
65
|
+
should "set and get var" do
|
66
|
+
PostsController.flash "something"
|
67
|
+
assert_equal "something", PostsController.flash
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
context "block accessor" do
|
72
|
+
setup do
|
73
|
+
PostsController.class_eval do
|
74
|
+
block_accessor :something
|
75
|
+
end
|
76
|
+
@controller = PostsController.new
|
77
|
+
end
|
78
|
+
|
79
|
+
should "store blocks" do
|
80
|
+
@controller.something {}
|
81
|
+
assert @controller.something.first
|
82
|
+
end
|
83
|
+
|
84
|
+
should "store symbols as well" do
|
85
|
+
@controller.something(:method, :method_two) {}
|
86
|
+
assert_equal :method, @controller.something[0]
|
87
|
+
assert_equal :method_two, @controller.something[1]
|
88
|
+
assert @controller.something[2].is_a?(Proc)
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require File.dirname(__FILE__)+'/../test_helper'
|
2
|
+
|
3
|
+
class ActionOptionsTest < Test::Unit::TestCase
|
4
|
+
def setup
|
5
|
+
@controller = PostsController.new
|
6
|
+
@create = ResourceController::ActionOptions.new
|
7
|
+
end
|
8
|
+
|
9
|
+
should "have attr accessor for flash" do
|
10
|
+
@create.flash "Successfully created."
|
11
|
+
assert_equal "Successfully created.", @create.flash
|
12
|
+
end
|
13
|
+
|
14
|
+
%w(before after).each do |accessor|
|
15
|
+
should "have a block accessor for #{accessor}" do
|
16
|
+
@create.send(accessor) do
|
17
|
+
"return_something"
|
18
|
+
end
|
19
|
+
|
20
|
+
assert_equal "return_something", @create.send(accessor).first.call(nil)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
context "response yielding to response collector" do
|
25
|
+
setup do
|
26
|
+
@create.response do |wants|
|
27
|
+
wants.html
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
should "accept symbols" do
|
32
|
+
@create.response :html, :js, :xml
|
33
|
+
assert @create.wants[:html]
|
34
|
+
assert @create.wants[:js]
|
35
|
+
assert @create.wants[:xml]
|
36
|
+
end
|
37
|
+
|
38
|
+
should "accept symbols and blocks" do
|
39
|
+
@create.responds_to :html do |wants| # note the aliasing of response here
|
40
|
+
wants.js
|
41
|
+
end
|
42
|
+
|
43
|
+
assert @create.wants[:html]
|
44
|
+
assert @create.wants[:js]
|
45
|
+
end
|
46
|
+
|
47
|
+
should "collect responses" do
|
48
|
+
assert @create.wants[:html]
|
49
|
+
end
|
50
|
+
|
51
|
+
should "clear the collector on a subsequent call" do
|
52
|
+
@create.respond_to do |wants| # note the other aliasing of response
|
53
|
+
wants.js
|
54
|
+
end
|
55
|
+
|
56
|
+
assert_nil @create.wants[:html]
|
57
|
+
assert @create.wants[:js]
|
58
|
+
end
|
59
|
+
|
60
|
+
should "add response without clearing" do
|
61
|
+
@create.wants.js
|
62
|
+
assert @create.wants[:js]
|
63
|
+
assert @create.wants[:html]
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
require File.dirname(__FILE__)+'/../test_helper'
|
2
|
+
|
3
|
+
class FailableActionOptionsTest < Test::Unit::TestCase
|
4
|
+
def setup
|
5
|
+
@controller = PostsController.new
|
6
|
+
@create = ResourceController::FailableActionOptions.new
|
7
|
+
end
|
8
|
+
|
9
|
+
should "have success and fails" do
|
10
|
+
assert ResourceController::ActionOptions, @create.success.class
|
11
|
+
assert ResourceController::ActionOptions, @create.fails.class
|
12
|
+
end
|
13
|
+
|
14
|
+
%w(before).each do |accessor|
|
15
|
+
should "have a block accessor for #{accessor}" do
|
16
|
+
@create.send(accessor) do
|
17
|
+
"return_something"
|
18
|
+
end
|
19
|
+
|
20
|
+
assert_equal "return_something", @create.send(accessor).first.call(nil)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
should "delegate flash to success" do
|
25
|
+
@create.flash "Successfully created."
|
26
|
+
assert_equal "Successfully created.", @create.success.flash
|
27
|
+
end
|
28
|
+
|
29
|
+
should "delegate after to success" do
|
30
|
+
@create.after do
|
31
|
+
"something"
|
32
|
+
end
|
33
|
+
|
34
|
+
assert_equal "something", @create.success.after.first.call
|
35
|
+
end
|
36
|
+
|
37
|
+
should "delegate response to success" do
|
38
|
+
@create.response do |wants|
|
39
|
+
wants.html
|
40
|
+
end
|
41
|
+
|
42
|
+
assert @create.wants[:html]
|
43
|
+
end
|
44
|
+
|
45
|
+
should "delegate wants to success" do
|
46
|
+
@create.wants.html
|
47
|
+
|
48
|
+
assert @create.wants[:html]
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,127 @@
|
|
1
|
+
require File.dirname(__FILE__)+'/../../test_helper'
|
2
|
+
|
3
|
+
class Helpers::CurrentObjectsTest < Test::Unit::TestCase
|
4
|
+
def setup
|
5
|
+
@controller = PostsController.new
|
6
|
+
|
7
|
+
@params = stub :[] => "1"
|
8
|
+
@controller.stubs(:params).returns(@params)
|
9
|
+
|
10
|
+
@object = Post.new
|
11
|
+
Post.stubs(:find).with("1").returns(@object)
|
12
|
+
|
13
|
+
@collection = mock()
|
14
|
+
Post.stubs(:find).with(:all).returns(@collection)
|
15
|
+
end
|
16
|
+
|
17
|
+
context "model helper" do
|
18
|
+
should "return constant" do
|
19
|
+
assert_equal Post, @controller.send(:model)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
context "collection helper" do
|
24
|
+
should "find all" do
|
25
|
+
assert_equal @collection, @controller.send(:collection)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
context "param helper" do
|
30
|
+
should "return the correct param" do
|
31
|
+
assert_equal "1", @controller.send(:param)
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
context "object helper" do
|
36
|
+
should "find the correct object" do
|
37
|
+
assert_equal @object, @controller.send(:object)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
context "load object helper" do
|
42
|
+
setup do
|
43
|
+
@controller.send(:load_object)
|
44
|
+
end
|
45
|
+
|
46
|
+
should "load object as instance variable" do
|
47
|
+
assert_equal @object, @controller.instance_variable_get("@post")
|
48
|
+
end
|
49
|
+
|
50
|
+
context "with an alternate object_name" do
|
51
|
+
setup do
|
52
|
+
@controller.stubs(:object_name).returns('asdf')
|
53
|
+
@controller.send(:load_object)
|
54
|
+
end
|
55
|
+
|
56
|
+
should "use the variable name" do
|
57
|
+
assert_equal @object, @controller.instance_variable_get("@asdf")
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
context "load_collection helper" do
|
63
|
+
context "with resource_name" do
|
64
|
+
setup do
|
65
|
+
@controller.send(:load_collection)
|
66
|
+
end
|
67
|
+
|
68
|
+
should "load collection in to instance variable with plural model_name" do
|
69
|
+
assert_equal @collection, @controller.instance_variable_get("@posts")
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
context "object params helper" do
|
75
|
+
context "without alternate variable name" do
|
76
|
+
setup do
|
77
|
+
@params.expects(:[]).with("post").returns(2)
|
78
|
+
end
|
79
|
+
|
80
|
+
should "get params for object" do
|
81
|
+
assert_equal 2, @controller.send(:object_params)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
context "with alternate object_name" do
|
86
|
+
setup do
|
87
|
+
@params.expects(:[]).with("something").returns(3)
|
88
|
+
@controller.expects(:object_name).returns("something")
|
89
|
+
end
|
90
|
+
|
91
|
+
should "use variable name" do
|
92
|
+
assert_equal 3, @controller.send(:object_params)
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
context "build object helper" do
|
98
|
+
context "with no parents" do
|
99
|
+
setup do
|
100
|
+
Post.expects(:new).with("1").returns("a new post")
|
101
|
+
end
|
102
|
+
|
103
|
+
should "build new object" do
|
104
|
+
assert_equal "a new post", @controller.send(:build_object)
|
105
|
+
end
|
106
|
+
end
|
107
|
+
|
108
|
+
context "with parent" do
|
109
|
+
setup do
|
110
|
+
@comments_controller = CommentsController.new
|
111
|
+
@comment_params = stub()
|
112
|
+
@comment_params.stubs(:[]).with(:post_id).returns 2
|
113
|
+
@comment_params.stubs(:[]).with('comment').returns ""
|
114
|
+
@comments_controller.stubs(:params).returns(@comment_params)
|
115
|
+
|
116
|
+
Post.expects(:find).with(2).returns(Post.new)
|
117
|
+
@comments = stub()
|
118
|
+
@comments.expects(:build).with("").returns("a new comment")
|
119
|
+
Post.any_instance.stubs(:comments).returns(@comments)
|
120
|
+
end
|
121
|
+
|
122
|
+
should "build new object" do
|
123
|
+
assert_equal "a new comment", @comments_controller.send(:build_object)
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
127
|
+
end
|