francois-shoulda 2.0.5.4 → 2.10.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.
- data/README.rdoc +60 -10
- data/Rakefile +7 -7
- data/lib/shoulda.rb +7 -15
- data/lib/shoulda/action_controller.rb +28 -0
- data/lib/shoulda/action_controller/helpers.rb +47 -0
- data/lib/shoulda/action_controller/macros.rb +277 -0
- data/lib/shoulda/action_controller/matchers.rb +37 -0
- data/lib/shoulda/action_controller/matchers/assign_to_matcher.rb +109 -0
- data/lib/shoulda/action_controller/matchers/filter_param_matcher.rb +57 -0
- data/lib/shoulda/action_controller/matchers/render_with_layout_matcher.rb +81 -0
- data/lib/shoulda/action_controller/matchers/respond_with_content_type_matcher.rb +70 -0
- data/lib/shoulda/action_controller/matchers/respond_with_matcher.rb +81 -0
- data/lib/shoulda/action_controller/matchers/route_matcher.rb +93 -0
- data/lib/shoulda/action_controller/matchers/set_session_matcher.rb +87 -0
- data/lib/shoulda/action_controller/matchers/set_the_flash_matcher.rb +85 -0
- data/lib/shoulda/action_mailer.rb +1 -1
- data/lib/shoulda/action_mailer/assertions.rb +32 -33
- data/lib/shoulda/action_view.rb +10 -0
- data/lib/shoulda/action_view/macros.rb +56 -0
- data/lib/shoulda/active_record.rb +6 -2
- data/lib/shoulda/active_record/assertions.rb +62 -89
- data/lib/shoulda/active_record/helpers.rb +40 -0
- data/lib/shoulda/active_record/macros.rb +520 -684
- data/lib/shoulda/active_record/matchers.rb +42 -0
- data/lib/shoulda/active_record/matchers/allow_mass_assignment_of_matcher.rb +83 -0
- data/lib/shoulda/active_record/matchers/allow_value_matcher.rb +102 -0
- data/lib/shoulda/active_record/matchers/association_matcher.rb +226 -0
- data/lib/shoulda/active_record/matchers/ensure_inclusion_of_matcher.rb +87 -0
- data/lib/shoulda/active_record/matchers/ensure_length_of_matcher.rb +141 -0
- data/lib/shoulda/active_record/matchers/have_db_column_matcher.rb +169 -0
- data/lib/shoulda/active_record/matchers/have_index_matcher.rb +105 -0
- data/lib/shoulda/active_record/matchers/have_named_scope_matcher.rb +125 -0
- data/lib/shoulda/active_record/matchers/have_readonly_attribute_matcher.rb +59 -0
- data/lib/shoulda/active_record/matchers/validate_acceptance_of_matcher.rb +41 -0
- data/lib/shoulda/active_record/matchers/validate_numericality_of_matcher.rb +39 -0
- data/lib/shoulda/active_record/matchers/validate_presence_of_matcher.rb +60 -0
- data/lib/shoulda/active_record/matchers/validate_uniqueness_of_matcher.rb +148 -0
- data/lib/shoulda/active_record/matchers/validation_matcher.rb +56 -0
- data/lib/shoulda/assertions.rb +50 -40
- data/lib/shoulda/autoload_macros.rb +46 -0
- data/lib/shoulda/context.rb +124 -126
- data/lib/shoulda/helpers.rb +5 -7
- data/lib/shoulda/macros.rb +63 -64
- data/lib/shoulda/private_helpers.rb +16 -18
- data/lib/shoulda/rails.rb +5 -11
- data/lib/shoulda/rspec.rb +11 -0
- data/lib/shoulda/tasks/list_tests.rake +6 -1
- data/lib/shoulda/test_unit.rb +19 -0
- data/rails/init.rb +7 -1
- data/test/README +2 -2
- data/test/fail_macros.rb +15 -15
- data/test/fixtures/tags.yml +1 -1
- data/test/functional/posts_controller_test.rb +46 -26
- data/test/functional/users_controller_test.rb +0 -19
- data/test/matchers/active_record/allow_mass_assignment_of_matcher_test.rb +68 -0
- data/test/matchers/active_record/allow_value_matcher_test.rb +41 -0
- data/test/matchers/active_record/association_matcher_test.rb +258 -0
- data/test/matchers/active_record/ensure_inclusion_of_matcher_test.rb +80 -0
- data/test/matchers/active_record/ensure_length_of_matcher_test.rb +158 -0
- data/test/matchers/active_record/have_db_column_matcher_test.rb +169 -0
- data/test/matchers/active_record/have_index_matcher_test.rb +74 -0
- data/test/matchers/active_record/have_named_scope_matcher_test.rb +65 -0
- data/test/matchers/active_record/have_readonly_attributes_matcher_test.rb +29 -0
- data/test/matchers/active_record/validate_acceptance_of_matcher_test.rb +44 -0
- data/test/matchers/active_record/validate_numericality_of_matcher_test.rb +52 -0
- data/test/matchers/active_record/validate_presence_of_matcher_test.rb +86 -0
- data/test/matchers/active_record/validate_uniqueness_of_matcher_test.rb +147 -0
- data/test/matchers/controller/assign_to_matcher_test.rb +35 -0
- data/test/matchers/controller/filter_param_matcher_test.rb +32 -0
- data/test/matchers/controller/render_with_layout_matcher_test.rb +33 -0
- data/test/matchers/controller/respond_with_content_type_matcher_test.rb +27 -0
- data/test/matchers/controller/respond_with_matcher_test.rb +106 -0
- data/test/matchers/controller/route_matcher_test.rb +58 -0
- data/test/matchers/controller/set_session_matcher_test.rb +31 -0
- data/test/matchers/controller/set_the_flash_matcher.rb +41 -0
- data/test/model_builder.rb +106 -0
- data/test/other/autoload_macro_test.rb +18 -0
- data/test/other/helpers_test.rb +58 -0
- data/test/other/private_helpers_test.rb +1 -1
- data/test/other/should_test.rb +16 -16
- data/test/rails_root/app/controllers/posts_controller.rb +6 -5
- data/test/rails_root/app/models/pets/dog.rb +10 -0
- data/test/rails_root/app/models/treat.rb +3 -0
- data/test/rails_root/app/models/user.rb +4 -3
- data/test/rails_root/app/views/layouts/posts.rhtml +2 -0
- data/test/rails_root/config/database.yml +1 -1
- data/test/rails_root/config/environment.rb +1 -1
- data/test/rails_root/config/environments/{sqlite3.rb → test.rb} +0 -0
- data/test/rails_root/db/migrate/001_create_users.rb +3 -2
- data/test/rails_root/db/migrate/011_create_treats.rb +12 -0
- data/test/rails_root/test/shoulda_macros/custom_macro.rb +6 -0
- data/test/rails_root/vendor/gems/gem_with_macro-0.0.1/shoulda_macros/gem_macro.rb +6 -0
- data/test/rails_root/vendor/plugins/plugin_with_macro/shoulda_macros/plugin_macro.rb +6 -0
- data/test/rspec_test.rb +207 -0
- data/test/test_helper.rb +3 -1
- data/test/unit/address_test.rb +1 -23
- data/test/unit/dog_test.rb +5 -2
- data/test/unit/post_test.rb +7 -3
- data/test/unit/product_test.rb +2 -2
- data/test/unit/tag_test.rb +2 -1
- data/test/unit/user_test.rb +25 -9
- metadata +84 -23
- data/lib/shoulda/controller.rb +0 -30
- data/lib/shoulda/controller/formats/html.rb +0 -201
- data/lib/shoulda/controller/formats/xml.rb +0 -170
- data/lib/shoulda/controller/helpers.rb +0 -64
- data/lib/shoulda/controller/macros.rb +0 -316
- data/lib/shoulda/controller/resource_options.rb +0 -236
- data/test/rails_root/app/models/dog.rb +0 -5
data/lib/shoulda/helpers.rb
CHANGED
@@ -1,10 +1,8 @@
|
|
1
|
-
module
|
2
|
-
module
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
puts("#{caller.first}: #{msg}")
|
7
|
-
end
|
1
|
+
module Shoulda # :nodoc:
|
2
|
+
module Helpers
|
3
|
+
# Prints a message to stdout, tagged with the name of the calling method.
|
4
|
+
def report!(msg = "")
|
5
|
+
puts("#{caller.first}: #{msg}")
|
8
6
|
end
|
9
7
|
end
|
10
8
|
end
|
data/lib/shoulda/macros.rb
CHANGED
@@ -1,74 +1,73 @@
|
|
1
1
|
require 'shoulda/private_helpers'
|
2
2
|
|
3
|
-
module
|
4
|
-
module
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
stmt << " by #{by.inspect}" if by
|
3
|
+
module Shoulda # :nodoc:
|
4
|
+
module Macros
|
5
|
+
# Macro that creates a test asserting a change between the return value
|
6
|
+
# of an expression that is run before and after the current setup block
|
7
|
+
# is run. This is similar to Active Support's <tt>assert_difference</tt>
|
8
|
+
# assertion, but supports more than just numeric values. See also
|
9
|
+
# should_not_change.
|
10
|
+
#
|
11
|
+
# Example:
|
12
|
+
#
|
13
|
+
# context "Creating a post" do
|
14
|
+
# setup { Post.create }
|
15
|
+
# should_change "Post.count", :by => 1
|
16
|
+
# end
|
17
|
+
#
|
18
|
+
# As shown in this example, the <tt>:by</tt> option expects a numeric
|
19
|
+
# difference between the before and after values of the expression. You
|
20
|
+
# may also specify <tt>:from</tt> and <tt>:to</tt> options:
|
21
|
+
#
|
22
|
+
# should_change "Post.count", :from => 0, :to => 1
|
23
|
+
# should_change "@post.title", :from => "old", :to => "new"
|
24
|
+
#
|
25
|
+
# Combinations of <tt>:by</tt>, <tt>:from</tt>, and <tt>:to</tt> are allowed:
|
26
|
+
#
|
27
|
+
# should_change "@post.title" # => assert the value changed in some way
|
28
|
+
# should_change "@post.title", :from => "old" # => assert the value changed to anything other than "old"
|
29
|
+
# should_change "@post.title", :to => "new" # => assert the value changed from anything other than "new"
|
30
|
+
def should_change(expression, options = {})
|
31
|
+
by, from, to = get_options!([options], :by, :from, :to)
|
32
|
+
stmt = "change #{expression.inspect}"
|
33
|
+
stmt << " from #{from.inspect}" if from
|
34
|
+
stmt << " to #{to.inspect}" if to
|
35
|
+
stmt << " by #{by.inspect}" if by
|
37
36
|
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
end
|
37
|
+
expression_eval = lambda { eval(expression) }
|
38
|
+
before = lambda { @_before_should_change = expression_eval.bind(self).call }
|
39
|
+
should stmt, :before => before do
|
40
|
+
old_value = @_before_should_change
|
41
|
+
new_value = expression_eval.bind(self).call
|
42
|
+
assert_operator from, :===, old_value, "#{expression.inspect} did not originally match #{from.inspect}" if from
|
43
|
+
assert_not_equal old_value, new_value, "#{expression.inspect} did not change" unless by == 0
|
44
|
+
assert_operator to, :===, new_value, "#{expression.inspect} was not changed to match #{to.inspect}" if to
|
45
|
+
assert_equal old_value + by, new_value if by
|
48
46
|
end
|
47
|
+
end
|
49
48
|
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
end
|
49
|
+
# Macro that creates a test asserting no change between the return value
|
50
|
+
# of an expression that is run before and after the current setup block
|
51
|
+
# is run. This is the logical opposite of should_change.
|
52
|
+
#
|
53
|
+
# Example:
|
54
|
+
#
|
55
|
+
# context "Updating a post" do
|
56
|
+
# setup { @post.update_attributes(:title => "new") }
|
57
|
+
# should_not_change "Post.count"
|
58
|
+
# end
|
59
|
+
def should_not_change(expression)
|
60
|
+
expression_eval = lambda { eval(expression) }
|
61
|
+
before = lambda { @_before_should_not_change = expression_eval.bind(self).call }
|
62
|
+
should "not change #{expression.inspect}", :before => before do
|
63
|
+
new_value = expression_eval.bind(self).call
|
64
|
+
assert_equal @_before_should_not_change, new_value, "#{expression.inspect} changed"
|
67
65
|
end
|
66
|
+
end
|
68
67
|
|
69
|
-
|
68
|
+
private
|
70
69
|
|
71
|
-
|
72
|
-
end
|
70
|
+
include Shoulda::Private
|
73
71
|
end
|
74
72
|
end
|
73
|
+
|
@@ -1,22 +1,20 @@
|
|
1
|
-
module
|
2
|
-
module
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
end
|
1
|
+
module Shoulda # :nodoc:
|
2
|
+
module Private # :nodoc:
|
3
|
+
# Returns the values for the entries in the args hash who's keys are listed in the wanted array.
|
4
|
+
# Will raise if there are keys in the args hash that aren't listed.
|
5
|
+
def get_options!(args, *wanted)
|
6
|
+
ret = []
|
7
|
+
opts = (args.last.is_a?(Hash) ? args.pop : {})
|
8
|
+
wanted.each {|w| ret << opts.delete(w)}
|
9
|
+
raise ArgumentError, "Unsupported options given: #{opts.keys.join(', ')}" unless opts.keys.empty?
|
10
|
+
return *ret
|
11
|
+
end
|
13
12
|
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
end
|
13
|
+
# Returns the model class constant, as determined by the test class name.
|
14
|
+
#
|
15
|
+
# class TestUser; model_class; end => User
|
16
|
+
def model_class
|
17
|
+
self.name.gsub(/Test$/, '').constantize
|
20
18
|
end
|
21
19
|
end
|
22
20
|
end
|
data/lib/shoulda/rails.rb
CHANGED
@@ -2,18 +2,12 @@ require 'rubygems'
|
|
2
2
|
require 'active_support'
|
3
3
|
require 'shoulda'
|
4
4
|
|
5
|
-
require 'shoulda/active_record'
|
6
|
-
require 'shoulda/
|
7
|
-
require 'shoulda/
|
5
|
+
require 'shoulda/active_record' if defined? ActiveRecord::Base
|
6
|
+
require 'shoulda/action_controller' if defined? ActionController::Base
|
7
|
+
require 'shoulda/action_view' if defined? ActionView::Base
|
8
|
+
require 'shoulda/action_mailer' if defined? ActionMailer::Base
|
8
9
|
|
9
10
|
if defined?(RAILS_ROOT)
|
10
11
|
# load in the 3rd party macros from vendorized plugins and gems
|
11
|
-
|
12
|
-
require macro_file_path
|
13
|
-
end
|
14
|
-
|
15
|
-
# load in the local application specific macros
|
16
|
-
Dir[File.join(RAILS_ROOT, "test", "shoulda_macros", "*.rb")].each do |macro_file_path|
|
17
|
-
require macro_file_path
|
18
|
-
end
|
12
|
+
Shoulda.autoload_macros RAILS_ROOT, File.join("vendor", "{plugins,gems}", "*")
|
19
13
|
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
require 'shoulda/active_record/matchers'
|
2
|
+
require 'shoulda/action_controller/matchers'
|
3
|
+
require 'active_support/test_case'
|
4
|
+
|
5
|
+
# :enddoc:
|
6
|
+
module ActiveSupport
|
7
|
+
class TestCase
|
8
|
+
include Shoulda::ActiveRecord::Matchers
|
9
|
+
include Shoulda::ActionController::Matchers
|
10
|
+
end
|
11
|
+
end
|
@@ -13,7 +13,12 @@ namespace :shoulda do
|
|
13
13
|
test_files = Dir.glob(File.join('test', '**', '*_test.rb'))
|
14
14
|
test_files.each do |file|
|
15
15
|
load file
|
16
|
-
klass = File.basename(file, '.rb').classify
|
16
|
+
klass = File.basename(file, '.rb').classify
|
17
|
+
unless Object.const_defined?(klass.to_s)
|
18
|
+
puts "Skipping #{klass} because it doesn't map to a Class"
|
19
|
+
next
|
20
|
+
end
|
21
|
+
klass = klass.constantize
|
17
22
|
|
18
23
|
puts klass.name.gsub('Test', '')
|
19
24
|
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require 'shoulda/context'
|
2
|
+
require 'shoulda/proc_extensions'
|
3
|
+
require 'shoulda/assertions'
|
4
|
+
require 'shoulda/macros'
|
5
|
+
require 'shoulda/helpers'
|
6
|
+
require 'shoulda/autoload_macros'
|
7
|
+
require 'shoulda/rails' if defined? RAILS_ROOT
|
8
|
+
|
9
|
+
module Test # :nodoc: all
|
10
|
+
module Unit
|
11
|
+
class TestCase
|
12
|
+
extend Shoulda::ClassMethods
|
13
|
+
include Shoulda::Assertions
|
14
|
+
extend Shoulda::Macros
|
15
|
+
include Shoulda::Helpers
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
data/rails/init.rb
CHANGED
data/test/README
CHANGED
@@ -6,7 +6,7 @@ The test directory contains the following files and subdirectories:
|
|
6
6
|
|
7
7
|
* rails_root - contains the stripped down rails application that the tests run against. The rails root contains:
|
8
8
|
** the models, controllers, and views defined under app/
|
9
|
-
** the
|
9
|
+
** the test.rb environment file
|
10
10
|
** a migration file for each model
|
11
11
|
** a shoulda initializer that simulates loading the plugin but without relying on vendor/plugins
|
12
12
|
* fixtures - contain the sample DB data for each model
|
@@ -14,7 +14,7 @@ The test directory contains the following files and subdirectories:
|
|
14
14
|
* unit - model tests for each of the models under rails_root/app
|
15
15
|
* other - tests for the shoulda contexts, should statements, and assertions
|
16
16
|
* test_helper.rb - responsible for initializing the test environment
|
17
|
-
** sets the rails_env to
|
17
|
+
** sets the rails_env to test
|
18
18
|
** sets the rails_root
|
19
19
|
** runs all the migrations against the in-memory sqlite3 db
|
20
20
|
** adds some magic to load the right fixture files
|
data/test/fail_macros.rb
CHANGED
@@ -1,14 +1,14 @@
|
|
1
|
-
module
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
end
|
1
|
+
module Shoulda
|
2
|
+
class << self
|
3
|
+
attr_accessor :expected_exceptions
|
4
|
+
end
|
6
5
|
|
6
|
+
module ClassMethods
|
7
7
|
# Enables the core shoulda test suite to test for failure scenarios. For
|
8
8
|
# example, to ensure that a set of test macros should fail, do this:
|
9
9
|
#
|
10
10
|
# should_fail do
|
11
|
-
#
|
11
|
+
# should_validate_presence_of :comments
|
12
12
|
# should_not_allow_mass_assignment_of :name
|
13
13
|
# end
|
14
14
|
def should_fail(&block)
|
@@ -18,17 +18,17 @@ module Thoughtbot
|
|
18
18
|
Shoulda.expected_exceptions = nil
|
19
19
|
end
|
20
20
|
end
|
21
|
+
end
|
21
22
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
end
|
29
|
-
should_without_failure_scenario(name, options, &(failure_block || block))
|
23
|
+
class Context
|
24
|
+
# alias_method_chain hack to allow the should_fail macro to work
|
25
|
+
def should_with_failure_scenario(name, options = {}, &block)
|
26
|
+
if Shoulda.expected_exceptions
|
27
|
+
expected_exceptions = Shoulda.expected_exceptions
|
28
|
+
failure_block = lambda { assert_raise(*expected_exceptions, &block.bind(self)) }
|
30
29
|
end
|
31
|
-
|
30
|
+
should_without_failure_scenario(name, options, &(failure_block || block))
|
32
31
|
end
|
32
|
+
alias_method_chain :should, :failure_scenario
|
33
33
|
end
|
34
34
|
end
|
data/test/fixtures/tags.yml
CHANGED
@@ -13,7 +13,7 @@ class PostsControllerTest < Test::Unit::TestCase
|
|
13
13
|
@response = ActionController::TestResponse.new
|
14
14
|
@post = Post.find(:first)
|
15
15
|
end
|
16
|
-
|
16
|
+
|
17
17
|
# autodetects the :controller
|
18
18
|
should_route :get, '/posts', :action => :index
|
19
19
|
# explicitly specify :controller
|
@@ -24,7 +24,7 @@ class PostsControllerTest < Test::Unit::TestCase
|
|
24
24
|
should_route :put, '/posts/1', :action => :update, :id => "1"
|
25
25
|
should_route :delete, '/posts/1', :action => :destroy, :id => 1
|
26
26
|
should_route :get, '/posts/new', :action => :new
|
27
|
-
|
27
|
+
|
28
28
|
# Test the nested routes
|
29
29
|
should_route :get, '/users/5/posts', :action => :index, :user_id => 5
|
30
30
|
should_route :post, '/users/5/posts', :action => :create, :user_id => 5
|
@@ -33,46 +33,31 @@ class PostsControllerTest < Test::Unit::TestCase
|
|
33
33
|
should_route :get, '/users/5/posts/new', :action => :new, :user_id => 5
|
34
34
|
should_route :put, '/users/5/posts/1', :action => :update, :id => 1, :user_id => 5
|
35
35
|
|
36
|
-
context "The public" do
|
37
|
-
setup do
|
38
|
-
@request.session[:logged_in] = false
|
39
|
-
end
|
40
|
-
|
41
|
-
should_be_restful do |resource|
|
42
|
-
resource.parent = :user
|
43
|
-
|
44
|
-
resource.denied.actions = [:index, :show, :edit, :new, :create, :update, :destroy]
|
45
|
-
resource.denied.flash = /what/i
|
46
|
-
resource.denied.redirect = '"/"'
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
36
|
context "Logged in" do
|
51
37
|
setup do
|
52
38
|
@request.session[:logged_in] = true
|
53
39
|
end
|
54
40
|
|
55
|
-
should_be_restful do |resource|
|
56
|
-
resource.parent = :user
|
57
|
-
|
58
|
-
resource.create.params = { :title => "first post", :body => 'blah blah blah'}
|
59
|
-
resource.update.params = { :title => "changed" }
|
60
|
-
end
|
61
|
-
|
62
41
|
context "viewing posts for a user" do
|
63
42
|
setup do
|
64
43
|
get :index, :user_id => users(:first)
|
65
44
|
end
|
66
45
|
should_respond_with :success
|
67
46
|
should_assign_to :user, :class => User, :equals => 'users(:first)'
|
47
|
+
should_assign_to(:user) { users(:first) }
|
68
48
|
should_fail do
|
69
49
|
should_assign_to :user, :class => Post
|
70
50
|
end
|
71
51
|
should_fail do
|
72
52
|
should_assign_to :user, :equals => 'posts(:first)'
|
73
53
|
end
|
54
|
+
should_fail do
|
55
|
+
should_assign_to(:user) { posts(:first) }
|
56
|
+
end
|
74
57
|
should_assign_to :posts
|
75
58
|
should_not_assign_to :foo, :bar
|
59
|
+
should_render_page_with_metadata :description => /Posts/, :title => /index/
|
60
|
+
should_render_page_with_metadata :keywords => "posts"
|
76
61
|
end
|
77
62
|
|
78
63
|
context "viewing posts for a user with rss format" do
|
@@ -84,8 +69,22 @@ class PostsControllerTest < Test::Unit::TestCase
|
|
84
69
|
should_respond_with_content_type 'application/rss+xml'
|
85
70
|
should_respond_with_content_type :rss
|
86
71
|
should_respond_with_content_type /rss/
|
87
|
-
|
88
|
-
|
72
|
+
context "deprecated" do # to avoid redefining a test
|
73
|
+
should_return_from_session :special, "'$2 off your next purchase'"
|
74
|
+
end
|
75
|
+
should_fail do
|
76
|
+
should_return_from_session :special, "'not special'"
|
77
|
+
end
|
78
|
+
should_set_session(:mischief) { nil }
|
79
|
+
should_return_from_session :malarky, "nil"
|
80
|
+
should_set_session :special, "'$2 off your next purchase'"
|
81
|
+
should_set_session :special_user_id, '@user.id'
|
82
|
+
context "with a block" do
|
83
|
+
should_set_session(:special_user_id) { @user.id }
|
84
|
+
end
|
85
|
+
should_fail do # to avoid redefining a test
|
86
|
+
should_set_session(:special_user_id) { 'value' }
|
87
|
+
end
|
89
88
|
should_assign_to :user, :posts
|
90
89
|
should_not_assign_to :foo, :bar
|
91
90
|
end
|
@@ -93,13 +92,34 @@ class PostsControllerTest < Test::Unit::TestCase
|
|
93
92
|
context "viewing a post on GET to #show" do
|
94
93
|
setup { get :show, :user_id => users(:first), :id => posts(:first) }
|
95
94
|
should_render_with_layout 'wide'
|
96
|
-
|
95
|
+
context "with a symbol" do # to avoid redefining a test
|
96
|
+
should_render_with_layout :wide
|
97
|
+
end
|
98
|
+
should_assign_to :false_flag
|
97
99
|
end
|
98
100
|
|
99
101
|
context "on GET to #new" do
|
100
102
|
setup { get :new, :user_id => users(:first) }
|
101
103
|
should_render_without_layout
|
102
104
|
end
|
105
|
+
|
106
|
+
context "on POST to #create" do
|
107
|
+
setup do
|
108
|
+
post :create, :user_id => users(:first),
|
109
|
+
:post => { :title => "first post",
|
110
|
+
:body => 'blah blah blah' }
|
111
|
+
end
|
112
|
+
|
113
|
+
should_redirect_to 'user_post_url(@post.user, @post)'
|
114
|
+
should_redirect_to('the created post') { user_post_url(users(:first),
|
115
|
+
assigns(:post)) }
|
116
|
+
should_fail do
|
117
|
+
should_redirect_to 'user_posts_url(@post.user)'
|
118
|
+
end
|
119
|
+
should_fail do
|
120
|
+
should_redirect_to('elsewhere') { user_posts_url(users(:first)) }
|
121
|
+
end
|
122
|
+
end
|
103
123
|
end
|
104
124
|
|
105
125
|
end
|