| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
 | require 'spec_helper'
describe User, :type => :model do
  # it { should validate_uniqueness_of :email }
  # it { should validate_presence_of :name }
  describe "SSO" do
    let(:ticket) do
      CASClient::ServiceTicket.new("ST-test", nil).tap do |ticket|
        ticket.extra_attributes = {
          :full_name         => 'john doe',
          :username          => 'john.doe',
          :email             => 'john.doe@af83.com',
          :organisation_code => '0083',
          :organisation_name => 'af83',
          :functional_scope  => "[\"STIF:CODIFLIGNE:Line:C00840\", \"STIF:CODIFLIGNE:Line:C00086\"]"
        }
        ticket.user    = "john.doe"
        ticket.success = true
      end
    end
    context 'First time sign on' do
      it 'should create a new user if user is not registered' do
        expect{User.authenticate_with_cas_ticket(ticket)}.to change{ User.count }
        user = User.find_by(username: 'john.doe')
        expect(user.email).to eq(ticket.extra_attributes[:email])
        expect(user.name).to  eq(ticket.extra_attributes[:full_name])
      end
      it 'should create a new organisation if organisation is not present' do
        expect{User.authenticate_with_cas_ticket(ticket)}.to change{ Organisation.count }
        expect(Organisation.find_by(code: ticket.extra_attributes[:organisation_code])).to be_truthy
      end
      it 'should store organisation functional_scope' do
        User.authenticate_with_cas_ticket(ticket)
        org = Organisation.find_by(code: ticket.extra_attributes[:organisation_code])
        expect(org.sso_attributes['functional_scope']).to eq "[STIF:CODIFLIGNE:Line:C00840, STIF:CODIFLIGNE:Line:C00086]"
      end
      it 'should not create a new organisation if organisation is already present' do
        ticket.extra_attributes[:organisation_code] = create(:organisation).code
        expect{User.authenticate_with_cas_ticket(ticket)}.not_to change{ Organisation.count }
      end
    end
    context 'Update attributes on sign on' do
      let!(:organisation) { create(:organisation) }
      let!(:user) { create(:user, username: 'john.doe', name:'fake name' , email: 'test@example.com', :organisation => organisation) }
      it 'should update user attributes on sign on' do
        User.authenticate_with_cas_ticket(ticket)
        expect(user.reload.email).to eq(ticket.extra_attributes[:email])
        expect(user.reload.name).to  eq(ticket.extra_attributes[:full_name])
      end
    end
  end
  describe "Portail sync" do
    let(:conf) { Rails.application.config.stif_portail_api }
    before :each do
      stub_request(:get, "#{conf[:url]}/api/v1/users").
        with(headers: { 'Authorization' => "Token token=\"#{conf[:key]}\"" }).
        to_return(body: File.open(File.join(Rails.root, 'spec', 'fixtures', 'users.json')), status: 200)
    end
    it 'should retrieve data from portail api' do
      expect(User.portail_api_request).to be_truthy
      expect(WebMock).to have_requested(:get, "#{conf[:url]}/api/v1/users").
        with(headers: { 'Authorization' => "Token token=\"#{conf[:key]}\"" })
    end
    it 'should create new users' do
      User.portail_sync
      expect(User.count).to eq(11)
      expect(Organisation.count).to eq(3)
    end
    it 'should update existing users' do
      create :user, username: 'alban.peignier', email:'dummy@example.com', updated_at: 10.days.ago
      User.portail_sync
      user = User.find_by(username: 'alban.peignier')
      expect(user.name).to eq('Alban Peignier')
      expect(user.email).to eq('alban.peignier@af83.com')
      expect(user.updated_at.utc).to be_within(1.second).of Time.now
      expect(user.synced_at.utc).to be_within(1.second).of Time.now
    end
    it 'should update organisation assignement' do
      create :user, username: 'alban.peignier', organisation: create(:organisation)
      User.portail_sync
      expect(User.find_by(username: 'alban.peignier').organisation.name).to eq("STIF")
    end
    it 'should update locked_at attribute' do
      create :user, username: 'alban.peignier', locked_at: Time.now
      User.portail_sync
      expect(User.find_by(username: 'alban.peignier').locked_at).to be_nil
      expect(User.find_by(username: 'jane.doe').locked_at).to eq("2016-08-05T12:34:03.995Z")
    end
    it 'should not create new user if username is already present' do
      create :user, username: 'alban.peignier'
      User.portail_sync
      expect(User.count).to eq(11)
    end
  end
  describe "#destroy" do
    let!(:organisation){create(:organisation)}
    let!(:user){create(:user, :organisation => organisation)}
    context "user's organisation contains many user" do
      let!(:other_user){create(:user, :organisation => organisation)}
      it "should destoy also user's organisation" do
        user.destroy
        expect(Organisation.where(:name => organisation.name).exists?).to be_truthy
        read_organisation = Organisation.where(:name => organisation.name).first
        expect(read_organisation.users.count).to eq(1)
        expect(read_organisation.users.first).to eq(other_user)
      end
    end
  end
end
 |