jeffleeismyhero-shoulda_generator 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (52) hide show
  1. data/LICENSE +20 -0
  2. data/Manifest +28 -0
  3. data/README.markdown +78 -0
  4. data/Rakefile +26 -0
  5. data/TODO +8 -0
  6. data/VERSION.yml +4 -0
  7. data/rails_generators/shoulda_model/USAGE +27 -0
  8. data/rails_generators/shoulda_model/shoulda_model_generator.rb +49 -0
  9. data/rails_generators/shoulda_model/templates/factory.rb +5 -0
  10. data/rails_generators/shoulda_model/templates/fixtures.yml +19 -0
  11. data/rails_generators/shoulda_model/templates/migration.rb +18 -0
  12. data/rails_generators/shoulda_model/templates/model.rb +2 -0
  13. data/rails_generators/shoulda_model/templates/unit_test.rb +7 -0
  14. data/rails_generators/shoulda_scaffold/USAGE +34 -0
  15. data/rails_generators/shoulda_scaffold/shoulda_scaffold_generator.rb +164 -0
  16. data/rails_generators/shoulda_scaffold/templates/controller.rb +72 -0
  17. data/rails_generators/shoulda_scaffold/templates/erb/edit.html.erb +21 -0
  18. data/rails_generators/shoulda_scaffold/templates/erb/index.html.erb +27 -0
  19. data/rails_generators/shoulda_scaffold/templates/erb/layout.html.erb +22 -0
  20. data/rails_generators/shoulda_scaffold/templates/erb/new.html.erb +19 -0
  21. data/rails_generators/shoulda_scaffold/templates/erb/show.html.erb +14 -0
  22. data/rails_generators/shoulda_scaffold/templates/functional_test/basic.rb +66 -0
  23. data/rails_generators/shoulda_scaffold/templates/functional_test/should_be_restful.rb +13 -0
  24. data/rails_generators/shoulda_scaffold/templates/haml/_form.html.haml +7 -0
  25. data/rails_generators/shoulda_scaffold/templates/haml/edit.html.haml +9 -0
  26. data/rails_generators/shoulda_scaffold/templates/haml/index.html.haml +18 -0
  27. data/rails_generators/shoulda_scaffold/templates/haml/layout.html.haml +15 -0
  28. data/rails_generators/shoulda_scaffold/templates/haml/new.html.haml +7 -0
  29. data/rails_generators/shoulda_scaffold/templates/haml/show.html.haml +10 -0
  30. data/rails_generators/shoulda_scaffold/templates/helper.rb +2 -0
  31. data/test/fixtures/about_yml_plugins/bad_about_yml/about.yml +1 -0
  32. data/test/fixtures/about_yml_plugins/bad_about_yml/init.rb +1 -0
  33. data/test/fixtures/about_yml_plugins/plugin_without_about_yml/init.rb +1 -0
  34. data/test/fixtures/eager/zoo/reptile_house.rb +2 -0
  35. data/test/fixtures/eager/zoo.rb +3 -0
  36. data/test/fixtures/environment_with_constant.rb +1 -0
  37. data/test/fixtures/lib/generators/missing_class/missing_class_generator.rb +0 -0
  38. data/test/fixtures/lib/generators/working/working_generator.rb +2 -0
  39. data/test/fixtures/plugins/alternate/a/generators/a_generator/a_generator.rb +4 -0
  40. data/test/fixtures/plugins/default/gemlike/init.rb +1 -0
  41. data/test/fixtures/plugins/default/gemlike/lib/gemlike.rb +2 -0
  42. data/test/fixtures/plugins/default/gemlike/rails/init.rb +7 -0
  43. data/test/fixtures/plugins/default/plugin_with_no_lib_dir/init.rb +0 -0
  44. data/test/fixtures/plugins/default/stubby/about.yml +2 -0
  45. data/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb +4 -0
  46. data/test/fixtures/plugins/default/stubby/init.rb +7 -0
  47. data/test/fixtures/plugins/default/stubby/lib/stubby_mixin.rb +2 -0
  48. data/test/rails_generators/shoulda_model_generator_test.rb +38 -0
  49. data/test/shoulda_macros/generator_macros.rb +36 -0
  50. data/test/stolen_from_railties.rb +288 -0
  51. data/test/test_helper.rb +41 -0
  52. metadata +123 -0
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2008 Josh Nichols
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/Manifest ADDED
@@ -0,0 +1,28 @@
1
+ rails_generators/shoulda_model/shoulda_model_generator.rb
2
+ rails_generators/shoulda_model/templates/factory.rb
3
+ rails_generators/shoulda_model/templates/fixtures.yml
4
+ rails_generators/shoulda_model/templates/migration.rb
5
+ rails_generators/shoulda_model/templates/model.rb
6
+ rails_generators/shoulda_model/templates/unit_test.rb
7
+ rails_generators/shoulda_model/USAGE
8
+ rails_generators/shoulda_scaffold/shoulda_scaffold_generator.rb
9
+ rails_generators/shoulda_scaffold/templates/controller.rb
10
+ rails_generators/shoulda_scaffold/templates/erb/edit.html.erb
11
+ rails_generators/shoulda_scaffold/templates/erb/index.html.erb
12
+ rails_generators/shoulda_scaffold/templates/erb/layout.html.erb
13
+ rails_generators/shoulda_scaffold/templates/erb/new.html.erb
14
+ rails_generators/shoulda_scaffold/templates/erb/show.html.erb
15
+ rails_generators/shoulda_scaffold/templates/functional_test/basic.rb
16
+ rails_generators/shoulda_scaffold/templates/functional_test/should_be_restful.rb
17
+ rails_generators/shoulda_scaffold/templates/haml/_form.html.haml
18
+ rails_generators/shoulda_scaffold/templates/haml/edit.html.haml
19
+ rails_generators/shoulda_scaffold/templates/haml/index.html.haml
20
+ rails_generators/shoulda_scaffold/templates/haml/layout.html.haml
21
+ rails_generators/shoulda_scaffold/templates/haml/new.html.haml
22
+ rails_generators/shoulda_scaffold/templates/haml/show.html.haml
23
+ rails_generators/shoulda_scaffold/templates/helper.rb
24
+ rails_generators/shoulda_scaffold/USAGE
25
+ Rakefile
26
+ README.markdown
27
+ shoulda_generator.gemspec
28
+ Manifest
data/README.markdown ADDED
@@ -0,0 +1,78 @@
1
+ # Shoulda generators
2
+
3
+ I've customized the Shoulda Generator gem from technicalpickles with my own views and defaults. I'm not a fan of haml and will eventually remove it from this fork. I also do not require blueprint so that will be removed as well.
4
+
5
+ One night at a Boston Ruby hackfest, I finally got sick of using the Rails default generators, and then having to twiddle them to meet my needs and tastes. This includes using things like:
6
+
7
+ * [shoulda](http://thoughtbot.com/projects/shoulda)
8
+ * [factory\_girl](http://github.com/thoughtbot/factory_girl)
9
+ * [haml](http://haml.hamptoncatlin.com/)
10
+
11
+ The next morning, I was struck awake at 5am with the inspiration to start implementing it. shoulda\_generator is the result of this effort.
12
+
13
+ ## What you get
14
+
15
+ ### shoulda\_model
16
+
17
+ * A new model
18
+ * A migration for the model
19
+ * Skip using --skip-migration
20
+ * A factory defined with [factory_girl](http://github.com/thoughtbot/factory_girl)
21
+ * Skip using --skip-factory
22
+ * A [shoulda](http://thoughtbot.com/projects/shoulda) unit test with a few simple 'should's
23
+
24
+ #### Prereqs:
25
+
26
+ * [shoulda](http://thoughtbot.com/projects/shoulda) installed as a plugin
27
+ * [factory\_girl](http://github.com/thoughtbot/factory_girl) gem installed
28
+ * [factory\_girl\_on\_rails](http://github.com/technicalpickles/factory_girl_on_rails) installed as a plugin
29
+
30
+ ### shoulda\_scaffold
31
+
32
+ * Everything included in shoulda_model
33
+ * A controller (sans unnecessary comments)
34
+ * Choice of [haml](http://haml.hamptoncatlin.com/) or ERB (default)
35
+ * Specify which with the --templating option
36
+ * Skip using --skip-layout
37
+ * A helper
38
+ * A shoulda functional test using factory_girl factory, using should\_be\_restful or not
39
+ * Specify with --functional-test-style, accepts basic and should\_be\_restful
40
+
41
+ #### Prereqs:
42
+
43
+ * [shoulda](http://thoughtbot.com/projects/shoulda) installed as a plugin
44
+ * [factory\_girl](http://github.com/thoughtbot/factory_girl) gem installed
45
+ * [factory\_girl\_on\_rails](http://github.com/technicalpickles/factory_girl_on_rails) installed as a plugin
46
+
47
+ ## Getting it
48
+
49
+ shoulda\_generator is available as a gem via [GitHub](http://github.com). If you haven't done so already, you need to setup GitHub as a gem source:
50
+
51
+ $ gem sources -a http://gems.github.com
52
+
53
+ Now you can install it:
54
+
55
+ $ sudo gem install jeffleeismyhero-shoulda_generator
56
+
57
+ ## Example usage
58
+
59
+ Usage is the same as the default Rails generators.
60
+
61
+ $ script/generate shoulda_model post title:string body:text published:boolean
62
+ $ script/generate shoulda_scaffold post title:string body:text published:boolean
63
+
64
+
65
+ ## Configuring it
66
+
67
+ You can override the default values for templating and functional\_test\_style by placing a .shoulda\_generator file in your home directory.
68
+
69
+ Here's an example `.shoulda_generator`:
70
+
71
+ :templating: erb # supported options: haml|erb
72
+ :functional_test_syle: basic # supported options: should_be_restful|basic
73
+
74
+ ## Developing it
75
+
76
+ Source is hosted on GitHub: [http://github.com/jeffleeismyhero/shoulda_generator/tree/master](http://github.com/jeffleeismyhero/shoulda_generator/tree/master)
77
+
78
+ You can do the usual fork/commit cycle until you have something ready to share. Send pull requests my way.
data/Rakefile ADDED
@@ -0,0 +1,26 @@
1
+ require 'rake'
2
+ require 'rake/testtask'
3
+
4
+ begin
5
+ require 'jeweler'
6
+ Jeweler::Tasks.new do |s|
7
+ s.name = "shoulda_generator"
8
+ s.summary = "Generators which create tests using shoulda"
9
+ s.email = "jlee42@gmail.com"
10
+ s.homepage = "http://github.com/jeffleeismyhero/shoulda_generator"
11
+ s.description = "Generators which create tests using shoulda"
12
+ s.authors = ["Josh Nichols", "Jeffrey Lee"]
13
+ s.files = FileList["[A-Z]*", "{rails_generators,lib,test}/**/*"]
14
+ end
15
+ rescue LoadError
16
+ puts "Jeweler not available. Install it with: sudo gem install technicalpickles-jeweler -s http://gems.github.com"
17
+ end
18
+
19
+ Rake::TestTask.new do |t|
20
+ t.libs << 'lib'
21
+ t.pattern = 'test/**/*_test.rb'
22
+ t.verbose = false
23
+ end
24
+
25
+ desc 'Test by default'
26
+ task :default => :test
data/TODO ADDED
@@ -0,0 +1,8 @@
1
+ * When installing, there's an warning:
2
+
3
+ Successfully installed shoulda_generator-0.2.0
4
+ 1 gem installed
5
+ Installing ri documentation for shoulda_generator-0.2.0...
6
+ File not found: lib
7
+
8
+ * Support using resource_controller?
data/VERSION.yml ADDED
@@ -0,0 +1,4 @@
1
+ ---
2
+ :major: 0
3
+ :minor: 3
4
+ :patch: 0
@@ -0,0 +1,27 @@
1
+ Description:
2
+ Stubs out a new model. Pass the model name, either CamelCased or
3
+ under_scored, and an optional list of attribute pairs as arguments.
4
+
5
+ Attribute pairs are column_name:sql_type arguments specifying the
6
+ model's attributes. Timestamps are added by default, so you don't have to
7
+ specify them by hand as 'created_at:datetime updated_at:datetime'.
8
+
9
+ You don't have to think up every attribute up front, but it helps to
10
+ sketch out a few so you can start working with the model immediately.
11
+
12
+ This generates a model class in app/models, a unit test in test/unit,
13
+ a test fixture in test/fixtures/singular_name.yml, and a migration in
14
+ db/migrate.
15
+
16
+ Examples:
17
+ `./script/generate shoulda_model account`
18
+
19
+ creates an Account model, test, factory, and migration:
20
+ Model: app/models/account.rb
21
+ Test: test/unit/account_test.rb
22
+ Factory: test/factories/account_factory.rb
23
+ Migration: db/migrate/XXX_add_accounts.rb
24
+
25
+ `./script/generate shoulda_model post title:string body:text published:boolean`
26
+
27
+ creates a Post model with a string title, text body, and published flag.
@@ -0,0 +1,49 @@
1
+ class ShouldaModelGenerator < Rails::Generator::NamedBase
2
+ default_options :skip_timestamps => false, :skip_migration => false, :skip_factory => false
3
+
4
+ def manifest
5
+ record do |m|
6
+ # Check for class naming collisions.
7
+ m.class_collisions class_path, class_name, "#{class_name}Test"
8
+
9
+ # Model, test, and fixture directories.
10
+ m.directory File.join('app/models', class_path)
11
+ m.directory File.join('test/unit', class_path)
12
+ m.directory File.join('test/factories', class_path)
13
+
14
+ # Model class, unit test, and fixtures.
15
+ m.template 'model.rb', File.join('app/models', class_path, "#{file_name}.rb")
16
+ m.template 'unit_test.rb', File.join('test/unit', class_path, "#{file_name}_test.rb")
17
+
18
+ unless options[:skip_factory]
19
+ m.template 'factory.rb', File.join('test/factories', class_path, "#{file_name}_factory.rb")
20
+ end
21
+
22
+ unless options[:skip_migration]
23
+ m.migration_template 'migration.rb', 'db/migrate', :assigns => {
24
+ :migration_name => "Create#{class_name.pluralize.gsub(/::/, '')}"
25
+ }, :migration_file_name => "create_#{file_path.gsub(/\//, '_').pluralize}"
26
+ end
27
+ end
28
+ end
29
+
30
+ def factory_line(attribute)
31
+ "#{file_name}.#{attribute.name} '#{attribute.default}'"
32
+ end
33
+
34
+ protected
35
+ def banner
36
+ "Usage: #{$0} #{spec.name} ModelName [field:type, field:type]"
37
+ end
38
+
39
+ def add_options!(opt)
40
+ opt.separator ''
41
+ opt.separator 'Options:'
42
+ opt.on("--skip-timestamps",
43
+ "Don't add timestamps to the migration file for this model") { |v| options[:skip_timestamps] = v }
44
+ opt.on("--skip-migration",
45
+ "Don't generate a migration file for this model") { |v| options[:skip_migration] = v }
46
+ opt.on("--skip-factory",
47
+ "Don't generation a fixture file for this model") { |v| options[:skip_factory] = v}
48
+ end
49
+ end
@@ -0,0 +1,5 @@
1
+ Factory.define :<%= file_name %> do |<%= file_name %>|
2
+ <% for attribute in attributes -%>
3
+ <%= factory_line(attribute) %>
4
+ <% end -%>
5
+ end
@@ -0,0 +1,19 @@
1
+ # Read about fixtures at http://ar.rubyonrails.org/classes/Fixtures.html
2
+
3
+ <% unless attributes.empty? -%>
4
+ one:
5
+ <% for attribute in attributes -%>
6
+ <%= attribute.name %>: <%= attribute.default %>
7
+ <% end -%>
8
+
9
+ two:
10
+ <% for attribute in attributes -%>
11
+ <%= attribute.name %>: <%= attribute.default %>
12
+ <% end -%>
13
+ <% else -%>
14
+ # one:
15
+ # column: value
16
+ #
17
+ # two:
18
+ # column: value
19
+ <% end -%>
@@ -0,0 +1,18 @@
1
+ class <%= migration_name %> < ActiveRecord::Migration
2
+ def self.up
3
+ create_table :<%= table_name %> do |t|
4
+ <% for attribute in attributes -%>
5
+ <% unless ['updated_at','created_at'].include?(attribute.name) %>
6
+ t.<%= attribute.type %> :<%= attribute.name %>
7
+ <% end %>
8
+ <% end -%>
9
+ <% unless options[:skip_timestamps] %>
10
+ t.timestamps
11
+ <% end -%>
12
+ end
13
+ end
14
+
15
+ def self.down
16
+ drop_table :<%= table_name %>
17
+ end
18
+ end
@@ -0,0 +1,2 @@
1
+ class <%= class_name %> < ActiveRecord::Base
2
+ end
@@ -0,0 +1,7 @@
1
+ require File.dirname(__FILE__) + '/../test_helper'
2
+
3
+ class <%= class_name %>Test < ActiveSupport::TestCase
4
+ <% for attribute in attributes -%>
5
+ should_have_db_column :<%= attribute.name %>
6
+ <% end -%>
7
+ end
@@ -0,0 +1,34 @@
1
+ Description:
2
+ Scaffolds an entire resource, from model and migration to controller and
3
+ views, along with a full test suite. The resource is ready to use as a
4
+ starting point for your restful, resource-oriented application.
5
+
6
+ Pass the name of the model, either CamelCased or under_scored, as the first
7
+ argument, and an optional list of attribute pairs.
8
+
9
+ Attribute pairs are column_name:sql_type arguments specifying the
10
+ model's attributes. Timestamps are added by default, so you don't have to
11
+ specify them by hand as 'created_at:datetime updated_at:datetime'.
12
+
13
+ You don't have to think up every attribute up front, but it helps to
14
+ sketch out a few so you can start working with the resource immediately.
15
+
16
+ For example, `scaffold post title:string body:text published:boolean`
17
+ gives you a model with those three attributes, a controller that handles
18
+ the create/show/update/destroy, forms to create and edit your posts, and
19
+ an index that lists them all, as well as a map.resources :posts
20
+ declaration in config/routes.rb.
21
+
22
+ You can override the default values for templating and
23
+ functional\_test\_style by placing a .shoulda\_generator file in your home
24
+ directory.
25
+
26
+ Here's an example `.shoulda_generator`:
27
+
28
+ :templating: erb # supported options: haml|erb
29
+ :functional_test_syle: basic # supported options: should_be_restful|basic
30
+
31
+ Examples:
32
+ `./script/generate shoulda_scaffold post` # no attributes, view will be anemic
33
+ `./script/generate shoulda_scaffold post title:string body:text published:boolean`
34
+ `./script/generate shoulda_scaffold purchase order_id:integer amount:decimal`
@@ -0,0 +1,164 @@
1
+ #--
2
+ # ShouldaScaffoldGeneratorConfig based on rubygems code.
3
+ # Thank you Chad Fowler, Rich Kilmer, Jim Weirich and others.
4
+ #++
5
+ class ShouldaScaffoldGeneratorConfig
6
+
7
+ DEFAULT_TEMPLATING = 'erb'
8
+ DEFAULT_FUNCTIONAL_TEST_STYLE = 'basic'
9
+
10
+ def initialize()
11
+ @config = load_file(config_file)
12
+
13
+ @templating = @config[:templating] || DEFAULT_TEMPLATING
14
+ @functional_test_style = @config[:functional_test_style] || DEFAULT_FUNCTIONAL_TEST_STYLE
15
+ end
16
+
17
+ attr_reader :templating, :functional_test_style
18
+
19
+ private
20
+
21
+ def load_file(filename)
22
+ begin
23
+ YAML.load(File.read(filename)) if filename and File.exist?(filename)
24
+ rescue ArgumentError
25
+ warn "Failed to load #{config_file_name}"
26
+ rescue Errno::EACCES
27
+ warn "Failed to load #{config_file_name} due to permissions problem."
28
+ end or {}
29
+ end
30
+
31
+ def config_file
32
+ File.join(find_home, '.shoulda_generator')
33
+ end
34
+
35
+ ##
36
+ # Finds the user's home directory.
37
+
38
+ def find_home
39
+ ['HOME', 'USERPROFILE'].each do |homekey|
40
+ return ENV[homekey] if ENV[homekey]
41
+ end
42
+
43
+ if ENV['HOMEDRIVE'] && ENV['HOMEPATH'] then
44
+ return "#{ENV['HOMEDRIVE']}:#{ENV['HOMEPATH']}"
45
+ end
46
+
47
+ begin
48
+ File.expand_path("~")
49
+ rescue
50
+ if File::ALT_SEPARATOR then
51
+ "C:/"
52
+ else
53
+ "/"
54
+ end
55
+ end
56
+ end
57
+ end
58
+
59
+ class ShouldaScaffoldGenerator < Rails::Generator::NamedBase
60
+ default_options :skip_timestamps => false, :skip_migration => false, :skip_layout => true
61
+
62
+ attr_reader :controller_name,
63
+ :controller_class_path,
64
+ :controller_file_path,
65
+ :controller_class_nesting,
66
+ :controller_class_nesting_depth,
67
+ :controller_class_name,
68
+ :controller_underscore_name,
69
+ :controller_singular_name,
70
+ :controller_plural_name
71
+ alias_method :controller_file_name, :controller_underscore_name
72
+ alias_method :controller_table_name, :controller_plural_name
73
+
74
+ def initialize(runtime_args, runtime_options = {})
75
+ super
76
+
77
+ @configuration = ShouldaScaffoldGeneratorConfig.new
78
+
79
+ @controller_name = @name.pluralize
80
+
81
+ base_name, @controller_class_path, @controller_file_path, @controller_class_nesting, @controller_class_nesting_depth = extract_modules(@controller_name)
82
+ @controller_class_name_without_nesting, @controller_underscore_name, @controller_plural_name = inflect_names(base_name)
83
+ @controller_singular_name=base_name.singularize
84
+ if @controller_class_nesting.empty?
85
+ @controller_class_name = @controller_class_name_without_nesting
86
+ else
87
+ @controller_class_name = "#{@controller_class_nesting}::#{@controller_class_name_without_nesting}"
88
+ end
89
+ end
90
+
91
+ def manifest
92
+ record do |m|
93
+ # Check for class naming collisions.
94
+ m.class_collisions(controller_class_path, "#{controller_class_name}Controller", "#{controller_class_name}Helper")
95
+ m.class_collisions(class_path, "#{class_name}")
96
+
97
+ # Controller, helper, views, and test directories.
98
+ m.directory(File.join('app/models', class_path))
99
+ m.directory(File.join('app/controllers', controller_class_path))
100
+ m.directory(File.join('app/helpers', controller_class_path))
101
+ m.directory(File.join('app/views', controller_class_path, controller_file_name))
102
+ m.directory(File.join('app/views/layouts', controller_class_path))
103
+ m.directory(File.join('test/functional', controller_class_path))
104
+ m.directory(File.join('test/unit', class_path))
105
+
106
+ m.directory('public/stylesheets/blueprint')
107
+
108
+ for view in scaffold_views
109
+ m.template(
110
+ "#{templating}/#{view}.html.#{templating}",
111
+ File.join('app/views', controller_class_path, controller_file_name, "#{view}.html.#{templating}")
112
+ )
113
+ end
114
+
115
+ # Layout and stylesheet.
116
+ m.template("#{templating}/layout.html.#{templating}", File.join('app/views/layouts', controller_class_path, "#{controller_file_name}.html.#{templating}"))
117
+
118
+ m.template(
119
+ 'controller.rb', File.join('app/controllers', controller_class_path, "#{controller_file_name}_controller.rb")
120
+ )
121
+
122
+ m.template("functional_test/#{functional_test_style}.rb", File.join('test/functional', controller_class_path, "#{controller_file_name}_controller_test.rb"))
123
+ m.template('helper.rb', File.join('app/helpers', controller_class_path, "#{controller_file_name}_helper.rb"))
124
+
125
+ m.route_resources controller_file_name
126
+
127
+ m.dependency 'shoulda_model', [name] + @args, :collision => :skip
128
+ end
129
+ end
130
+
131
+ def templating
132
+ options[:templating] || @configuration.templating
133
+ end
134
+
135
+ def functional_test_style
136
+ options[:functional_test_style] || @configuration.functional_test_style
137
+ end
138
+
139
+ protected
140
+ # Override with your own usage banner.
141
+ def banner
142
+ "Usage: #{$0} scaffold ModelName [field:type, field:type]"
143
+ end
144
+
145
+ def add_options!(opt)
146
+ opt.separator ''
147
+ opt.separator 'Options:'
148
+ opt.on("--skip-timestamps",
149
+ "Don't add timestamps to the migration file for this model") { |v| options[:skip_timestamps] = v }
150
+ opt.on("--skip-migration",
151
+ "Don't generate a migration file for this model") { |v| options[:skip_migration] = v }
152
+ opt.on("--templating [erb|haml]", "Specify the templating to use (erb by default)") { |v| options[:templating] = v }
153
+ opt.on("--functional-test-style [basic|should_be_restful]", "Specify the style of the functional test (basic by default)") { |v| options[:functional_test_style] = v }
154
+
155
+ end
156
+
157
+ def scaffold_views
158
+ %w[ index show new edit ]
159
+ end
160
+
161
+ def model_name
162
+ class_name.demodulize
163
+ end
164
+ end
@@ -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] = '<%= singular_name.humanize %> 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] = '<%= singular_name.humanize %> 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,21 @@
1
+ <div class="inline-actions">
2
+ <%= link_to 'Show', @<%= singular_name %> %>
3
+ |
4
+ <%%= link_to 'Back', <%= plural_name %>_path %>
5
+ </div>
6
+
7
+ <h1>Editing <%= singular_name.humanize %></h1>
8
+
9
+ <%% form_for(@<%= singular_name %>) do |f| %>
10
+ <%%= f.error_messages %>
11
+
12
+ <% for attribute in attributes -%>
13
+ <fieldset>
14
+ <%%= f.label :<%= attribute.name %> %>
15
+ <%%= f.<%= attribute.field_type %> :<%= attribute.name %> %>
16
+ </fieldset>
17
+ <% end -%>
18
+ <p>
19
+ <%%= f.submit 'Update' %>
20
+ </p>
21
+ <%% end %>
@@ -0,0 +1,27 @@
1
+ <div class="inline-actions">
2
+ <%%= link_to 'New <%= singular_name.humanize %>', new_<%= singular_name %>_path %>
3
+ </div>
4
+
5
+ <h1> Listing <%= plural_name.humanize %></h1>
6
+
7
+ <table>
8
+ <tr>
9
+ <% for attribute in attributes -%>
10
+ <th><%= attribute.column.human_name %></th>
11
+ <% end -%>
12
+ <th>Actions</th>
13
+ </tr>
14
+
15
+ <%% for <%= singular_name %> in @<%= plural_name %> %>
16
+ <tr>
17
+ <% for attribute in attributes -%>
18
+ <td><%%= h <%= singular_name %>.<%= attribute.name %> %></td>
19
+ <% end -%>
20
+ <td>
21
+ <%%= link_to 'Show', <%= singular_name %> %>
22
+ <%%= link_to 'Edit', edit_<%= singular_name %>_path(<%= singular_name %>) %>
23
+ <%%= link_to 'Destroy', <%= singular_name %>, :confirm => 'Are you sure?', :method => :delete %>
24
+ </td>
25
+ </tr>
26
+ <%% end %>
27
+ </table>
@@ -0,0 +1,22 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html>
3
+ <head>
4
+ <title><%%= "#{controller.controller_name}: #{controller.action_name}" %></title>
5
+ <%%= stylesheet_link_tag 'blueprint/screen', :media => 'screen' %>
6
+ <%%= stylesheet_link_tag 'blueprint/print', :media => 'print' %>
7
+ <%%= "<!--[if IE]>#{stylesheet_link_tag 'blueprint/ie', :media => 'screen'}<![endif]-->" %>
8
+ </head>
9
+ <body>
10
+ <div class="container">
11
+ <div id="content" class="column span-24">
12
+ <%% flash.each do |key, value| -%>
13
+ <div class="<%%= key %>">
14
+ <%%= h(value) %>
15
+ </div>
16
+ <%% end %>
17
+
18
+ <%%= yield %>
19
+ </div>
20
+ </div>
21
+ </body>
22
+ </html>