db_leftovers 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/.document CHANGED
File without changes
data/Gemfile CHANGED
@@ -11,8 +11,9 @@ gem 'rails', '>= 3.0.0'
11
11
  # Add dependencies to develop your gem here.
12
12
  # Include everything needed to run rake, tests, features, etc.
13
13
  group :development do
14
- gem "rspec", "~> 2.3.0"
15
- gem "bundler", "~> 1.0.0"
14
+ gem "rspec", "~> 2.4.0"
15
+ gem "bundler"
16
16
  gem "jeweler", "~> 1.6.4"
17
17
  gem "rcov", ">= 0"
18
18
  end
19
+
data/Gemfile.lock CHANGED
@@ -76,18 +76,18 @@ GEM
76
76
  rcov (0.9.11)
77
77
  rdoc (3.12)
78
78
  json (~> 1.4)
79
- rspec (2.3.0)
80
- rspec-core (~> 2.3.0)
81
- rspec-expectations (~> 2.3.0)
82
- rspec-mocks (~> 2.3.0)
83
- rspec-core (2.3.1)
84
- rspec-expectations (2.3.0)
79
+ rspec (2.4.0)
80
+ rspec-core (~> 2.4.0)
81
+ rspec-expectations (~> 2.4.0)
82
+ rspec-mocks (~> 2.4.0)
83
+ rspec-core (2.4.0)
84
+ rspec-expectations (2.4.0)
85
85
  diff-lcs (~> 1.1.2)
86
- rspec-mocks (2.3.0)
86
+ rspec-mocks (2.4.0)
87
87
  sprockets (2.0.3)
88
88
  hike (~> 1.2)
89
89
  rack (~> 1.0)
90
- tilt (!= 1.3.0, ~> 1.1)
90
+ tilt (~> 1.1, != 1.3.0)
91
91
  thor (0.14.6)
92
92
  tilt (1.3.3)
93
93
  treetop (1.4.10)
@@ -99,8 +99,8 @@ PLATFORMS
99
99
  ruby
100
100
 
101
101
  DEPENDENCIES
102
- bundler (~> 1.0.0)
102
+ bundler
103
103
  jeweler (~> 1.6.4)
104
104
  rails (>= 3.0.0)
105
105
  rcov
106
- rspec (~> 2.3.0)
106
+ rspec (~> 2.4.0)
data/LICENSE.txt CHANGED
File without changes
data/README.html CHANGED
File without changes
data/README.md CHANGED
@@ -99,6 +99,6 @@ Contributing to db\_leftovers
99
99
  Copyright
100
100
  ---------
101
101
 
102
- Copyright (c) 2012 Paul A. Jungwirth. See LICENSE.txt for
103
- further details.
102
+ Copyright (c) 2012 Paul A. Jungwirth.
103
+ See LICENSE.txt for further details.
104
104
 
data/Rakefile CHANGED
File without changes
data/TODO CHANGED
@@ -1,3 +1,8 @@
1
1
  - Write the README
2
2
  - Support altering index and foreign keys if their definition changes
3
3
  - don't show "{index,fk} already exists" unless you set the verbosity higher
4
+
5
+ - Use Sequel to introspect databases for their indexes, to get easy support for non-Postgres databases.
6
+ - BUT: Sequel can't return partial indexes (i.e. indexes created with a WHERE clause), and using those kind of indexes is a major feature for db_leftovers. So this will have to wait until I can get a patch accepted to let at least the Postgres Sequel adapter optionally query for those type of indexes.
7
+
8
+
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.3.0
1
+ 0.4.0
data/db_leftovers.gemspec CHANGED
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "db_leftovers"
8
- s.version = "0.3.0"
8
+ s.version = "0.4.0"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Paul A. Jungwirth"]
12
- s.date = "2012-01-20"
12
+ s.date = "2012-09-27"
13
13
  s.description = " Define indexes and foreign keys for your Rails app\n in one place using an easy-to-read DSL,\n then run a rake task to bring your database up-to-date.\n"
14
14
  s.email = "pj@illuminatedcomputing.com"
15
15
  s.extra_rdoc_files = [
@@ -28,6 +28,7 @@ Gem::Specification.new do |s|
28
28
  "VERSION",
29
29
  "db_leftovers.gemspec",
30
30
  "lib/db_leftovers.rb",
31
+ "lib/db_leftovers/constraint.rb",
31
32
  "lib/db_leftovers/database_interface.rb",
32
33
  "lib/db_leftovers/definition.rb",
33
34
  "lib/db_leftovers/dsl.rb",
@@ -41,7 +42,7 @@ Gem::Specification.new do |s|
41
42
  s.homepage = "http://github.com/pjungwir/db_leftovers"
42
43
  s.licenses = ["MIT"]
43
44
  s.require_paths = ["lib"]
44
- s.rubygems_version = "1.8.10"
45
+ s.rubygems_version = "1.8.24"
45
46
  s.summary = "Used to define indexes and foreign keys for your Rails app"
46
47
 
47
48
  if s.respond_to? :specification_version then
@@ -49,21 +50,21 @@ Gem::Specification.new do |s|
49
50
 
50
51
  if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
51
52
  s.add_runtime_dependency(%q<rails>, [">= 3.0.0"])
52
- s.add_development_dependency(%q<rspec>, ["~> 2.3.0"])
53
- s.add_development_dependency(%q<bundler>, ["~> 1.0.0"])
53
+ s.add_development_dependency(%q<rspec>, ["~> 2.4.0"])
54
+ s.add_development_dependency(%q<bundler>, [">= 0"])
54
55
  s.add_development_dependency(%q<jeweler>, ["~> 1.6.4"])
55
56
  s.add_development_dependency(%q<rcov>, [">= 0"])
56
57
  else
57
58
  s.add_dependency(%q<rails>, [">= 3.0.0"])
58
- s.add_dependency(%q<rspec>, ["~> 2.3.0"])
59
- s.add_dependency(%q<bundler>, ["~> 1.0.0"])
59
+ s.add_dependency(%q<rspec>, ["~> 2.4.0"])
60
+ s.add_dependency(%q<bundler>, [">= 0"])
60
61
  s.add_dependency(%q<jeweler>, ["~> 1.6.4"])
61
62
  s.add_dependency(%q<rcov>, [">= 0"])
62
63
  end
63
64
  else
64
65
  s.add_dependency(%q<rails>, [">= 3.0.0"])
65
- s.add_dependency(%q<rspec>, ["~> 2.3.0"])
66
- s.add_dependency(%q<bundler>, ["~> 1.0.0"])
66
+ s.add_dependency(%q<rspec>, ["~> 2.4.0"])
67
+ s.add_dependency(%q<bundler>, [">= 0"])
67
68
  s.add_dependency(%q<jeweler>, ["~> 1.6.4"])
68
69
  s.add_dependency(%q<rcov>, [">= 0"])
69
70
  end
data/lib/db_leftovers.rb CHANGED
@@ -1,6 +1,7 @@
1
1
  require 'db_leftovers/database_interface.rb'
2
2
  require 'db_leftovers/index.rb'
3
3
  require 'db_leftovers/foreign_key.rb'
4
+ require 'db_leftovers/constraint.rb'
4
5
  require 'db_leftovers/table_dsl.rb'
5
6
  require 'db_leftovers/dsl.rb'
6
7
  require 'db_leftovers/definition.rb'
@@ -0,0 +1,13 @@
1
+ module DBLeftovers
2
+
3
+ class Constraint
4
+ attr_accessor :constraint_name, :on_table, :check
5
+
6
+ def initialize(constraint_name, on_table, check)
7
+ @constraint_name = constraint_name.to_s
8
+ @on_table = on_table.to_s
9
+ @check = check
10
+ end
11
+ end
12
+
13
+ end
@@ -44,6 +44,22 @@ module DBLeftovers
44
44
  return ret
45
45
  end
46
46
 
47
+ def lookup_all_constraints
48
+ ret = {}
49
+ sql = <<-EOQ
50
+ SELECT t.constraint_name, t.table_name
51
+ FROM information_schema.table_constraints t
52
+ WHERE t.constraint_type = 'CHECK'
53
+ AND EXISTS (SELECT 1
54
+ FROM information_schema.constraint_column_usage c
55
+ WHERE t.constraint_name = c.constraint_name)
56
+ EOQ
57
+ ActiveRecord::Base.connection.select_rows(sql).each do |constr_name, on_table|
58
+ ret[constr_name] = Constraint.new(constr_name, on_table, nil)
59
+ end
60
+ return ret
61
+ end
62
+
47
63
  def execute_add_index(idx)
48
64
  unique = idx.unique? ? 'UNIQUE' : ''
49
65
  where = idx.where_clause.present? ? "WHERE #{idx.where_clause}" : ''
@@ -75,8 +91,18 @@ module DBLeftovers
75
91
  end
76
92
 
77
93
  def execute_drop_foreign_key(constraint_name, from_table, from_column)
78
- execute_sql %{ALTER TABLE #{from_table}
79
- DROP CONSTRAINT #{constraint_name}}
94
+ execute_sql %{ALTER TABLE #{from_table} DROP CONSTRAINT #{constraint_name}}
95
+ end
96
+
97
+ def execute_add_constraint(chk)
98
+ sql = <<-EOQ
99
+ ALTER TABLE #{chk.on_table} ADD CONSTRAINT #{chk.constraint_name} CHECK (#{chk.check})
100
+ EOQ
101
+ execute_sql sql
102
+ end
103
+
104
+ def execute_drop_constraint(constraint_name, on_table)
105
+ execute_sql %{ALTER TABLE #{on_table} DROP CONSTRAINT #{constraint_name}}
80
106
  end
81
107
 
82
108
  def execute_sql(sql)
@@ -4,12 +4,14 @@ module DBLeftovers
4
4
  def self.define(opts={}, &block)
5
5
  opts = {
6
6
  :do_indexes => true,
7
- :do_foreign_keys => true
7
+ :do_foreign_keys => true,
8
+ :do_constraints => true
8
9
  }.merge(opts)
9
10
  dsl = DSL.new
10
11
  dsl.define(&block)
11
12
  dsl.record_indexes if opts[:do_indexes]
12
13
  dsl.record_foreign_keys if opts[:do_foreign_keys]
14
+ dsl.record_constraints if opts[:do_constraints]
13
15
  end
14
16
  end
15
17
 
@@ -10,6 +10,10 @@ module DBLeftovers
10
10
  @foreign_keys_by_table = {} # Set from the DSL
11
11
  @old_foreign_keys = @db.lookup_all_foreign_keys
12
12
  @new_foreign_keys = {}
13
+
14
+ @constraints_by_table = {} # Set from the DSL
15
+ @old_constraints = @db.lookup_all_constraints
16
+ @new_constraints = {}
13
17
  end
14
18
 
15
19
  def define(&block)
@@ -31,6 +35,10 @@ module DBLeftovers
31
35
  add_foreign_key(ForeignKey.new(name_constraint(from_table, from_column), from_table, from_column, to_table, to_column, opts))
32
36
  end
33
37
 
38
+ def check(table_name, constraint_name, check_expression)
39
+ add_constraint(Constraint.new(constraint_name, table_name, check_expression))
40
+ end
41
+
34
42
  def record_indexes
35
43
  # First create any new indexes:
36
44
  @indexes_by_table.each do |table_name, indexes|
@@ -79,6 +87,29 @@ module DBLeftovers
79
87
  end
80
88
  end
81
89
 
90
+ def record_constraints
91
+ # First create any new constraints:
92
+ @constraints_by_table.each do |table_name, chks|
93
+ chks.each do |chk|
94
+ if constraint_exists?(chk)
95
+ puts "Constraint already exists: #{chk.constraint_name} on #{chk.on_table}"
96
+ else
97
+ @db.execute_add_constraint(chk)
98
+ puts "Created CHECK constraint: #{chk.constraint_name} on #{chk.on_table}"
99
+ end
100
+ @new_constraints[chk.constraint_name] = chk
101
+ end
102
+ end
103
+
104
+ # Now drop any old constraints that are no longer in the definition file:
105
+ @old_constraints.each do |constraint_name, chk|
106
+ if not @new_constraints[constraint_name]
107
+ @db.execute_drop_constraint(constraint_name, chk.on_table)
108
+ puts "Dropped CHECK constraint: #{constraint_name} on #{chk.on_table}"
109
+ end
110
+ end
111
+ end
112
+
82
113
  private
83
114
 
84
115
  def add_index(idx)
@@ -91,6 +122,11 @@ module DBLeftovers
91
122
  t << fk
92
123
  end
93
124
 
125
+ def add_constraint(chk)
126
+ t = (@constraints_by_table[chk.on_table] ||= [])
127
+ t << chk
128
+ end
129
+
94
130
  def truncate_index_name(index_name)
95
131
  index_name[0,63]
96
132
  end
@@ -103,6 +139,10 @@ module DBLeftovers
103
139
  @old_foreign_keys[fk.constraint_name]
104
140
  end
105
141
 
142
+ def constraint_exists?(chk)
143
+ @old_constraints[chk.constraint_name]
144
+ end
145
+
106
146
  def name_constraint(from_table, from_column)
107
147
  "fk_#{from_table}_#{from_column}"
108
148
  end
File without changes
File without changes
@@ -17,6 +17,10 @@ module DBLeftovers
17
17
  def foreign_key(from_column, to_table, to_column='id', opts={})
18
18
  @dsl.foreign_key(@table_name, from_column, to_table, to_column, opts)
19
19
  end
20
+
21
+ def check(constraint_name, check_expression)
22
+ @dsl.check(@table_name, constraint_name, check_expression)
23
+ end
20
24
  end
21
25
 
22
26
  end
@@ -1,19 +1,25 @@
1
1
  namespace :db do
2
2
 
3
- desc "Set up indexes and foreign keys"
3
+ desc "Set up indexes, foreign keys, and constraints"
4
4
  task :leftovers, [] => [:environment] do
5
5
  load File.join(::Rails.root.to_s, 'config', 'db_leftovers.rb')
6
6
  end
7
7
 
8
8
  desc "Drop all the indexes"
9
9
  task :drop_indexes, [] => [:environment] do
10
- DBLeftovers::Definition.define(:do_indexes => true, :do_foreign_keys => false) do
10
+ DBLeftovers::Definition.define(:do_indexes => true, :do_foreign_keys => false, :do_constraints => false) do
11
11
  end
12
12
  end
13
13
 
14
14
  desc "Drop all the foreign keys"
15
15
  task :drop_foreign_keys, [] => [:environment] do
16
- DBLeftovers::Definition.define(:do_indexes => false, :do_foreign_keys => true) do
16
+ DBLeftovers::Definition.define(:do_indexes => false, :do_foreign_keys => true, :do_constraints => false) do
17
+ end
18
+ end
19
+
20
+ desc "Drop all the constraints"
21
+ task :drop_constraints, [] => [:environment] do
22
+ DBLeftovers::Definition.define(:do_indexes => false, :do_foreign_keys => false, :do_constraints => true) do
17
23
  end
18
24
  end
19
25
 
@@ -1,7 +1,8 @@
1
1
  require 'rails'
2
2
  require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
3
3
 
4
- DBLeftovers::DatabaseInterface.class_eval do
4
+ # DBLeftovers::DatabaseInterface.class_eval do
5
+ class DBLeftovers::DatabaseInterface
5
6
 
6
7
  def initialize
7
8
  @@sqls = []
@@ -23,10 +24,11 @@ DBLeftovers::DatabaseInterface.class_eval do
23
24
  )
24
25
  end
25
26
 
26
- def self.starts_with(indexes, foreign_keys)
27
+ def self.starts_with(indexes, foreign_keys, constraints={})
27
28
  # Convert symbols to strings:
28
29
  @@indexes = indexes.inject({}) do |h, (k, v)| h[k.to_s] = v; h end
29
30
  @@foreign_keys = foreign_keys.inject({}) do |h, (k, v)| h[k.to_s] = v; h end
31
+ @@constraints = constraints.inject({}) do |h, (k, v)| h[k.to_s] = v; h end
30
32
  end
31
33
 
32
34
  def lookup_all_indexes
@@ -37,6 +39,10 @@ DBLeftovers::DatabaseInterface.class_eval do
37
39
  @@foreign_keys
38
40
  end
39
41
 
42
+ def lookup_all_constraints
43
+ @@constraints
44
+ end
45
+
40
46
  end
41
47
 
42
48
  RSpec::Matchers.define :have_seen_sql do |sql|
@@ -58,6 +64,15 @@ describe DBLeftovers do
58
64
  DBLeftovers::DatabaseInterface.sqls.should be_empty
59
65
  end
60
66
 
67
+ it "should allow an empty table definition" do
68
+ DBLeftovers::DatabaseInterface.starts_with({}, {})
69
+ DBLeftovers::Definition.define do
70
+ table :books do
71
+ end
72
+ end
73
+ DBLeftovers::DatabaseInterface.sqls.should be_empty
74
+ end
75
+
61
76
  it "should create indexes on an empty database" do
62
77
  DBLeftovers::DatabaseInterface.starts_with({}, {})
63
78
  DBLeftovers::Definition.define do
@@ -78,6 +93,32 @@ describe DBLeftovers do
78
93
  EOQ
79
94
  end
80
95
 
96
+
97
+
98
+ it "should create table-prefixed indexes on an empty database" do
99
+ DBLeftovers::DatabaseInterface.starts_with({}, {})
100
+ DBLeftovers::Definition.define do
101
+ table :books do
102
+ index :shelf_id
103
+ index :publisher_id, :where => 'published'
104
+ end
105
+ end
106
+ DBLeftovers::DatabaseInterface.sqls.size.should == 2
107
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
108
+ CREATE INDEX index_books_on_shelf_id
109
+ ON books
110
+ (shelf_id)
111
+ EOQ
112
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
113
+ CREATE INDEX index_books_on_publisher_id
114
+ ON books
115
+ (publisher_id)
116
+ WHERE published
117
+ EOQ
118
+ end
119
+
120
+
121
+
81
122
  it "should create foreign keys on an empty database" do
82
123
  DBLeftovers::DatabaseInterface.starts_with({}, {})
83
124
  DBLeftovers::Definition.define do
@@ -110,6 +151,40 @@ describe DBLeftovers do
110
151
 
111
152
 
112
153
 
154
+ it "should create table-prefixed foreign keys on an empty database" do
155
+ DBLeftovers::DatabaseInterface.starts_with({}, {})
156
+ DBLeftovers::Definition.define do
157
+ table :books do
158
+ foreign_key :shelf_id, :shelves
159
+ foreign_key :publisher_id, :publishers, :id, :set_null => true
160
+ foreign_key :author_id, :authors, :id, :cascade => true
161
+ end
162
+ end
163
+ DBLeftovers::DatabaseInterface.sqls.should have(3).items
164
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
165
+ ALTER TABLE books
166
+ ADD CONSTRAINT fk_books_shelf_id
167
+ FOREIGN KEY (shelf_id)
168
+ REFERENCES shelves (id)
169
+ EOQ
170
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
171
+ ALTER TABLE books
172
+ ADD CONSTRAINT fk_books_publisher_id
173
+ FOREIGN KEY (publisher_id)
174
+ REFERENCES publishers (id)
175
+ ON DELETE SET NULL
176
+ EOQ
177
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
178
+ ALTER TABLE books
179
+ ADD CONSTRAINT fk_books_author_id
180
+ FOREIGN KEY (author_id)
181
+ REFERENCES authors (id)
182
+ ON DELETE CASCADE
183
+ EOQ
184
+ end
185
+
186
+
187
+
113
188
  it "should not create indexes when they already exist" do
114
189
  DBLeftovers::DatabaseInterface.starts_with({
115
190
  :index_books_on_shelf_id => DBLeftovers::Index.new(:books, :index_id),
@@ -126,6 +201,24 @@ describe DBLeftovers do
126
201
 
127
202
 
128
203
 
204
+ it "should not create table-prefixed indexes when they already exist" do
205
+ DBLeftovers::DatabaseInterface.starts_with({
206
+ :index_books_on_shelf_id => DBLeftovers::Index.new(:books, :index_id),
207
+ :index_books_on_publisher_id => DBLeftovers::Index.new(
208
+ :books, :publisher_id, :where => 'published')
209
+ }, {})
210
+ DBLeftovers::Definition.define do
211
+ table :books do
212
+ index :shelf_id
213
+ index :publisher_id, :where => 'published'
214
+ end
215
+ end
216
+ DBLeftovers::DatabaseInterface.sqls.should have(0).items
217
+ end
218
+
219
+
220
+
221
+
129
222
  it "should not create foreign keys when they already exist" do
130
223
  DBLeftovers::DatabaseInterface.starts_with({}, {
131
224
  :fk_books_shelf_id => DBLeftovers::ForeignKey.new('fk_books_shelf_id',
@@ -139,6 +232,21 @@ describe DBLeftovers do
139
232
 
140
233
 
141
234
 
235
+ it "should not create table-prefixed foreign keys when they already exist" do
236
+ DBLeftovers::DatabaseInterface.starts_with({}, {
237
+ :fk_books_shelf_id => DBLeftovers::ForeignKey.new('fk_books_shelf_id',
238
+ 'books', 'shelf_id', 'shelves', 'id')
239
+ })
240
+ DBLeftovers::Definition.define do
241
+ table :books do
242
+ foreign_key :shelf_id, :shelves
243
+ end
244
+ end
245
+ DBLeftovers::DatabaseInterface.sqls.should have(0).items
246
+ end
247
+
248
+
249
+
142
250
  it "should drop indexes when they are removed from the definition" do
143
251
  DBLeftovers::DatabaseInterface.starts_with({
144
252
  :index_books_on_shelf_id => DBLeftovers::Index.new(:books, :index_id),
@@ -173,4 +281,61 @@ describe DBLeftovers do
173
281
  end
174
282
 
175
283
 
284
+
285
+ it "should support creating multi-column indexes" do
286
+ DBLeftovers::DatabaseInterface.starts_with({}, {})
287
+ DBLeftovers::Definition.define do
288
+ index :books, [:year, :title]
289
+ end
290
+ DBLeftovers::DatabaseInterface.sqls.should have(1).item
291
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
292
+ CREATE INDEX index_books_on_year_and_title
293
+ ON books
294
+ (year, title)
295
+ EOQ
296
+ end
297
+
298
+
299
+
300
+ it "should support dropping multi-column indexes" do
301
+ DBLeftovers::DatabaseInterface.starts_with({
302
+ :index_books_on_year_and_title => DBLeftovers::Index.new(:books, [:year, :title])
303
+ }, {})
304
+ DBLeftovers::Definition.define do
305
+ end
306
+ DBLeftovers::DatabaseInterface.sqls.should have(1).item
307
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
308
+ DROP INDEX index_books_on_year_and_title
309
+ EOQ
310
+ end
311
+
312
+
313
+
314
+ it "should allow mixing indexes and foreign keys in the same table" do
315
+ DBLeftovers::DatabaseInterface.starts_with({}, {})
316
+ DBLeftovers::Definition.define do
317
+ table :books do
318
+ index :author_id
319
+ foreign_key :author_id, :authors, :id
320
+ end
321
+ end
322
+ DBLeftovers::DatabaseInterface.sqls.should have(2).items
323
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
324
+ CREATE INDEX index_books_on_author_id
325
+ ON books
326
+ (author_id)
327
+ EOQ
328
+ DBLeftovers::DatabaseInterface.should have_seen_sql <<-EOQ
329
+ ALTER TABLE books
330
+ ADD CONSTRAINT fk_books_author_id
331
+ FOREIGN KEY (author_id)
332
+ REFERENCES authors (id)
333
+ EOQ
334
+ end
335
+
336
+
337
+
338
+ it "should allow separating indexes and foreign keys from the same table" do
339
+ end
340
+
176
341
  end
data/spec/spec_helper.rb CHANGED
File without changes
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: db_leftovers
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.4.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-01-20 00:00:00.000000000Z
12
+ date: 2012-09-27 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: rails
16
- requirement: &80697560 !ruby/object:Gem::Requirement
16
+ requirement: !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,32 +21,47 @@ dependencies:
21
21
  version: 3.0.0
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *80697560
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: 3.0.0
25
30
  - !ruby/object:Gem::Dependency
26
31
  name: rspec
27
- requirement: &80697230 !ruby/object:Gem::Requirement
32
+ requirement: !ruby/object:Gem::Requirement
28
33
  none: false
29
34
  requirements:
30
35
  - - ~>
31
36
  - !ruby/object:Gem::Version
32
- version: 2.3.0
37
+ version: 2.4.0
33
38
  type: :development
34
39
  prerelease: false
35
- version_requirements: *80697230
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ~>
44
+ - !ruby/object:Gem::Version
45
+ version: 2.4.0
36
46
  - !ruby/object:Gem::Dependency
37
47
  name: bundler
38
- requirement: &80696850 !ruby/object:Gem::Requirement
48
+ requirement: !ruby/object:Gem::Requirement
39
49
  none: false
40
50
  requirements:
41
- - - ~>
51
+ - - ! '>='
42
52
  - !ruby/object:Gem::Version
43
- version: 1.0.0
53
+ version: '0'
44
54
  type: :development
45
55
  prerelease: false
46
- version_requirements: *80696850
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
47
62
  - !ruby/object:Gem::Dependency
48
63
  name: jeweler
49
- requirement: &80691820 !ruby/object:Gem::Requirement
64
+ requirement: !ruby/object:Gem::Requirement
50
65
  none: false
51
66
  requirements:
52
67
  - - ~>
@@ -54,10 +69,15 @@ dependencies:
54
69
  version: 1.6.4
55
70
  type: :development
56
71
  prerelease: false
57
- version_requirements: *80691820
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ none: false
74
+ requirements:
75
+ - - ~>
76
+ - !ruby/object:Gem::Version
77
+ version: 1.6.4
58
78
  - !ruby/object:Gem::Dependency
59
79
  name: rcov
60
- requirement: &80691390 !ruby/object:Gem::Requirement
80
+ requirement: !ruby/object:Gem::Requirement
61
81
  none: false
62
82
  requirements:
63
83
  - - ! '>='
@@ -65,7 +85,12 @@ dependencies:
65
85
  version: '0'
66
86
  type: :development
67
87
  prerelease: false
68
- version_requirements: *80691390
88
+ version_requirements: !ruby/object:Gem::Requirement
89
+ none: false
90
+ requirements:
91
+ - - ! '>='
92
+ - !ruby/object:Gem::Version
93
+ version: '0'
69
94
  description: ! " Define indexes and foreign keys for your Rails app\n in
70
95
  one place using an easy-to-read DSL,\n then run a rake task to bring your
71
96
  database up-to-date.\n"
@@ -87,6 +112,7 @@ files:
87
112
  - VERSION
88
113
  - db_leftovers.gemspec
89
114
  - lib/db_leftovers.rb
115
+ - lib/db_leftovers/constraint.rb
90
116
  - lib/db_leftovers/database_interface.rb
91
117
  - lib/db_leftovers/definition.rb
92
118
  - lib/db_leftovers/dsl.rb
@@ -113,7 +139,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
113
139
  version: '0'
114
140
  segments:
115
141
  - 0
116
- hash: -934339327
142
+ hash: -2560177434569701108
117
143
  required_rubygems_version: !ruby/object:Gem::Requirement
118
144
  none: false
119
145
  requirements:
@@ -122,7 +148,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
122
148
  version: '0'
123
149
  requirements: []
124
150
  rubyforge_project:
125
- rubygems_version: 1.8.10
151
+ rubygems_version: 1.8.24
126
152
  signing_key:
127
153
  specification_version: 3
128
154
  summary: Used to define indexes and foreign keys for your Rails app