2020-05-24 23:13:21 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2022-01-26 12:08:38 +05:30
|
|
|
RSpec.describe ApplicationCable::Connection, :clean_gitlab_redis_sessions do
|
2020-05-24 23:13:21 +05:30
|
|
|
let(:session_id) { Rack::Session::SessionId.new('6919a6f1bb119dd7396fadc38fd18d0d') }
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'when session cookie is set' do
|
|
|
|
before do
|
2022-01-26 12:08:38 +05:30
|
|
|
Gitlab::Redis::Sessions.with do |redis|
|
2021-01-03 14:25:43 +05:30
|
|
|
redis.set("session:gitlab:#{session_id.private_id}", Marshal.dump(session_hash))
|
|
|
|
end
|
|
|
|
|
|
|
|
cookies[Gitlab::Application.config.session_options[:key]] = session_id.public_id
|
2020-05-24 23:13:21 +05:30
|
|
|
end
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'when user is logged in' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:session_hash) { { 'warden.user.user.key' => [[user.id], user.encrypted_password[0, 29]] } }
|
|
|
|
|
|
|
|
it 'sets current_user' do
|
|
|
|
connect
|
|
|
|
|
|
|
|
expect(connection.current_user).to eq(user)
|
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'with a stale password' do
|
|
|
|
let(:partial_password_hash) { build(:user, password: 'some_old_password').encrypted_password[0, 29] }
|
|
|
|
let(:session_hash) { { 'warden.user.user.key' => [[user.id], partial_password_hash] } }
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
it 'sets current_user to nil' do
|
|
|
|
connect
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
expect(connection.current_user).to be_nil
|
|
|
|
end
|
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
end
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'when user is not logged in' do
|
|
|
|
let(:session_hash) { {} }
|
2020-05-24 23:13:21 +05:30
|
|
|
|
|
|
|
it 'sets current_user to nil' do
|
|
|
|
connect
|
|
|
|
|
|
|
|
expect(connection.current_user).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'when session cookie is not set' do
|
|
|
|
it 'sets current_user to nil' do
|
|
|
|
connect
|
|
|
|
|
|
|
|
expect(connection.current_user).to be_nil
|
|
|
|
end
|
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
context 'when session cookie is an empty string' do
|
2020-05-24 23:13:21 +05:30
|
|
|
it 'sets current_user to nil' do
|
2021-01-03 14:25:43 +05:30
|
|
|
cookies[Gitlab::Application.config.session_options[:key]] = ''
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
connect
|
|
|
|
|
|
|
|
expect(connection.current_user).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|