module Rswag3 module Specs module ExampleGroupHelpers def path(template, metadata={}, &block) metadata[:path_item] = { template: template } describe(template, metadata, &block) end [ :get, :post, :patch, :put, :delete, :head ].each do |verb| define_method(verb) do |summary, &block| api_metadata = { operation: { verb: verb, summary: summary } } describe(verb, api_metadata, &block) end end [ :operationId, :deprecated, :security ].each do |attr_name| define_method(attr_name) do |value| metadata[:operation][attr_name] = value end end # NOTE: 'description' requires special treatment because ExampleGroup already # defines a method with that name. Provide an override that supports the existing # functionality while also setting the appropriate metadata if applicable def description(value=nil) return super() if value.nil? metadata[:operation][:description] = value end # These are array properties - note the splat operator [ :tags, :consumes, :produces, :schemes ].each do |attr_name| define_method(attr_name) do |*value| metadata[:operation][attr_name] = value end end def requestBody(value) metadata[:operation][:requestBody] = value end def parameter(attributes) if attributes[:in] && attributes[:in].to_sym == :path attributes[:required] = true end if metadata.has_key?(:operation) metadata[:operation][:parameters] ||= [] metadata[:operation][:parameters] << attributes else metadata[:path_item][:parameters] ||= [] metadata[:path_item][:parameters] << attributes end end def response(code, description, metadata={}, &block) metadata[:response] = { code: code, description: description } context(description, metadata, &block) end def schema(value) metadata[:response][:schema] = value end def content(value) metadata[:response][:content] = value end def header(name, attributes) metadata[:response][:headers] ||= {} metadata[:response][:headers][name] = attributes end # NOTE: Similar to 'description', 'examples' need to handle the case when # being invoked with no params to avoid overriding 'examples' method of # rspec-core ExampleGroup def examples(example = nil) return super() if example.nil? metadata[:response][:examples] = example end def run_test!(&block) # NOTE: rspec 2.x support if RSPEC_VERSION < 3 before do submit_request(example.metadata) end it "returns a #{metadata[:response][:code]} response" do assert_response_matches_metadata(metadata) block.call(response) if block_given? end else before do |example| submit_request(example.metadata) end it "returns a #{metadata[:response][:code]} response" do |example| assert_response_matches_metadata(example.metadata, &block) example.instance_exec(response, &block) if block_given? end end end end end end