Commit 15750f4817f2d869eef04370a459bf3d02a3a15c
1 parent
ce74c679
Exists in
master
and in
1 other branch
Upgrading thoughtbot/limerick_rake plugin.
So we get rid of Rake's deprecations warnings: DEPRECATION WARNING: Rake tasks in vendor/plugins/limerick_rake/tasks, ... The gem itself is deprecated, so we might be better of removing it completely.
Showing
32 changed files
with
600 additions
and
548 deletions
Show diff stats
vendor/plugins/limerick_rake/MIT-LICENSE
@@ -17,4 +17,4 @@ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | @@ -17,4 +17,4 @@ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||
17 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | 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 | 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 | 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. | ||
21 | \ No newline at end of file | 20 | \ No newline at end of file |
21 | +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
@@ -0,0 +1,166 @@ | @@ -0,0 +1,166 @@ | ||
1 | +Limerick Rake | ||
2 | +============= | ||
3 | + | ||
4 | +A collection of useful rake tasks. | ||
5 | + | ||
6 | +To use in a Rails app, in your Gemfile: | ||
7 | + | ||
8 | + gem 'limerick_rake' | ||
9 | + | ||
10 | +DEPRECATED | ||
11 | +---------- | ||
12 | + | ||
13 | +We no longer use `limerick_rake`, and as such no longer maintain it. If you | ||
14 | +wish to take over the project please email <support@thoughtbot.com>. | ||
15 | + | ||
16 | +Database | ||
17 | +-------- | ||
18 | + | ||
19 | +Read tasks/database.rake for details for configuration. | ||
20 | + | ||
21 | + rake db:bootstrap:load # Load initial database fixtures (in db/bootstrap/*.yml) into the current environment's database. Load specific fixtures using FIXTURES=x,y | ||
22 | + rake db:indexes:missing # Prints a list of unindexed foreign keys so you can index them. | ||
23 | + rake db:shell # Launches the database shell using the values defined in config/database.yml. | ||
24 | + rake db:validate_models # Run model validations on all model records in database. | ||
25 | + rake db:recreate # Recreate database with seeds (drop, create, migrate and seed) | ||
26 | + | ||
27 | +Git | ||
28 | +--- | ||
29 | + | ||
30 | + rake git:push:staging # Merge a branch into the origin/staging branch. | ||
31 | + rake git:push:production # Merge the staging branch into origin/production for launch. | ||
32 | + rake git:diff:staging # Show the difference between current branch and origin/staging. | ||
33 | + rake git:diff:production # Show the difference between origin/staging and origin/production. | ||
34 | + rake git:pull:suspenders # Pull updates from suspenders, the thoughtbot rails template. | ||
35 | + rake git:branch:production #Branch origin/production into BRANCH locally. | ||
36 | + | ||
37 | +Backup | ||
38 | +------ | ||
39 | + | ||
40 | + rake backup:db # Backup the current database. Timestamped file is created as :rails_root/../db-name-timestamp.sql | ||
41 | + rake backup:assets # Backup all assets under public/system. File is created as :rails_root/../system.tgz | ||
42 | + | ||
43 | +Haml & Sass | ||
44 | +----------- | ||
45 | + | ||
46 | + rake sass:all_css2sass # Convert all CSS files in public/stylesheets to Sass. | ||
47 | + rake sass:all_sass2css # Convert all Sass files to CSS. | ||
48 | + rake haml:all_html2haml # Convert all HTML files to Haml. | ||
49 | + | ||
50 | +Rails 2+ | ||
51 | +-------- | ||
52 | + | ||
53 | + rake rails_two:rename_views # Renames all .rhtml views to .html.erb, .rjs to .js.rjs, .rxml to .xml.builder and .haml to .html.haml. | ||
54 | + | ||
55 | +Subversion | ||
56 | +---------- | ||
57 | + | ||
58 | + rake svn:add # Adds all files with an svn status flag of '?' | ||
59 | + rake svn:delete # Deletes all files with an svn status flag of '!' | ||
60 | + rake svn:log # Writes the log file to doc/svn_log.txt | ||
61 | + rake svn:update\_svn\_ignore # Updates svn:ignore from .svnignore | ||
62 | + | ||
63 | +Test Coverage | ||
64 | +------------- | ||
65 | + | ||
66 | +Install rcov from http://github.com/mergulhao/rcov | ||
67 | + | ||
68 | + rake test:coverage # Uses rcov to provide reports about test coverage of your application. | ||
69 | + | ||
70 | +Mass Assignment | ||
71 | +--------------- | ||
72 | + | ||
73 | +From "mhartl":http://github.com/mhartl/find_mass_assignment | ||
74 | + | ||
75 | + rake find_mass_assignment | ||
76 | + | ||
77 | +The Limerick Rake | ||
78 | +================= | ||
79 | + | ||
80 | +Traditional Irish song. [YouTube](http://www.youtube.com/v/e8moLHIW8xw) | ||
81 | + | ||
82 | + I am a young fellow that's easy and bold, | ||
83 | + In Castletown conners I'm very well known. | ||
84 | + In Newcastle West I spent many a note, | ||
85 | + With Kitty and Judy and Mary. | ||
86 | + | ||
87 | + My father rebuked me for being such a rake, | ||
88 | + And spending me time in such frolicsome ways, | ||
89 | + But I ne'er could forget the good nature of Jane, | ||
90 | + Agus fágaimíd siúd mar atá sé. | ||
91 | + | ||
92 | + My parents had reared me to shake and to mow, | ||
93 | + To plough and to harrow, to reap and to sow. | ||
94 | + But my heart being airy to drop it so low, | ||
95 | + I set out on high speculation. | ||
96 | + | ||
97 | + On paper and parchment they taught me to write, | ||
98 | + In Euclid and grammar they opened my eyes, | ||
99 | + And in multiplication in truth I was bright, | ||
100 | + Agus fágaimíd siúd mar atá sé. | ||
101 | + | ||
102 | + If I chance for to go to the town of Rathkeale, | ||
103 | + The girls all round me do flock on the square. | ||
104 | + Some give me a bottle and others sweet cakes, | ||
105 | + To treat me unknown to their parents. | ||
106 | + | ||
107 | + There is one from Askeaton and one from the Pike, | ||
108 | + Another from Arda, my heart was beguiled, | ||
109 | + Tho' being from the mountains her stockings are white, | ||
110 | + Agus fágaimíd siúd mar atá sé. | ||
111 | + | ||
112 | + To quarrel for riches I ne'er was inclined, | ||
113 | + For the greatest of misers that must leave all behind. | ||
114 | + I'll purchase a cow that will never run dry, | ||
115 | + And I'll milk her by twisting her horn. | ||
116 | + | ||
117 | + John Damer of Shronel had plenty of gold, | ||
118 | + And Lord Devonshire's treasures are twenty times more, | ||
119 | + But he's laid on his back among nettles and stones, | ||
120 | + Agus fágaimíd siúd mar atá sé. | ||
121 | + | ||
122 | + The old cow could be milked without clover or grass, | ||
123 | + She'd be pampered with corn, good barley and hops. | ||
124 | + She's warm and stout, and she's free in the paps, | ||
125 | + And she'll milk without spancil or halter. | ||
126 | + | ||
127 | + The man that will drink it will cock his caubeen, | ||
128 | + And if anyone laughs there'd be wigs on the green, | ||
129 | + And the feeble old hag will get supple and free, | ||
130 | + Agus fágaimíd siúd mar atá sé. | ||
131 | + | ||
132 | + There's some say I'm foolish and more say I'm wise, | ||
133 | + But being fond of the women I think is no crime, | ||
134 | + For the son of King David had ten hundred wives, | ||
135 | + And his wisdom was highly regarded. | ||
136 | + | ||
137 | + I'll take a good garden and live at my ease, | ||
138 | + And each woman and child can partake of the same, | ||
139 | + If there'd be war in the cabin, themselves they'd be to blame, | ||
140 | + Agus fágaimíd siúd mar atá sé. | ||
141 | + | ||
142 | + And now for the future I mean to be wise, | ||
143 | + And I'll send for the women that acted so kind, | ||
144 | + I'd marry them all on the morrow by and by, | ||
145 | + If the clergy agree to the bargain. | ||
146 | + | ||
147 | + And when I'd be old and my soul is at peace, | ||
148 | + These women will crowd for to cry at my wake, | ||
149 | + And their sons and their daughters will offer their prayer, | ||
150 | + To the Lord for the soul of their father. | ||
151 | + | ||
152 | +Credits | ||
153 | +------- | ||
154 | + | ||
155 | + | ||
156 | + | ||
157 | +Limerick Rake is maintained and funded by [thoughtbot, inc](http://thoughtbot.com/community) | ||
158 | + | ||
159 | +Thank you to all [the contributors](https://github.com/thoughtbot/limerick_rake/contributors)! | ||
160 | + | ||
161 | +The names and logos for thoughtbot are trademarks of thoughtbot, inc. | ||
162 | + | ||
163 | +License | ||
164 | +------- | ||
165 | + | ||
166 | +Limerick Rake is Copyright © 2008-2011 thoughtbot. It is free software, and may be redistributed under the terms specified in the LICENSE file. |
vendor/plugins/limerick_rake/README.textile
@@ -1,140 +0,0 @@ | @@ -1,140 +0,0 @@ | ||
1 | -Limerick Rake | ||
2 | -============= | ||
3 | - | ||
4 | -A collection of useful rake tasks. | ||
5 | - | ||
6 | -To use in a Rails app: | ||
7 | - | ||
8 | - script/plugin install git://github.com/thoughtbot/limerick_rake.git | ||
9 | - | ||
10 | -h2. Database | ||
11 | - | ||
12 | -Read tasks/database.rake for details for configuration. | ||
13 | - | ||
14 | -* rake db:bootstrap:load - Load initial database fixtures (in db/bootstrap/*.yml) into the current environment's database. Load specific fixtures using FIXTURES=x,y | ||
15 | -* rake db:indexes:missing - Prints a list of unindexed foreign keys so you can index them. | ||
16 | -* rake db:shell - Launches the database shell using the values defined in config/database.yml. | ||
17 | -* rake db:validate_models - Run model validations on all model records in database. | ||
18 | - | ||
19 | -h2. Git | ||
20 | - | ||
21 | -* rake git:push:staging - Merge a branch into the origin/staging branch. | ||
22 | -* rake git:push:production - Merge the staging branch into origin/production for launch. | ||
23 | -* rake git:diff:staging - Show the difference between current branch and origin/staging. | ||
24 | -* rake git:diff:production - Show the difference between origin/staging and origin/production. | ||
25 | -* rake git:pull:suspenders - Pull updates from suspenders, the thoughtbot rails template. | ||
26 | -* rake git:branch:production - Branch origin/production into BRANCH locally. | ||
27 | - | ||
28 | -h2. Backup | ||
29 | - | ||
30 | -* rake backup:db - Backup the current database. Timestamped file is created as :rails_root/../db-name-timestamp.sql | ||
31 | -* rake backup:assets - Backup all assets under public/system. File is created as :rails_root/../system.tgz | ||
32 | - | ||
33 | -h2. Haml & Sass | ||
34 | - | ||
35 | -* rake sass:all_css2sass - Convert all CSS files in public/stylesheets to Sass. | ||
36 | -* rake sass:all_sass2css - Convert all Sass files to CSS. | ||
37 | -* rake haml:all_html2haml - Convert all HTML files to Haml. | ||
38 | - | ||
39 | -h2. Rails 2+ | ||
40 | - | ||
41 | -* rake rails_two:rename_views - Renames all .rhtml views to .html.erb, .rjs to .js.rjs, .rxml to .xml.builder and .haml to .html.haml. | ||
42 | - | ||
43 | -h2. Subversion | ||
44 | - | ||
45 | -* rake svn:add - Adds all files with an svn status flag of '?' | ||
46 | -* rake svn:delete - Deletes all files with an svn status flag of '!' | ||
47 | -* rake svn:log - Writes the log file to doc/svn_log.txt | ||
48 | -* rake svn:update\_svn\_ignore - Updates svn:ignore from .svnignore | ||
49 | - | ||
50 | -h2. Test Coverage | ||
51 | - | ||
52 | -Install rcov from http://github.com/mergulhao/rcov | ||
53 | - | ||
54 | -* rake test:coverage - Uses rcov to provide reports about test coverage of your application. | ||
55 | - | ||
56 | -h2. Mass Assignment | ||
57 | - | ||
58 | -From "mhartl":http://github.com/mhartl/find_mass_assignment | ||
59 | - | ||
60 | -* rake find_mass_assignment | ||
61 | - | ||
62 | -The Limerick Rake | ||
63 | -================= | ||
64 | - | ||
65 | -Traditional Irish song. "YouTube":http://www.youtube.com/v/e8moLHIW8xw | ||
66 | - | ||
67 | - I am a young fellow that's easy and bold, | ||
68 | - In Castletown conners I'm very well known. | ||
69 | - In Newcastle West I spent many a note, | ||
70 | - With Kitty and Judy and Mary. | ||
71 | - | ||
72 | - My father rebuked me for being such a rake, | ||
73 | - And spending me time in such frolicsome ways, | ||
74 | - But I ne'er could forget the good nature of Jane, | ||
75 | - Agus fágaimíd siúd mar atá sé. | ||
76 | - | ||
77 | - My parents had reared me to shake and to mow, | ||
78 | - To plough and to harrow, to reap and to sow. | ||
79 | - But my heart being airy to drop it so low, | ||
80 | - I set out on high speculation. | ||
81 | - | ||
82 | - On paper and parchment they taught me to write, | ||
83 | - In Euclid and grammar they opened my eyes, | ||
84 | - And in multiplication in truth I was bright, | ||
85 | - Agus fágaimíd siúd mar atá sé. | ||
86 | - | ||
87 | - If I chance for to go to the town of Rathkeale, | ||
88 | - The girls all round me do flock on the square. | ||
89 | - Some give me a bottle and others sweet cakes, | ||
90 | - To treat me unknown to their parents. | ||
91 | - | ||
92 | - There is one from Askeaton and one from the Pike, | ||
93 | - Another from Arda, my heart was beguiled, | ||
94 | - Tho' being from the mountains her stockings are white, | ||
95 | - Agus fágaimíd siúd mar atá sé. | ||
96 | - | ||
97 | - To quarrel for riches I ne'er was inclined, | ||
98 | - For the greatest of misers that must leave all behind. | ||
99 | - I'll purchase a cow that will never run dry, | ||
100 | - And I'll milk her by twisting her horn. | ||
101 | - | ||
102 | - John Damer of Shronel had plenty of gold, | ||
103 | - And Lord Devonshire's treasures are twenty times more, | ||
104 | - But he's laid on his back among nettles and stones, | ||
105 | - Agus fágaimíd siúd mar atá sé. | ||
106 | - | ||
107 | - The old cow could be milked without clover or grass, | ||
108 | - She'd be pampered with corn, good barley and hops. | ||
109 | - She's warm and stout, and she's free in the paps, | ||
110 | - And she'll milk without spancil or halter. | ||
111 | - | ||
112 | - The man that will drink it will cock his caubeen, | ||
113 | - And if anyone laughs there'd be wigs on the green, | ||
114 | - And the feeble old hag will get supple and free, | ||
115 | - Agus fágaimíd siúd mar atá sé. | ||
116 | - | ||
117 | - There's some say I'm foolish and more say I'm wise, | ||
118 | - But being fond of the women I think is no crime, | ||
119 | - For the son of King David had ten hundred wives, | ||
120 | - And his wisdom was highly regarded. | ||
121 | - | ||
122 | - I'll take a good garden and live at my ease, | ||
123 | - And each woman and child can partake of the same, | ||
124 | - If there'd be war in the cabin, themselves they'd be to blame, | ||
125 | - Agus fágaimíd siúd mar atá sé. | ||
126 | - | ||
127 | - And now for the future I mean to be wise, | ||
128 | - And I'll send for the women that acted so kind, | ||
129 | - I'd marry them all on the morrow by and by, | ||
130 | - If the clergy agree to the bargain. | ||
131 | - | ||
132 | - And when I'd be old and my soul is at peace, | ||
133 | - These women will crowd for to cry at my wake, | ||
134 | - And their sons and their daughters will offer their prayer, | ||
135 | - To the Lord for the soul of their father. | ||
136 | - | ||
137 | -License | ||
138 | -------- | ||
139 | - | ||
140 | -MIT License, under the same terms as Ruby. |
vendor/plugins/limerick_rake/Rakefile
vendor/plugins/limerick_rake/lib/find_mass_assignment.rb
@@ -2,22 +2,22 @@ | @@ -2,22 +2,22 @@ | ||
2 | # http://github.com/mhartl/find_mass_assignment | 2 | # http://github.com/mhartl/find_mass_assignment |
3 | 3 | ||
4 | require 'active_support' | 4 | require 'active_support' |
5 | - | 5 | + |
6 | # Find potential mass assignment problems. | 6 | # Find potential mass assignment problems. |
7 | # The method is to scan the controllers for likely mass assignment, | 7 | # The method is to scan the controllers for likely mass assignment, |
8 | # and then find the corresponding models that *don't* have | 8 | # and then find the corresponding models that *don't* have |
9 | # attr_accessible defined. Any time that happens, it's a potential problem. | 9 | # attr_accessible defined. Any time that happens, it's a potential problem. |
10 | - | 10 | + |
11 | class String | 11 | class String |
12 | - | 12 | + |
13 | @@cache = {} | 13 | @@cache = {} |
14 | - | 14 | + |
15 | # A regex to match likely cases of mass assignment | 15 | # A regex to match likely cases of mass assignment |
16 | # Examples of matching strings: | 16 | # Examples of matching strings: |
17 | # "Foo.new( { :bar => 'baz' } )" | 17 | # "Foo.new( { :bar => 'baz' } )" |
18 | # "Foo.update_attributes!(params[:foo])" | 18 | # "Foo.update_attributes!(params[:foo])" |
19 | MASS_ASSIGNMENT = /(\w+)\.(new|create|update_attributes|build)!*\(/ | 19 | MASS_ASSIGNMENT = /(\w+)\.(new|create|update_attributes|build)!*\(/ |
20 | - | 20 | + |
21 | # Return the strings that represent potential mass assignment problems. | 21 | # Return the strings that represent potential mass assignment problems. |
22 | # The MASS_ASSIGNMENT regex returns, e.g., ['Post', 'new'] because of | 22 | # The MASS_ASSIGNMENT regex returns, e.g., ['Post', 'new'] because of |
23 | # the grouping methods; we want the first of the two for each match. | 23 | # the grouping methods; we want the first of the two for each match. |
@@ -28,17 +28,17 @@ class String | @@ -28,17 +28,17 @@ class String | ||
28 | def mass_assignment_models | 28 | def mass_assignment_models |
29 | scan(MASS_ASSIGNMENT).map { |problem| problem.first.classify } | 29 | scan(MASS_ASSIGNMENT).map { |problem| problem.first.classify } |
30 | end | 30 | end |
31 | - | 31 | + |
32 | # Return true if the string has potential mass assignment code. | 32 | # Return true if the string has potential mass assignment code. |
33 | def mass_assignment? | 33 | def mass_assignment? |
34 | self =~ MASS_ASSIGNMENT | 34 | self =~ MASS_ASSIGNMENT |
35 | end | 35 | end |
36 | - | 36 | + |
37 | # Return true if the model defines attr_accessible. | 37 | # Return true if the model defines attr_accessible. |
38 | # Note that 'attr_accessible' must be preceded by nothing other than | 38 | # Note that 'attr_accessible' must be preceded by nothing other than |
39 | # whitespace; this catches cases where attr_accessible is commented out. | 39 | # whitespace; this catches cases where attr_accessible is commented out. |
40 | def attr_accessible? | 40 | def attr_accessible? |
41 | - model = "#{RAILS_ROOT}/app/models/#{self.classify}.rb" | 41 | + model = "#{Rails.root.to_s}/app/models/#{self.classify}.rb" |
42 | if File.exist?(model) | 42 | if File.exist?(model) |
43 | return @@cache[model] unless @@cache[model].nil? | 43 | return @@cache[model] unless @@cache[model].nil? |
44 | @@cache[model] = File.open(model).read =~ /^\s*attr_accessible/ | 44 | @@cache[model] = File.open(model).read =~ /^\s*attr_accessible/ |
@@ -48,17 +48,17 @@ class String | @@ -48,17 +48,17 @@ class String | ||
48 | true | 48 | true |
49 | end | 49 | end |
50 | end | 50 | end |
51 | - | 51 | + |
52 | # Returnt true if a model does not define attr_accessible. | 52 | # Returnt true if a model does not define attr_accessible. |
53 | def problem? | 53 | def problem? |
54 | not attr_accessible? | 54 | not attr_accessible? |
55 | end | 55 | end |
56 | - | 56 | + |
57 | # Return true if a line has a problem model (no attr_accessible). | 57 | # Return true if a line has a problem model (no attr_accessible). |
58 | def problem_model? | 58 | def problem_model? |
59 | mass_assignment_models.find { |model| model.problem? } | 59 | mass_assignment_models.find { |model| model.problem? } |
60 | end | 60 | end |
61 | - | 61 | + |
62 | # Return true if a controller string has a (likely) mass assignment problem. | 62 | # Return true if a controller string has a (likely) mass assignment problem. |
63 | # This is true if at least one of the controller's lines | 63 | # This is true if at least one of the controller's lines |
64 | # (1) Has a likely mass assignment | 64 | # (1) Has a likely mass assignment |
@@ -67,9 +67,9 @@ class String | @@ -67,9 +67,9 @@ class String | ||
67 | File.open(self).find { |l| l.mass_assignment? and l.problem_model? } | 67 | File.open(self).find { |l| l.mass_assignment? and l.problem_model? } |
68 | end | 68 | end |
69 | end | 69 | end |
70 | - | 70 | + |
71 | module MassAssignment | 71 | module MassAssignment |
72 | - | 72 | + |
73 | def self.print_mass_assignment_problems(controller) | 73 | def self.print_mass_assignment_problems(controller) |
74 | lines = File.open(controller) | 74 | lines = File.open(controller) |
75 | lines.each_with_index do |line, number| | 75 | lines.each_with_index do |line, number| |
@@ -78,9 +78,9 @@ module MassAssignment | @@ -78,9 +78,9 @@ module MassAssignment | ||
78 | end | 78 | end |
79 | end | 79 | end |
80 | end | 80 | end |
81 | - | 81 | + |
82 | def self.find | 82 | def self.find |
83 | - controllers = Dir.glob("#{RAILS_ROOT}/app/controllers/*_controller.rb") | 83 | + controllers = Dir.glob("#{Rails.root.to_s}/app/controllers/*_controller.rb") |
84 | controllers.each do |controller| | 84 | controllers.each do |controller| |
85 | if controller.mass_assignment_problem? | 85 | if controller.mass_assignment_problem? |
86 | puts "\n#{controller}" | 86 | puts "\n#{controller}" |
@@ -88,4 +88,4 @@ module MassAssignment | @@ -88,4 +88,4 @@ module MassAssignment | ||
88 | end | 88 | end |
89 | end | 89 | end |
90 | end | 90 | end |
91 | -end | ||
92 | \ No newline at end of file | 91 | \ No newline at end of file |
92 | +end |
vendor/plugins/limerick_rake/lib/limerick_rake/engine.rb
0 → 100644
vendor/plugins/limerick_rake/lib/limerick_rake/version.rb
0 → 100644
@@ -0,0 +1,40 @@ | @@ -0,0 +1,40 @@ | ||
1 | +require 'fileutils' | ||
2 | +require 'pathname' | ||
3 | + | ||
4 | +namespace :backup do | ||
5 | + desc "Backup the current database. Timestamped file is created as :rails_root/../db-name-timestamp.sql" | ||
6 | + task :db => :environment do | ||
7 | + config = ActiveRecord::Base.configurations[Rails.env || 'development'] | ||
8 | + filename = "#{config['database'].gsub(/_/, '-')}-#{Time.now.strftime('%Y-%m-%d-%H-%M-%S')}.sql" | ||
9 | + backupdir = File.expand_path(File.join(Rails.root.to_s, '..')) | ||
10 | + filepath = File.join(backupdir, filename) | ||
11 | + mysqldump = `which mysqldump`.strip | ||
12 | + options = "-e -u #{config['username']}" | ||
13 | + options += " -p'#{config['password']}'" if config['password'] | ||
14 | + options += " -h #{config['host']}" if config['host'] | ||
15 | + options += " -S #{config['socket']}" if config['socket'] | ||
16 | + | ||
17 | + raise RuntimeError, "I only work with mysql." unless config['adapter'] == 'mysql' | ||
18 | + raise RuntimeError, "Cannot find mysqldump." if mysqldump.blank? | ||
19 | + | ||
20 | + FileUtils.mkdir_p backupdir | ||
21 | + `#{mysqldump} #{options} #{config['database']} > #{filepath}` | ||
22 | + puts "#{config['database']} => #{filepath}" | ||
23 | + end | ||
24 | + | ||
25 | + | ||
26 | + desc "Backup all assets under public/system. File is created as :rails_root/../system.tgz" | ||
27 | + task :assets do | ||
28 | + path = (Pathname.new(Rails.root.to_s) + 'public' + 'system').realpath | ||
29 | + base_dir = path.parent | ||
30 | + system_dir = path.basename | ||
31 | + outfile = (Pathname.new(Rails.root.to_s) + '..').realpath + 'system.tgz' | ||
32 | + | ||
33 | + cd base_dir | ||
34 | + `tar -czf #{outfile} #{system_dir}` | ||
35 | + puts "Assets => #{outfile}" | ||
36 | + end | ||
37 | +end | ||
38 | + | ||
39 | +desc 'Backup the database and all assets by running the backup:db and backup:assets tasks.' | ||
40 | +task :backup => ["backup:db", "backup:assets"] |
@@ -0,0 +1,14 @@ | @@ -0,0 +1,14 @@ | ||
1 | +namespace :test do | ||
2 | + | ||
3 | + desc 'Measures test coverage' | ||
4 | + task :coverage do | ||
5 | + rm_f "coverage" | ||
6 | + rm_f "coverage.data" | ||
7 | + rcov = "rcov -Itest --rails --aggregate coverage.data -T -x \" rubygems/*,/Library/Ruby/Site/*,gems/*,rcov*\"" | ||
8 | + system("#{rcov} --no-html test/unit/*_test.rb test/unit/helpers/*_test.rb") | ||
9 | + system("#{rcov} --no-html test/functional/*_test.rb") | ||
10 | + system("#{rcov} --html test/integration/*_test.rb") | ||
11 | + system("open coverage/index.html") if PLATFORM['darwin'] | ||
12 | + end | ||
13 | + | ||
14 | +end |
vendor/plugins/limerick_rake/lib/tasks/db/bootstrap.rake
0 → 100644
@@ -0,0 +1,15 @@ | @@ -0,0 +1,15 @@ | ||
1 | +namespace :db do | ||
2 | + desc "Loads a schema.rb file into the database and then loads the initial database fixtures." | ||
3 | + task :bootstrap => ['db:schema:load', 'db:bootstrap:load'] | ||
4 | + | ||
5 | + namespace :bootstrap do | ||
6 | + desc "Load initial database fixtures (in db/bootstrap/*.yml) into the current environment's database. Load specific fixtures using FIXTURES=x,y" | ||
7 | + task :load => :environment do | ||
8 | + require 'active_record/fixtures' | ||
9 | + ActiveRecord::Base.establish_connection(Rails.env.to_sym) | ||
10 | + (ENV['FIXTURES'] ? ENV['FIXTURES'].split(/,/) : Dir.glob(File.join(Rails.root.to_s, 'db', 'bootstrap', '*.{yml,csv}'))).each do |fixture_file| | ||
11 | + Fixtures.create_fixtures('db/bootstrap', File.basename(fixture_file, '.*')) | ||
12 | + end | ||
13 | + end | ||
14 | + end | ||
15 | +end |
@@ -0,0 +1,22 @@ | @@ -0,0 +1,22 @@ | ||
1 | +namespace :db do | ||
2 | + namespace :indexes do | ||
3 | + desc "Prints a list of unindexed foreign keys so you can index them" | ||
4 | + task :missing => :environment do | ||
5 | + indexes = {} | ||
6 | + conn = ActiveRecord::Base.connection | ||
7 | + conn.tables.each do |table| | ||
8 | + indexed_columns = conn.indexes(table).map { |i| i.columns }.flatten | ||
9 | + conn.columns(table).each do |column| | ||
10 | + if column.name.match(/_id$/) && !indexed_columns.include?(column.name) | ||
11 | + indexes[table] ||= [] | ||
12 | + indexes[table] << column.name | ||
13 | + end | ||
14 | + end | ||
15 | + end | ||
16 | + puts "Foreign Keys:" | ||
17 | + indexes.sort.each do |table, columns| | ||
18 | + puts columns.map { |c| "\s\sadd_index '#{table}', '#{c}'\n"} | ||
19 | + end | ||
20 | + end | ||
21 | + end | ||
22 | +end |
@@ -0,0 +1,26 @@ | @@ -0,0 +1,26 @@ | ||
1 | +namespace :db do | ||
2 | + desc 'Launches the database shell using the values defined in config/database.yml' | ||
3 | + task :shell => :environment do | ||
4 | + config = ActiveRecord::Base.configurations[Rails.env || 'development'] | ||
5 | + command = "" | ||
6 | + | ||
7 | + case config['adapter'] | ||
8 | + when 'mysql' | ||
9 | + command << "mysql " | ||
10 | + command << "--host=#{config['host'] || 'localhost'} " | ||
11 | + command << "--port=#{config['port'] || 3306} " | ||
12 | + command << "--user=#{config['username'] || 'root'} " | ||
13 | + command << "--password=#{config['password'] || ''} " | ||
14 | + command << config['database'] | ||
15 | + when 'postgresql' | ||
16 | + command << "psql " | ||
17 | + command << "-h #{config['host'] || 'localhost'} " | ||
18 | + command << "-p #{config['port'] || 5432} " | ||
19 | + command << "-U #{config['username'] || 'postgres'} " | ||
20 | + command << "\"dbname=#{config['database']} password=#{config['password']}\"" | ||
21 | + else | ||
22 | + command << "echo Unsupported database adapter: #{config['adapter']}" | ||
23 | + end | ||
24 | + system command | ||
25 | + end | ||
26 | +end |
vendor/plugins/limerick_rake/lib/tasks/db/validate_models.rake
0 → 100644
@@ -0,0 +1,31 @@ | @@ -0,0 +1,31 @@ | ||
1 | +namespace :db do | ||
2 | + # From http://blog.hasmanythrough.com/2006/8/27/validate-all-your-records | ||
3 | + desc "Run model validations on all model records in database" | ||
4 | + task :validate_models => :environment do | ||
5 | + # because rails loads stuff on demand... | ||
6 | + Dir.glob(Rails.root.to_s + '/app/models/**/*.rb').each do |file| | ||
7 | + silence_warnings do | ||
8 | + require file | ||
9 | + end | ||
10 | + end | ||
11 | + | ||
12 | + Object.subclasses_of(ActiveRecord::Base).select { |c| c.base_class == c}.sort_by(&:name).each do |klass| | ||
13 | + next if klass.name == "CGI::Session::ActiveRecordStore::Session" | ||
14 | + unless klass.table_exists? | ||
15 | + puts "WARNING: Could not find table for #{klass} (skipping)" | ||
16 | + next | ||
17 | + end | ||
18 | + invalid_count = 0 | ||
19 | + total = klass.count | ||
20 | + chunk_size = 1000 | ||
21 | + (total / chunk_size + 1).times do |i| | ||
22 | + chunk = klass.find(:all, :offset => (i * chunk_size), :limit => chunk_size) | ||
23 | + chunk.reject(&:valid?).each do |record| | ||
24 | + invalid_count += 1 | ||
25 | + puts "#{klass} #{record.id}: #{record.errors.full_messages.to_sentence}" | ||
26 | + end rescue nil | ||
27 | + end | ||
28 | + puts "#{invalid_count} of #{total} #{klass.name.pluralize} are invalid." if invalid_count > 0 | ||
29 | + end | ||
30 | + end | ||
31 | +end |
vendor/plugins/limerick_rake/lib/tasks/find_mass_assignment_tasks.rake
0 → 100644
@@ -0,0 +1,109 @@ | @@ -0,0 +1,109 @@ | ||
1 | +module GitCommands | ||
2 | + class ShellError < RuntimeError; end | ||
3 | + | ||
4 | + @logging = ENV['LOGGING'] != "false" | ||
5 | + | ||
6 | + def self.run cmd, *expected_exitstatuses | ||
7 | + puts "+ #{cmd}" if @logging | ||
8 | + output = `#{cmd} 2>&1` | ||
9 | + puts output.gsub(/^/, "- ") if @logging | ||
10 | + expected_exitstatuses << 0 if expected_exitstatuses.empty? | ||
11 | + raise ShellError.new("ERROR: '#{cmd}' failed with exit status #{$?.exitstatus}") unless | ||
12 | + [expected_exitstatuses].flatten.include?( $?.exitstatus ) | ||
13 | + output | ||
14 | + end | ||
15 | + | ||
16 | + def self.current_branch | ||
17 | + run("git branch --no-color | grep '*' | cut -d ' ' -f 2").chomp | ||
18 | + end | ||
19 | + | ||
20 | + def self.remote_branch_exists?(branch) | ||
21 | + ! run("git branch -r --no-color | grep '#{branch}'").empty? | ||
22 | + end | ||
23 | + | ||
24 | + def self.ensure_clean_working_directory! | ||
25 | + return if run("git status", 0, 1).match(/working directory clean/) | ||
26 | + raise "Must have clean working directory" | ||
27 | + end | ||
28 | + | ||
29 | + def self.diff_staging | ||
30 | + puts run("git diff HEAD origin/staging") | ||
31 | + end | ||
32 | + | ||
33 | + def self.diff_production | ||
34 | + puts run("git diff origin/staging origin/production") | ||
35 | + end | ||
36 | + | ||
37 | + def self.push(src_branch, dst_branch) | ||
38 | + raise "origin/#{dst_branch} branch does not exist" unless remote_branch_exists?("origin/#{dst_branch}") | ||
39 | + ensure_clean_working_directory! | ||
40 | + begin | ||
41 | + run "git fetch" | ||
42 | + run "git push -f origin #{src_branch}:#{dst_branch}" | ||
43 | + rescue | ||
44 | + puts "Pushing #{src_branch} to origin/#{dst_branch} failed." | ||
45 | + raise | ||
46 | + end | ||
47 | + end | ||
48 | + | ||
49 | + def self.push_staging | ||
50 | + push(current_branch, "staging") | ||
51 | + end | ||
52 | + | ||
53 | + def self.push_production | ||
54 | + push("origin/staging", "production") | ||
55 | + end | ||
56 | + | ||
57 | + def self.branch_production(branch) | ||
58 | + raise "You must specify a branch name." if branch.blank? | ||
59 | + ensure_clean_working_directory! | ||
60 | + run "git fetch" | ||
61 | + run "git branch -f #{branch} origin/production" | ||
62 | + run "git checkout #{branch}" | ||
63 | + end | ||
64 | + | ||
65 | + def self.pull_template | ||
66 | + ensure_clean_working_directory! | ||
67 | + run "git pull git://github.com/thoughtbot/suspenders.git master" | ||
68 | + end | ||
69 | +end | ||
70 | + | ||
71 | +namespace :git do | ||
72 | + namespace :push do | ||
73 | + desc "Reset origin's staging branch to be the current branch." | ||
74 | + task :staging do | ||
75 | + GitCommands.push_staging | ||
76 | + end | ||
77 | + | ||
78 | + desc "Reset origin's production branch to origin's staging branch." | ||
79 | + task :production do | ||
80 | + GitCommands.push_production | ||
81 | + end | ||
82 | + end | ||
83 | + | ||
84 | + namespace :diff do | ||
85 | + desc "Show the difference between current branch and origin/staging." | ||
86 | + task :staging do | ||
87 | + GitCommands.diff_staging | ||
88 | + end | ||
89 | + | ||
90 | + desc "Show the difference between origin/staging and origin/production." | ||
91 | + task :production do | ||
92 | + GitCommands.diff_production | ||
93 | + end | ||
94 | + end | ||
95 | + | ||
96 | + namespace :pull do | ||
97 | + desc "Pull updates from suspenders, the thoughtbot rails template." | ||
98 | + task :suspenders do | ||
99 | + GitCommands.pull_template | ||
100 | + end | ||
101 | + end | ||
102 | + | ||
103 | + namespace :branch do | ||
104 | + desc "Branch origin/production into BRANCH locally." | ||
105 | + task :production do | ||
106 | + GitCommands.branch_production(branch) | ||
107 | + end | ||
108 | + end | ||
109 | +end |
@@ -0,0 +1,77 @@ | @@ -0,0 +1,77 @@ | ||
1 | +# Dan Croak, February 2008 | ||
2 | + | ||
3 | +@css_dir = "#{Rails.root.to_s}/public/stylesheets" | ||
4 | +@sass_dir = "#{@css_dir}/sass" | ||
5 | +@views_dir = "#{Rails.root.to_s}/app/views" | ||
6 | + | ||
7 | +def convert_css_to_sass(basename) | ||
8 | + system "css2sass #{@css_dir}/#{basename}.css > #{@sass_dir}/#{basename}.sass" | ||
9 | +end | ||
10 | + | ||
11 | +def convert_sass_to_css(basename) | ||
12 | + system "sass #{@sass_dir}/#{basename}.sass > #{@css_dir}/#{basename}.css" | ||
13 | +end | ||
14 | + | ||
15 | +def convert_html_to_haml(controller, basename) | ||
16 | + extname = basename.include?("erb") ? ".html.erb" : ".rhtml" | ||
17 | + basename = basename.split(".").first | ||
18 | + system "html2haml #{@views_dir}/#{controller}/#{basename}#{extname} > #{@views_dir}/#{controller}/#{basename}.html.haml" | ||
19 | + system "rm #{@views_dir}/#{controller}/#{basename}#{extname}" | ||
20 | +end | ||
21 | + | ||
22 | +namespace :sass do | ||
23 | + desc "Convert all CSS files to Sass." | ||
24 | + task :all_css2sass => :environment do | ||
25 | + begin | ||
26 | + Dir.mkdir(@sass_dir) | ||
27 | + rescue Exception => e | ||
28 | + nil | ||
29 | + end | ||
30 | + | ||
31 | + files = Dir.entries(@css_dir).find_all do |f| | ||
32 | + File.extname("#{@css_dir}/#{f}") == ".css" && | ||
33 | + File.basename("#{@css_dir}/#{f}") !~ /^[.]/ | ||
34 | + end | ||
35 | + | ||
36 | + files.each do |filename| | ||
37 | + basename = File.basename("#{@css_dir}/#{filename}", ".css") | ||
38 | + convert_css_to_sass basename | ||
39 | + convert_sass_to_css basename | ||
40 | + end | ||
41 | + end | ||
42 | + | ||
43 | + desc "Convert all Sass files to CSS." | ||
44 | + task :all_sass2css => :environment do | ||
45 | + files = Dir.entries(@sass_dir).find_all do |f| | ||
46 | + File.extname("#{@sass_dir}/#{f}") == ".sass" && | ||
47 | + File.basename("#{@sass_dir}/#{f}") !~ /^[.]/ | ||
48 | + end | ||
49 | + | ||
50 | + files.each do |filename| | ||
51 | + basename = File.basename("#{@sass_dir}/#{filename}", ".sass") | ||
52 | + convert_sass_to_css basename | ||
53 | + end | ||
54 | + end | ||
55 | +end | ||
56 | + | ||
57 | +namespace :haml do | ||
58 | + desc "Convert all HTML files to Haml." | ||
59 | + task :all_html2haml => :environment do | ||
60 | + controllers = Dir.entries(@views_dir).find_all do |c| | ||
61 | + File.directory?("#{@views_dir}/#{c}") && | ||
62 | + File.basename("#{@views_dir}/#{c}") !~ /^[.]/ | ||
63 | + end | ||
64 | + | ||
65 | + controllers.each do |controller| | ||
66 | + files = Dir.entries("#{@views_dir}/#{controller}").find_all do |f| | ||
67 | + (File.new("#{@views_dir}/#{controller}/#{f}").path.include?(".html.erb") || | ||
68 | + File.new("#{@views_dir}/#{controller}/#{f}").path.include?(".rhtml")) && | ||
69 | + File.basename("#{@views_dir}/#{controller}/#{f}") !~ /^[.]/ | ||
70 | + end | ||
71 | + files.each do |filename| | ||
72 | + basename = File.basename("#{@views_dir}/#{controller}/#{filename}") | ||
73 | + convert_html_to_haml controller, basename | ||
74 | + end | ||
75 | + end | ||
76 | + end | ||
77 | +end |
@@ -0,0 +1,20 @@ | @@ -0,0 +1,20 @@ | ||
1 | +desc 'Renames all .rhtml views to .html.erb, .rjs to .js.rjs, .rxml to .xml.builder and .haml to .html.haml' | ||
2 | +namespace :rails_two do | ||
3 | + task :rename_views do | ||
4 | + Dir.glob('app/views/**/[^_]*.rhtml').each do |file| | ||
5 | + puts `git mv #{file} #{file.gsub(/\.rhtml$/, '.html.erb')}` | ||
6 | + end | ||
7 | + | ||
8 | + Dir.glob('app/views/**/[^_]*.rjs').each do |file| | ||
9 | + puts `git mv #{file} #{file.gsub(/\.rjs$/, '.js.rjs')}` | ||
10 | + end | ||
11 | + | ||
12 | + Dir.glob('app/views/**/[^_]*.rxml').each do |file| | ||
13 | + puts `git mv #{file} #{file.gsub(/\.rxml$/, '.xml.builder')}` | ||
14 | + end | ||
15 | + | ||
16 | + Dir.glob('app/views/**/[^_]*.haml').each do |file| | ||
17 | + puts `git mv #{file} #{file.gsub(/\.haml$/, '.html.haml')}` | ||
18 | + end | ||
19 | + end | ||
20 | +end |
@@ -0,0 +1,21 @@ | @@ -0,0 +1,21 @@ | ||
1 | +# Pulled together from various mailing lists. | ||
2 | + | ||
3 | +namespace :svn do | ||
4 | + desc "Adds all files with an svn status flag of '?'" | ||
5 | + task(:add) { system %q(svn status | awk '/\\?/ {print $2}' | xargs svn add) } | ||
6 | + | ||
7 | + desc "Deletes all files with an svn status flag of '!'" | ||
8 | + task(:delete) { system %q(svn status | awk '/\\!/ {print $2}' | xargs svn delete) } | ||
9 | + | ||
10 | + desc "Writes the log file to doc/svn_log.txt" | ||
11 | + task(:log) do | ||
12 | + File.delete("#{Rails.root.to_s}/doc/svn_log.txt") if File::exists?("#{Rails.root.to_s}/doc/svn_log.txt") | ||
13 | + File.new("#{Rails.root.to_s}/doc/svn_log.txt", "w+") | ||
14 | + system("svn log >> doc/svn_log.txt") | ||
15 | + end | ||
16 | + | ||
17 | + desc 'Updates svn:ignore from .svnignore' | ||
18 | + task(:update_svn_ignore) do | ||
19 | + system %q(svn propset svn:ignore -F .svnignore .) | ||
20 | + end | ||
21 | +end |
vendor/plugins/limerick_rake/limerick_rake.gemspec
1 | +# -*- encoding: utf-8 -*- | ||
2 | +$:.push File.expand_path("../lib", __FILE__) | ||
3 | +require "limerick_rake/version" | ||
4 | + | ||
1 | Gem::Specification.new do |s| | 5 | Gem::Specification.new do |s| |
2 | - s.name = "limerick_rake" | ||
3 | - s.version = "0.0.2" | ||
4 | - s.date = "2008-10-07" | ||
5 | - s.summary = "A collection of useful rake tasks." | ||
6 | - s.email = "support@thoughtbot.com" | ||
7 | - s.homepage = "http://github.com/thoughtbot/limerick_rake" | 6 | + s.name = "limerick_rake" |
7 | + s.version = LimerickRake::VERSION.dup | ||
8 | + s.platform = Gem::Platform::RUBY | ||
9 | + s.authors = ["the Ruby community", "thoughtbot, inc."] | ||
10 | + s.email = "support@thoughtbot.com" | ||
11 | + s.homepage = "http://github.com/thoughtbot/limerick_rake" | ||
12 | + s.summary = "A collection of useful rake tasks." | ||
8 | s.description = "A collection of useful rake tasks." | 13 | s.description = "A collection of useful rake tasks." |
9 | - s.authors = ["the Ruby community", "thoughtbot, inc."] | ||
10 | - s.files = ["README.textile", | ||
11 | - "limerick_rake.gemspec", | ||
12 | - "tasks/backup.rake", | ||
13 | - "tasks/db/bootstrap.rake", | ||
14 | - "tasks/db/indexes.rake", | ||
15 | - "tasks/db/shell.rake", | ||
16 | - "tasks/db/validate_models.rake", | ||
17 | - "tasks/git.rake", | ||
18 | - "tasks/haml_sass.rake", | ||
19 | - "tasks/svn.rake"] | ||
20 | -end | ||
21 | \ No newline at end of file | 14 | \ No newline at end of file |
15 | + | ||
16 | + s.files = `git ls-files`.split("\n") | ||
17 | + s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n") | ||
18 | + s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) } | ||
19 | + s.require_paths = ["lib"] | ||
20 | +end |
vendor/plugins/limerick_rake/tasks/backup.rake
@@ -1,39 +0,0 @@ | @@ -1,39 +0,0 @@ | ||
1 | -require 'fileutils' | ||
2 | -require 'pathname' | ||
3 | - | ||
4 | -namespace :backup do | ||
5 | - desc "Backup the current database. Timestamped file is created as :rails_root/../db-name-timestamp.sql" | ||
6 | - task :db => :environment do | ||
7 | - config = ActiveRecord::Base.configurations[RAILS_ENV || 'development'] | ||
8 | - filename = "#{config['database'].gsub(/_/, '-')}-#{Time.now.strftime('%Y-%m-%d-%H-%M-%S')}.sql" | ||
9 | - backupdir = File.expand_path(File.join(RAILS_ROOT, '..')) | ||
10 | - filepath = File.join(backupdir, filename) | ||
11 | - mysqldump = `which mysqldump`.strip | ||
12 | - options = "-e -u #{config['username']}" | ||
13 | - options += " -p#{config['password']}" if config['password'] | ||
14 | - options += " -h #{config['host']}" if config['host'] | ||
15 | - | ||
16 | - raise RuntimeError, "I only work with mysql." unless config['adapter'] == 'mysql' | ||
17 | - raise RuntimeError, "Cannot find mysqldump." if mysqldump.blank? | ||
18 | - | ||
19 | - FileUtils.mkdir_p backupdir | ||
20 | - `#{mysqldump} #{options} #{config['database']} > #{filepath}` | ||
21 | - puts "#{config['database']} => #{filepath}" | ||
22 | - end | ||
23 | - | ||
24 | - | ||
25 | - desc "Backup all assets under public/system. File is created as :rails_root/../system.tgz" | ||
26 | - task :assets do | ||
27 | - path = (Pathname.new(RAILS_ROOT) + 'public' + 'system').realpath | ||
28 | - base_dir = path.parent | ||
29 | - system_dir = path.basename | ||
30 | - outfile = (Pathname.new(RAILS_ROOT) + '..').realpath + 'system.tgz' | ||
31 | - | ||
32 | - cd base_dir | ||
33 | - `tar -czf #{outfile} #{system_dir}` | ||
34 | - puts "Assets => #{outfile}" | ||
35 | - end | ||
36 | -end | ||
37 | - | ||
38 | -desc 'Backup the database and all assets by running the backup:db and backup:assets tasks.' | ||
39 | -task :backup => ["backup:db", "backup:assets"] |
vendor/plugins/limerick_rake/tasks/coverage.rake
@@ -1,14 +0,0 @@ | @@ -1,14 +0,0 @@ | ||
1 | -namespace :test do | ||
2 | - | ||
3 | - desc 'Measures test coverage' | ||
4 | - task :coverage do | ||
5 | - rm_f "coverage" | ||
6 | - rm_f "coverage.data" | ||
7 | - rcov = "rcov -Itest --rails --aggregate coverage.data -T -x \" rubygems/*,/Library/Ruby/Site/*,gems/*,rcov*\"" | ||
8 | - system("#{rcov} --no-html test/unit/*_test.rb test/unit/helpers/*_test.rb") | ||
9 | - system("#{rcov} --no-html test/functional/*_test.rb") | ||
10 | - system("#{rcov} --html test/integration/*_test.rb") | ||
11 | - system("open coverage/index.html") if PLATFORM['darwin'] | ||
12 | - end | ||
13 | - | ||
14 | -end |
vendor/plugins/limerick_rake/tasks/db/bootstrap.rake
@@ -1,15 +0,0 @@ | @@ -1,15 +0,0 @@ | ||
1 | -namespace :db do | ||
2 | - desc "Loads a schema.rb file into the database and then loads the initial database fixtures." | ||
3 | - task :bootstrap => ['db:schema:load', 'db:bootstrap:load'] | ||
4 | - | ||
5 | - namespace :bootstrap do | ||
6 | - desc "Load initial database fixtures (in db/bootstrap/*.yml) into the current environment's database. Load specific fixtures using FIXTURES=x,y" | ||
7 | - task :load => :environment do | ||
8 | - require 'active_record/fixtures' | ||
9 | - ActiveRecord::Base.establish_connection(RAILS_ENV.to_sym) | ||
10 | - (ENV['FIXTURES'] ? ENV['FIXTURES'].split(/,/) : Dir.glob(File.join(RAILS_ROOT, 'db', 'bootstrap', '*.{yml,csv}'))).each do |fixture_file| | ||
11 | - Fixtures.create_fixtures('db/bootstrap', File.basename(fixture_file, '.*')) | ||
12 | - end | ||
13 | - end | ||
14 | - end | ||
15 | -end |
vendor/plugins/limerick_rake/tasks/db/indexes.rake
@@ -1,22 +0,0 @@ | @@ -1,22 +0,0 @@ | ||
1 | -namespace :db do | ||
2 | - namespace :indexes do | ||
3 | - desc "Prints a list of unindexed foreign keys so you can index them" | ||
4 | - task :missing => :environment do | ||
5 | - indexes = {} | ||
6 | - conn = ActiveRecord::Base.connection | ||
7 | - conn.tables.each do |table| | ||
8 | - indexed_columns = conn.indexes(table).map { |i| i.columns }.flatten | ||
9 | - conn.columns(table).each do |column| | ||
10 | - if column.name.match(/_id/) && !indexed_columns.include?(column.name) | ||
11 | - indexes[table] ||= [] | ||
12 | - indexes[table] << column.name | ||
13 | - end | ||
14 | - end | ||
15 | - end | ||
16 | - puts "Foreign Keys:" | ||
17 | - indexes.each do |table, columns| | ||
18 | - puts columns.map { |c| "\s\sadd_index '#{table}', '#{c}'\n"} | ||
19 | - end | ||
20 | - end | ||
21 | - end | ||
22 | -end | ||
23 | \ No newline at end of file | 0 | \ No newline at end of file |
vendor/plugins/limerick_rake/tasks/db/shell.rake
@@ -1,23 +0,0 @@ | @@ -1,23 +0,0 @@ | ||
1 | -namespace :db do | ||
2 | - desc 'Launches the database shell using the values defined in config/database.yml' | ||
3 | - task :shell => :environment do | ||
4 | - config = ActiveRecord::Base.configurations[RAILS_ENV || 'development'] | ||
5 | - command = "" | ||
6 | - | ||
7 | - case config['adapter'] | ||
8 | - when 'mysql' | ||
9 | - command << "mysql " | ||
10 | - command << "--host=#{config['host'] || 'localhost'} " | ||
11 | - command << "--port=#{config['port'] || 3306} " | ||
12 | - command << "--user=#{config['username'] || 'root'} " | ||
13 | - command << "--password=#{config['password'] || ''} " | ||
14 | - command << config['database'] | ||
15 | - when 'postgresql' | ||
16 | - puts 'You should consider switching to MySQL or get off your butt and submit a patch' | ||
17 | - else | ||
18 | - command << "echo Unsupported database adapter: #{config['adapter']}" | ||
19 | - end | ||
20 | - | ||
21 | - system command | ||
22 | - end | ||
23 | -end | ||
24 | \ No newline at end of file | 0 | \ No newline at end of file |
vendor/plugins/limerick_rake/tasks/db/validate_models.rake
@@ -1,27 +0,0 @@ | @@ -1,27 +0,0 @@ | ||
1 | -namespace :db do | ||
2 | - # From http://blog.hasmanythrough.com/2006/8/27/validate-all-your-records | ||
3 | - desc "Run model validations on all model records in database" | ||
4 | - task :validate_models => :environment do | ||
5 | - # because rails loads stuff on demand... | ||
6 | - Dir.glob(RAILS_ROOT + '/app/models/**/*.rb').each do |file| | ||
7 | - silence_warnings do | ||
8 | - require file | ||
9 | - end | ||
10 | - end | ||
11 | - | ||
12 | - Object.subclasses_of(ActiveRecord::Base).select { |c| c.base_class == c}.sort_by(&:name).each do |klass| | ||
13 | - next if klass.name == "CGI::Session::ActiveRecordStore::Session" | ||
14 | - invalid_count = 0 | ||
15 | - total = klass.count | ||
16 | - chunk_size = 1000 | ||
17 | - (total / chunk_size + 1).times do |i| | ||
18 | - chunk = klass.find(:all, :offset => (i * chunk_size), :limit => chunk_size) | ||
19 | - chunk.reject(&:valid?).each do |record| | ||
20 | - invalid_count += 1 | ||
21 | - puts "#{klass} #{record.id}: #{record.errors.full_messages.to_sentence}" | ||
22 | - end rescue nil | ||
23 | - end | ||
24 | - puts "#{invalid_count} of #{total} #{klass.name.pluralize} are invalid." if invalid_count > 0 | ||
25 | - end | ||
26 | - end | ||
27 | -end |
vendor/plugins/limerick_rake/tasks/find_mass_assignment_tasks.rake
vendor/plugins/limerick_rake/tasks/git.rake
@@ -1,109 +0,0 @@ | @@ -1,109 +0,0 @@ | ||
1 | -module GitCommands | ||
2 | - class ShellError < RuntimeError; end | ||
3 | - | ||
4 | - @logging = ENV['LOGGING'] != "false" | ||
5 | - | ||
6 | - def self.run cmd, *expected_exitstatuses | ||
7 | - puts "+ #{cmd}" if @logging | ||
8 | - output = `#{cmd} 2>&1` | ||
9 | - puts output.gsub(/^/, "- ") if @logging | ||
10 | - expected_exitstatuses << 0 if expected_exitstatuses.empty? | ||
11 | - raise ShellError.new("ERROR: '#{cmd}' failed with exit status #{$?.exitstatus}") unless | ||
12 | - [expected_exitstatuses].flatten.include?( $?.exitstatus ) | ||
13 | - output | ||
14 | - end | ||
15 | - | ||
16 | - def self.current_branch | ||
17 | - run("git branch --no-color | grep '*' | cut -d ' ' -f 2").chomp | ||
18 | - end | ||
19 | - | ||
20 | - def self.remote_branch_exists?(branch) | ||
21 | - ! run("git branch -r --no-color | grep '#{branch}'").blank? | ||
22 | - end | ||
23 | - | ||
24 | - def self.ensure_clean_working_directory! | ||
25 | - return if run("git status", 0, 1).match(/working directory clean/) | ||
26 | - raise "Must have clean working directory" | ||
27 | - end | ||
28 | - | ||
29 | - def self.diff_staging | ||
30 | - puts run("git diff HEAD origin/staging") | ||
31 | - end | ||
32 | - | ||
33 | - def self.diff_production | ||
34 | - puts run("git diff origin/staging origin/production") | ||
35 | - end | ||
36 | - | ||
37 | - def self.push(src_branch, dst_branch) | ||
38 | - raise "origin/#{dst_branch} branch does not exist" unless remote_branch_exists?("origin/#{dst_branch}") | ||
39 | - ensure_clean_working_directory! | ||
40 | - begin | ||
41 | - run "git fetch" | ||
42 | - run "git push -f origin #{src_branch}:#{dst_branch}" | ||
43 | - rescue | ||
44 | - puts "Pushing #{src_branch} to origin/#{dst_branch} failed." | ||
45 | - raise | ||
46 | - end | ||
47 | - end | ||
48 | - | ||
49 | - def self.push_staging | ||
50 | - push(current_branch, "staging") | ||
51 | - end | ||
52 | - | ||
53 | - def self.push_production | ||
54 | - push("origin/staging", "production") | ||
55 | - end | ||
56 | - | ||
57 | - def self.branch_production(branch) | ||
58 | - raise "You must specify a branch name." if branch.blank? | ||
59 | - ensure_clean_working_directory! | ||
60 | - run "git fetch" | ||
61 | - run "git branch -f #{branch} origin/production" | ||
62 | - run "git checkout #{branch}" | ||
63 | - end | ||
64 | - | ||
65 | - def self.pull_template | ||
66 | - ensure_clean_working_directory! | ||
67 | - run "git pull git://github.com/thoughtbot/suspenders.git master" | ||
68 | - end | ||
69 | -end | ||
70 | - | ||
71 | -namespace :git do | ||
72 | - namespace :push do | ||
73 | - desc "Reset origin's staging branch to be the current branch." | ||
74 | - task :staging do | ||
75 | - GitCommands.push_staging | ||
76 | - end | ||
77 | - | ||
78 | - desc "Reset origin's production branch to origin's staging branch." | ||
79 | - task :production do | ||
80 | - GitCommands.push_production | ||
81 | - end | ||
82 | - end | ||
83 | - | ||
84 | - namespace :diff do | ||
85 | - desc "Show the difference between current branch and origin/staging." | ||
86 | - task :staging do | ||
87 | - GitCommands.diff_staging | ||
88 | - end | ||
89 | - | ||
90 | - desc "Show the difference between origin/staging and origin/production." | ||
91 | - task :production do | ||
92 | - GitCommands.diff_production | ||
93 | - end | ||
94 | - end | ||
95 | - | ||
96 | - namespace :pull do | ||
97 | - desc "Pull updates from suspenders, the thoughtbot rails template." | ||
98 | - task :suspenders do | ||
99 | - GitCommands.pull_template | ||
100 | - end | ||
101 | - end | ||
102 | - | ||
103 | - namespace :branch do | ||
104 | - desc "Branch origin/production into BRANCH locally." | ||
105 | - task :production do | ||
106 | - GitCommands.branch_production(branch) | ||
107 | - end | ||
108 | - end | ||
109 | -end |
vendor/plugins/limerick_rake/tasks/haml_sass.rake
@@ -1,78 +0,0 @@ | @@ -1,78 +0,0 @@ | ||
1 | -# Dan Croak, February 2008 | ||
2 | - | ||
3 | -@css_dir = "#{RAILS_ROOT}/public/stylesheets" | ||
4 | -@sass_dir = "#{@css_dir}/sass" | ||
5 | -@views_dir = "#{RAILS_ROOT}/app/views" | ||
6 | - | ||
7 | -def convert_css_to_sass(basename) | ||
8 | - system "css2sass #{@css_dir}/#{basename}.css > #{@sass_dir}/#{basename}.sass" | ||
9 | -end | ||
10 | - | ||
11 | -def convert_sass_to_css(basename) | ||
12 | - system "sass #{@sass_dir}/#{basename}.sass > #{@css_dir}/#{basename}.css" | ||
13 | -end | ||
14 | - | ||
15 | -def convert_html_to_haml(controller, basename) | ||
16 | - extname = basename.include?("erb") ? ".html.erb" : ".rhtml" | ||
17 | - basename = basename.split(".").first | ||
18 | - system "html2haml #{@views_dir}/#{controller}/#{basename}#{extname} > #{@views_dir}/#{controller}/#{basename}.html.haml" | ||
19 | - system "rm #{@views_dir}/#{controller}/#{basename}#{extname}" | ||
20 | -end | ||
21 | - | ||
22 | -namespace :sass do | ||
23 | - desc "Convert all CSS files to Sass." | ||
24 | - task :all_css2sass => :environment do | ||
25 | - begin | ||
26 | - Dir.mkdir(@sass_dir) | ||
27 | - rescue Exception => e | ||
28 | - nil | ||
29 | - end | ||
30 | - | ||
31 | - files = Dir.entries(@css_dir).find_all do |f| | ||
32 | - File.extname("#{@css_dir}/#{f}") == ".css" && | ||
33 | - File.basename("#{@css_dir}/#{f}") !~ /^[.]/ | ||
34 | - end | ||
35 | - | ||
36 | - files.each do |filename| | ||
37 | - basename = File.basename("#{@css_dir}/#{filename}", ".css") | ||
38 | - convert_css_to_sass basename | ||
39 | - convert_sass_to_css basename | ||
40 | - end | ||
41 | - end | ||
42 | - | ||
43 | - desc "Convert all Sass files to CSS." | ||
44 | - task :all_sass2css => :environment do | ||
45 | - files = Dir.entries(@sass_dir).find_all do |f| | ||
46 | - File.extname("#{@sass_dir}/#{f}") == ".sass" && | ||
47 | - File.basename("#{@sass_dir}/#{f}") !~ /^[.]/ | ||
48 | - end | ||
49 | - | ||
50 | - files.each do |filename| | ||
51 | - basename = File.basename("#{@sass_dir}/#{filename}", ".sass") | ||
52 | - convert_sass_to_css basename | ||
53 | - end | ||
54 | - end | ||
55 | -end | ||
56 | - | ||
57 | -namespace :haml do | ||
58 | - desc "Convert all HTML files to Haml." | ||
59 | - task :all_html2haml => :environment do | ||
60 | - controllers = Dir.entries(@views_dir).find_all do |c| | ||
61 | - File.directory?("#{@views_dir}/#{c}") && | ||
62 | - File.basename("#{@views_dir}/#{c}") !~ /^[.]/ | ||
63 | - end | ||
64 | - | ||
65 | - controllers.each do |controller| | ||
66 | - files = Dir.entries("#{@views_dir}/#{controller}").find_all do |f| | ||
67 | - (File.new("#{@views_dir}/#{controller}/#{f}").path.include?(".html.erb") || | ||
68 | - File.new("#{@views_dir}/#{controller}/#{f}").path.include?(".rhtml")) && | ||
69 | - File.basename("#{@views_dir}/#{controller}/#{f}") !~ /^[.]/ | ||
70 | - end | ||
71 | - files.each do |filename| | ||
72 | - basename = File.basename("#{@views_dir}/#{controller}/#{filename}") | ||
73 | - convert_html_to_haml controller, basename | ||
74 | - end | ||
75 | - end | ||
76 | - end | ||
77 | -end | ||
78 | - |
vendor/plugins/limerick_rake/tasks/rails_two.rake
@@ -1,20 +0,0 @@ | @@ -1,20 +0,0 @@ | ||
1 | -desc 'Renames all .rhtml views to .html.erb, .rjs to .js.rjs, .rxml to .xml.builder and .haml to .html.haml' | ||
2 | -namespace :rails_two do | ||
3 | - task :rename_views do | ||
4 | - Dir.glob('app/views/**/[^_]*.rhtml').each do |file| | ||
5 | - puts `git mv #{file} #{file.gsub(/\.rhtml$/, '.html.erb')}` | ||
6 | - end | ||
7 | - | ||
8 | - Dir.glob('app/views/**/[^_]*.rjs').each do |file| | ||
9 | - puts `git mv #{file} #{file.gsub(/\.rjs$/, '.js.rjs')}` | ||
10 | - end | ||
11 | - | ||
12 | - Dir.glob('app/views/**/[^_]*.rxml').each do |file| | ||
13 | - puts `git mv #{file} #{file.gsub(/\.rxml$/, '.xml.builder')}` | ||
14 | - end | ||
15 | - | ||
16 | - Dir.glob('app/views/**/[^_]*.haml').each do |file| | ||
17 | - puts `git mv #{file} #{file.gsub(/\.haml$/, '.html.haml')}` | ||
18 | - end | ||
19 | - end | ||
20 | -end | ||
21 | \ No newline at end of file | 0 | \ No newline at end of file |
vendor/plugins/limerick_rake/tasks/svn.rake
@@ -1,21 +0,0 @@ | @@ -1,21 +0,0 @@ | ||
1 | -# Pulled together from various mailing lists. | ||
2 | - | ||
3 | -namespace :svn do | ||
4 | - desc "Adds all files with an svn status flag of '?'" | ||
5 | - task(:add) { system %q(svn status | awk '/\\?/ {print $2}' | xargs svn add) } | ||
6 | - | ||
7 | - desc "Deletes all files with an svn status flag of '!'" | ||
8 | - task(:delete) { system %q(svn status | awk '/\\!/ {print $2}' | xargs svn delete) } | ||
9 | - | ||
10 | - desc "Writes the log file to doc/svn_log.txt" | ||
11 | - task(:log) do | ||
12 | - File.delete("#{RAILS_ROOT}/doc/svn_log.txt") if File::exists?("#{RAILS_ROOT}/doc/svn_log.txt") | ||
13 | - File.new("#{RAILS_ROOT}/doc/svn_log.txt", "w+") | ||
14 | - system("svn log >> doc/svn_log.txt") | ||
15 | - end | ||
16 | - | ||
17 | - desc 'Updates svn:ignore from .svnignore' | ||
18 | - task(:update_svn_ignore) do | ||
19 | - system %q(svn propset svn:ignore -F .svnignore .) | ||
20 | - end | ||
21 | -end |