fx 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (89) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +9 -0
  3. data/.rspec +2 -0
  4. data/.ruby-version +1 -0
  5. data/.travis.yml +27 -0
  6. data/.yardopts +4 -0
  7. data/Appraisals +21 -0
  8. data/CONTRIBUTING.md +15 -0
  9. data/Gemfile +4 -0
  10. data/README.md +81 -0
  11. data/Rakefile +23 -0
  12. data/bin/appraisal +17 -0
  13. data/bin/console +14 -0
  14. data/bin/rake +17 -0
  15. data/bin/rspec +17 -0
  16. data/bin/setup +12 -0
  17. data/bin/yard +17 -0
  18. data/fx.gemspec +38 -0
  19. data/gemfiles/rails40.gemfile +8 -0
  20. data/gemfiles/rails40.gemfile.lock +111 -0
  21. data/gemfiles/rails41.gemfile +8 -0
  22. data/gemfiles/rails41.gemfile.lock +113 -0
  23. data/gemfiles/rails42.gemfile +8 -0
  24. data/gemfiles/rails42.gemfile.lock +130 -0
  25. data/gemfiles/rails50.gemfile +8 -0
  26. data/gemfiles/rails50.gemfile.lock +126 -0
  27. data/lib/fx.rb +21 -0
  28. data/lib/fx/adapters/postgres.rb +142 -0
  29. data/lib/fx/adapters/postgres/connection.rb +16 -0
  30. data/lib/fx/adapters/postgres/functions.rb +55 -0
  31. data/lib/fx/adapters/postgres/triggers.rb +56 -0
  32. data/lib/fx/command_recorder.rb +29 -0
  33. data/lib/fx/command_recorder/arguments.rb +43 -0
  34. data/lib/fx/command_recorder/function.rb +30 -0
  35. data/lib/fx/command_recorder/trigger.rb +30 -0
  36. data/lib/fx/configuration.rb +38 -0
  37. data/lib/fx/definition.rb +36 -0
  38. data/lib/fx/function.rb +24 -0
  39. data/lib/fx/schema_dumper.rb +15 -0
  40. data/lib/fx/schema_dumper/function.rb +29 -0
  41. data/lib/fx/schema_dumper/trigger.rb +29 -0
  42. data/lib/fx/statements.rb +16 -0
  43. data/lib/fx/statements/function.rb +105 -0
  44. data/lib/fx/statements/trigger.rb +133 -0
  45. data/lib/fx/trigger.rb +24 -0
  46. data/lib/fx/version.rb +4 -0
  47. data/lib/generators.rb +11 -0
  48. data/lib/generators/fx/function/USAGE +9 -0
  49. data/lib/generators/fx/function/function_generator.rb +98 -0
  50. data/lib/generators/fx/function/templates/db/migrate/create_function.erb +5 -0
  51. data/lib/generators/fx/function/templates/db/migrate/update_function.erb +5 -0
  52. data/lib/generators/fx/trigger/USAGE +18 -0
  53. data/lib/generators/fx/trigger/templates/db/migrate/create_trigger.erb +5 -0
  54. data/lib/generators/fx/trigger/templates/db/migrate/update_trigger.erb +5 -0
  55. data/lib/generators/fx/trigger/trigger_generator.rb +108 -0
  56. data/spec/acceptance/user_manages_functions_spec.rb +37 -0
  57. data/spec/acceptance/user_manages_triggers_spec.rb +51 -0
  58. data/spec/acceptance_helper.rb +61 -0
  59. data/spec/dummy/.gitignore +16 -0
  60. data/spec/dummy/Rakefile +6 -0
  61. data/spec/dummy/bin/bundle +3 -0
  62. data/spec/dummy/bin/rails +4 -0
  63. data/spec/dummy/bin/rake +4 -0
  64. data/spec/dummy/config.ru +4 -0
  65. data/spec/dummy/config/application.rb +15 -0
  66. data/spec/dummy/config/boot.rb +5 -0
  67. data/spec/dummy/config/database.yml +9 -0
  68. data/spec/dummy/config/environment.rb +5 -0
  69. data/spec/dummy/db/migrate/.keep +0 -0
  70. data/spec/features/functions/migrations_spec.rb +65 -0
  71. data/spec/features/functions/revert_spec.rb +75 -0
  72. data/spec/features/triggers/migrations_spec.rb +56 -0
  73. data/spec/features/triggers/revert_spec.rb +95 -0
  74. data/spec/fx/adapters/postgres_spec.rb +149 -0
  75. data/spec/fx/command_recorder/arguments_spec.rb +41 -0
  76. data/spec/fx/command_recorder_spec.rb +171 -0
  77. data/spec/fx/configuration_spec.rb +21 -0
  78. data/spec/fx/definition_spec.rb +111 -0
  79. data/spec/fx/schema_dumper/function_spec.rb +22 -0
  80. data/spec/fx/schema_dumper/trigger_spec.rb +40 -0
  81. data/spec/fx/statements/function_spec.rb +103 -0
  82. data/spec/fx/statements/trigger_spec.rb +132 -0
  83. data/spec/generators/fx/function/function_generator_spec.rb +34 -0
  84. data/spec/generators/fx/trigger/trigger_generator_spec.rb +47 -0
  85. data/spec/spec_helper.rb +21 -0
  86. data/spec/support/definition_helpers.rb +37 -0
  87. data/spec/support/generator_setup.rb +11 -0
  88. data/spec/support/migration_helpers.rb +17 -0
  89. metadata +334 -0
@@ -0,0 +1,47 @@
1
+ require "spec_helper"
2
+ require "generators/fx/trigger/trigger_generator"
3
+
4
+ describe Fx::Generators::TriggerGenerator, :generator do
5
+ it "creates a trigger definition file, and a migration" do
6
+ migration = file("db/migrate/create_trigger_test.rb")
7
+ trigger_definition = file("db/triggers/test_v01.sql")
8
+
9
+ run_generator ["test", "table_name" => "some_table"]
10
+
11
+ expect(trigger_definition).to exist
12
+ expect(migration).to be_a_migration
13
+ expect(migration_file(migration)).to contain "CreateTriggerTest"
14
+ expect(migration_file(migration)).to contain "on: :some_table"
15
+ end
16
+
17
+ it "supports naming the table as `on` aswell as `table_name`" do
18
+ migration = file("db/migrate/create_trigger_test.rb")
19
+ trigger_definition = file("db/triggers/test_v01.sql")
20
+
21
+ run_generator ["test", "on" => "some_table"]
22
+
23
+ expect(trigger_definition).to exist
24
+ expect(migration).to be_a_migration
25
+ expect(migration_file(migration)).to contain "CreateTriggerTest"
26
+ expect(migration_file(migration)).to contain "on: :some_table"
27
+ end
28
+
29
+ it "requires `table_name` or `on` to be specified" do
30
+ expect {
31
+ run_generator ["test", "foo" => "some_table"]
32
+ }.to raise_error ArgumentError
33
+ end
34
+
35
+ it "updates an existing trigger" do
36
+ allow(Dir).to receive(:entries).and_return(["test_v01.sql"])
37
+ migration = file("db/migrate/update_trigger_test_to_version_2.rb")
38
+ trigger_definition = file("db/triggers/test_v02.sql")
39
+
40
+ run_generator ["test", "table_name" => "some_table"]
41
+
42
+ expect(trigger_definition).to exist
43
+ expect(migration).to be_a_migration
44
+ expect(migration_file(migration)).to contain "UpdateTriggerTestToVersion2"
45
+ expect(migration_file(migration)).to contain "on: :some_table"
46
+ end
47
+ end
@@ -0,0 +1,21 @@
1
+ ENV["RAILS_ENV"] = "test"
2
+ require "database_cleaner"
3
+
4
+ require File.expand_path("../dummy/config/environment", __FILE__)
5
+ Dir["spec/support/**/*.rb"].sort.each { |file| load file }
6
+
7
+ RSpec.configure do |config|
8
+ config.order = "random"
9
+ DatabaseCleaner.strategy = :transaction
10
+
11
+ config.around(:each, db: true) do |example|
12
+ DatabaseCleaner.start
13
+ example.run
14
+ DatabaseCleaner.clean
15
+ end
16
+
17
+ unless defined?(silence_stream)
18
+ require "active_support/testing/stream"
19
+ config.include ActiveSupport::Testing::Stream
20
+ end
21
+ end
@@ -0,0 +1,37 @@
1
+ module DefinitionHelpers
2
+ def with_function_definition(name:, sql_definition:, version: 1, &block)
3
+ definition = Fx::Definition.new(name: name, version: version)
4
+
5
+ with_definition(
6
+ definition: definition,
7
+ sql_definition: sql_definition,
8
+ block: block,
9
+ )
10
+ end
11
+
12
+ def with_trigger_definition(name:, sql_definition:, version: 1, &block)
13
+ definition = Fx::Definition.new(
14
+ name: name,
15
+ version: version,
16
+ type: "trigger",
17
+ )
18
+
19
+ with_definition(
20
+ definition: definition,
21
+ sql_definition: sql_definition,
22
+ block: block,
23
+ )
24
+ end
25
+
26
+ def with_definition(definition:, sql_definition:, block:)
27
+ FileUtils.mkdir_p(File.dirname(definition.full_path))
28
+ File.open(definition.full_path, "w") { |f| f.write(sql_definition) }
29
+ block.call
30
+ ensure
31
+ File.delete definition.full_path
32
+ end
33
+ end
34
+
35
+ RSpec.configure do |config|
36
+ config.include DefinitionHelpers
37
+ end
@@ -0,0 +1,11 @@
1
+ require "ammeter/init"
2
+
3
+ RSpec.configure do |config|
4
+ config.before(:each, :generator) do
5
+ fake_rails_root = File.expand_path("../../../tmp", __FILE__)
6
+ allow(Rails).to receive(:root).and_return(Pathname.new(fake_rails_root))
7
+
8
+ destination fake_rails_root
9
+ prepare_destination
10
+ end
11
+ end
@@ -0,0 +1,17 @@
1
+ module MigrationsHelper
2
+ def run_migration(migration, directions)
3
+ silence_stream(STDOUT) do
4
+ Array.wrap(directions).each do |direction|
5
+ migration.migrate(direction)
6
+ end
7
+ end
8
+ end
9
+
10
+ def connection
11
+ @_connection ||= ActiveRecord::Base.connection
12
+ end
13
+ end
14
+
15
+ RSpec.configure do |config|
16
+ config.include MigrationsHelper
17
+ end
metadata ADDED
@@ -0,0 +1,334 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fx
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Teo Ljungberg
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-10-12 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: appraisal
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '1.5'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '1.5'
41
+ - !ruby/object:Gem::Dependency
42
+ name: database_cleaner
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '3.3'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '3.3'
83
+ - !ruby/object:Gem::Dependency
84
+ name: pg
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: pry
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: ammeter
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: 1.1.3
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: 1.1.3
125
+ - !ruby/object:Gem::Dependency
126
+ name: yard
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: redcarpet
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: activerecord
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - ">="
158
+ - !ruby/object:Gem::Version
159
+ version: 4.0.0
160
+ type: :runtime
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - ">="
165
+ - !ruby/object:Gem::Version
166
+ version: 4.0.0
167
+ - !ruby/object:Gem::Dependency
168
+ name: railties
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - ">="
172
+ - !ruby/object:Gem::Version
173
+ version: 4.0.0
174
+ type: :runtime
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - ">="
179
+ - !ruby/object:Gem::Version
180
+ version: 4.0.0
181
+ description: |2
182
+ Adds methods to ActiveRecord::Migration to create and manage database functions
183
+ and triggers in Rails
184
+ email:
185
+ - teo@teoljungberg.com
186
+ executables: []
187
+ extensions: []
188
+ extra_rdoc_files: []
189
+ files:
190
+ - ".gitignore"
191
+ - ".rspec"
192
+ - ".ruby-version"
193
+ - ".travis.yml"
194
+ - ".yardopts"
195
+ - Appraisals
196
+ - CONTRIBUTING.md
197
+ - Gemfile
198
+ - README.md
199
+ - Rakefile
200
+ - bin/appraisal
201
+ - bin/console
202
+ - bin/rake
203
+ - bin/rspec
204
+ - bin/setup
205
+ - bin/yard
206
+ - fx.gemspec
207
+ - gemfiles/rails40.gemfile
208
+ - gemfiles/rails40.gemfile.lock
209
+ - gemfiles/rails41.gemfile
210
+ - gemfiles/rails41.gemfile.lock
211
+ - gemfiles/rails42.gemfile
212
+ - gemfiles/rails42.gemfile.lock
213
+ - gemfiles/rails50.gemfile
214
+ - gemfiles/rails50.gemfile.lock
215
+ - lib/fx.rb
216
+ - lib/fx/adapters/postgres.rb
217
+ - lib/fx/adapters/postgres/connection.rb
218
+ - lib/fx/adapters/postgres/functions.rb
219
+ - lib/fx/adapters/postgres/triggers.rb
220
+ - lib/fx/command_recorder.rb
221
+ - lib/fx/command_recorder/arguments.rb
222
+ - lib/fx/command_recorder/function.rb
223
+ - lib/fx/command_recorder/trigger.rb
224
+ - lib/fx/configuration.rb
225
+ - lib/fx/definition.rb
226
+ - lib/fx/function.rb
227
+ - lib/fx/schema_dumper.rb
228
+ - lib/fx/schema_dumper/function.rb
229
+ - lib/fx/schema_dumper/trigger.rb
230
+ - lib/fx/statements.rb
231
+ - lib/fx/statements/function.rb
232
+ - lib/fx/statements/trigger.rb
233
+ - lib/fx/trigger.rb
234
+ - lib/fx/version.rb
235
+ - lib/generators.rb
236
+ - lib/generators/fx/function/USAGE
237
+ - lib/generators/fx/function/function_generator.rb
238
+ - lib/generators/fx/function/templates/db/migrate/create_function.erb
239
+ - lib/generators/fx/function/templates/db/migrate/update_function.erb
240
+ - lib/generators/fx/trigger/USAGE
241
+ - lib/generators/fx/trigger/templates/db/migrate/create_trigger.erb
242
+ - lib/generators/fx/trigger/templates/db/migrate/update_trigger.erb
243
+ - lib/generators/fx/trigger/trigger_generator.rb
244
+ - spec/acceptance/user_manages_functions_spec.rb
245
+ - spec/acceptance/user_manages_triggers_spec.rb
246
+ - spec/acceptance_helper.rb
247
+ - spec/dummy/.gitignore
248
+ - spec/dummy/Rakefile
249
+ - spec/dummy/bin/bundle
250
+ - spec/dummy/bin/rails
251
+ - spec/dummy/bin/rake
252
+ - spec/dummy/config.ru
253
+ - spec/dummy/config/application.rb
254
+ - spec/dummy/config/boot.rb
255
+ - spec/dummy/config/database.yml
256
+ - spec/dummy/config/environment.rb
257
+ - spec/dummy/db/migrate/.keep
258
+ - spec/features/functions/migrations_spec.rb
259
+ - spec/features/functions/revert_spec.rb
260
+ - spec/features/triggers/migrations_spec.rb
261
+ - spec/features/triggers/revert_spec.rb
262
+ - spec/fx/adapters/postgres_spec.rb
263
+ - spec/fx/command_recorder/arguments_spec.rb
264
+ - spec/fx/command_recorder_spec.rb
265
+ - spec/fx/configuration_spec.rb
266
+ - spec/fx/definition_spec.rb
267
+ - spec/fx/schema_dumper/function_spec.rb
268
+ - spec/fx/schema_dumper/trigger_spec.rb
269
+ - spec/fx/statements/function_spec.rb
270
+ - spec/fx/statements/trigger_spec.rb
271
+ - spec/generators/fx/function/function_generator_spec.rb
272
+ - spec/generators/fx/trigger/trigger_generator_spec.rb
273
+ - spec/spec_helper.rb
274
+ - spec/support/definition_helpers.rb
275
+ - spec/support/generator_setup.rb
276
+ - spec/support/migration_helpers.rb
277
+ homepage: https://github.com/teoljungberg/fx
278
+ licenses:
279
+ - MIT
280
+ metadata: {}
281
+ post_install_message:
282
+ rdoc_options: []
283
+ require_paths:
284
+ - lib
285
+ required_ruby_version: !ruby/object:Gem::Requirement
286
+ requirements:
287
+ - - "~>"
288
+ - !ruby/object:Gem::Version
289
+ version: '2.1'
290
+ required_rubygems_version: !ruby/object:Gem::Requirement
291
+ requirements:
292
+ - - ">="
293
+ - !ruby/object:Gem::Version
294
+ version: '0'
295
+ requirements: []
296
+ rubyforge_project:
297
+ rubygems_version: 2.5.1
298
+ signing_key:
299
+ specification_version: 4
300
+ summary: Support for database functions and triggers in Rails migrations
301
+ test_files:
302
+ - spec/acceptance/user_manages_functions_spec.rb
303
+ - spec/acceptance/user_manages_triggers_spec.rb
304
+ - spec/acceptance_helper.rb
305
+ - spec/dummy/.gitignore
306
+ - spec/dummy/Rakefile
307
+ - spec/dummy/bin/bundle
308
+ - spec/dummy/bin/rails
309
+ - spec/dummy/bin/rake
310
+ - spec/dummy/config.ru
311
+ - spec/dummy/config/application.rb
312
+ - spec/dummy/config/boot.rb
313
+ - spec/dummy/config/database.yml
314
+ - spec/dummy/config/environment.rb
315
+ - spec/dummy/db/migrate/.keep
316
+ - spec/features/functions/migrations_spec.rb
317
+ - spec/features/functions/revert_spec.rb
318
+ - spec/features/triggers/migrations_spec.rb
319
+ - spec/features/triggers/revert_spec.rb
320
+ - spec/fx/adapters/postgres_spec.rb
321
+ - spec/fx/command_recorder/arguments_spec.rb
322
+ - spec/fx/command_recorder_spec.rb
323
+ - spec/fx/configuration_spec.rb
324
+ - spec/fx/definition_spec.rb
325
+ - spec/fx/schema_dumper/function_spec.rb
326
+ - spec/fx/schema_dumper/trigger_spec.rb
327
+ - spec/fx/statements/function_spec.rb
328
+ - spec/fx/statements/trigger_spec.rb
329
+ - spec/generators/fx/function/function_generator_spec.rb
330
+ - spec/generators/fx/trigger/trigger_generator_spec.rb
331
+ - spec/spec_helper.rb
332
+ - spec/support/definition_helpers.rb
333
+ - spec/support/generator_setup.rb
334
+ - spec/support/migration_helpers.rb