spectacles 0.5.1 → 0.5.2
Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6bff68ef734659627597aa1deae49e6357b55a1a
|
4
|
+
data.tar.gz: 9562fb0f911b796007471e34520a8c29a960e943
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4195cc3601e942d02ef38564c16b7ac0bacfff12ea6559165b4b673b90cfb230679a9a88bc9db941260d4f8c28d422912ece536a97b71c760783d0f0f977cfc2
|
7
|
+
data.tar.gz: 51e088f02be3e2a436956339d340376fefb379e4a3164a7c07b24f94a484c39a1d89d9b09016e6ede1a853619bd7d8362d7388243bb49a4a6d0a1862a75c0589
|
@@ -4,7 +4,7 @@ module Spectacles
|
|
4
4
|
module SchemaStatements
|
5
5
|
module PostgreSQLAdapter
|
6
6
|
include Spectacles::SchemaStatements::AbstractAdapter
|
7
|
-
|
7
|
+
|
8
8
|
def views(name = nil) #:nodoc:
|
9
9
|
q = <<-SQL
|
10
10
|
SELECT table_name, table_type
|
@@ -12,22 +12,23 @@ module Spectacles
|
|
12
12
|
WHERE table_schema IN (#{schemas})
|
13
13
|
AND table_type = 'VIEW'
|
14
14
|
SQL
|
15
|
-
|
15
|
+
|
16
16
|
execute(q, name).map { |row| row['table_name'] }
|
17
17
|
end
|
18
18
|
|
19
19
|
def view_build_query(view, name = nil)
|
20
20
|
q = <<-SQL
|
21
21
|
SELECT view_definition
|
22
|
-
FROM information_schema.views
|
22
|
+
FROM information_schema.views
|
23
23
|
WHERE table_catalog = (SELECT catalog_name FROM information_schema.information_schema_catalog_name)
|
24
24
|
AND table_schema IN (#{schemas})
|
25
25
|
AND table_name = '#{view}'
|
26
26
|
SQL
|
27
|
-
|
28
|
-
select_value(q, name) or raise "No view called #{view} found"
|
27
|
+
|
28
|
+
view_sql = select_value(q, name) or raise "No view called #{view} found"
|
29
|
+
view_sql.gsub("\"", "\\\"")
|
29
30
|
end
|
30
|
-
|
31
|
+
|
31
32
|
private
|
32
33
|
def schemas
|
33
34
|
schema_search_path.split(/,/).map { |p| quote(p) }.join(',')
|
data/lib/spectacles/version.rb
CHANGED
@@ -14,4 +14,16 @@ describe "Spectacles::SchemaStatements::PostgreSQLAdapter" do
|
|
14
14
|
|
15
15
|
it_behaves_like "an adapter", "PostgreSQLAdapter"
|
16
16
|
it_behaves_like "a view model"
|
17
|
+
|
18
|
+
describe "#view_build_query" do
|
19
|
+
test_base = Class.new do
|
20
|
+
extend Spectacles::SchemaStatements::PostgreSQLAdapter
|
21
|
+
def self.schema_search_path; ""; end
|
22
|
+
def self.select_value(_, _); "\"products\""; end;
|
23
|
+
end
|
24
|
+
|
25
|
+
it "should escape double-quotes returned by Postgres" do
|
26
|
+
test_base.view_build_query(:new_product_users).must_match(/\\"/)
|
27
|
+
end
|
28
|
+
end
|
17
29
|
end
|
metadata
CHANGED
@@ -1,69 +1,69 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: spectacles
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.5.
|
4
|
+
version: 0.5.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Adam Hutchison, Brandon Dewitt
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2014-
|
11
|
+
date: 2014-12-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- -
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
19
|
version: 3.2.0
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- -
|
24
|
+
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: 3.2.0
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: activesupport
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- -
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
33
|
version: 3.2.0
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- -
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: 3.2.0
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rake
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- -
|
45
|
+
- - ">="
|
46
46
|
- !ruby/object:Gem::Version
|
47
47
|
version: '0'
|
48
48
|
type: :development
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- -
|
52
|
+
- - ">="
|
53
53
|
- !ruby/object:Gem::Version
|
54
54
|
version: '0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: minitest
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
|
-
- -
|
59
|
+
- - ">="
|
60
60
|
- !ruby/object:Gem::Version
|
61
61
|
version: '0'
|
62
62
|
type: :development
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
|
-
- -
|
66
|
+
- - ">="
|
67
67
|
- !ruby/object:Gem::Version
|
68
68
|
version: '0'
|
69
69
|
description: Spectacles adds database view functionality to ActiveRecord. Current
|
@@ -74,7 +74,7 @@ executables: []
|
|
74
74
|
extensions: []
|
75
75
|
extra_rdoc_files: []
|
76
76
|
files:
|
77
|
-
- .gitignore
|
77
|
+
- ".gitignore"
|
78
78
|
- Gemfile
|
79
79
|
- LICENSE
|
80
80
|
- Rakefile
|
@@ -117,17 +117,17 @@ require_paths:
|
|
117
117
|
- lib
|
118
118
|
required_ruby_version: !ruby/object:Gem::Requirement
|
119
119
|
requirements:
|
120
|
-
- -
|
120
|
+
- - ">="
|
121
121
|
- !ruby/object:Gem::Version
|
122
122
|
version: '0'
|
123
123
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
124
124
|
requirements:
|
125
|
-
- -
|
125
|
+
- - ">="
|
126
126
|
- !ruby/object:Gem::Version
|
127
127
|
version: '0'
|
128
128
|
requirements: []
|
129
129
|
rubyforge_project:
|
130
|
-
rubygems_version: 2.
|
130
|
+
rubygems_version: 2.4.3
|
131
131
|
signing_key:
|
132
132
|
specification_version: 4
|
133
133
|
summary: Spectacles (derived from RailsSQLViews) adds database view functionality
|