Codebase list ruby-gitlab / debian/4.5.0-2 spec / gitlab / request_spec.rb
debian/4.5.0-2

Tree @debian/4.5.0-2 (Download .tar.gz)

request_spec.rb @debian/4.5.0-2raw · history · blame

require 'spec_helper'

describe Gitlab::Request do
  it { is_expected.to respond_to :get }
  it { is_expected.to respond_to :post }
  it { is_expected.to respond_to :put }
  it { is_expected.to respond_to :delete }
  before do
    @request = Gitlab::Request.new
  end

  describe ".default_options" do
    it "has default values" do
      default_options = Gitlab::Request.default_options
      expect(default_options).to be_a Hash
      expect(default_options[:parser]).to be_a Proc
      expect(default_options[:format]).to eq(:json)
      expect(default_options[:headers]).to eq('Accept' => 'application/json', 'Content-Type' => 'application/x-www-form-urlencoded')
      expect(default_options[:default_params]).to be_nil
    end
  end

  describe ".parse" do
    it "returns ObjectifiedHash" do
      body = JSON.unparse(a: 1, b: 2)
      expect(Gitlab::Request.parse(body)).to be_an Gitlab::ObjectifiedHash
      expect(Gitlab::Request.parse("true")).to be true
      expect(Gitlab::Request.parse("false")).to be false

      expect { Gitlab::Request.parse("string") }.to raise_error(Gitlab::Error::Parsing)
    end
  end

  describe "#request_defaults" do
    context "when endpoint is not set" do
      it "raises Error::MissingCredentials" do
        @request.endpoint = nil
        expect do
          @request.request_defaults
        end.to raise_error(Gitlab::Error::MissingCredentials, 'Please set an endpoint to API')
      end
    end

    context "when endpoint is set" do
      before(:each) do
        @request.endpoint = 'http://rabbit-hole.example.com'
      end

      it "sets default_params" do
        @request.request_defaults('sudoer')
        expect(Gitlab::Request.default_params).to eq(sudo: 'sudoer')
      end
    end
  end

  describe "#authorization_header" do
    it "raises MissingCredentials when auth_token and private_token are not set" do
      expect do
        @request.send(:authorization_header, {})
      end.to raise_error(Gitlab::Error::MissingCredentials)
    end

    it "sets the correct header when given a private_token" do
      @request.private_token = 'ys9BtunN3rDKbaJCYXaN'
      expect(@request.send(:authorization_header, {})).to eq("PRIVATE-TOKEN" => 'ys9BtunN3rDKbaJCYXaN')
    end

    it "sets the correct header when setting an auth_token via the private_token config option" do
      @request.private_token = '3225e2804d31fea13fc41fc83bffef00cfaedc463118646b154acc6f94747603'
      expect(@request.send(:authorization_header, {})).to eq("Authorization" => "Bearer 3225e2804d31fea13fc41fc83bffef00cfaedc463118646b154acc6f94747603")
    end
  end
end