webapi-active-query-builder 1.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (46) hide show
  1. data/LICENSE +201 -0
  2. data/README.md +55 -0
  3. data/docs/ActiveQueryBuilderApi.md +102 -0
  4. data/docs/Condition.md +10 -0
  5. data/docs/ConditionGroup.md +10 -0
  6. data/docs/HiddenColumn.md +8 -0
  7. data/docs/Pagination.md +9 -0
  8. data/docs/QueryColumn.md +9 -0
  9. data/docs/Sorting.md +9 -0
  10. data/docs/SqlQuery.md +9 -0
  11. data/docs/Totals.md +9 -0
  12. data/docs/Transform.md +14 -0
  13. data/docs/TransformResult.md +10 -0
  14. data/git_push.sh +67 -0
  15. data/lib/webapi-active-query-builder.rb +61 -0
  16. data/lib/webapi-active-query-builder/api/active_query_builder_api.rb +148 -0
  17. data/lib/webapi-active-query-builder/api_client.rb +378 -0
  18. data/lib/webapi-active-query-builder/api_error.rb +47 -0
  19. data/lib/webapi-active-query-builder/configuration.rb +207 -0
  20. data/lib/webapi-active-query-builder/models/condition.rb +255 -0
  21. data/lib/webapi-active-query-builder/models/condition_group.rb +257 -0
  22. data/lib/webapi-active-query-builder/models/hidden_column.rb +200 -0
  23. data/lib/webapi-active-query-builder/models/pagination.rb +210 -0
  24. data/lib/webapi-active-query-builder/models/query_column.rb +210 -0
  25. data/lib/webapi-active-query-builder/models/sorting.rb +243 -0
  26. data/lib/webapi-active-query-builder/models/sql_query.rb +210 -0
  27. data/lib/webapi-active-query-builder/models/totals.rb +243 -0
  28. data/lib/webapi-active-query-builder/models/transform.rb +261 -0
  29. data/lib/webapi-active-query-builder/models/transform_result.rb +220 -0
  30. data/lib/webapi-active-query-builder/version.rb +26 -0
  31. data/spec/api/active_query_builder_api_spec.rb +70 -0
  32. data/spec/api_client_spec.rb +237 -0
  33. data/spec/configuration_spec.rb +53 -0
  34. data/spec/models/condition_group_spec.rb +69 -0
  35. data/spec/models/condition_spec.rb +69 -0
  36. data/spec/models/hidden_column_spec.rb +53 -0
  37. data/spec/models/pagination_spec.rb +59 -0
  38. data/spec/models/query_column_spec.rb +59 -0
  39. data/spec/models/sorting_spec.rb +63 -0
  40. data/spec/models/sql_query_spec.rb +59 -0
  41. data/spec/models/totals_spec.rb +63 -0
  42. data/spec/models/transform_result_spec.rb +65 -0
  43. data/spec/models/transform_spec.rb +89 -0
  44. data/spec/spec_helper.rb +122 -0
  45. data/webapi-active-query-builder.gemspec +55 -0
  46. metadata +307 -0
@@ -0,0 +1,26 @@
1
+ =begin
2
+ #QueryBuilderApi
3
+
4
+ #Active Query Builder Web API lets create, analyze and modify SQL queries for different database servers using RESTful HTTP requests to a cloud-based service. It requires SQL execution context (information about database schema and used database server) to be stored under the registered account at https://webapi.activequerybuilder.com/.
5
+
6
+ OpenAPI spec version: 1.1.3
7
+ Contact: support@activedbsoft.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+
10
+ Licensed under the Apache License, Version 2.0 (the "License");
11
+ you may not use this file except in compliance with the License.
12
+ You may obtain a copy of the License at
13
+
14
+ http://www.apache.org/licenses/LICENSE-2.0
15
+
16
+ Unless required by applicable law or agreed to in writing, software
17
+ distributed under the License is distributed on an "AS IS" BASIS,
18
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ See the License for the specific language governing permissions and
20
+ limitations under the License.
21
+
22
+ =end
23
+
24
+ module WebApiActivequerybuilder
25
+ VERSION = "1.1.3"
26
+ end
@@ -0,0 +1,70 @@
1
+ =begin
2
+ #QueryBuilderApi
3
+
4
+ #Active Query Builder Web API lets create, analyze and modify SQL queries for different database servers using RESTful HTTP requests to a cloud-based service. It requires SQL execution context (information about database schema and used database server) to be stored under the registered account at https://webapi.activequerybuilder.com/.
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@activedbsoft.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+
10
+ Licensed under the Apache License, Version 2.0 (the "License");
11
+ you may not use this file except in compliance with the License.
12
+ You may obtain a copy of the License at
13
+
14
+ http://www.apache.org/licenses/LICENSE-2.0
15
+
16
+ Unless required by applicable law or agreed to in writing, software
17
+ distributed under the License is distributed on an "AS IS" BASIS,
18
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ See the License for the specific language governing permissions and
20
+ limitations under the License.
21
+
22
+ =end
23
+
24
+ require 'spec_helper'
25
+ require 'json'
26
+
27
+ # Unit tests for WebApiActivequerybuilder::ActiveQueryBuilderApi
28
+ # Automatically generated by swagger-codegen (github.com/swagger-api/swagger-codegen)
29
+ # Please update as you see appropriate
30
+ describe 'ActiveQueryBuilderApi' do
31
+ before do
32
+ # run before each test
33
+ @instance = WebApiActivequerybuilder::ActiveQueryBuilderApi.new
34
+ end
35
+
36
+ after do
37
+ # run after each test
38
+ end
39
+
40
+ describe 'test an instance of ActiveQueryBuilderApi' do
41
+ it 'should create an instact of ActiveQueryBuilderApi' do
42
+ expect(@instance).to be_instance_of(WebApiActivequerybuilder::ActiveQueryBuilderApi)
43
+ end
44
+ end
45
+
46
+ # unit tests for get_query_columns_post
47
+ #
48
+ # Returns list of columns for the given SQL query.
49
+ # @param query Information about SQL query and it's context.
50
+ # @param [Hash] opts the optional parameters
51
+ # @return [Array<QueryColumn>]
52
+ describe 'get_query_columns_post test' do
53
+ it "should work" do
54
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
55
+ end
56
+ end
57
+
58
+ # unit tests for transform_sql_post
59
+ #
60
+ # Transforms the given SQL query according to the commands provided in this request. You can add constraints, hide some of the resultset columns, chang sorting or limit rows of resultset. All transformations can only lead to reorganization or limitation of the resultset data. This means that it&#39;s impossible to get transformed SQL that reveals any other data than the data retutned by original query.
61
+ # @param transform SQL transformation parameters and commands.
62
+ # @param [Hash] opts the optional parameters
63
+ # @return [TransformResult]
64
+ describe 'transform_sql_post test' do
65
+ it "should work" do
66
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
67
+ end
68
+ end
69
+
70
+ end
@@ -0,0 +1,237 @@
1
+ =begin
2
+ #QueryBuilderApi
3
+
4
+ #Active Query Builder Web API lets create, analyze and modify SQL queries for different database servers using RESTful HTTP requests to a cloud-based service. It requires SQL execution context (information about database schema and used database server) to be stored under the registered account at https://webapi.activequerybuilder.com/.
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@activedbsoft.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+
10
+ Licensed under the Apache License, Version 2.0 (the "License");
11
+ you may not use this file except in compliance with the License.
12
+ You may obtain a copy of the License at
13
+
14
+ http://www.apache.org/licenses/LICENSE-2.0
15
+
16
+ Unless required by applicable law or agreed to in writing, software
17
+ distributed under the License is distributed on an "AS IS" BASIS,
18
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ See the License for the specific language governing permissions and
20
+ limitations under the License.
21
+
22
+ =end
23
+
24
+ require 'spec_helper'
25
+
26
+ describe WebApiActivequerybuilder::ApiClient do
27
+ context 'initialization' do
28
+ context 'URL stuff' do
29
+ context 'host' do
30
+ it 'removes http from host' do
31
+ WebApiActivequerybuilder.configure { |c| c.host = 'http://example.com' }
32
+ expect(WebApiActivequerybuilder::Configuration.default.host).to eq('example.com')
33
+ end
34
+
35
+ it 'removes https from host' do
36
+ WebApiActivequerybuilder.configure { |c| c.host = 'https://wookiee.com' }
37
+ expect(WebApiActivequerybuilder::ApiClient.default.config.host).to eq('wookiee.com')
38
+ end
39
+
40
+ it 'removes trailing path from host' do
41
+ WebApiActivequerybuilder.configure { |c| c.host = 'hobo.com/v4' }
42
+ expect(WebApiActivequerybuilder::Configuration.default.host).to eq('hobo.com')
43
+ end
44
+ end
45
+
46
+ context 'base_path' do
47
+ it "prepends a slash to base_path" do
48
+ WebApiActivequerybuilder.configure { |c| c.base_path = 'v4/dog' }
49
+ expect(WebApiActivequerybuilder::Configuration.default.base_path).to eq('/v4/dog')
50
+ end
51
+
52
+ it "doesn't prepend a slash if one is already there" do
53
+ WebApiActivequerybuilder.configure { |c| c.base_path = '/v4/dog' }
54
+ expect(WebApiActivequerybuilder::Configuration.default.base_path).to eq('/v4/dog')
55
+ end
56
+
57
+ it "ends up as a blank string if nil" do
58
+ WebApiActivequerybuilder.configure { |c| c.base_path = nil }
59
+ expect(WebApiActivequerybuilder::Configuration.default.base_path).to eq('')
60
+ end
61
+ end
62
+ end
63
+ end
64
+
65
+ describe "params_encoding in #build_request" do
66
+ let(:config) { WebApiActivequerybuilder::Configuration.new }
67
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new(config) }
68
+
69
+ it "defaults to nil" do
70
+ expect(WebApiActivequerybuilder::Configuration.default.params_encoding).to eq(nil)
71
+ expect(config.params_encoding).to eq(nil)
72
+
73
+ request = api_client.build_request(:get, '/test')
74
+ expect(request.options[:params_encoding]).to eq(nil)
75
+ end
76
+
77
+ it "can be customized" do
78
+ config.params_encoding = :multi
79
+ request = api_client.build_request(:get, '/test')
80
+ expect(request.options[:params_encoding]).to eq(:multi)
81
+ end
82
+ end
83
+
84
+ describe "timeout in #build_request" do
85
+ let(:config) { WebApiActivequerybuilder::Configuration.new }
86
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new(config) }
87
+
88
+ it "defaults to 0" do
89
+ expect(WebApiActivequerybuilder::Configuration.default.timeout).to eq(0)
90
+ expect(config.timeout).to eq(0)
91
+
92
+ request = api_client.build_request(:get, '/test')
93
+ expect(request.options[:timeout]).to eq(0)
94
+ end
95
+
96
+ it "can be customized" do
97
+ config.timeout = 100
98
+ request = api_client.build_request(:get, '/test')
99
+ expect(request.options[:timeout]).to eq(100)
100
+ end
101
+ end
102
+
103
+ describe "#deserialize" do
104
+ it "handles Array<Integer>" do
105
+ api_client = WebApiActivequerybuilder::ApiClient.new
106
+ headers = {'Content-Type' => 'application/json'}
107
+ response = double('response', headers: headers, body: '[12, 34]')
108
+ data = api_client.deserialize(response, 'Array<Integer>')
109
+ expect(data).to be_instance_of(Array)
110
+ expect(data).to eq([12, 34])
111
+ end
112
+
113
+ it "handles Array<Array<Integer>>" do
114
+ api_client = WebApiActivequerybuilder::ApiClient.new
115
+ headers = {'Content-Type' => 'application/json'}
116
+ response = double('response', headers: headers, body: '[[12, 34], [56]]')
117
+ data = api_client.deserialize(response, 'Array<Array<Integer>>')
118
+ expect(data).to be_instance_of(Array)
119
+ expect(data).to eq([[12, 34], [56]])
120
+ end
121
+
122
+ it "handles Hash<String, String>" do
123
+ api_client = WebApiActivequerybuilder::ApiClient.new
124
+ headers = {'Content-Type' => 'application/json'}
125
+ response = double('response', headers: headers, body: '{"message": "Hello"}')
126
+ data = api_client.deserialize(response, 'Hash<String, String>')
127
+ expect(data).to be_instance_of(Hash)
128
+ expect(data).to eq({:message => 'Hello'})
129
+ end
130
+ end
131
+
132
+ describe "#object_to_hash" do
133
+ it "ignores nils and includes empty arrays" do
134
+ # uncomment below to test object_to_hash for model
135
+ #api_client = WebApiActivequerybuilder::ApiClient.new
136
+ #_model = WebApiActivequerybuilder::ModelName.new
137
+ # update the model attribute below
138
+ #_model.id = 1
139
+ # update the expected value (hash) below
140
+ #expected = {id: 1, name: '', tags: []}
141
+ #expect(api_client.object_to_hash(_model)).to eq(expected)
142
+ end
143
+ end
144
+
145
+ describe "#build_collection_param" do
146
+ let(:param) { ['aa', 'bb', 'cc'] }
147
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new }
148
+
149
+ it "works for csv" do
150
+ expect(api_client.build_collection_param(param, :csv)).to eq('aa,bb,cc')
151
+ end
152
+
153
+ it "works for ssv" do
154
+ expect(api_client.build_collection_param(param, :ssv)).to eq('aa bb cc')
155
+ end
156
+
157
+ it "works for tsv" do
158
+ expect(api_client.build_collection_param(param, :tsv)).to eq("aa\tbb\tcc")
159
+ end
160
+
161
+ it "works for pipes" do
162
+ expect(api_client.build_collection_param(param, :pipes)).to eq('aa|bb|cc')
163
+ end
164
+
165
+ it "works for multi" do
166
+ expect(api_client.build_collection_param(param, :multi)).to eq(['aa', 'bb', 'cc'])
167
+ end
168
+
169
+ it "fails for invalid collection format" do
170
+ expect(proc { api_client.build_collection_param(param, :INVALID) }).to raise_error(RuntimeError, 'unknown collection format: :INVALID')
171
+ end
172
+ end
173
+
174
+ describe "#json_mime?" do
175
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new }
176
+
177
+ it "works" do
178
+ expect(api_client.json_mime?(nil)).to eq false
179
+ expect(api_client.json_mime?('')).to eq false
180
+
181
+ expect(api_client.json_mime?('application/json')).to eq true
182
+ expect(api_client.json_mime?('application/json; charset=UTF8')).to eq true
183
+ expect(api_client.json_mime?('APPLICATION/JSON')).to eq true
184
+
185
+ expect(api_client.json_mime?('application/xml')).to eq false
186
+ expect(api_client.json_mime?('text/plain')).to eq false
187
+ expect(api_client.json_mime?('application/jsonp')).to eq false
188
+ end
189
+ end
190
+
191
+ describe "#select_header_accept" do
192
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new }
193
+
194
+ it "works" do
195
+ expect(api_client.select_header_accept(nil)).to be_nil
196
+ expect(api_client.select_header_accept([])).to be_nil
197
+
198
+ expect(api_client.select_header_accept(['application/json'])).to eq('application/json')
199
+ expect(api_client.select_header_accept(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
200
+ expect(api_client.select_header_accept(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')
201
+
202
+ expect(api_client.select_header_accept(['application/xml'])).to eq('application/xml')
203
+ expect(api_client.select_header_accept(['text/html', 'application/xml'])).to eq('text/html,application/xml')
204
+ end
205
+ end
206
+
207
+ describe "#select_header_content_type" do
208
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new }
209
+
210
+ it "works" do
211
+ expect(api_client.select_header_content_type(nil)).to eq('application/json')
212
+ expect(api_client.select_header_content_type([])).to eq('application/json')
213
+
214
+ expect(api_client.select_header_content_type(['application/json'])).to eq('application/json')
215
+ expect(api_client.select_header_content_type(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
216
+ expect(api_client.select_header_content_type(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')
217
+ expect(api_client.select_header_content_type(['application/xml'])).to eq('application/xml')
218
+ expect(api_client.select_header_content_type(['text/plain', 'application/xml'])).to eq('text/plain')
219
+ end
220
+ end
221
+
222
+ describe "#sanitize_filename" do
223
+ let(:api_client) { WebApiActivequerybuilder::ApiClient.new }
224
+
225
+ it "works" do
226
+ expect(api_client.sanitize_filename('sun')).to eq('sun')
227
+ expect(api_client.sanitize_filename('sun.gif')).to eq('sun.gif')
228
+ expect(api_client.sanitize_filename('../sun.gif')).to eq('sun.gif')
229
+ expect(api_client.sanitize_filename('/var/tmp/sun.gif')).to eq('sun.gif')
230
+ expect(api_client.sanitize_filename('./sun.gif')).to eq('sun.gif')
231
+ expect(api_client.sanitize_filename('..\sun.gif')).to eq('sun.gif')
232
+ expect(api_client.sanitize_filename('\var\tmp\sun.gif')).to eq('sun.gif')
233
+ expect(api_client.sanitize_filename('c:\var\tmp\sun.gif')).to eq('sun.gif')
234
+ expect(api_client.sanitize_filename('.\sun.gif')).to eq('sun.gif')
235
+ end
236
+ end
237
+ end
@@ -0,0 +1,53 @@
1
+ =begin
2
+ #QueryBuilderApi
3
+
4
+ #Active Query Builder Web API lets create, analyze and modify SQL queries for different database servers using RESTful HTTP requests to a cloud-based service. It requires SQL execution context (information about database schema and used database server) to be stored under the registered account at https://webapi.activequerybuilder.com/.
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@activedbsoft.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+
10
+ Licensed under the Apache License, Version 2.0 (the "License");
11
+ you may not use this file except in compliance with the License.
12
+ You may obtain a copy of the License at
13
+
14
+ http://www.apache.org/licenses/LICENSE-2.0
15
+
16
+ Unless required by applicable law or agreed to in writing, software
17
+ distributed under the License is distributed on an "AS IS" BASIS,
18
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ See the License for the specific language governing permissions and
20
+ limitations under the License.
21
+
22
+ =end
23
+
24
+ require 'spec_helper'
25
+
26
+ describe WebApiActivequerybuilder::Configuration do
27
+ let(:config) { WebApiActivequerybuilder::Configuration.default }
28
+
29
+ before(:each) do
30
+ # uncomment below to setup host and base_path
31
+ #require 'URI'
32
+ #uri = URI.parse("https://webapi.activequerybuilder.com")
33
+ #WebApiActivequerybuilder.configure do |c|
34
+ # c.host = uri.host
35
+ # c.base_path = uri.path
36
+ #end
37
+ end
38
+
39
+ describe '#base_url' do
40
+ it 'should have the default value' do
41
+ # uncomment below to test default value of the base path
42
+ #expect(config.base_url).to eq("https://webapi.activequerybuilder.com")
43
+ end
44
+
45
+ it 'should remove trailing slashes' do
46
+ [nil, '', '/', '//'].each do |base_path|
47
+ config.base_path = base_path
48
+ # uncomment below to test trailing slashes
49
+ #expect(config.base_url).to eq("https://webapi.activequerybuilder.com")
50
+ end
51
+ end
52
+ end
53
+ end
@@ -0,0 +1,69 @@
1
+ =begin
2
+ #QueryBuilderApi
3
+
4
+ #Active Query Builder Web API lets create, analyze and modify SQL queries for different database servers using RESTful HTTP requests to a cloud-based service. It requires SQL execution context (information about database schema and used database server) to be stored under the registered account at https://webapi.activequerybuilder.com/.
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@activedbsoft.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+
10
+ Licensed under the Apache License, Version 2.0 (the "License");
11
+ you may not use this file except in compliance with the License.
12
+ You may obtain a copy of the License at
13
+
14
+ http://www.apache.org/licenses/LICENSE-2.0
15
+
16
+ Unless required by applicable law or agreed to in writing, software
17
+ distributed under the License is distributed on an "AS IS" BASIS,
18
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
+ See the License for the specific language governing permissions and
20
+ limitations under the License.
21
+
22
+ =end
23
+
24
+ require 'spec_helper'
25
+ require 'json'
26
+ require 'date'
27
+
28
+ # Unit tests for WebApiActivequerybuilder::ConditionGroup
29
+ # Automatically generated by swagger-codegen (github.com/swagger-api/swagger-codegen)
30
+ # Please update as you see appropriate
31
+ describe 'ConditionGroup' do
32
+ before do
33
+ # run before each test
34
+ @instance = WebApiActivequerybuilder::ConditionGroup.new
35
+ end
36
+
37
+ after do
38
+ # run after each test
39
+ end
40
+
41
+ describe 'test an instance of ConditionGroup' do
42
+ it 'should create an instact of ConditionGroup' do
43
+ expect(@instance).to be_instance_of(WebApiActivequerybuilder::ConditionGroup)
44
+ end
45
+ end
46
+ describe 'test attribute "junction_type"' do
47
+ it 'should work' do
48
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
49
+ #validator = Petstore::EnumTest::EnumAttributeValidator.new('String', ["And", "Or", "Any", "All"])
50
+ #validator.allowable_values.each do |value|
51
+ # expect { @instance.junction_type = value }.not_to raise_error
52
+ #end
53
+ end
54
+ end
55
+
56
+ describe 'test attribute "conditions"' do
57
+ it 'should work' do
58
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
59
+ end
60
+ end
61
+
62
+ describe 'test attribute "condition_groups"' do
63
+ it 'should work' do
64
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
65
+ end
66
+ end
67
+
68
+ end
69
+