Skip to content

Commit 89bce57

Browse files
committed
Merge branch 'release/v2.7.3'
2 parents 5f37a97 + db3eb14 commit 89bce57

21 files changed

+1177
-227
lines changed

.rubocop_todo.yml

+19-53
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
# This configuration was generated by
22
# `rubocop --auto-gen-config`
3-
# on 2016-12-17 10:16:05 +0100 using RuboCop version 0.46.0.
3+
# on 2017-10-13 10:01:18 +0200 using RuboCop version 0.46.0.
44
# The point is for the user to remove these configuration records
55
# one by one as the offenses are removed from the code base.
66
# Note that changes in the inspected code, or installation of new
@@ -65,11 +65,6 @@ Lint/HandleExceptions:
6565
Exclude:
6666
- 'bin/annotate'
6767

68-
# Offense count: 8
69-
Lint/IneffectiveAccessModifier:
70-
Exclude:
71-
- 'lib/annotate/annotate_routes.rb'
72-
7368
# Offense count: 1
7469
# Cop supports --auto-correct.
7570
# Configuration parameters: EnforcedStyle, SupportedStyles.
@@ -88,62 +83,51 @@ Lint/ShadowingOuterLocalVariable:
8883
Exclude:
8984
- 'Rakefile'
9085

91-
# Offense count: 6
86+
# Offense count: 7
9287
# Cop supports --auto-correct.
9388
# Configuration parameters: IgnoreEmptyBlocks, AllowUnusedKeywordArguments.
9489
Lint/UnusedBlockArgument:
9590
Exclude:
9691
- 'bin/annotate'
9792

98-
# Offense count: 1
99-
# Configuration parameters: ContextCreatingMethods.
100-
Lint/UselessAccessModifier:
101-
Exclude:
102-
- 'lib/annotate/annotate_routes.rb'
103-
104-
# Offense count: 17
93+
# Offense count: 18
10594
Metrics/AbcSize:
106-
Max: 159
95+
Max: 142
10796

10897
# Offense count: 3
10998
# Configuration parameters: CountComments.
11099
Metrics/BlockLength:
111-
Max: 134
100+
Max: 142
112101

113102
# Offense count: 2
114103
Metrics/BlockNesting:
115104
Max: 4
116105

117-
# Offense count: 8
106+
# Offense count: 9
118107
Metrics/CyclomaticComplexity:
119-
Max: 42
108+
Max: 36
120109

121-
# Offense count: 350
110+
# Offense count: 380
122111
# Configuration parameters: AllowHeredoc, AllowURI, URISchemes, IgnoreCopDirectives, IgnoredPatterns.
123112
# URISchemes: http, https
124113
Metrics/LineLength:
125-
Max: 543
114+
Max: 276
126115

127-
# Offense count: 24
116+
# Offense count: 26
128117
# Configuration parameters: CountComments.
129118
Metrics/MethodLength:
130-
Max: 79
131-
132-
# Offense count: 1
133-
# Configuration parameters: CountComments.
134-
Metrics/ModuleLength:
135-
Max: 116
119+
Max: 75
136120

137121
# Offense count: 7
138122
Metrics/PerceivedComplexity:
139-
Max: 48
123+
Max: 42
140124

141125
# Offense count: 1
142126
Style/AccessorMethodName:
143127
Exclude:
144128
- 'lib/annotate.rb'
145129

146-
# Offense count: 3
130+
# Offense count: 2
147131
# Cop supports --auto-correct.
148132
Style/AlignArray:
149133
Exclude:
@@ -259,21 +243,14 @@ Style/ExtraSpacing:
259243
- 'spec/integration/rails_4.2.0/Gemfile'
260244
- 'spec/integration/rails_4.2.0/config.ru'
261245

262-
# Offense count: 9
246+
# Offense count: 10
263247
# Configuration parameters: EnforcedStyle, SupportedStyles.
264248
# SupportedStyles: format, sprintf, percent
265249
Style/FormatString:
266250
Exclude:
267251
- 'lib/annotate/annotate_models.rb'
268252
- 'lib/annotate/annotate_routes.rb'
269253

270-
# Offense count: 181
271-
# Cop supports --auto-correct.
272-
# Configuration parameters: EnforcedStyle, SupportedStyles.
273-
# SupportedStyles: when_needed, always
274-
Style/FrozenStringLiteralComment:
275-
Enabled: false
276-
277254
# Offense count: 7
278255
# Configuration parameters: MinBodyLength.
279256
Style/GuardClause:
@@ -356,16 +333,6 @@ Style/NumericLiterals:
356333

357334
# Offense count: 2
358335
# Cop supports --auto-correct.
359-
# Configuration parameters: AutoCorrect, EnforcedStyle, SupportedStyles.
360-
# SupportedStyles: predicate, comparison
361-
Style/NumericPredicate:
362-
Exclude:
363-
- 'spec/**/*'
364-
- 'lib/annotate.rb'
365-
- 'lib/annotate/annotate_models.rb'
366-
367-
# Offense count: 6
368-
# Cop supports --auto-correct.
369336
# Configuration parameters: PreferredDelimiters.
370337
Style/PercentLiteralDelimiters:
371338
Exclude:
@@ -458,16 +425,15 @@ Style/SpaceAroundKeyword:
458425
- 'spec/integration/rails_4.2.0/Gemfile'
459426
- 'spec/integration/standalone/Gemfile'
460427

461-
# Offense count: 6
428+
# Offense count: 4
462429
# Cop supports --auto-correct.
463430
# Configuration parameters: AllowForAlignment.
464431
Style/SpaceAroundOperators:
465432
Exclude:
466433
- 'lib/annotate/annotate_models.rb'
467-
- 'lib/tasks/annotate_models.rake'
468434
- 'lib/tasks/annotate_routes.rake'
469435

470-
# Offense count: 4
436+
# Offense count: 1
471437
# Cop supports --auto-correct.
472438
# Configuration parameters: EnforcedStyle, SupportedStyles.
473439
# SupportedStyles: space, no_space
@@ -517,14 +483,14 @@ Style/SpaceInsideStringInterpolation:
517483
Exclude:
518484
- 'lib/annotate/annotate_models.rb'
519485

520-
# Offense count: 223
486+
# Offense count: 237
521487
# Cop supports --auto-correct.
522488
# Configuration parameters: EnforcedStyle, SupportedStyles, ConsistentQuotesInMultiline.
523489
# SupportedStyles: single_quotes, double_quotes
524490
Style/StringLiterals:
525491
Enabled: false
526492

527-
# Offense count: 2
493+
# Offense count: 1
528494
# Cop supports --auto-correct.
529495
# Configuration parameters: EnforcedStyle, SupportedStyles.
530496
# SupportedStyles: single_quotes, double_quotes
@@ -581,7 +547,7 @@ Style/UnneededInterpolation:
581547
Exclude:
582548
- 'bin/annotate'
583549

584-
# Offense count: 8
550+
# Offense count: 4
585551
# Cop supports --auto-correct.
586552
Style/UnneededPercentQ:
587553
Exclude:

.travis.yml

+16-12
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,23 @@
11
sudo: false
22
language: ruby
33
rvm:
4-
- 1.9.3
5-
- 2.0
6-
- 2.1
7-
- 2.2.5
8-
- 2.3.0
9-
- 2.4.0
10-
- ruby-head
4+
- 2.2.7
5+
- 2.3.4
6+
- 2.4.1
7+
- ruby-head
118
matrix:
129
allow_failures:
13-
- rvm: ruby-head
14-
- rvm: 1.9.3
10+
- rvm: ruby-head
1511
before_install:
16-
- gem update --system
17-
- gem update bundler
12+
- gem update --system
13+
- gem update bundler
1814
script:
19-
- bundle exec rubocop && bundle exec rspec
15+
- bundle exec rubocop && bundle exec rspec
16+
deploy:
17+
provider: rubygems
18+
api_key:
19+
secure: Y7DUitak26kcRAAkgph/7m6Y1wHeObD0BelSSJbmCfjkRd/qaVy7fz9VvHL9zxlRJtLGVHInyCnwcfzinibY6OFd3MoMYHKv8GFa2LxLJNEVSY46KQYFxfH5JTg1ejh6ldoJRRBoeOx9dcWS80pRNjYMKPGnpSz7yDBl1azibFs=
20+
gem: annotate
21+
on:
22+
tags: true
23+
repo: ctran/annotate_models

CHANGELOG.rdoc

+3
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,6 @@
1+
== 2.7.3
2+
See https://github.com/ctran/annotate_models/releases/tag/v2.7.3
3+
14
== 2.7.2
25
See https://github.com/ctran/annotate_models/releases/tag/v2.7.2
36

Gemfile

+3
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,14 @@
11
source 'https://rubygems.org'
22

3+
ruby '>= 2.2.0'
4+
35
gem 'activerecord', '>= 4.2.5', require: false
46
gem 'rake', require: false
57

68
group :development do
79
gem 'bump'
810
gem 'mg', require: false
11+
gem 'travis', require: false
912
platforms :mri, :mingw do
1013
gem 'yard', require: false
1114
end

README.rdoc

+24-8
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ your...
1717
- Object Daddy exemplars
1818
- Machinist blueprints
1919
- Fabrication fabricators
20-
- Thoughtbot's factory_girl factories, i.e. the (spec|test)/factories/<model>_factory.rb files
20+
- Thoughtbot's factory_bot factories, i.e. the (spec|test)/factories/<model>_factory.rb files
2121
- routes.rb file (for Rails projects)
2222

2323
The schema comment looks like this:
@@ -55,11 +55,15 @@ Also, if you pass the -r option, it'll annotate routes.rb with the output of
5555

5656
Into Gemfile from rubygems.org:
5757

58-
gem 'annotate'
58+
group :development do
59+
gem 'annotate'
60+
end
5961

6062
Into Gemfile from Github:
6163

62-
gem 'annotate', git: 'https://github.com/ctran/annotate_models.git'
64+
group :development do
65+
gem 'annotate', git: 'https://github.com/ctran/annotate_models.git'
66+
end
6367

6468
Into environment gems from rubygems.org:
6569

@@ -154,14 +158,15 @@ If you want to run <code>rake db:migrate</code> as a one-off without running ann
154158
you can do so with a simple environment variable, instead of editing the
155159
+.rake+ file:
156160

157-
skip_on_db_migrate=1 rake db:migrate
161+
ANNOTATE_SKIP_ON_DB_MIGRATE=1 rake db:migrate
158162

159163

160164
== Options
161165

162166
Usage: annotate [options] [model_file]*
163167
-d, --delete Remove annotations from all model files or the routes.rb file
164-
-p, --position [before|top|after|bottom] Place the annotations at the top (before) or the bottom (after) of the model/test/fixture/factory/routes file(s)
168+
-p [before|top|after|bottom], Place the annotations at the top (before) or the bottom (after) of the model/test/fixture/factory/route/serializer file(s)
169+
--position
165170
--pc, --position-in-class [before|top|after|bottom]
166171
Place the annotations at the top (before) or the bottom (after) of the model file
167172
--pf, --position-in-factory [before|top|after|bottom]
@@ -179,15 +184,19 @@ you can do so with a simple environment variable, instead of editing the
179184
--wo, --wrapper-open STR Annotation wrapper opening.
180185
--wc, --wrapper-close STR Annotation wrapper closing
181186
-r, --routes Annotate routes.rb with the output of 'rake routes'
182-
-aa, --active-admin Annotate all activeadmin models
187+
-a, --active-admin Annotate active_admin models
183188
-v, --version Show the current version of this gem
184189
-m, --show-migration Include the migration version number in the annotation
185-
-i, --show-indexes List the table's database indexes in the annotation
186190
-k, --show-foreign-keys List the table's foreign key constraints in the annotation
191+
--ck, --complete-foreign-keys
192+
Complete foreign key names in the annotation
193+
-i, --show-indexes List the table's database indexes in the annotation
187194
-s, --simple-indexes Concat the column's related indexes in the annotation
188195
--model-dir dir Annotate model files stored in dir rather than app/models, separate multiple dirs with commas
196+
--root-dir dir Annotate files stored within root dir projects, separate multiple dirs with commas
189197
--ignore-model-subdirects Ignore subdirectories of the models directory
190198
--sort Sort columns alphabetically, rather than in creation order
199+
--classified-sort Sort columns alphabetically, but first goes id, then the rest columns, then the timestamp columns and then the association columns
191200
-R, --require path Additional file to require before loading models, may be used multiple times
192201
-e [tests,fixtures,factories,serializers],
193202
--exclude Do not annotate fixtures, test files, factories, and/or serializers
@@ -197,6 +206,13 @@ you can do so with a simple environment variable, instead of editing the
197206
--timestamp Include timestamp in (routes) annotation
198207
--trace If unable to annotate a file, print the full stack trace, not just the exception message.
199208
-I, --ignore-columns REGEX don't annotate columns that match a given REGEX (i.e., `annotate -I '^(id|updated_at|created_at)'`
209+
--ignore-routes REGEX don't annotate routes that match a given REGEX (i.e., `annotate -I '(mobile|resque|pghero)'`
210+
--hide-limit-column-types VALUES
211+
don't show limit for given column types, separated by commas (i.e., `integer,boolean,text`)
212+
--hide-default-column-types VALUES
213+
don't show default for given column types, separated by commas (i.e., `json,jsonb,hstore`)
214+
--ignore-unknown-models don't display warnings for bad model files
215+
--with-comment include database comments in model annotations
200216

201217

202218

@@ -242,7 +258,7 @@ extra carefully, and consider using one.
242258

243259
== Links
244260

245-
- Factory Girl: http://github.com/thoughtbot/factory_girl
261+
- Factory Bot: http://github.com/thoughtbot/factory_bot
246262
- Object Daddy: http://github.com/flogic/object_daddy
247263
- Machinist: http://github.com/notahat/machinist
248264
- Fabrication: http://github.com/paulelliott/fabrication

Rakefile

+1-1
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ require 'mg'
2828
begin
2929
MG.new('annotate.gemspec')
3030
rescue Exception
31-
STDERR.puts("WARNING: Couldn't read gemspec. As such, a number of tasks may be unavailable to you until you run 'rake gem:gemspec' to correct the issue.")
31+
$stderr.puts("WARNING: Couldn't read gemspec. As such, a number of tasks may be unavailable to you until you run 'rake gem:gemspec' to correct the issue.")
3232
# Gemspec is probably in a broken state, so let's give ourselves a chance to
3333
# build a new one...
3434
end

annotate.gemspec

+1-1
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@ Gem::Specification.new do |s|
77
s.name = 'annotate'
88
s.version = Annotate.version
99

10-
s.required_ruby_version = '>= 1.9.3'
10+
s.required_ruby_version = '>= 2.2.0'
1111
s.required_rubygems_version = Gem::Requirement.new('>= 0') if s.respond_to? :required_rubygems_version=
1212
s.authors = ['Alex Chaffee', 'Cuong Tran', 'Marcos Piccinini', 'Turadg Aleahmad', 'Jon Frisby']
1313
s.description = 'Annotates Rails/ActiveRecord Models, routes, fixtures, and others based on the database schema.'

bin/annotate

+12-2
Original file line numberDiff line numberDiff line change
@@ -90,7 +90,7 @@ OptionParser.new do |opts|
9090
ENV['routes'] = 'true'
9191
end
9292

93-
opts.on('-aa', '--active-admin', 'Annotate active_admin models') do
93+
opts.on('-a', '--active-admin', 'Annotate active_admin models') do
9494
ENV['active_admin'] = 'true'
9595
end
9696

@@ -107,6 +107,12 @@ OptionParser.new do |opts|
107107
ENV['show_foreign_keys'] = 'yes'
108108
end
109109

110+
opts.on('--ck',
111+
'--complete-foreign-keys', 'Complete foreign key names in the annotation') do
112+
ENV['show_foreign_keys'] = 'yes'
113+
ENV['show_complete_foreign_keys'] = 'yes'
114+
end
115+
110116
opts.on('-i', '--show-indexes',
111117
"List the table's database indexes in the annotation") do
112118
ENV['show_indexes'] = 'yes'
@@ -191,12 +197,16 @@ OptionParser.new do |opts|
191197
opts.on('--ignore-unknown-models', "don't display warnings for bad model files") do |values|
192198
ENV['ignore_unknown_models'] = 'true'
193199
end
200+
201+
opts.on('--with-comment', "include database comments in model annotations") do |values|
202+
ENV['with_comment'] = 'true'
203+
end
194204
end.parse!
195205

196206
options = Annotate.setup_options(
197207
is_rake: ENV['is_rake'] && !ENV['is_rake'].empty?
198208
)
199-
Annotate.eager_load(options)
209+
Annotate.eager_load(options) if Annotate.include_models?
200210

201211
AnnotateModels.send(target_action, options) if Annotate.include_models?
202212
AnnotateRoutes.send(target_action, options) if Annotate.include_routes?

0 commit comments

Comments
 (0)