user_spec.rb 1.5 KB
Newer Older
1 2
require 'spec_helper'

3
describe Gitlab::LDAP::User do
4
  let(:gl_user) { Gitlab::LDAP::User }
5 6
  let(:info) do
    double(
7
      name: 'John',
8
      email: 'john@example.com',
D
Dmitriy Zaporozhets 已提交
9
      nickname: 'john'
10 11
    )
  end
12 13 14 15 16 17 18 19 20
  before { Gitlab.config.stub(omniauth: {}) }

  describe :find_or_create do
    let(:auth) do
      double(info: info, provider: 'ldap', uid: 'my-uid')
    end

    it "finds the user if already existing" do
      existing_user = create(:user, extern_uid: 'my-uid', provider: 'ldap')
21

22
      expect{ gl_user.find_or_create(auth) }.to_not change{ User.count }
23 24
    end

25 26
    it "connects to existing non-ldap user if the email matches" do
      existing_user = create(:user, email: 'john@example.com')
27
      expect{ gl_user.find_or_create(auth) }.to_not change{ User.count }
28 29 30 31

      existing_user.reload
      expect(existing_user.extern_uid).to eql 'my-uid'
      expect(existing_user.provider).to eql 'ldap'
32 33
    end

34
    it "creates a new user if not found" do
35
      expect{ gl_user.find_or_create(auth) }.to change{ User.count }.by(1)
36 37
    end
  end
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53

  describe "authenticate" do
    let(:login) { 'john' }
    let(:password) { 'my-secret' }

    before {
      Gitlab.config.ldap['enabled'] = true
      Gitlab.config.ldap['user_filter'] = 'employeeType=developer'
    }
    after  { Gitlab.config.ldap['enabled'] = false }

    it "send an authentication request to ldap" do
      expect( Gitlab::LDAP::User.adapter ).to receive(:bind_as)
      Gitlab::LDAP::User.authenticate(login, password)
    end
  end
54
end