rails_best_practices 0.3.7 → 0.3.8

Sign up to get free protection for your applications and to get access to all the features.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.3.7
1
+ 0.3.8
@@ -46,29 +46,31 @@ module RailsBestPractices
46
46
 
47
47
  private
48
48
 
49
- def check_references(node)
50
- create_table_node = node.grep_nodes({:node_type => :call, :message => :create_table}).first
51
- if create_table_node
52
- table_name = create_table_node.arguments[1].to_ruby_string
53
- node.grep_nodes({:node_type => :call, :message => :integer}).each do |integer_node|
54
- column_name = integer_node.arguments[1].to_ruby_string
55
- if column_name =~ /_id$/ and !@@indexes[table_name].include? column_name
56
- add_error "always add db index (#{table_name} => #{column_name})"
57
- end
58
- end
59
- node.grep_nodes({:node_type => :call, :message => :references}).each do |references_node|
60
- column_name = references_node.arguments[1].to_ruby_string + "_id"
61
- if !@@indexes[table_name].include? column_name
62
- add_error "always add db index (#{table_name} => #{column_name})"
63
- end
64
- end
65
- node.grep_nodes({:node_type => :call, :message => :column}).each do |column_node|
66
- if 'integer' == column_node.arguments[2].to_ruby_string
67
- column_name = column_node.arguments[1].to_ruby_string
49
+ def check_references(nodes)
50
+ nodes[1..-1].each do |node|
51
+ create_table_node = node.grep_nodes({:node_type => :call, :message => :create_table}).first
52
+ if create_table_node
53
+ table_name = create_table_node.arguments[1].to_ruby_string
54
+ node.grep_nodes({:node_type => :call, :message => :integer}).each do |integer_node|
55
+ column_name = integer_node.arguments[1].to_ruby_string
68
56
  if column_name =~ /_id$/ and !@@indexes[table_name].include? column_name
69
57
  add_error "always add db index (#{table_name} => #{column_name})"
70
58
  end
71
59
  end
60
+ node.grep_nodes({:node_type => :call, :message => :references}).each do |references_node|
61
+ column_name = references_node.arguments[1].to_ruby_string + "_id"
62
+ if !@@indexes[table_name].include? column_name
63
+ add_error "always add db index (#{table_name} => #{column_name})"
64
+ end
65
+ end
66
+ node.grep_nodes({:node_type => :call, :message => :column}).each do |column_node|
67
+ if 'integer' == column_node.arguments[2].to_ruby_string
68
+ column_name = column_node.arguments[1].to_ruby_string
69
+ if column_name =~ /_id$/ and !@@indexes[table_name].include? column_name
70
+ add_error "always add db index (#{table_name} => #{column_name})"
71
+ end
72
+ end
73
+ end
72
74
  end
73
75
  end
74
76
  end
@@ -79,7 +81,7 @@ module RailsBestPractices
79
81
  # add_index *args
80
82
  # end
81
83
  def remember_indexes(nodes)
82
- nodes.each do |node|
84
+ nodes[1..-1].each do |node|
83
85
  begin
84
86
  eval(node.to_ruby)
85
87
  rescue Exception
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{rails_best_practices}
8
- s.version = "0.3.7"
8
+ s.version = "0.3.8"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Richard Huang"]
12
- s.date = %q{2009-11-25}
12
+ s.date = %q{2009-11-26}
13
13
  s.default_executable = %q{rails_best_practices}
14
14
  s.description = %q{check rails files according to ihower's presentation 'rails best practices'}
15
15
  s.email = %q{flyerhzm@gmail.com}
@@ -193,4 +193,29 @@ describe RailsBestPractices::Checks::AlwaysAddDbIndexCheck do
193
193
  @runner.check('db/migrate/20090706091635_move_categories_to_profile_area.rb', content)
194
194
  errors = @runner.errors
195
195
  end
196
+
197
+ it "should always add db index without duplicate error outputs" do
198
+ content = <<-EOF
199
+ class AllTables < ActiveRecord::Migration
200
+ def self.up
201
+ create_table "ducks" do |t|
202
+ t.column "registration", :string, :limit => 32
203
+ t.column "description", :string
204
+ end
205
+
206
+ create_table "lab_data" do |t|
207
+ t.integer "input_biologist_id", :null => true
208
+ t.integer "owner_biologist_id", :null => false
209
+ t.column "remark", :string, :limit => 250
210
+ end
211
+ end
212
+ end
213
+ EOF
214
+ @runner.check('db/migrate/20090204160203_all_tables.rb', content)
215
+ @runner.check('db/migrate/20090204160203_all_tables.rb', content)
216
+ errors = @runner.errors
217
+ errors.should_not be_empty
218
+ errors[0].to_s.should == "db/migrate/20090204160203_all_tables.rb:2 - always add db index (lab_data => input_biologist_id)"
219
+ errors[1].to_s.should == "db/migrate/20090204160203_all_tables.rb:2 - always add db index (lab_data => owner_biologist_id)"
220
+ end
196
221
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rails_best_practices
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.7
4
+ version: 0.3.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - Richard Huang
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2009-11-25 00:00:00 +08:00
12
+ date: 2009-11-26 00:00:00 +08:00
13
13
  default_executable: rails_best_practices
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency