Sha256: 55e81314432260a0036df79f62d4826b55f611b423aac84dd37c622f9fa7ce27
Contents?: true
Size: 1.31 KB
Versions: 4
Compression:
Stored size: 1.31 KB
Contents
class << RSpec::OpenAPI::SchemaMerger = Object.new # @param [Hash] base # @param [Hash] spec def merge!(base, spec) spec = normalize_keys(spec) merge_schema!(base, spec) end private def normalize_keys(spec) case spec when Hash spec.map do |key, value| [key.to_s, normalize_keys(value)] end.to_h when Array spec.map { |s| normalize_keys(s) } else spec end end # Not doing `base.replace(deep_merge(base, spec))` to preserve key orders. # Also this needs to be aware of OpenAPI details because a Hash-like structure # may be an array whose Hash elements have a key name. # # TODO: Should we probably force-merge `summary` regardless of manual modifications? def merge_schema!(base, spec) spec.each do |key, value| if base[key].is_a?(Hash) && value.is_a?(Hash) if !base[key].key?("$ref") merge_schema!(base[key], value) end elsif base[key].is_a?(Array) && value.is_a?(Array) # parameters need to be merged as if `name` and `in` were the Hash keys. if key == 'parameters' base[key] = value | base[key] base[key].uniq! { |param| param.slice('name', 'in') } else base[key] = value end else base[key] = value end end base end end
Version data entries
4 entries across 4 versions & 1 rubygems