sequel-pg-comment 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,18 @@
1
+ require_relative 'spec_helper'
2
+ require 'sequel'
3
+
4
+ describe "#create_view" do
5
+ let(:db) do
6
+ Sequel.connect("mock://postgres").extension(:pg_comment)
7
+ end
8
+
9
+ it "sets a table comment" do
10
+ db.create_view(
11
+ :gold_albums,
12
+ db[:albums].where { copies_sold > 500_000 },
13
+ :comment => "Rich!"
14
+ )
15
+ expect(db.sqls.last).
16
+ to eq("COMMENT ON VIEW \"gold_albums\" IS 'Rich!'")
17
+ end
18
+ end
@@ -0,0 +1,11 @@
1
+ require_relative "spec_helper"
2
+ require 'sequel'
3
+
4
+ context "pg-comment extension" do
5
+ it "loads successfully" do
6
+ expect do
7
+ Sequel::Database.extension :pg_comment
8
+ Sequel::Database.connect "mock://postgres"
9
+ end.to_not raise_error
10
+ end
11
+ end
@@ -0,0 +1,48 @@
1
+ require_relative 'spec_helper'
2
+ require 'sequel'
3
+ require 'sequel/extensions/pg_comment'
4
+
5
+ context "Sequel::Extension::PgComment.normalise_comment" do
6
+ def nc(s)
7
+ Sequel::Extension::PgComment.normalise_comment(s)
8
+ end
9
+
10
+ it "does nothing to a string with no leading whitespace" do
11
+ expect(nc("foo\nbar\nbaz")).to eq("foo\nbar\nbaz")
12
+ end
13
+
14
+ it "strips leading empty lines" do
15
+ expect(nc("\n\n\nfoo\nbar\nbaz")).to eq("foo\nbar\nbaz")
16
+ end
17
+
18
+ it "strips trailing empty lines" do
19
+ expect(nc("foo\nbar\nbaz\n\n\n")).to eq("foo\nbar\nbaz")
20
+ end
21
+
22
+ it "strips leading whitespace from all lines" do
23
+ expect(nc(" foo\n bar\n baz")).to eq("foo\nbar\nbaz")
24
+ end
25
+
26
+ it "correctly handles intermediate empty lines" do
27
+ expect(nc(" foo\n bar\n\n baz")).to eq("foo\nbar\n\nbaz")
28
+ end
29
+
30
+ it "ignores different leading whitespace" do
31
+ expect(nc(" foo\n bar\n\t baz")).to eq("foo\nbar\n\t baz")
32
+ end
33
+
34
+ it "partially truncates extra-whitespaced lines" do
35
+ expect(nc(" foo\n bar\n baz")).to eq("foo\nbar\n baz")
36
+ end
37
+
38
+ it "handles everything at once" do
39
+ expect(nc(<<-EOF)).to eq("foo\n\t bar\n baz")
40
+
41
+ foo
42
+ bar
43
+ baz
44
+
45
+
46
+ EOF
47
+ end
48
+ end
@@ -0,0 +1,23 @@
1
+ require 'spork'
2
+
3
+ Spork.prefork do
4
+ require 'bundler'
5
+ Bundler.setup(:default, :test)
6
+ require 'rspec/core'
7
+ require 'rspec/mocks'
8
+
9
+ require 'pry'
10
+
11
+ RSpec.configure do |config|
12
+ config.fail_fast = true
13
+ # config.full_backtrace = true
14
+
15
+ config.expect_with :rspec do |c|
16
+ c.syntax = :expect
17
+ end
18
+ end
19
+ end
20
+
21
+ Spork.each_run do
22
+ # Nothing to do here, specs will load the files they need
23
+ end
@@ -0,0 +1,96 @@
1
+ require_relative 'spec_helper'
2
+
3
+ require 'sequel'
4
+ require 'sequel/extensions/pg_comment'
5
+
6
+ describe "SqlGenerator" do
7
+ SqlGenerator = Sequel::Extension::PgComment::SqlGenerator
8
+ PrefixSqlGenerator = Sequel::Extension::PgComment::PrefixSqlGenerator
9
+
10
+ context "a simple type expressed as a string" do
11
+ let(:generator) { SqlGenerator.create("TABLE", :foo, "Ohai!") }
12
+
13
+ it "generates quoted SQL" do
14
+ expect(generator.generate).
15
+ to eq("COMMENT ON TABLE \"foo\" IS 'Ohai!'")
16
+ end
17
+ end
18
+
19
+ context "a simple type expressed as a crazy-case string" do
20
+ let(:generator) { SqlGenerator.create("TaBlE", :foo, "Ohai!") }
21
+
22
+ it "generates quoted SQL" do
23
+ expect(generator.generate).
24
+ to eq("COMMENT ON TABLE \"foo\" IS 'Ohai!'")
25
+ end
26
+ end
27
+
28
+ context "a simple type expressed as a symbol" do
29
+ let(:generator) { SqlGenerator.create(:table, :foo, "Ohai!") }
30
+
31
+ it "generates quoted SQL" do
32
+ expect(generator.generate).
33
+ to eq("COMMENT ON TABLE \"foo\" IS 'Ohai!'")
34
+ end
35
+ end
36
+
37
+ context "a multi-word type expressed as a symbol" do
38
+ let(:generator) { SqlGenerator.create(:event_trigger, :foo, "Ohai!") }
39
+
40
+ it "generates correct SQL" do
41
+ expect(generator.generate).
42
+ to eq("COMMENT ON EVENT TRIGGER \"foo\" IS 'Ohai!'")
43
+ end
44
+ end
45
+
46
+ context "with a string as the object name" do
47
+ let(:generator) { SqlGenerator.create(:table, "foo", "Ohai!") }
48
+
49
+ it "generates unquoted SQL" do
50
+ expect(generator.generate).
51
+ to eq("COMMENT ON TABLE foo IS 'Ohai!'")
52
+ end
53
+ end
54
+
55
+ it "escapes the comment" do
56
+ expect(SqlGenerator.create(:table, :foo, "O'hai!").generate).
57
+ to eq("COMMENT ON TABLE \"foo\" IS 'O''hai!'")
58
+ end
59
+
60
+ it "explodes if an invalid object type is given" do
61
+ expect do
62
+ SqlGenerator.create(:foobooblee, :foo, "O'hai!")
63
+ end.to raise_error(ArgumentError, /unrecognised object type/i)
64
+ end
65
+
66
+ it "sets a column comment correctly" do
67
+ expect(SqlGenerator.create(:column, :foo__bar_id, "Ohai, column!").generate).
68
+ to eq("COMMENT ON COLUMN \"foo\".\"bar_id\" IS 'Ohai, column!'")
69
+ end
70
+
71
+ it "sets a constraint comment correctly" do
72
+ g = SqlGenerator.create(:constraint, :foo__not_for_you, "Ohai, constraint!")
73
+ expect(g.generate).
74
+ to eq("COMMENT ON CONSTRAINT \"not_for_you\" ON \"foo\" IS 'Ohai, constraint!'")
75
+ end
76
+
77
+ it "sets a rule comment correctly" do
78
+ g = SqlGenerator.create(:rule, :foo__not_for_you, "Ohai, rule!")
79
+ expect(g.generate).
80
+ to eq("COMMENT ON RULE \"not_for_you\" ON \"foo\" IS 'Ohai, rule!'")
81
+ end
82
+
83
+ it "sets a trigger comment correctly" do
84
+ g = SqlGenerator.create(:trigger, :foo__spoing, "Ohai, trigger!")
85
+ expect(g.generate).
86
+ to eq("COMMENT ON TRIGGER \"spoing\" ON \"foo\" IS 'Ohai, trigger!'")
87
+ end
88
+
89
+ it "sets a comment on a prefixed name correctly" do
90
+ g = PrefixSqlGenerator.new(:index, :_pkey, "Ohai, pkey!")
91
+ g.table_name = :foo
92
+
93
+ expect(g.generate).
94
+ to eq("COMMENT ON INDEX \"foo_pkey\" IS 'Ohai, pkey!'")
95
+ end
96
+ end
metadata ADDED
@@ -0,0 +1,242 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sequel-pg-comment
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Matt Palmer
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-02-15 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: git-version-bump
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '0.10'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '0.10'
27
+ - !ruby/object:Gem::Dependency
28
+ name: sequel
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
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: github-release
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: guard-spork
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: guard-rspec
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: rb-inotify
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: '0.9'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: '0.9'
111
+ - !ruby/object:Gem::Dependency
112
+ name: pry-byebug
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: rake
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: '10.4'
132
+ - - ">="
133
+ - !ruby/object:Gem::Version
134
+ version: 10.4.2
135
+ type: :development
136
+ prerelease: false
137
+ version_requirements: !ruby/object:Gem::Requirement
138
+ requirements:
139
+ - - "~>"
140
+ - !ruby/object:Gem::Version
141
+ version: '10.4'
142
+ - - ">="
143
+ - !ruby/object:Gem::Version
144
+ version: 10.4.2
145
+ - !ruby/object:Gem::Dependency
146
+ name: redcarpet
147
+ requirement: !ruby/object:Gem::Requirement
148
+ requirements:
149
+ - - ">="
150
+ - !ruby/object:Gem::Version
151
+ version: '0'
152
+ type: :development
153
+ prerelease: false
154
+ version_requirements: !ruby/object:Gem::Requirement
155
+ requirements:
156
+ - - ">="
157
+ - !ruby/object:Gem::Version
158
+ version: '0'
159
+ - !ruby/object:Gem::Dependency
160
+ name: rspec
161
+ requirement: !ruby/object:Gem::Requirement
162
+ requirements:
163
+ - - "~>"
164
+ - !ruby/object:Gem::Version
165
+ version: '3.0'
166
+ type: :development
167
+ prerelease: false
168
+ version_requirements: !ruby/object:Gem::Requirement
169
+ requirements:
170
+ - - "~>"
171
+ - !ruby/object:Gem::Version
172
+ version: '3.0'
173
+ - !ruby/object:Gem::Dependency
174
+ name: yard
175
+ requirement: !ruby/object:Gem::Requirement
176
+ requirements:
177
+ - - ">="
178
+ - !ruby/object:Gem::Version
179
+ version: '0'
180
+ type: :development
181
+ prerelease: false
182
+ version_requirements: !ruby/object:Gem::Requirement
183
+ requirements:
184
+ - - ">="
185
+ - !ruby/object:Gem::Version
186
+ version: '0'
187
+ description:
188
+ email:
189
+ executables: []
190
+ extensions: []
191
+ extra_rdoc_files:
192
+ - README.md
193
+ files:
194
+ - ".gitignore"
195
+ - ".yardopts"
196
+ - Gemfile
197
+ - Guardfile
198
+ - LICENCE
199
+ - README.md
200
+ - Rakefile
201
+ - lib/sequel/extensions/pg_comment.rb
202
+ - lib/sequel/extensions/pg_comment/alter_table_generator_methods.rb
203
+ - lib/sequel/extensions/pg_comment/create_table_generator_methods.rb
204
+ - lib/sequel/extensions/pg_comment/database_methods.rb
205
+ - lib/sequel/extensions/pg_comment/dataset_methods.rb
206
+ - lib/sequel/extensions/pg_comment/sql_generator.rb
207
+ - sequel-pg-comment.gemspec
208
+ - spec/alter_table_comment_spec.rb
209
+ - spec/comment_for_spec.rb
210
+ - spec/comment_on_spec.rb
211
+ - spec/create_join_table_comment_spec.rb
212
+ - spec/create_table_comment_spec.rb
213
+ - spec/create_view_comment_spec.rb
214
+ - spec/extension_spec.rb
215
+ - spec/normalise_comment_spec.rb
216
+ - spec/spec_helper.rb
217
+ - spec/sql_generator_spec.rb
218
+ homepage: http://theshed.hezmatt.org/sequel-pg-comment
219
+ licenses: []
220
+ metadata: {}
221
+ post_install_message:
222
+ rdoc_options: []
223
+ require_paths:
224
+ - lib
225
+ required_ruby_version: !ruby/object:Gem::Requirement
226
+ requirements:
227
+ - - ">="
228
+ - !ruby/object:Gem::Version
229
+ version: '0'
230
+ required_rubygems_version: !ruby/object:Gem::Requirement
231
+ requirements:
232
+ - - ">="
233
+ - !ruby/object:Gem::Version
234
+ version: '0'
235
+ requirements: []
236
+ rubyforge_project:
237
+ rubygems_version: 2.2.2
238
+ signing_key:
239
+ specification_version: 4
240
+ summary: Set comments on PgSQL objects from seuqel migrations
241
+ test_files: []
242
+ has_rdoc: