123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348 |
- require 'test_helper'
- class SessionEnhancedTest < ActiveSupport::TestCase
- test 'check clients and send messages' do
- # create users
- roles = Role.where(name: ['Agent'])
- groups = Group.all
- UserInfo.current_user_id = 1
- agent1 = User.create_or_update(
- login: 'session-agent-1',
- firstname: 'Session',
- lastname: 'Agent 1',
- email: 'session-agent1@example.com',
- password: 'agentpw',
- active: true,
- roles: roles,
- groups: groups,
- )
- agent1.save!
- agent2 = User.create_or_update(
- login: 'session-agent-2',
- firstname: 'Session',
- lastname: 'Agent 2',
- email: 'session-agent2@example.com',
- password: 'agentpw',
- active: true,
- roles: roles,
- groups: groups,
- )
- agent2.save!
- agent3 = User.create_or_update(
- login: 'session-agent-3',
- firstname: 'Session',
- lastname: 'Agent 3',
- email: 'session-agent3@example.com',
- password: 'agentpw',
- active: true,
- roles: roles,
- groups: groups,
- )
- agent3.save!
- # create sessions
- client_id1 = 'a1234'
- client_id2 = 'a123456'
- client_id3 = 'aabc'
- Sessions.destroy(client_id1)
- Sessions.destroy(client_id2)
- Sessions.destroy(client_id3)
- Sessions.create(client_id1, agent1.attributes, { type: 'websocket' })
- Sessions.create(client_id2, agent2.attributes, { type: 'ajax' })
- Sessions.create(client_id3, agent3.attributes, { type: 'ajax' })
- # check if session exists
- assert(Sessions.session_exists?(client_id1), 'check if session exists')
- assert(Sessions.session_exists?(client_id2), 'check if session exists')
- assert(Sessions.session_exists?(client_id3), 'check if session exists')
- # check if session still exists after idle cleanup
- sleep 1
- Sessions.destroy_idle_sessions(3)
- assert(Sessions.session_exists?(client_id1), 'check if session exists after 1 sec')
- assert(Sessions.session_exists?(client_id2), 'check if session exists after 1 sec')
- assert(Sessions.session_exists?(client_id3), 'check if session exists after 1 sec')
- # check if session still exists after idle cleanup with touched sessions
- sleep 4
- Sessions.touch(client_id1)
- Sessions.touch(client_id2)
- Sessions.touch(client_id3)
- Sessions.destroy_idle_sessions(3)
- assert(Sessions.session_exists?(client_id1), 'check if session exists after touch')
- assert(Sessions.session_exists?(client_id2), 'check if session exists after touch')
- assert(Sessions.session_exists?(client_id3), 'check if session exists after touch')
- # check session data
- data = Sessions.get(client_id1)
- assert(data[:meta], 'check if meta exists')
- assert(data[:user], 'check if user exists')
- assert_equal(data[:user]['id'], agent1.id, 'check if user id is correct')
- data = Sessions.get(client_id2)
- assert(data[:meta], 'check if meta exists')
- assert(data[:user], 'check if user exists')
- assert_equal(data[:user]['id'], agent2.id, 'check if user id is correct')
- data = Sessions.get(client_id3)
- assert(data[:meta], 'check if meta exists')
- assert(data[:user], 'check if user exists')
- assert_equal(data[:user]['id'], agent3.id, 'check if user id is correct')
- # send data to one client
- Sessions.send(client_id1, { msg: 'äöüß123' })
- Sessions.send(client_id1, { msg: 'äöüß1234' })
- messages = Sessions.queue(client_id1)
- assert_equal(3, messages.count, 'messages count')
- assert_equal('ws:login', messages[0]['event'], 'messages 1')
- assert_equal(true, messages[0]['data']['success'], 'messages 1')
- assert_equal('äöüß123', messages[1]['msg'], 'messages 2')
- assert_equal('äöüß1234', messages[2]['msg'], 'messages 3')
- messages = Sessions.queue(client_id2)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ws:login', messages[0]['event'], 'messages 1')
- assert_equal(true, messages[0]['data']['success'], 'messages 1')
- messages = Sessions.queue(client_id3)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ws:login', messages[0]['event'], 'messages 1')
- assert_equal(true, messages[0]['data']['success'], 'messages 1')
- # broadcast to all clients
- Sessions.broadcast({ msg: 'ooo123123123123123123' })
- messages = Sessions.queue(client_id1)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ooo123123123123123123', messages[0]['msg'], 'messages broadcast 1')
- messages = Sessions.queue(client_id2)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ooo123123123123123123', messages[0]['msg'], 'messages broadcast 1')
- messages = Sessions.queue(client_id3)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ooo123123123123123123', messages[0]['msg'], 'messages broadcast 1')
- # send dedicated message to user
- Sessions.send_to(agent1.id, { msg: 'ooo1231231231231231234' })
- messages = Sessions.queue(client_id1)
- assert_equal(messages.count, 1, 'messages count')
- assert_equal('ooo1231231231231231234', messages[0]['msg'], 'messages send 1')
- messages = Sessions.queue(client_id2)
- assert_equal(messages.count, 0, 'messages count')
- messages = Sessions.queue(client_id3)
- assert_equal(messages.count, 0, 'messages count')
- # start jobs
- jobs = Thread.new do
- Sessions.jobs
- end
- sleep 6
- # check client threads
- assert(Sessions.thread_client_exists?(client_id1), 'check if client is running')
- assert(Sessions.thread_client_exists?(client_id2), 'check if client is running')
- assert(Sessions.thread_client_exists?(client_id3), 'check if client is running')
- # check if session still exists after idle cleanup
- travel 10.seconds
- client_ids = Sessions.destroy_idle_sessions(2)
- travel 2.seconds
- # check client sessions
- assert(!Sessions.session_exists?(client_id1), 'check if session is removed')
- assert(!Sessions.session_exists?(client_id2), 'check if session is removed')
- assert(!Sessions.session_exists?(client_id3), 'check if session is removed')
- sleep 6
- # check client threads
- assert(!Sessions.thread_client_exists?(client_id1), 'check if client is running')
- assert(!Sessions.thread_client_exists?(client_id2), 'check if client is running')
- assert(!Sessions.thread_client_exists?(client_id3), 'check if client is running')
- # exit jobs
- jobs.exit
- jobs.join
- travel_back
- end
- test 'check client and backends' do
- # create users
- roles = Role.where(name: ['Agent'])
- groups = Group.all
- organization = Organization.create(
- name: 'SomeOrg::' + rand(999_999).to_s, active: true,
- updated_by_id: 1,
- created_by_id: 1,
- )
- UserInfo.current_user_id = 1
- agent1 = User.create_or_update(
- login: 'session-agent-1',
- firstname: 'Session',
- lastname: 'Agent 1',
- email: 'session-agent1@example.com',
- password: 'agentpw',
- active: true,
- organization: organization,
- roles: roles,
- groups: groups,
- )
- agent1.save!
- agent2 = User.create_or_update(
- login: 'session-agent-2',
- firstname: 'Session',
- lastname: 'Agent 2',
- email: 'session-agent2@example.com',
- password: 'agentpw',
- active: true,
- organization: organization,
- roles: roles,
- groups: groups,
- )
- agent2.save!
- agent3 = User.create_or_update(
- login: 'session-agent-3',
- firstname: 'Session',
- lastname: 'Agent 3',
- email: 'session-agent3@example.com',
- password: 'agentpw',
- active: true,
- organization: organization,
- roles: roles,
- groups: groups,
- )
- agent3.save!
- # create sessions
- client_id1_0 = 'b1234-1'
- client_id1_1 = 'b1234-2'
- client_id2 = 'b123456'
- client_id3 = 'c123456'
- Sessions.destroy(client_id1_0)
- Sessions.destroy(client_id1_1)
- Sessions.destroy(client_id2)
- Sessions.destroy(client_id3)
- # start jobs
- jobs = Thread.new do
- Sessions.jobs
- end
- sleep 5
- Sessions.create(client_id1_0, agent1.attributes, { type: 'websocket' })
- sleep 6.5
- Sessions.create(client_id1_1, agent1.attributes, { type: 'websocket' })
- sleep 3.2
- Sessions.create(client_id2, agent2.attributes, { type: 'ajax' })
- sleep 3.2
- Sessions.create(client_id3, agent3.attributes, { type: 'websocket' })
- # check if session exists
- assert(Sessions.session_exists?(client_id1_0), 'check if session exists')
- assert(Sessions.session_exists?(client_id1_1), 'check if session exists')
- assert(Sessions.session_exists?(client_id2), 'check if session exists')
- assert(Sessions.session_exists?(client_id3), 'check if session exists')
- travel 8.seconds
- sleep 8
- # check collections
- collections = {
- 'Group' => true,
- 'User' => nil,
- }
- assert_if_collection_reset_message_exists(client_id1_0, collections, 'init')
- assert_if_collection_reset_message_exists(client_id1_1, collections, 'init')
- assert_if_collection_reset_message_exists(client_id2, collections, 'init')
- assert_if_collection_reset_message_exists(client_id3, collections, 'init')
- collections = {
- 'Group' => nil,
- 'User' => nil,
- }
- assert_if_collection_reset_message_exists(client_id1_0, collections, 'init2')
- assert_if_collection_reset_message_exists(client_id1_1, collections, 'init2')
- assert_if_collection_reset_message_exists(client_id2, collections, 'init2')
- assert_if_collection_reset_message_exists(client_id3, collections, 'init2')
- travel 8.seconds
- sleep 8
- collections = {
- 'Group' => nil,
- 'User' => nil,
- }
- assert_if_collection_reset_message_exists(client_id1_0, collections, 'init3')
- assert_if_collection_reset_message_exists(client_id1_1, collections, 'init3')
- assert_if_collection_reset_message_exists(client_id2, collections, 'init3')
- assert_if_collection_reset_message_exists(client_id3, collections, 'init3')
- # change collection
- group = Group.first
- travel 4.seconds
- group.touch
- travel 12.seconds
- sleep 12
- # check collections
- collections = {
- 'Group' => true,
- 'User' => nil,
- }
- assert_if_collection_reset_message_exists(client_id1_0, collections, 'update')
- assert_if_collection_reset_message_exists(client_id1_1, collections, 'update')
- assert_if_collection_reset_message_exists(client_id2, collections, 'update')
- assert_if_collection_reset_message_exists(client_id3, collections, 'update')
- # check if session still exists after idle cleanup
- travel 10.seconds
- client_ids = Sessions.destroy_idle_sessions(2)
- travel 2.seconds
- # check client sessions
- assert(!Sessions.session_exists?(client_id1_0), 'check if session is removed')
- assert(!Sessions.session_exists?(client_id1_1), 'check if session is removed')
- assert(!Sessions.session_exists?(client_id2), 'check if session is removed')
- assert(!Sessions.session_exists?(client_id3), 'check if session is removed')
- # exit jobs
- jobs.exit
- jobs.join
- travel_back
- end
- def assert_if_collection_reset_message_exists(client_id, collections_orig, type)
- messages = Sessions.queue(client_id)
- #puts "cid: #{client_id}"
- #puts "m: #{messages.inspect}"
- collections_result = {}
- messages.each do |message|
- #puts ""
- #puts "message: #{message.inspect}"
- next if message['event'] != 'resetCollection'
- #puts "rc: "
- next if !message['data']
- message['data'].each_key do |key|
- #puts "rc: #{key}"
- collections_result[key] = true
- end
- end
- #puts "c: #{collections_result.inspect}"
- collections_orig.each_key do |key|
- if collections_orig[key].nil?
- assert_nil(collections_result[key], "collection message for #{key} #{type}-check (client_id #{client_id})")
- else
- assert_equal(collections_orig[key], collections_result[key], "collection message for #{key} #{type}-check (client_id #{client_id})")
- end
- end
- end
- end
|