apipie-rails-jq 1.4.3.pre.beta.pre.jq.1
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.
- checksums.yaml +7 -0
- data/.github/workflows/build.yml +32 -0
- data/.github/workflows/rubocop-challenger.yml +26 -0
- data/.github/workflows/rubocop.yml +18 -0
- data/.gitignore +16 -0
- data/.rspec +2 -0
- data/.rubocop.yml +132 -0
- data/.rubocop_todo.yml +1967 -0
- data/.vscode/settings.json +3 -0
- data/APACHE-LICENSE-2.0 +202 -0
- data/CHANGELOG.md +693 -0
- data/Gemfile +19 -0
- data/MIT-LICENSE +20 -0
- data/NOTICE +4 -0
- data/PROPOSAL_FOR_RESPONSE_DESCRIPTIONS.md +244 -0
- data/README.md +2088 -0
- data/Rakefile +8 -0
- data/apipie-rails.gemspec +44 -0
- data/app/controllers/apipie/apipies_controller.rb +184 -0
- data/app/helpers/apipie_helper.rb +10 -0
- data/app/public/apipie/javascripts/apipie.js +6 -0
- data/app/public/apipie/javascripts/bundled/bootstrap-collapse.js +167 -0
- data/app/public/apipie/javascripts/bundled/bootstrap.js +2280 -0
- data/app/public/apipie/javascripts/bundled/jquery.js +2 -0
- data/app/public/apipie/javascripts/bundled/prettify.js +28 -0
- data/app/public/apipie/stylesheets/application.css +7 -0
- data/app/public/apipie/stylesheets/bundled/bootstrap-responsive.min.css +9 -0
- data/app/public/apipie/stylesheets/bundled/bootstrap.min.css +9 -0
- data/app/public/apipie/stylesheets/bundled/prettify.css +30 -0
- data/app/views/apipie/apipies/_deprecation.html.erb +16 -0
- data/app/views/apipie/apipies/_disqus.html.erb +13 -0
- data/app/views/apipie/apipies/_errors.html.erb +23 -0
- data/app/views/apipie/apipies/_headers.html.erb +26 -0
- data/app/views/apipie/apipies/_languages.erb +6 -0
- data/app/views/apipie/apipies/_metadata.erb +1 -0
- data/app/views/apipie/apipies/_method_detail.erb +63 -0
- data/app/views/apipie/apipies/_params.html.erb +49 -0
- data/app/views/apipie/apipies/_params_plain.html.erb +21 -0
- data/app/views/apipie/apipies/apipie_404.html.erb +17 -0
- data/app/views/apipie/apipies/apipie_checksum.json.erb +1 -0
- data/app/views/apipie/apipies/getting_started.html.erb +6 -0
- data/app/views/apipie/apipies/index.html.erb +56 -0
- data/app/views/apipie/apipies/method.html.erb +41 -0
- data/app/views/apipie/apipies/plain.html.erb +77 -0
- data/app/views/apipie/apipies/resource.html.erb +80 -0
- data/app/views/apipie/apipies/static.html.erb +103 -0
- data/app/views/layouts/apipie/apipie.html.erb +27 -0
- data/config/locales/de.yml +28 -0
- data/config/locales/en.yml +41 -0
- data/config/locales/es.yml +28 -0
- data/config/locales/fr.yml +31 -0
- data/config/locales/it.yml +41 -0
- data/config/locales/ja.yml +31 -0
- data/config/locales/ko.yml +32 -0
- data/config/locales/pl.yml +28 -0
- data/config/locales/pt-BR.yml +28 -0
- data/config/locales/ru.yml +28 -0
- data/config/locales/tr.yml +28 -0
- data/config/locales/zh-CN.yml +28 -0
- data/config/locales/zh-TW.yml +28 -0
- data/gemfiles/Gemfile.tools +9 -0
- data/images/screenshot-1.png +0 -0
- data/images/screenshot-2.png +0 -0
- data/lib/apipie/apipie_module.rb +83 -0
- data/lib/apipie/application.rb +499 -0
- data/lib/apipie/configuration.rb +196 -0
- data/lib/apipie/core_ext/route.rb +9 -0
- data/lib/apipie/dsl_definition.rb +630 -0
- data/lib/apipie/error_description.rb +46 -0
- data/lib/apipie/errors.rb +86 -0
- data/lib/apipie/extractor/collector.rb +116 -0
- data/lib/apipie/extractor/recorder.rb +193 -0
- data/lib/apipie/extractor/writer.rb +454 -0
- data/lib/apipie/extractor.rb +181 -0
- data/lib/apipie/generator/config.rb +12 -0
- data/lib/apipie/generator/generator.rb +2 -0
- data/lib/apipie/generator/swagger/computed_interface_id.rb +23 -0
- data/lib/apipie/generator/swagger/config.rb +80 -0
- data/lib/apipie/generator/swagger/context.rb +38 -0
- data/lib/apipie/generator/swagger/method_description/api_decorator.rb +20 -0
- data/lib/apipie/generator/swagger/method_description/api_schema_service.rb +89 -0
- data/lib/apipie/generator/swagger/method_description/decorator.rb +22 -0
- data/lib/apipie/generator/swagger/method_description/parameters_service.rb +139 -0
- data/lib/apipie/generator/swagger/method_description/response_schema_service.rb +46 -0
- data/lib/apipie/generator/swagger/method_description/response_service.rb +71 -0
- data/lib/apipie/generator/swagger/method_description.rb +2 -0
- data/lib/apipie/generator/swagger/operation_id.rb +51 -0
- data/lib/apipie/generator/swagger/param_description/builder.rb +114 -0
- data/lib/apipie/generator/swagger/param_description/composite.rb +119 -0
- data/lib/apipie/generator/swagger/param_description/description.rb +15 -0
- data/lib/apipie/generator/swagger/param_description/in.rb +37 -0
- data/lib/apipie/generator/swagger/param_description/name.rb +18 -0
- data/lib/apipie/generator/swagger/param_description/path_params_composite.rb +61 -0
- data/lib/apipie/generator/swagger/param_description/referenced_composite.rb +36 -0
- data/lib/apipie/generator/swagger/param_description/type.rb +132 -0
- data/lib/apipie/generator/swagger/param_description.rb +18 -0
- data/lib/apipie/generator/swagger/path_decorator.rb +36 -0
- data/lib/apipie/generator/swagger/referenced_definitions.rb +17 -0
- data/lib/apipie/generator/swagger/resource_description_collection.rb +30 -0
- data/lib/apipie/generator/swagger/resource_description_composite.rb +56 -0
- data/lib/apipie/generator/swagger/schema.rb +63 -0
- data/lib/apipie/generator/swagger/swagger.rb +2 -0
- data/lib/apipie/generator/swagger/type.rb +16 -0
- data/lib/apipie/generator/swagger/type_extractor.rb +51 -0
- data/lib/apipie/generator/swagger/warning.rb +74 -0
- data/lib/apipie/generator/swagger/warning_writer.rb +54 -0
- data/lib/apipie/helpers.rb +73 -0
- data/lib/apipie/markup.rb +52 -0
- data/lib/apipie/method_description/api.rb +12 -0
- data/lib/apipie/method_description/apis_service.rb +82 -0
- data/lib/apipie/method_description.rb +230 -0
- data/lib/apipie/middleware/checksum_in_headers.rb +35 -0
- data/lib/apipie/param_description/deprecation.rb +24 -0
- data/lib/apipie/param_description.rb +313 -0
- data/lib/apipie/railtie.rb +9 -0
- data/lib/apipie/resource_description.rb +152 -0
- data/lib/apipie/response_description.rb +157 -0
- data/lib/apipie/response_description_adapter.rb +202 -0
- data/lib/apipie/routes_formatter.rb +33 -0
- data/lib/apipie/routing.rb +16 -0
- data/lib/apipie/rspec/response_validation_helper.rb +194 -0
- data/lib/apipie/see_description.rb +39 -0
- data/lib/apipie/static_dispatcher.rb +75 -0
- data/lib/apipie/swagger_generator.rb +45 -0
- data/lib/apipie/tag_list_description.rb +11 -0
- data/lib/apipie/validator.rb +552 -0
- data/lib/apipie/version.rb +3 -0
- data/lib/apipie-rails.rb +60 -0
- data/lib/generators/apipie/install/README +6 -0
- data/lib/generators/apipie/install/install_generator.rb +25 -0
- data/lib/generators/apipie/install/templates/initializer.rb.erb +7 -0
- data/lib/generators/apipie/views_generator.rb +11 -0
- data/lib/tasks/apipie.rake +355 -0
- data/rel-eng/gem_release.ipynb +398 -0
- data/rel-eng/packages/.readme +3 -0
- data/rel-eng/packages/rubygem-apipie-rails +1 -0
- data/rel-eng/tito.props +5 -0
- data/spec/controllers/api/v1/architectures_controller_spec.rb +29 -0
- data/spec/controllers/api/v2/architectures_controller_spec.rb +19 -0
- data/spec/controllers/api/v2/empty_middle_controller_spec.rb +23 -0
- data/spec/controllers/api/v2/nested/resources_controller_spec.rb +27 -0
- data/spec/controllers/api/v2/sub/footguns_controller_spec.rb +19 -0
- data/spec/controllers/concerns_controller_spec.rb +42 -0
- data/spec/controllers/extended_controller_spec.rb +14 -0
- data/spec/controllers/included_param_group_controller_spec.rb +13 -0
- data/spec/controllers/pets_controller_spec.rb +98 -0
- data/spec/controllers/users_controller_spec.rb +794 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/controllers/api/base_controller.rb +4 -0
- data/spec/dummy/app/controllers/api/v1/architectures_controller.rb +43 -0
- data/spec/dummy/app/controllers/api/v1/base_controller.rb +11 -0
- data/spec/dummy/app/controllers/api/v2/architectures_controller.rb +31 -0
- data/spec/dummy/app/controllers/api/v2/base_controller.rb +17 -0
- data/spec/dummy/app/controllers/api/v2/empty_middle_controller.rb +14 -0
- data/spec/dummy/app/controllers/api/v2/nested/architectures_controller.rb +32 -0
- data/spec/dummy/app/controllers/api/v2/nested/resources_controller.rb +33 -0
- data/spec/dummy/app/controllers/api/v2/sub/footguns_controller.rb +30 -0
- data/spec/dummy/app/controllers/application_controller.rb +18 -0
- data/spec/dummy/app/controllers/concerns_controller.rb +8 -0
- data/spec/dummy/app/controllers/extended_controller.rb +14 -0
- data/spec/dummy/app/controllers/extending_concern.rb +10 -0
- data/spec/dummy/app/controllers/files_controller.rb +5 -0
- data/spec/dummy/app/controllers/included_param_group_controller.rb +19 -0
- data/spec/dummy/app/controllers/overridden_concerns_controller.rb +31 -0
- data/spec/dummy/app/controllers/pets_controller.rb +408 -0
- data/spec/dummy/app/controllers/pets_using_auto_views_controller.rb +73 -0
- data/spec/dummy/app/controllers/pets_using_self_describing_classes_controller.rb +95 -0
- data/spec/dummy/app/controllers/sample_controller.rb +39 -0
- data/spec/dummy/app/controllers/tagged_cats_controller.rb +32 -0
- data/spec/dummy/app/controllers/tagged_dogs_controller.rb +15 -0
- data/spec/dummy/app/controllers/twitter_example_controller.rb +307 -0
- data/spec/dummy/app/controllers/users_controller.rb +310 -0
- data/spec/dummy/app/helpers/random_param_group.rb +8 -0
- data/spec/dummy/app/views/layouts/application.html.erb +21 -0
- data/spec/dummy/components/test_engine/Gemfile +6 -0
- data/spec/dummy/components/test_engine/app/controllers/test_engine/application_controller.rb +4 -0
- data/spec/dummy/components/test_engine/app/controllers/test_engine/memes_controller.rb +37 -0
- data/spec/dummy/components/test_engine/config/routes.rb +3 -0
- data/spec/dummy/components/test_engine/db/.gitkeep +0 -0
- data/spec/dummy/components/test_engine/lib/test_engine.rb +7 -0
- data/spec/dummy/components/test_engine/test_engine.gemspec +11 -0
- data/spec/dummy/config/application.rb +47 -0
- data/spec/dummy/config/boot.rb +12 -0
- data/spec/dummy/config/database.yml +21 -0
- data/spec/dummy/config/environment.rb +8 -0
- data/spec/dummy/config/environments/development.rb +25 -0
- data/spec/dummy/config/environments/production.rb +49 -0
- data/spec/dummy/config/environments/test.rb +33 -0
- data/spec/dummy/config/initializers/apipie.rb +110 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/inflections.rb +10 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +8 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +61 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/db/.gitkeep +0 -0
- data/spec/dummy/doc/apipie_examples.json +1 -0
- data/spec/dummy/doc/users/desc_from_file.md +1 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +26 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/public/stylesheets/.gitkeep +0 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/lib/apipie/apipies_controller_spec.rb +345 -0
- data/spec/lib/apipie/application_spec.rb +62 -0
- data/spec/lib/apipie/configuration_spec.rb +38 -0
- data/spec/lib/apipie/extractor/collector_spec.rb +57 -0
- data/spec/lib/apipie/extractor/recorder/middleware_spec.rb +44 -0
- data/spec/lib/apipie/extractor/recorder_spec.rb +77 -0
- data/spec/lib/apipie/extractor/writer_spec.rb +112 -0
- data/spec/lib/apipie/extractor_spec.rb +9 -0
- data/spec/lib/apipie/file_handler_spec.rb +25 -0
- data/spec/lib/apipie/generator/swagger/config_spec.rb +19 -0
- data/spec/lib/apipie/generator/swagger/context_spec.rb +56 -0
- data/spec/lib/apipie/generator/swagger/method_description/api_schema_service_spec.rb +119 -0
- data/spec/lib/apipie/generator/swagger/method_description/response_schema_service_spec.rb +105 -0
- data/spec/lib/apipie/generator/swagger/method_description/response_service_spec.rb +62 -0
- data/spec/lib/apipie/generator/swagger/operation_id_spec.rb +63 -0
- data/spec/lib/apipie/generator/swagger/param_description/builder_spec.rb +245 -0
- data/spec/lib/apipie/generator/swagger/param_description/composite_spec.rb +95 -0
- data/spec/lib/apipie/generator/swagger/param_description/description_spec.rb +79 -0
- data/spec/lib/apipie/generator/swagger/param_description/in_spec.rb +86 -0
- data/spec/lib/apipie/generator/swagger/param_description/name_spec.rb +81 -0
- data/spec/lib/apipie/generator/swagger/param_description/type_spec.rb +210 -0
- data/spec/lib/apipie/generator/swagger/param_description_spec.rb +28 -0
- data/spec/lib/apipie/generator/swagger/path_decorator_spec.rb +57 -0
- data/spec/lib/apipie/generator/swagger/referenced_definitions_spec.rb +35 -0
- data/spec/lib/apipie/generator/swagger/resource_description_composite_spec.rb +37 -0
- data/spec/lib/apipie/generator/swagger/resource_descriptions_collection_spec.rb +57 -0
- data/spec/lib/apipie/generator/swagger/schema_spec.rb +89 -0
- data/spec/lib/apipie/generator/swagger/type_extractor_spec.rb +38 -0
- data/spec/lib/apipie/generator/swagger/warning_spec.rb +51 -0
- data/spec/lib/apipie/generator/swagger/warning_writer_spec.rb +71 -0
- data/spec/lib/apipie/method_description/apis_service_spec.rb +60 -0
- data/spec/lib/apipie/method_description_spec.rb +133 -0
- data/spec/lib/apipie/no_documented_method_spec.rb +17 -0
- data/spec/lib/apipie/param_description/deprecation_spec.rb +31 -0
- data/spec/lib/apipie/param_description_spec.rb +671 -0
- data/spec/lib/apipie/param_group_spec.rb +61 -0
- data/spec/lib/apipie/resource_description_spec.rb +91 -0
- data/spec/lib/apipie/response_description/response_object_spec.rb +22 -0
- data/spec/lib/apipie/response_description_spec.rb +56 -0
- data/spec/lib/apipie/response_does_not_match_swagger_schema_spec.rb +35 -0
- data/spec/lib/apipie/swagger_generator_spec.rb +94 -0
- data/spec/lib/apipie/validator_spec.rb +149 -0
- data/spec/lib/rake_spec.rb +69 -0
- data/spec/lib/swagger/openapi_2_0_schema.json +1614 -0
- data/spec/lib/swagger/rake_swagger_spec.rb +159 -0
- data/spec/lib/swagger/swagger_dsl_spec.rb +664 -0
- data/spec/lib/validators/array_validator_spec.rb +85 -0
- data/spec/spec_helper.rb +92 -0
- data/spec/support/custom_bool_validator.rb +17 -0
- data/spec/support/rake.rb +21 -0
- data/spec/test_engine/memes_controller_spec.rb +10 -0
- metadata +499 -0
@@ -0,0 +1,112 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Apipie::Extractor::Writer do
|
4
|
+
|
5
|
+
let(:collector) { double "collector" }
|
6
|
+
let(:writer_class) { Apipie::Extractor::Writer }
|
7
|
+
let(:writer) { writer_class.new(collector) }
|
8
|
+
let(:test_examples_file) { File.join(Rails.root, "doc", "apipie_examples_test.json") }
|
9
|
+
let(:records) do
|
10
|
+
{
|
11
|
+
"concern_resources#show" =>
|
12
|
+
[{
|
13
|
+
:controller=>ConcernsController,
|
14
|
+
:action=>"show",
|
15
|
+
:verb=>:GET,
|
16
|
+
:path=>"/api/concerns/5",
|
17
|
+
:params=>{},
|
18
|
+
:query=>"session=secret_hash",
|
19
|
+
:request_data=>nil,
|
20
|
+
:response_data=>"OK {\"session\"=>\"secret_hash\", \"id\"=>\"5\", \"controller\"=>\"concerns\", \"action\"=>\"show\"}",
|
21
|
+
:code=>"200"
|
22
|
+
}, {
|
23
|
+
:controller=>ConcernsController,
|
24
|
+
:action=>"show",
|
25
|
+
:verb=>:GET,
|
26
|
+
:path=>"/api/concerns/5",
|
27
|
+
:params=>{},
|
28
|
+
:query=>"",
|
29
|
+
:request_data=>nil,
|
30
|
+
:response_data=>"OK {\"id\"=>\"5\", \"controller\"=>\"concerns\", \"action\"=>\"show\"}",
|
31
|
+
:code=>"200"
|
32
|
+
}]
|
33
|
+
}
|
34
|
+
end
|
35
|
+
let(:loaded_records) do
|
36
|
+
{
|
37
|
+
"concern_resources#show" =>
|
38
|
+
[{
|
39
|
+
"verb"=>:GET,
|
40
|
+
"path"=>"/api/concerns/5",
|
41
|
+
"versions"=>["development"],
|
42
|
+
"query"=>"session=secret_hash",
|
43
|
+
"request_data"=>nil,
|
44
|
+
"response_data"=>"OK {\"session\"=>\"secret_hash\", \"id\"=>\"5\", \"controller\"=>\"concerns\", \"action\"=>\"show\"}",
|
45
|
+
"code"=>"200",
|
46
|
+
"show_in_doc"=>1,
|
47
|
+
"recorded"=>true
|
48
|
+
}, {
|
49
|
+
"verb"=>:GET,
|
50
|
+
"path"=>"/api/concerns/5",
|
51
|
+
"versions"=>["development"],
|
52
|
+
"query"=>"",
|
53
|
+
"request_data"=>nil,
|
54
|
+
"response_data"=>"OK {\"id\"=>\"5\", \"controller\"=>\"concerns\", \"action\"=>\"show\"}",
|
55
|
+
"code"=>"200",
|
56
|
+
"show_in_doc"=>0,
|
57
|
+
"recorded"=>true
|
58
|
+
}]
|
59
|
+
}
|
60
|
+
end
|
61
|
+
|
62
|
+
context 'with doc_path overridden in configuration' do
|
63
|
+
around(:each) do |example|
|
64
|
+
standard_path = Apipie.configuration.doc_path
|
65
|
+
Apipie.configuration.doc_path = 'tmp/user_specified_doc_path'
|
66
|
+
example.run
|
67
|
+
Apipie.configuration.doc_path = standard_path
|
68
|
+
end
|
69
|
+
|
70
|
+
it 'uses the doc_path specified in configuration' do
|
71
|
+
expect(writer_class.examples_file).to eql(File.join(Rails.root, 'tmp', 'user_specified_doc_path', 'apipie_examples.json'))
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
context 'when compressing examples' do
|
76
|
+
around(:each) do |example|
|
77
|
+
Apipie.configuration.compress_examples = true
|
78
|
+
example.run
|
79
|
+
FileUtils.rm(writer_class.examples_file) if File.exist?(writer_class.examples_file)
|
80
|
+
Apipie.configuration.compress_examples = nil
|
81
|
+
end
|
82
|
+
|
83
|
+
it 'writes to a compressed file' do
|
84
|
+
expect(writer_class.examples_file).to match(/\.gz$/)
|
85
|
+
writer_class.write_recorded_examples(records)
|
86
|
+
expect(File.exist?(writer_class.examples_file))
|
87
|
+
end
|
88
|
+
|
89
|
+
it 'reads from a compressed file' do
|
90
|
+
writer_class.write_recorded_examples(records)
|
91
|
+
expected_string = writer_class.send(:serialize_examples, records)
|
92
|
+
expect(writer_class.load_recorded_examples)
|
93
|
+
.to eql(writer_class.send(:deserialize_examples, expected_string))
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
describe "storing of examples" do
|
98
|
+
before do
|
99
|
+
allow(writer_class).to receive(:examples_file) { test_examples_file }
|
100
|
+
expect(collector).to receive(:records).and_return(records)
|
101
|
+
end
|
102
|
+
|
103
|
+
it "reads and write examples" do
|
104
|
+
writer.write_examples
|
105
|
+
expect(writer.send(:load_recorded_examples)).to eql(loaded_records)
|
106
|
+
end
|
107
|
+
|
108
|
+
after do
|
109
|
+
File.unlink(test_examples_file) if File.exist?(test_examples_file)
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Apipie::FileHandler do
|
4
|
+
|
5
|
+
describe "match?" do
|
6
|
+
let(:file_handler) { Apipie::FileHandler.new File.dirname(__FILE__) }
|
7
|
+
|
8
|
+
it { expect(file_handler.match? 'file_handler_spec.rb').to be_truthy }
|
9
|
+
it { expect(file_handler.match? 'foo.bar').to be_falsy }
|
10
|
+
|
11
|
+
context 'path contains null bytes' do
|
12
|
+
let(:path) { "foo%00.bar" }
|
13
|
+
|
14
|
+
it { expect(file_handler.match? path).to be_falsy }
|
15
|
+
it { expect { file_handler.match? path }.to_not raise_error }
|
16
|
+
end
|
17
|
+
|
18
|
+
context 'when the path contains an invalid byte sequence in UTF-8' do
|
19
|
+
let(:path) { "%B6" }
|
20
|
+
|
21
|
+
it { expect(file_handler.match? path).to be_falsy }
|
22
|
+
it { expect { file_handler.match? path }.to_not raise_error }
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::Config do
|
4
|
+
let(:config) { described_class.clone.instance }
|
5
|
+
|
6
|
+
before { Singleton.__init__(described_class) }
|
7
|
+
|
8
|
+
describe 'deprecation warnings' do
|
9
|
+
context 'when a deprecated method is call' do
|
10
|
+
subject(:deprecated_method_call) { config.swagger_include_warning_tags? }
|
11
|
+
|
12
|
+
it 'returns a deprecations warning' do
|
13
|
+
expect { deprecated_method_call }
|
14
|
+
.to output(/DEPRECATION WARNING: config.swagger_include_warning_tags is deprecated/)
|
15
|
+
.to_stderr
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::Context do
|
4
|
+
let(:allow_null) { true }
|
5
|
+
let(:in_schema) { true }
|
6
|
+
let(:http_method) { 'get' }
|
7
|
+
let(:prefix) { nil }
|
8
|
+
|
9
|
+
let(:context_instance) do
|
10
|
+
described_class.new(
|
11
|
+
allow_null: allow_null,
|
12
|
+
http_method: http_method,
|
13
|
+
in_schema: in_schema,
|
14
|
+
controller_method: 'show',
|
15
|
+
prefix: prefix
|
16
|
+
)
|
17
|
+
end
|
18
|
+
|
19
|
+
describe '#in_schema?' do
|
20
|
+
subject { context_instance }
|
21
|
+
|
22
|
+
it { is_expected.to be_in_schema }
|
23
|
+
|
24
|
+
context 'when in_schema is false' do
|
25
|
+
let(:in_schema) { false }
|
26
|
+
|
27
|
+
it { is_expected.not_to be_in_schema }
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
describe '#allow_null?' do
|
32
|
+
subject { context_instance }
|
33
|
+
|
34
|
+
it { is_expected.to be_allow_null }
|
35
|
+
|
36
|
+
context 'when allow_null is false' do
|
37
|
+
let(:allow_null) { false }
|
38
|
+
|
39
|
+
it { is_expected.not_to be_allow_null }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
describe '#add_to_prefix!' do
|
44
|
+
before { context_instance.add_to_prefix!('some-prefix') }
|
45
|
+
|
46
|
+
subject { context_instance.prefix }
|
47
|
+
|
48
|
+
it { is_expected.to eq('some-prefix') }
|
49
|
+
|
50
|
+
context 'when context has already a prefix' do
|
51
|
+
let(:prefix) { 'existing-prefix' }
|
52
|
+
|
53
|
+
it { is_expected.to eq('existing-prefix[some-prefix]') }
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,119 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::MethodDescription::ApiSchemaService do
|
4
|
+
let(:path) { '/api' }
|
5
|
+
let(:http_method) { 'get' }
|
6
|
+
let(:resource_id) { 'users' }
|
7
|
+
let(:method_description_description) { nil }
|
8
|
+
let(:tags) { [] }
|
9
|
+
|
10
|
+
let(:dsl_data) do
|
11
|
+
ActionController::Base
|
12
|
+
.send(:_apipie_dsl_data_init)
|
13
|
+
.merge(
|
14
|
+
{
|
15
|
+
description: method_description_description,
|
16
|
+
api_args: [[http_method, path, 'Some api description', { deprecated: true }]],
|
17
|
+
tag_list: tags
|
18
|
+
}
|
19
|
+
)
|
20
|
+
end
|
21
|
+
|
22
|
+
let(:resource_desc) do
|
23
|
+
Apipie::ResourceDescription.new(UsersController, resource_id)
|
24
|
+
end
|
25
|
+
|
26
|
+
let(:method_description) do
|
27
|
+
Apipie::Generator::Swagger::MethodDescription::Decorator.new(
|
28
|
+
Apipie::MethodDescription.new(:show, resource_desc, dsl_data)
|
29
|
+
)
|
30
|
+
end
|
31
|
+
|
32
|
+
let(:service) { described_class.new(method_description) }
|
33
|
+
|
34
|
+
describe '#call' do
|
35
|
+
subject(:schema) { service.call }
|
36
|
+
|
37
|
+
it 'returns the path' do
|
38
|
+
expect(schema).to include(path)
|
39
|
+
end
|
40
|
+
|
41
|
+
it 'returns the http method' do
|
42
|
+
expect(schema[path]).to include(http_method)
|
43
|
+
end
|
44
|
+
|
45
|
+
it 'returns the correct attributes' do
|
46
|
+
expect(schema[path][http_method].keys).to include(
|
47
|
+
:tags,
|
48
|
+
:consumes,
|
49
|
+
:operationId,
|
50
|
+
:parameters,
|
51
|
+
:responses
|
52
|
+
)
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
describe 'tags' do
|
57
|
+
subject { service.call[path][http_method][:tags] }
|
58
|
+
|
59
|
+
it { is_expected.to eq([resource_id]) }
|
60
|
+
|
61
|
+
context 'when tags are available' do
|
62
|
+
let(:tags) { ['Tag 1', 'Tag 2'] }
|
63
|
+
|
64
|
+
it { is_expected.to include(*tags) }
|
65
|
+
end
|
66
|
+
|
67
|
+
context 'when Apipie.configuration.generator.swagger.skip_default_tags is enabled' do
|
68
|
+
before { Apipie.configuration.generator.swagger.skip_default_tags = true }
|
69
|
+
after { Apipie.configuration.generator.swagger.skip_default_tags = false }
|
70
|
+
|
71
|
+
it { is_expected.to be_empty }
|
72
|
+
|
73
|
+
context 'when tags are available' do
|
74
|
+
let(:tags) { ['Tag 1', 'Tag 2'] }
|
75
|
+
|
76
|
+
it { is_expected.to eq(tags) }
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
context 'when Apipie.configuration.generator.swagger.include_warning_tags is enabled' do
|
81
|
+
before { Apipie.configuration.generator.swagger.include_warning_tags = true }
|
82
|
+
|
83
|
+
context 'when warnings are issued' do
|
84
|
+
before do
|
85
|
+
Apipie::Generator::Swagger::Warning.for_code(
|
86
|
+
Apipie::Generator::Swagger::Warning::MISSING_METHOD_SUMMARY_CODE,
|
87
|
+
'some_method'
|
88
|
+
).warn_through_writer
|
89
|
+
end
|
90
|
+
|
91
|
+
it { is_expected.to include('warnings issued') }
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
describe 'consumes' do
|
97
|
+
subject { service.call[path]['get'][:consumes] }
|
98
|
+
|
99
|
+
it { is_expected.to eq(['application/x-www-form-urlencoded', 'multipart/form-data']) }
|
100
|
+
|
101
|
+
context 'when content type input is json' do
|
102
|
+
before { Apipie.configuration.generator.swagger.content_type_input = :json }
|
103
|
+
|
104
|
+
it { is_expected.to eq(['application/json']) }
|
105
|
+
end
|
106
|
+
end
|
107
|
+
|
108
|
+
describe 'description' do
|
109
|
+
subject { service.call[path]['get'][:description] }
|
110
|
+
|
111
|
+
it { is_expected.to be_blank }
|
112
|
+
|
113
|
+
context 'when description for method description exists' do
|
114
|
+
let(:method_description_description) { 'Some description' }
|
115
|
+
|
116
|
+
it { is_expected.to eq(method_description_description) }
|
117
|
+
end
|
118
|
+
end
|
119
|
+
end
|
@@ -0,0 +1,105 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::MethodDescription::ResponseSchemaService do
|
4
|
+
let(:http_method) { nil }
|
5
|
+
let(:controller_method) { nil }
|
6
|
+
let(:allow_null) { false }
|
7
|
+
|
8
|
+
let(:resource_description) do
|
9
|
+
Apipie::ResourceDescription.new(PetsController, 'pets')
|
10
|
+
end
|
11
|
+
|
12
|
+
let(:method_description) do
|
13
|
+
Apipie::MethodDescription.new(
|
14
|
+
'create',
|
15
|
+
resource_description,
|
16
|
+
ActionController::Base.send(:_apipie_dsl_data_init)
|
17
|
+
)
|
18
|
+
end
|
19
|
+
|
20
|
+
let(:response_description_dsl) do
|
21
|
+
proc do
|
22
|
+
property :a_number, Integer, example: 1
|
23
|
+
property :an_optional_number, Integer, required: false, example: 2
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
let(:options) { {} }
|
28
|
+
|
29
|
+
let(:response_description) do
|
30
|
+
Apipie::ResponseDescription.new(
|
31
|
+
method_description,
|
32
|
+
204,
|
33
|
+
options,
|
34
|
+
PetsController,
|
35
|
+
response_description_dsl,
|
36
|
+
nil
|
37
|
+
)
|
38
|
+
end
|
39
|
+
|
40
|
+
let(:service) do
|
41
|
+
described_class.new(
|
42
|
+
response_description,
|
43
|
+
allow_null: allow_null,
|
44
|
+
http_method: http_method,
|
45
|
+
controller_method: controller_method
|
46
|
+
)
|
47
|
+
end
|
48
|
+
|
49
|
+
describe '#to_swagger' do
|
50
|
+
let(:swagger_response) { service.to_swagger }
|
51
|
+
|
52
|
+
describe 'properties' do
|
53
|
+
subject(:properties) { swagger_response[:properties] }
|
54
|
+
|
55
|
+
it 'returns correct properties' do
|
56
|
+
expect(properties).to eq(
|
57
|
+
{
|
58
|
+
a_number: {
|
59
|
+
type: 'number', required: true, example: 1
|
60
|
+
},
|
61
|
+
an_optional_number: {
|
62
|
+
type: 'number', example: 2
|
63
|
+
}
|
64
|
+
}
|
65
|
+
)
|
66
|
+
end
|
67
|
+
|
68
|
+
context 'when nulls are allowed' do
|
69
|
+
let(:allow_null) { true }
|
70
|
+
|
71
|
+
it 'returns correct properties' do
|
72
|
+
expect(properties).to eq(
|
73
|
+
{
|
74
|
+
a_number: {
|
75
|
+
type: %w[number null], required: true, example: 1
|
76
|
+
},
|
77
|
+
an_optional_number: {
|
78
|
+
type: %w[number null], example: 2
|
79
|
+
}
|
80
|
+
}
|
81
|
+
)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
context 'when responses_use_refs is set to true' do
|
87
|
+
subject(:response) { swagger_response }
|
88
|
+
|
89
|
+
before { Apipie.configuration.generator.swagger.responses_use_refs = true }
|
90
|
+
after { Apipie.configuration.generator.swagger.responses_use_refs = false }
|
91
|
+
|
92
|
+
context 'when typename is given' do
|
93
|
+
let(:options) { { param_group: :some_param_group } }
|
94
|
+
|
95
|
+
it 'returns the reference' do
|
96
|
+
expect(response).to eq(
|
97
|
+
{
|
98
|
+
'$ref' => '#/definitions/some_param_group'
|
99
|
+
}
|
100
|
+
)
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::MethodDescription::ResponseService do
|
4
|
+
let(:http_method) { nil }
|
5
|
+
let(:language) { :en }
|
6
|
+
let(:dsl_data) { ActionController::Base.send(:_apipie_dsl_data_init) }
|
7
|
+
|
8
|
+
let(:method_description) do
|
9
|
+
Apipie::Generator::Swagger::MethodDescription::Decorator.new(
|
10
|
+
Apipie::MethodDescription.new(
|
11
|
+
'create',
|
12
|
+
Apipie::ResourceDescription.new(ApplicationController, 'pets'),
|
13
|
+
dsl_data
|
14
|
+
)
|
15
|
+
)
|
16
|
+
end
|
17
|
+
|
18
|
+
let(:returns) { [] }
|
19
|
+
|
20
|
+
let(:service) do
|
21
|
+
described_class.new(
|
22
|
+
method_description,
|
23
|
+
http_method: http_method,
|
24
|
+
language: language
|
25
|
+
)
|
26
|
+
end
|
27
|
+
|
28
|
+
describe '#call' do
|
29
|
+
describe 'headers' do
|
30
|
+
subject(:headers) { service.call[status_code][:headers] }
|
31
|
+
|
32
|
+
let(:status_code) { 200 }
|
33
|
+
|
34
|
+
it { is_expected.to be_blank }
|
35
|
+
|
36
|
+
context 'when headers exists' do
|
37
|
+
let(:dsl_data) { super().merge({ returns: returns }) }
|
38
|
+
let(:returns) { { status_code => [{}, nil, returns_dsl, nil] } }
|
39
|
+
|
40
|
+
let(:returns_dsl) do
|
41
|
+
proc do
|
42
|
+
header 'link', String, 'Relative links'
|
43
|
+
header 'Current-Page', Integer, 'The current page'
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
it 'returns the correct format headers' do
|
48
|
+
expect(headers).to eq({
|
49
|
+
'link' => {
|
50
|
+
description: 'Relative links',
|
51
|
+
type: 'string'
|
52
|
+
},
|
53
|
+
'Current-Page' => {
|
54
|
+
description: 'The current page',
|
55
|
+
type: 'integer'
|
56
|
+
}
|
57
|
+
})
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,63 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Apipie::Generator::Swagger::OperationId do
|
4
|
+
let(:path) { '/api' }
|
5
|
+
let(:http_method) { :GET }
|
6
|
+
let(:param) {}
|
7
|
+
|
8
|
+
let(:operation_id) do
|
9
|
+
described_class.new(path: path, http_method: http_method, param: param)
|
10
|
+
end
|
11
|
+
|
12
|
+
describe '#to_s' do
|
13
|
+
subject { operation_id.to_s}
|
14
|
+
|
15
|
+
it { is_expected.to eq('get_api') }
|
16
|
+
|
17
|
+
context 'when path has variable' do
|
18
|
+
let(:path) { '/api/users/:id' }
|
19
|
+
|
20
|
+
it { is_expected.to eq("#{http_method.downcase}_api_users_id") }
|
21
|
+
end
|
22
|
+
|
23
|
+
context 'when param is given' do
|
24
|
+
let(:param) { 'show' }
|
25
|
+
|
26
|
+
it { is_expected.to eq("#{http_method.downcase}_api_param_show") }
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
describe '.from' do
|
31
|
+
subject { described_class.from(describable).to_s }
|
32
|
+
|
33
|
+
context 'when an Apipie::MethodDescription::Api is given' do
|
34
|
+
let(:describable) do
|
35
|
+
Apipie::MethodDescription::Api.
|
36
|
+
new(http_method, path, '', { from_routes: '' })
|
37
|
+
end
|
38
|
+
|
39
|
+
it { is_expected.to eq("#{http_method.downcase}_api") }
|
40
|
+
end
|
41
|
+
|
42
|
+
context 'when an Apipie::MethodDescription is given' do
|
43
|
+
let(:dsl_data) do
|
44
|
+
ActionController::Base.
|
45
|
+
send(:_apipie_dsl_data_init).
|
46
|
+
merge({
|
47
|
+
api_args: [[http_method, path, "description", { :deprecated => true }]]
|
48
|
+
})
|
49
|
+
end
|
50
|
+
|
51
|
+
let(:resource_desc) do
|
52
|
+
Apipie::ResourceDescription.new(UsersController, "users")
|
53
|
+
end
|
54
|
+
|
55
|
+
let(:describable) do
|
56
|
+
Apipie::MethodDescription.new(:show, resource_desc, dsl_data)
|
57
|
+
end
|
58
|
+
|
59
|
+
it { is_expected.to eq("#{http_method.downcase}_api") }
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|