All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ruby-client.api_client_spec.mustache Maven / Gradle / Ivy

There is a newer version: 7.8.0
Show newest version
=begin
{{> api_info}}
=end

require 'spec_helper'

describe {{moduleName}}::ApiClient do
  context 'initialization' do
    context 'URL stuff' do
      context 'host' do
        it 'removes http from host' do
          {{moduleName}}.configure { |c| c.host = 'http://example.com' }
          expect({{moduleName}}::Configuration.default.host).to eq('example.com')
        end

        it 'removes https from host' do
          {{moduleName}}.configure { |c| c.host = 'https://wookiee.com' }
          expect({{moduleName}}::ApiClient.default.config.host).to eq('wookiee.com')
        end

        it 'removes trailing path from host' do
          {{moduleName}}.configure { |c| c.host = 'hobo.com/v4' }
          expect({{moduleName}}::Configuration.default.host).to eq('hobo.com')
        end
      end

      context 'base_path' do
        it "prepends a slash to base_path" do
          {{moduleName}}.configure { |c| c.base_path = 'v4/dog' }
          expect({{moduleName}}::Configuration.default.base_path).to eq('/v4/dog')
        end

        it "doesn't prepend a slash if one is already there" do
          {{moduleName}}.configure { |c| c.base_path = '/v4/dog' }
          expect({{moduleName}}::Configuration.default.base_path).to eq('/v4/dog')
        end

        it "ends up as a blank string if nil" do
          {{moduleName}}.configure { |c| c.base_path = nil }
          expect({{moduleName}}::Configuration.default.base_path).to eq('')
        end
      end
    end
  end

{{^isFaraday}}
  describe 'params_encoding in #build_request' do
    let(:config) { {{moduleName}}::Configuration.new }
    let(:api_client) { {{moduleName}}::ApiClient.new(config) }

    it 'defaults to nil' do
      expect({{moduleName}}::Configuration.default.params_encoding).to eq(nil)
      expect(config.params_encoding).to eq(nil)

      request = api_client.build_request(:get, '/test')
      expect(request.options[:params_encoding]).to eq(nil)
    end

    it 'can be customized' do
      config.params_encoding = :multi
      request = api_client.build_request(:get, '/test')
      expect(request.options[:params_encoding]).to eq(:multi)
    end
  end

  describe 'timeout in #build_request' do
    let(:config) { {{moduleName}}::Configuration.new }
    let(:api_client) { {{moduleName}}::ApiClient.new(config) }

    it 'defaults to 0' do
      expect({{moduleName}}::Configuration.default.timeout).to eq(0)
      expect(config.timeout).to eq(0)

      request = api_client.build_request(:get, '/test')
      expect(request.options[:timeout]).to eq(0)
    end

    it 'can be customized' do
      config.timeout = 100
      request = api_client.build_request(:get, '/test')
      expect(request.options[:timeout]).to eq(100)
    end
  end

{{/isFaraday}}

{{#isFaraday}}
  describe 'proxy in #build_connection' do
    let(:config) { {{moduleName}}::Configuration.new }
    let(:api_client) { {{moduleName}}::ApiClient.new(config) }
    let(:proxy_uri) { URI('http://example.org:8080') }

    it 'defaults to nil' do
      expect({{moduleName}}::Configuration.default.proxy).to be_nil
      expect(config.proxy).to be_nil

      connection = api_client.build_connection
      expect(connection.proxy_for_request('/test')).to be_nil
    end

    it 'can be customized with a string' do
      config.proxy = proxy_uri.to_s

      connection = api_client.build_connection
      configured_proxy = connection.proxy_for_request('/test')

      expect(configured_proxy).not_to be_nil
      expect(configured_proxy.uri.to_s).to eq proxy_uri.to_s
    end

    it 'can be customized with a hash' do
      config.proxy = { uri: proxy_uri }

      connection = api_client.build_connection
      configured_proxy = connection.proxy_for_request('/test')

      expect(configured_proxy).not_to be_nil
      expect(configured_proxy.uri).to eq proxy_uri
    end
  end
{{/isFaraday}}

  describe '#deserialize' do
    it "handles Array" do
      api_client = {{moduleName}}::ApiClient.new
      headers = { 'Content-Type' => 'application/json' }
      response = double('response', headers: headers, body: '[12, 34]')
      data = api_client.deserialize(response, 'Array')
      expect(data).to be_instance_of(Array)
      expect(data).to eq([12, 34])
    end

    it 'handles Array>' do
      api_client = {{moduleName}}::ApiClient.new
      headers = { 'Content-Type' => 'application/json' }
      response = double('response', headers: headers, body: '[[12, 34], [56]]')
      data = api_client.deserialize(response, 'Array>')
      expect(data).to be_instance_of(Array)
      expect(data).to eq([[12, 34], [56]])
    end

    it 'handles Hash' do
      api_client = {{moduleName}}::ApiClient.new
      headers = { 'Content-Type' => 'application/json' }
      response = double('response', headers: headers, body: '{"message": "Hello"}')
      data = api_client.deserialize(response, 'Hash')
      expect(data).to be_instance_of(Hash)
      expect(data).to eq(:message => 'Hello')
    end
  end

  describe "#object_to_hash" do
    it 'ignores nils and includes empty arrays' do
      # uncomment below to test object_to_hash for model
      # api_client = {{moduleName}}::ApiClient.new
      # _model = {{moduleName}}::ModelName.new
      # update the model attribute below
      # _model.id = 1
      # update the expected value (hash) below
      # expected = {id: 1, name: '', tags: []}
      # expect(api_client.object_to_hash(_model)).to eq(expected)
    end
  end

  describe '#build_collection_param' do
    let(:param) { ['aa', 'bb', 'cc'] }
    let(:api_client) { {{moduleName}}::ApiClient.new }

    it 'works for csv' do
      expect(api_client.build_collection_param(param, :csv)).to eq('aa,bb,cc')
    end

    it 'works for ssv' do
      expect(api_client.build_collection_param(param, :ssv)).to eq('aa bb cc')
    end

    it 'works for tsv' do
      expect(api_client.build_collection_param(param, :tsv)).to eq("aa\tbb\tcc")
    end

    it 'works for pipes' do
      expect(api_client.build_collection_param(param, :pipes)).to eq('aa|bb|cc')
    end

    it 'works for multi' do
      expect(api_client.build_collection_param(param, :multi)).to eq(['aa', 'bb', 'cc'])
    end

    it 'fails for invalid collection format' do
      expect { api_client.build_collection_param(param, :INVALID) }.to raise_error(RuntimeError, 'unknown collection format: :INVALID')
    end
  end

  describe '#json_mime?' do
    let(:api_client) { {{moduleName}}::ApiClient.new }

    it 'works' do
      expect(api_client.json_mime?(nil)).to eq false
      expect(api_client.json_mime?('')).to eq false

      expect(api_client.json_mime?('application/json')).to eq true
      expect(api_client.json_mime?('application/json; charset=UTF8')).to eq true
      expect(api_client.json_mime?('APPLICATION/JSON')).to eq true

      expect(api_client.json_mime?('application/xml')).to eq false
      expect(api_client.json_mime?('text/plain')).to eq false
      expect(api_client.json_mime?('application/jsonp')).to eq false
    end
  end

  describe '#select_header_accept' do
    let(:api_client) { {{moduleName}}::ApiClient.new }

    it 'works' do
      expect(api_client.select_header_accept(nil)).to be_nil
      expect(api_client.select_header_accept([])).to be_nil

      expect(api_client.select_header_accept(['application/json'])).to eq('application/json')
      expect(api_client.select_header_accept(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
      expect(api_client.select_header_accept(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')

      expect(api_client.select_header_accept(['application/xml'])).to eq('application/xml')
      expect(api_client.select_header_accept(['text/html', 'application/xml'])).to eq('text/html,application/xml')
    end
  end

  describe '#select_header_content_type' do
    let(:api_client) { {{moduleName}}::ApiClient.new }

    it 'works' do
      expect(api_client.select_header_content_type(nil)).to be_nil
      expect(api_client.select_header_content_type([])).to be_nil

      expect(api_client.select_header_content_type(['application/json'])).to eq('application/json')
      expect(api_client.select_header_content_type(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
      expect(api_client.select_header_content_type(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')
      expect(api_client.select_header_content_type(['application/xml'])).to eq('application/xml')
      expect(api_client.select_header_content_type(['text/plain', 'application/xml'])).to eq('text/plain')
    end
  end

  describe '#sanitize_filename' do
    let(:api_client) { {{moduleName}}::ApiClient.new }

    it 'works' do
      expect(api_client.sanitize_filename('sun')).to eq('sun')
      expect(api_client.sanitize_filename('sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('../sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('/var/tmp/sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('./sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('..\sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('\var\tmp\sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('c:\var\tmp\sun.gif')).to eq('sun.gif')
      expect(api_client.sanitize_filename('.\sun.gif')).to eq('sun.gif')
    end
  end
end




© 2015 - 2024 Weber Informatics LLC | Privacy Policy