hardbap-coulda 0.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (46) hide show
  1. data/LICENSE +21 -0
  2. data/README.markdown +128 -0
  3. data/Rakefile +27 -0
  4. data/TODO +3 -0
  5. data/VERSION.yml +4 -0
  6. data/generators/coulda_model/USAGE +27 -0
  7. data/generators/coulda_model/coulda_model_generator.rb +65 -0
  8. data/generators/coulda_model/templates/factory.rb +5 -0
  9. data/generators/coulda_model/templates/migration.rb +23 -0
  10. data/generators/coulda_model/templates/model.rb +5 -0
  11. data/generators/coulda_model/templates/unit_test.rb +12 -0
  12. data/generators/coulda_scaffold/USAGE +25 -0
  13. data/generators/coulda_scaffold/coulda_scaffold_generator.rb +107 -0
  14. data/generators/coulda_scaffold/templates/controller.rb +72 -0
  15. data/generators/coulda_scaffold/templates/functional_test/shoulda_controller.rb +67 -0
  16. data/generators/coulda_scaffold/templates/helper.rb +2 -0
  17. data/generators/coulda_scaffold/templates/helper_test.rb +5 -0
  18. data/generators/coulda_scaffold/templates/view/_form.html.erb +8 -0
  19. data/generators/coulda_scaffold/templates/view/edit.html.erb +12 -0
  20. data/generators/coulda_scaffold/templates/view/index.html.erb +22 -0
  21. data/generators/coulda_scaffold/templates/view/new.html.erb +8 -0
  22. data/generators/coulda_scaffold/templates/view/show.html.erb +12 -0
  23. data/lib/coulda.rb +0 -0
  24. data/test/fixtures/about_yml_plugins/bad_about_yml/about.yml +1 -0
  25. data/test/fixtures/about_yml_plugins/bad_about_yml/init.rb +1 -0
  26. data/test/fixtures/about_yml_plugins/plugin_without_about_yml/init.rb +1 -0
  27. data/test/fixtures/eager/zoo.rb +3 -0
  28. data/test/fixtures/eager/zoo/reptile_house.rb +2 -0
  29. data/test/fixtures/environment_with_constant.rb +1 -0
  30. data/test/fixtures/lib/generators/missing_class/missing_class_generator.rb +0 -0
  31. data/test/fixtures/lib/generators/working/working_generator.rb +2 -0
  32. data/test/fixtures/plugins/alternate/a/generators/a_generator/a_generator.rb +4 -0
  33. data/test/fixtures/plugins/default/gemlike/init.rb +1 -0
  34. data/test/fixtures/plugins/default/gemlike/lib/gemlike.rb +2 -0
  35. data/test/fixtures/plugins/default/gemlike/rails/init.rb +7 -0
  36. data/test/fixtures/plugins/default/plugin_with_no_lib_dir/init.rb +0 -0
  37. data/test/fixtures/plugins/default/stubby/about.yml +2 -0
  38. data/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb +4 -0
  39. data/test/fixtures/plugins/default/stubby/init.rb +7 -0
  40. data/test/fixtures/plugins/default/stubby/lib/stubby_mixin.rb +2 -0
  41. data/test/fixtures/tmp/test.log +1 -0
  42. data/test/rails_generators/coulda_model_generator_test.rb +39 -0
  43. data/test/shoulda_macros/generator_macros.rb +36 -0
  44. data/test/stolen_from_railties.rb +288 -0
  45. data/test/test_helper.rb +41 -0
  46. metadata +140 -0
@@ -0,0 +1,72 @@
1
+ class <%= controller_class_name %>Controller < ApplicationController
2
+ def index
3
+ @<%= table_name %> = <%= class_name %>.find :all
4
+
5
+ respond_to do |format|
6
+ format.html
7
+ format.xml { render :xml => @<%= table_name %> }
8
+ end
9
+ end
10
+
11
+ def show
12
+ @<%= file_name %> = <%= class_name %>.find params[:id]
13
+
14
+ respond_to do |format|
15
+ format.html
16
+ format.xml { render :xml => @<%= file_name %> }
17
+ end
18
+ end
19
+
20
+ def new
21
+ @<%= file_name %> = <%= class_name %>.new
22
+
23
+ respond_to do |format|
24
+ format.html
25
+ format.xml { render :xml => @<%= file_name %> }
26
+ end
27
+ end
28
+
29
+ def edit
30
+ @<%= file_name %> = <%= class_name %>.find params[:id]
31
+ end
32
+
33
+ def create
34
+ @<%= file_name %> = <%= class_name %>.new params[:<%= file_name %>]
35
+
36
+ respond_to do |format|
37
+ if @<%= file_name %>.save
38
+ flash[:notice] = '<%= class_name %> was successfully created.'
39
+ format.html { redirect_to(@<%= file_name %>) }
40
+ format.xml { render :xml => @<%= file_name %>, :status => :created, :location => @<%= file_name %> }
41
+ else
42
+ format.html { render :action => "new" }
43
+ format.xml { render :xml => @<%= file_name %>.errors, :status => :unprocessable_entity }
44
+ end
45
+ end
46
+ end
47
+
48
+ def update
49
+ @<%= file_name %> = <%= class_name %>.find params[:id]
50
+
51
+ respond_to do |format|
52
+ if @<%= file_name %>.update_attributes(params[:<%= file_name %>])
53
+ flash[:notice] = '<%= class_name %> was successfully updated.'
54
+ format.html { redirect_to(@<%= file_name %>) }
55
+ format.xml { head :ok }
56
+ else
57
+ format.html { render :action => "edit" }
58
+ format.xml { render :xml => @<%= file_name %>.errors, :status => :unprocessable_entity }
59
+ end
60
+ end
61
+ end
62
+
63
+ def destroy
64
+ @<%= file_name %> = <%= class_name %>.find params[:id]
65
+ @<%= file_name %>.destroy
66
+
67
+ respond_to do |format|
68
+ format.html { redirect_to(<%= table_name %>_url) }
69
+ format.xml { head :ok }
70
+ end
71
+ end
72
+ end
@@ -0,0 +1,67 @@
1
+ require File.dirname(__FILE__) + '/../test_helper'
2
+
3
+ class <%= controller_class_name %>ControllerTest < ActionController::TestCase
4
+ context "GET to index" do
5
+ setup { get :index }
6
+
7
+ should_respond_with :success
8
+ should_assign_to :<%= table_name %>
9
+ end
10
+
11
+ context "GET to new" do
12
+ setup { get :new }
13
+
14
+ should_respond_with :success
15
+ should_render_template :new
16
+ should_assign_to :<%= file_name %>
17
+ end
18
+
19
+ context 'POST to create' do
20
+ setup do
21
+ post :create, :<%= file_name %> => Factory.attributes_for(:<%= file_name %>)
22
+ @<%= file_name %> = <%= class_name %>.find(:all).last
23
+ end
24
+
25
+ should_redirect_to '<%= file_name %>_path(@<%= file_name %>)'
26
+ end
27
+
28
+ context 'GET to show' do
29
+ setup do
30
+ @<%= file_name %> = Factory(:<%= file_name %>)
31
+ get :show, :id => @<%= file_name %>.id
32
+ end
33
+
34
+ should_respond_with :success
35
+ should_render_template :show
36
+ should_assign_to :<%= file_name %>
37
+ end
38
+
39
+ context 'GET to edit' do
40
+ setup do
41
+ @<%= file_name %> = Factory(:<%= file_name %>)
42
+ get :edit, :id => @<%= file_name %>.id
43
+ end
44
+
45
+ should_respond_with :success
46
+ should_render_template :edit
47
+ should_assign_to :<%= file_name %>
48
+ end
49
+
50
+ context 'PUT to update' do
51
+ setup do
52
+ @<%= file_name %> = Factory(:<%= file_name %>)
53
+ put :update, :id => @<%= file_name %>.id, :<%= file_name %> => Factory.attributes_for(:<%= file_name %>)
54
+ end
55
+
56
+ should_redirect_to '<%= file_name %>_path(@<%= file_name %>)'
57
+ end
58
+
59
+ context 'DELETE to destroy' do
60
+ setup do
61
+ @<%= file_name %> = Factory(:<%= file_name %>)
62
+ delete :destroy, :id => @<%= file_name %>.id
63
+ end
64
+
65
+ should_redirect_to '<%= table_name %>_path'
66
+ end
67
+ end
@@ -0,0 +1,2 @@
1
+ module <%= controller_class_name %>Helper
2
+ end
@@ -0,0 +1,5 @@
1
+ require File.dirname(__FILE__) + '/../../test_helper'
2
+ require 'action_view/test_case'
3
+
4
+ class <%= controller_class_name %>HelperTest < ActionView::TestCase
5
+ end
@@ -0,0 +1,8 @@
1
+ <%%= form.error_messages %>
2
+
3
+ <dl>
4
+ <% for attribute in attributes -%>
5
+ <dt><%%= form.label :<%= attribute.name %> %></dt>
6
+ <dd><%%= form.<%= attribute.field_type %> :<%= attribute.name %> %></dd>
7
+ <% end -%>
8
+ </dl>
@@ -0,0 +1,12 @@
1
+ <h1>Editing <%= singular_name %></h1>
2
+
3
+ <%% form_for(@<%= singular_name %>) do |form| %>
4
+ <%%= render :partial => 'form', :locals => {:form => form} %>
5
+ <p><%%= form.submit 'Update' %></p>
6
+ <%% end %>
7
+
8
+ <p>
9
+ <%%= link_to 'Show', @<%= singular_name %> %>
10
+ |
11
+ <%%= link_to 'Back', <%= plural_name %>_path %>
12
+ </p>
@@ -0,0 +1,22 @@
1
+ <h1><%= plural_name %></h1>
2
+
3
+ <table>
4
+ <tr>
5
+ <% attributes.each do |attribute| -%>
6
+ <th><%= attribute.column.human_name %></th>
7
+ <% end -%>
8
+ </tr>
9
+
10
+ <%% @<%= plural_name %>.each do |<%= singular_name %>| %>
11
+ <tr>
12
+ <% attributes.each do |attribute| -%>
13
+ <td><%%= h <%= singular_name %>.<%= attribute.name %> %></td>
14
+ <% end -%>
15
+ <td><%%= link_to 'Show', <%= singular_name %> %></td>
16
+ <td><%%= link_to 'Edit', edit_<%= singular_name %>_path(<%= singular_name %>) %></td>
17
+ <td><%%= link_to 'Destroy', <%= singular_name %>, :confirm => 'Are you sure?', :method => :delete %></td>
18
+ </tr>
19
+ <%% end %>
20
+ </table>
21
+
22
+ <p><%%= link_to 'New <%= singular_name %>', new_<%= singular_name %>_path %></p>
@@ -0,0 +1,8 @@
1
+ <h1>New <%= singular_name %></h1>
2
+
3
+ <%% form_for(@<%= singular_name %>) do |form| %>
4
+ <%%= render :partial => 'form', :locals => {:form => form} %>
5
+ <p><%%= form.submit 'Create' %></p>
6
+ <%% end %>
7
+
8
+ <p><%%= link_to 'Back', <%= plural_name %>_path %></p>
@@ -0,0 +1,12 @@
1
+ <dl>
2
+ <% for attribute in attributes -%>
3
+ <dt><%= attribute.column.human_name %></dt>
4
+ <dd><%%= h @<%= singular_name %>.<%= attribute.name %> %></dd>
5
+ <% end -%>
6
+ </dl>
7
+
8
+ <p>
9
+ <%%= link_to 'Edit', edit_<%= singular_name %>_path(@<%= singular_name %>)%>
10
+ |
11
+ <%%= link_to 'Back', <%= plural_name %>_path %>
12
+ </p>
data/lib/coulda.rb ADDED
File without changes
@@ -0,0 +1 @@
1
+ # an empty YAML file - any content in here seems to get parsed as a string
@@ -0,0 +1 @@
1
+ # intentionally empty
@@ -0,0 +1 @@
1
+ # intentionally empty
@@ -0,0 +1,3 @@
1
+ class Zoo
2
+ include ReptileHouse
3
+ end
@@ -0,0 +1,2 @@
1
+ module Zoo::ReptileHouse
2
+ end
@@ -0,0 +1 @@
1
+ $initialize_test_set_from_env = 'success'
@@ -0,0 +1,2 @@
1
+ class WorkingGenerator < Rails::Generator::NamedBase
2
+ end
@@ -0,0 +1,4 @@
1
+ class AGenerator < Rails::Generator::Base
2
+ def manifest
3
+ end
4
+ end
@@ -0,0 +1 @@
1
+ raise 'This init.rb should not be evaluated because rails/init.rb exists'
@@ -0,0 +1,2 @@
1
+ module Gemlike
2
+ end
@@ -0,0 +1,7 @@
1
+ # I have access to my directory and the Rails config.
2
+ raise 'directory expected but undefined in init.rb' unless defined? directory
3
+ raise 'config expected but undefined in init.rb' unless defined? config
4
+
5
+ # My lib/ dir must be in the load path.
6
+ require 'gemlike'
7
+ raise 'missing mixin from my lib/ dir' unless defined? Gemlike
@@ -0,0 +1,2 @@
1
+ author: Plugin Author
2
+ version: 1.0.0
@@ -0,0 +1,4 @@
1
+ class StubbyGenerator < Rails::Generator::Base
2
+ def manifest
3
+ end
4
+ end
@@ -0,0 +1,7 @@
1
+ # I have access to my directory and the Rails config.
2
+ raise 'directory expected but undefined in init.rb' unless defined? directory
3
+ raise 'config expected but undefined in init.rb' unless defined? config
4
+
5
+ # My lib/ dir must be in the load path.
6
+ require 'stubby_mixin'
7
+ raise 'missing mixin from my lib/ dir' unless defined? StubbyMixin
@@ -0,0 +1,2 @@
1
+ module StubbyMixin
2
+ end
@@ -0,0 +1 @@
1
+ # Logfile created on Sun Dec 21 18:56:50 -0500 2008 by /
@@ -0,0 +1,39 @@
1
+ require File.join(File.dirname(__FILE__), '..', 'test_helper')
2
+
3
+
4
+ class CouldaModelGeneratorTest < GeneratorTestCase
5
+ context "running the default generator" do
6
+ setup do
7
+ run_generator('coulda_model', %w(Product name:string supplier_id:integer created_at:timestamp))
8
+ end
9
+
10
+ should_generate_model :product
11
+ should_generate_factory :product
12
+ should_generate_unit_test :product
13
+ should_generate_migration :create_products
14
+
15
+ should "generate migration" do
16
+ assert_generated_migration :create_products do |t|
17
+ assert_generated_column t, :name, :string
18
+ assert_generated_column t, :supplier_id, :integer
19
+ assert_generated_column t, :created_at, :timestamp
20
+ end
21
+ end
22
+ end
23
+
24
+ context "running the generator, when skipping factory and migration" do
25
+ setup do
26
+ run_generator('coulda_model', %w(Product name:string supplier_id:integer created_at:timestamp --skip-factory))
27
+ end
28
+
29
+ should_generate_model :product
30
+ should_not_generate_factory :product
31
+ should_generate_unit_test :product
32
+ should_generate_migration :create_products
33
+
34
+ should "not generate migration" do
35
+ assert_skipped_migration :create_products
36
+ end
37
+ end
38
+
39
+ end
@@ -0,0 +1,36 @@
1
+ class Test::Unit::TestCase
2
+ class << self
3
+ def should_generate_model(model)
4
+ should "generate #{model} model" do
5
+ assert_generated_model_for(model) do |body|
6
+ yield body if block_given?
7
+ end
8
+ end
9
+ end
10
+
11
+ def should_generate_factory(model)
12
+ should "generate #{model} factory" do
13
+ assert_generated_factory_for(model)
14
+ end
15
+ end
16
+
17
+ def should_generate_unit_test(model)
18
+ should "generate #{model} unit test" do
19
+ assert_generated_unit_test_for(model)
20
+ end
21
+ end
22
+
23
+ def should_generate_migration(migration)
24
+ should "generate a #{migration} migration" do
25
+ assert_generated_migration migration
26
+ end
27
+ end
28
+
29
+ def should_not_generate_factory(model)
30
+ should "not generate #{model} factory" do
31
+ deny_generated_factory_for(:product)
32
+ end
33
+ end
34
+
35
+ end
36
+ end
@@ -0,0 +1,288 @@
1
+ require 'test/unit'
2
+ require 'fileutils'
3
+
4
+ # Mock out what we need from AR::Base
5
+ module ActiveRecord
6
+ class Base
7
+ class << self
8
+ attr_accessor :pluralize_table_names, :timestamped_migrations
9
+ end
10
+ self.pluralize_table_names = true
11
+ self.timestamped_migrations = true
12
+ end
13
+
14
+ module ConnectionAdapters
15
+ class Column
16
+ attr_reader :name, :default, :type, :limit, :null, :sql_type, :precision, :scale
17
+
18
+ def initialize(name, default, sql_type = nil)
19
+ @name = name
20
+ @default = default
21
+ @type = @sql_type = sql_type
22
+ end
23
+
24
+ def human_name
25
+ @name.humanize
26
+ end
27
+ end
28
+ end
29
+ end
30
+
31
+ # Mock up necessities from ActionView
32
+ module ActionView
33
+ module Helpers
34
+ module ActionRecordHelper; end
35
+ class InstanceTag; end
36
+ end
37
+ end
38
+
39
+ # Set RAILS_ROOT appropriately fixture generation
40
+ tmp_dir = "#{File.dirname(__FILE__)}/fixtures/tmp"
41
+
42
+ if defined? RAILS_ROOT
43
+ RAILS_ROOT.replace tmp_dir
44
+ else
45
+ RAILS_ROOT = tmp_dir
46
+ end
47
+ FileUtils.mkdir_p RAILS_ROOT
48
+
49
+ # $LOAD_PATH.unshift "#{File.dirname(__FILE__)}/../../lib"
50
+ require 'initializer'
51
+
52
+ # Mocks out the configuration
53
+ module Rails
54
+ def self.configuration
55
+ Rails::Configuration.new
56
+ end
57
+ end
58
+
59
+ require 'rails_generator'
60
+
61
+ class GeneratorTestCase < Test::Unit::TestCase
62
+ include FileUtils
63
+
64
+ def setup
65
+ ActiveRecord::Base.pluralize_table_names = true
66
+
67
+ mkdir_p "#{RAILS_ROOT}/app/views/layouts"
68
+ mkdir_p "#{RAILS_ROOT}/config"
69
+ mkdir_p "#{RAILS_ROOT}/db"
70
+ mkdir_p "#{RAILS_ROOT}/test/fixtures"
71
+ mkdir_p "#{RAILS_ROOT}/public/stylesheets"
72
+
73
+ File.open("#{RAILS_ROOT}/config/routes.rb", 'w') do |f|
74
+ f << "ActionController::Routing::Routes.draw do |map|\n\nend"
75
+ end
76
+ end
77
+
78
+ def teardown
79
+ rm_rf "#{RAILS_ROOT}/app"
80
+ rm_rf "#{RAILS_ROOT}/test"
81
+ rm_rf "#{RAILS_ROOT}/config"
82
+ rm_rf "#{RAILS_ROOT}/db"
83
+ rm_rf "#{RAILS_ROOT}/public"
84
+ end
85
+
86
+ def test_truth
87
+ # don't complain, test/unit
88
+ end
89
+
90
+ # Instantiates the Generator.
91
+ def build_generator(name, params)
92
+ Rails::Generator::Base.instance(name, params)
93
+ end
94
+
95
+ # Runs the +create+ command (like the command line does).
96
+ def run_generator(name, params)
97
+ silence_generator do
98
+ build_generator(name, params).command(:create).invoke!
99
+ end
100
+ end
101
+
102
+ # Silences the logger temporarily and returns the output as a String.
103
+ def silence_generator
104
+ logger_original = Rails::Generator::Base.logger
105
+ myout = StringIO.new
106
+ Rails::Generator::Base.logger = Rails::Generator::SimpleLogger.new(myout)
107
+ yield if block_given?
108
+ Rails::Generator::Base.logger = logger_original
109
+ myout.string
110
+ end
111
+
112
+ # Asserts that the given controller was generated.
113
+ # It takes a name or symbol without the <tt>_controller</tt> part and an optional super class.
114
+ # The contents of the class source file is passed to a block.
115
+ def assert_generated_controller_for(name, parent = "ApplicationController")
116
+ assert_generated_class "app/controllers/#{name.to_s.underscore}_controller", parent do |body|
117
+ yield body if block_given?
118
+ end
119
+ end
120
+
121
+ # Asserts that the given model was generated.
122
+ # It takes a name or symbol and an optional super class.
123
+ # The contents of the class source file is passed to a block.
124
+ def assert_generated_model_for(name, parent = "ActiveRecord::Base")
125
+ assert_generated_class "app/models/#{name.to_s.underscore}", parent do |body|
126
+ yield body if block_given?
127
+ end
128
+ end
129
+
130
+ # Asserts that the given helper was generated.
131
+ # It takes a name or symbol without the <tt>_helper</tt> part.
132
+ # The contents of the module source file is passed to a block.
133
+ def assert_generated_helper_for(name)
134
+ assert_generated_module "app/helpers/#{name.to_s.underscore}_helper" do |body|
135
+ yield body if block_given?
136
+ end
137
+ end
138
+
139
+ # Asserts that the given functional test was generated.
140
+ # It takes a name or symbol without the <tt>_controller_test</tt> part and an optional super class.
141
+ # The contents of the class source file is passed to a block.
142
+ def assert_generated_functional_test_for(name, parent = "ActionController::TestCase")
143
+ assert_generated_class "test/functional/#{name.to_s.underscore}_controller_test",parent do |body|
144
+ yield body if block_given?
145
+ end
146
+ end
147
+
148
+ # Asserts that the given unit test was generated.
149
+ # It takes a name or symbol without the <tt>_test</tt> part and an optional super class.
150
+ # The contents of the class source file is passed to a block.
151
+ def assert_generated_unit_test_for(name, parent = "ActiveSupport::TestCase")
152
+ assert_generated_class "test/unit/#{name.to_s.underscore}_test", parent do |body|
153
+ yield body if block_given?
154
+ end
155
+ end
156
+
157
+ # Asserts that the given file was generated.
158
+ # The contents of the file is passed to a block.
159
+ def assert_generated_file(path)
160
+ assert_file_exists(path)
161
+ File.open("#{RAILS_ROOT}/#{path}") do |f|
162
+ yield f.read if block_given?
163
+ end
164
+ end
165
+
166
+ # asserts that the given file exists
167
+ def assert_file_exists(path)
168
+ assert File.exist?("#{RAILS_ROOT}/#{path}"),
169
+ "The file '#{RAILS_ROOT}/#{path}' should exist"
170
+ end
171
+
172
+ # Asserts that the given class source file was generated.
173
+ # It takes a path without the <tt>.rb</tt> part and an optional super class.
174
+ # The contents of the class source file is passed to a block.
175
+ def assert_generated_class(path, parent = nil)
176
+ # FIXME: Sucky way to detect namespaced classes
177
+ if path.split('/').size > 3
178
+ path =~ /\/?(\d+_)?(\w+)\/(\w+)$/
179
+ class_name = "#{$2.camelize}::#{$3.camelize}"
180
+ else
181
+ path =~ /\/?(\d+_)?(\w+)$/
182
+ class_name = $2.camelize
183
+ end
184
+
185
+ assert_generated_file("#{path}.rb") do |body|
186
+ assert_match /class #{class_name}#{parent.nil? ? '':" < #{parent}"}/, body, "the file '#{path}.rb' should be a class"
187
+ yield body if block_given?
188
+ end
189
+ end
190
+
191
+ # Asserts that the given module source file was generated.
192
+ # It takes a path without the <tt>.rb</tt> part.
193
+ # The contents of the class source file is passed to a block.
194
+ def assert_generated_module(path)
195
+ # FIXME: Sucky way to detect namespaced modules
196
+ if path.split('/').size > 3
197
+ path =~ /\/?(\w+)\/(\w+)$/
198
+ module_name = "#{$1.camelize}::#{$2.camelize}"
199
+ else
200
+ path =~ /\/?(\w+)$/
201
+ module_name = $1.camelize
202
+ end
203
+
204
+ assert_generated_file("#{path}.rb") do |body|
205
+ assert_match /module #{module_name}/, body, "the file '#{path}.rb' should be a module"
206
+ yield body if block_given?
207
+ end
208
+ end
209
+
210
+ # Asserts that the given CSS stylesheet file was generated.
211
+ # It takes a path without the <tt>.css</tt> part.
212
+ # The contents of the stylesheet source file is passed to a block.
213
+ def assert_generated_stylesheet(path)
214
+ assert_generated_file("public/stylesheets/#{path}.css") do |body|
215
+ yield body if block_given?
216
+ end
217
+ end
218
+
219
+ # Asserts that the given YAML file was generated.
220
+ # It takes a path without the <tt>.yml</tt> part.
221
+ # The parsed YAML tree is passed to a block.
222
+ def assert_generated_yaml(path)
223
+ assert_generated_file("#{path}.yml") do |body|
224
+ yaml = YAML.load(body)
225
+ assert yaml, 'YAML data missing'
226
+ yield yaml if block_given?
227
+ end
228
+ end
229
+
230
+ # Asserts that the given fixtures YAML file was generated.
231
+ # It takes a fixture name without the <tt>.yml</tt> part.
232
+ # The parsed YAML tree is passed to a block.
233
+ def assert_generated_fixtures_for(name)
234
+ assert_generated_yaml "test/fixtures/#{name.to_s.underscore}" do |yaml|
235
+ yield yaml if block_given?
236
+ end
237
+ end
238
+
239
+ # Asserts that the given views were generated.
240
+ # It takes a controller name and a list of views (including extensions).
241
+ # The body of each view is passed to a block.
242
+ def assert_generated_views_for(name, *actions)
243
+ actions.each do |action|
244
+ assert_generated_file("app/views/#{name.to_s.underscore}/#{action}") do |body|
245
+ yield body if block_given?
246
+ end
247
+ end
248
+ end
249
+
250
+ def assert_generated_migration(name, parent = "ActiveRecord::Migration")
251
+ file = Dir.glob("#{RAILS_ROOT}/db/migrate/*_#{name.to_s.underscore}.rb").first
252
+ file = file.match(/db\/migrate\/[0-9]+_\w+/).to_s
253
+ assert_generated_class file, parent do |body|
254
+ assert_match /timestamps/, body, "should have timestamps defined"
255
+ yield body if block_given?
256
+ end
257
+ end
258
+
259
+ # Asserts that the given migration file was not generated.
260
+ # It takes the name of the migration as a parameter.
261
+ def assert_skipped_migration(name)
262
+ migration_file = "#{RAILS_ROOT}/db/migrate/001_#{name.to_s.underscore}.rb"
263
+ assert !File.exist?(migration_file), "should not create migration #{migration_file}"
264
+ end
265
+
266
+ # Asserts that the given resource was added to the routes.
267
+ def assert_added_route_for(name)
268
+ assert_generated_file("config/routes.rb") do |body|
269
+ assert_match /map.resources :#{name.to_s.underscore}/, body,
270
+ "should add route for :#{name.to_s.underscore}"
271
+ end
272
+ end
273
+
274
+ # Asserts that the given methods are defined in the body.
275
+ # This does assume standard rails code conventions with regards to the source code.
276
+ # The body of each individual method is passed to a block.
277
+ def assert_has_method(body, *methods)
278
+ methods.each do |name|
279
+ assert body =~ /^ def #{name}(\(.+\))?\n((\n| .*\n)*) end/, "should have method #{name}"
280
+ yield(name, $2) if block_given?
281
+ end
282
+ end
283
+
284
+ # Asserts that the given column is defined in the migration.
285
+ def assert_generated_column(body, name, type)
286
+ assert_match /t\.#{type.to_s} :#{name.to_s}/, body, "should have column #{name.to_s} defined"
287
+ end
288
+ end