123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- require 'models/taskbar/has_attachments_examples'
- RSpec.describe Taskbar, type: :model do
- it_behaves_like 'Taskbar::HasAttachments'
- context 'item' do
- subject(:taskbar) { create(:taskbar) }
- it { is_expected.to validate_inclusion_of(:app).in_array(%w[desktop mobile]) }
- end
- context 'create and update' do
- let(:user) { create(:user) }
- context 'when creating' do
- it 'validates uniqueness of key + app' do
- create(:taskbar, user: user, key: 'Ticket-1234', app: 'desktop')
- expect { create(:taskbar, user: user, key: 'Ticket-1234', app: 'desktop') }.to raise_error(ActiveRecord::RecordInvalid)
- end
- end
- context 'when updating' do
- it 'validates uniqueness of key + app' do
- create(:taskbar, user: user, key: 'Ticket-1234', app: 'desktop')
- taskbar = create(:taskbar, user: user, key: 'Ticket-1234', app: 'mobile')
- expect { taskbar.update!(app: 'desktop') }.to raise_error(ActiveRecord::RecordInvalid)
- end
- it 'does not validate when no relevant field changes' do
- taskbar = create(:taskbar, user: user, key: 'Ticket-1234', app: 'desktop')
- allow(taskbar).to receive(:taskbar_exist?).and_call_original
- taskbar.update!(state: { example: '1234' })
- expect(taskbar).not_to have_received(:taskbar_exist?)
- end
- end
- end
- context 'single creation' do
- let(:taskbar) do
- described_class.destroy_all
- UserInfo.current_user_id = 1
- create(:taskbar, params: { id: 1234 }, key: 'Ticket-1234')
- end
- it 'existing key' do
- expect(taskbar.key).to eq('Ticket-1234')
- end
- it 'params' do
- expect(taskbar.params[:id]).to eq(1234)
- end
- it 'state' do
- expect(taskbar.state.blank?).to be(true)
- end
- it 'check last_contact' do
- UserInfo.current_user_id = 1
- last_contact1 = taskbar.last_contact
- travel 2.minutes
- taskbar.notify = false
- taskbar.state = { a: 1 }
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- last_contact2 = taskbar.last_contact
- travel 2.minutes
- taskbar.notify = true
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- expect(taskbar.last_contact.to_s).to eq(last_contact2.to_s)
- travel 2.minutes
- taskbar.notify = true
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- expect(taskbar.last_contact.to_s).to eq(last_contact2.to_s)
- travel 2.minutes
- taskbar.notify = false
- taskbar.state = { a: 1 }
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- expect(taskbar.last_contact.to_s).to eq(last_contact2.to_s)
- travel 2.minutes
- taskbar.notify = true
- taskbar.state = { a: 1 }
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- expect(taskbar.last_contact.to_s).to eq(last_contact2.to_s)
- travel 2.minutes
- taskbar.notify = true
- taskbar.state = { a: 2 }
- taskbar.save!
- expect(taskbar.last_contact.to_s).not_to eq(last_contact1.to_s)
- expect(taskbar.last_contact.to_s).not_to eq(last_contact2.to_s)
- end
- end
- context 'multiple creation', :aggregate_failures do
- it 'create tasks' do
- # skip 'What does this test?'
- described_class.destroy_all
- UserInfo.current_user_id = 1
- taskbar1 = described_class.create!(
- key: 'Ticket-1234',
- callback: 'TicketZoom',
- params: {
- id: 1234,
- },
- state: {},
- prio: 1,
- notify: false,
- user_id: 1,
- )
- UserInfo.current_user_id = 2
- taskbar2 = described_class.create!(
- key: 'Ticket-1234',
- callback: 'TicketZoom',
- params: {
- id: 1234,
- },
- state: {},
- prio: 2,
- notify: false,
- user_id: 1,
- )
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(2)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(2)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- taskbar3 = described_class.create(
- key: 'Ticket-4444',
- callback: 'TicketZoom',
- params: {
- id: 4444,
- },
- state: {},
- prio: 2,
- notify: false,
- user_id: 1,
- )
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(2)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(2)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- agent_id = create(:agent).id
- UserInfo.current_user_id = agent_id
- taskbar4 = described_class.create(
- key: 'Ticket-1234',
- callback: 'TicketZoom',
- params: {
- id: 1234,
- },
- state: {},
- prio: 4,
- notify: false,
- user_id: 1,
- )
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- UserInfo.current_user_id = 2
- taskbar2.state = { article: {}, ticket: {} }
- taskbar2.save!
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- UserInfo.current_user_id = 2
- taskbar2.state = { article: { body: 'some body' }, ticket: {} }
- taskbar2.save!
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- UserInfo.current_user_id = 1
- taskbar1.state = { article: { body: '' }, ticket: { state_id: 123 } }
- taskbar1.save!
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- taskbar1_last_contact = taskbar1.last_contact.to_s
- taskbar2_last_contact = taskbar2.last_contact.to_s
- taskbar3_last_contact = taskbar3.last_contact.to_s
- taskbar4_last_contact = taskbar4.last_contact.to_s
- travel 2.minutes
- UserInfo.current_user_id = 2
- taskbar2.state = { article: { body: 'some body' }, ticket: {} }
- taskbar2.notify = true
- taskbar2.save!
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).to eq(taskbar2_last_contact)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).to eq(taskbar2_last_contact)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar3_last_contact)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).to eq(taskbar2_last_contact)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- UserInfo.current_user_id = 2
- taskbar2.state = { article: { body: 'some body 222' }, ticket: {} }
- taskbar2.notify = true
- taskbar2.save!
- taskbar1.reload
- expect(taskbar1.preferences[:tasks].count).to eq(3)
- expect(taskbar1.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar1.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar1.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).not_to eq(taskbar2_last_contact)
- expect(taskbar1.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar1.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- taskbar2.reload
- expect(taskbar2.preferences[:tasks].count).to eq(3)
- expect(taskbar2.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar2.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar2.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).not_to eq(taskbar2_last_contact)
- expect(taskbar2.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar2.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- taskbar3.reload
- expect(taskbar3.preferences[:tasks].count).to eq(1)
- expect(taskbar3.preferences[:tasks][0][:user_id]).to eq(2)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:changed]).to be(false)
- expect(taskbar3.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar3_last_contact)
- taskbar4.reload
- expect(taskbar4.preferences[:tasks].count).to eq(3)
- expect(taskbar4.preferences[:tasks][0][:user_id]).to eq(1)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][0][:apps][:desktop][:last_contact].to_s).to eq(taskbar1_last_contact)
- expect(taskbar4.preferences[:tasks][1][:user_id]).to eq(2)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:changed]).to be(true)
- expect(taskbar4.preferences[:tasks][1][:apps][:desktop][:last_contact].to_s).not_to eq(taskbar2_last_contact)
- expect(taskbar4.preferences[:tasks][2][:user_id]).to eq(agent_id)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:changed]).to be(false)
- expect(taskbar4.preferences[:tasks][2][:apps][:desktop][:last_contact].to_s).to eq(taskbar4_last_contact)
- travel_back
- UserInfo.current_user_id = nil
- end
- end
- describe '#preferences_task_info' do
- it 'returns task info for an existing taskbar without changes' do
- taskbar = create(:taskbar)
- expect(taskbar.preferences_task_info)
- .to eq({
- id: taskbar.id, user_id: 1, apps: { desktop: { last_contact: taskbar.last_contact, changed: false } }
- })
- end
- it 'returns task info for an existing taskbar with changes' do
- taskbar = create(:taskbar, state: { a: 123 })
- expect(taskbar.preferences_task_info)
- .to eq({
- id: taskbar.id, user_id: 1, apps: { desktop: { last_contact: taskbar.last_contact, changed: true } }
- })
- end
- it 'returns task info for a new taskbar' do
- taskbar = build(:taskbar)
- expect(taskbar.preferences_task_info)
- .to eq({
- user_id: 1, apps: { desktop: { last_contact: taskbar.last_contact, changed: false } }
- })
- end
- end
- describe '#update_preferences_infos' do
- it 'do not process search taskbars' do
- taskbar = build(:taskbar, key: 'Search')
- allow(taskbar).to receive(:collect_related_tasks)
- taskbar.save
- expect(taskbar).not_to have_received(:collect_related_tasks)
- end
- it 'do not process items with local_update flag' do
- taskbar = create(:taskbar)
- allow(taskbar).to receive(:collect_related_tasks)
- taskbar.state = { a: 'b' }
- taskbar.local_update = true
- taskbar.save
- expect(taskbar).not_to have_received(:collect_related_tasks)
- end
- context 'with other taskbars' do
- let(:key) { Random.hex }
- let(:other_user) { create(:user) }
- let(:other_taskbar) { create(:taskbar, key: key, user: other_user) }
- before { other_taskbar }
- it 'sets tasks when creating a taskbar' do
- taskbar = create(:taskbar, key: key)
- expect(taskbar.preferences[:tasks]).to include(include(user_id: other_user.id), include(user_id: 1))
- end
- it 'updates related items when creating a taskbar' do
- create(:taskbar, key: key)
- expect(other_taskbar.reload.preferences[:tasks]).to include(include(user_id: other_user.id), include(user_id: 1))
- end
- it 'sets tasks when updating a taskbar' do
- taskbar = create(:taskbar, key: key)
- taskbar.update_columns preferences: {}
- taskbar.update! state: { a: :b }
- expect(taskbar.preferences[:tasks]).to include(include(user_id: other_user.id), include(user_id: 1))
- end
- it 'sets tasks when updating a taskbar with same user but different app' do
- taskbar = create(:taskbar, key: key, user: other_user, app: 'mobile')
- taskbar.update_columns preferences: {}
- taskbar.update! state: { a: :b }
- expect(taskbar.preferences[:tasks])
- .to include(include(user_id: other_user.id, apps: have_key(:desktop).and(have_key(:mobile))))
- end
- it 'updates related items when updating a taskbar' do
- taskbar = create(:taskbar, key: key)
- other_taskbar.update_columns preferences: {}
- taskbar.update! state: { a: :b }
- expect(other_taskbar.reload.preferences[:tasks]).to include(include(user_id: other_user.id), include(user_id: 1))
- end
- it 'updates related items when destroying a taskbar' do
- taskbar = create(:taskbar, key: key)
- taskbar.destroy!
- expect(other_taskbar.reload.preferences[:tasks]).to include(include(user_id: other_user.id))
- end
- end
- end
- describe '#collect_related_tasks' do
- let(:key) { Random.hex }
- let(:taskbar_1) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_2) { create(:taskbar, key: key, user: create(:user)) }
- before { taskbar_2 }
- it 'returns tasks for self and related items' do
- expect(taskbar_1.send(:collect_related_tasks))
- .to eq([taskbar_2.preferences_task_info, taskbar_1.preferences_task_info])
- end
- it 'returns tasks for a new taskbar' do
- new_taskbar = build(:taskbar, key: key)
- expect(new_taskbar.send(:collect_related_tasks))
- .to eq([taskbar_2.preferences_task_info, new_taskbar.preferences_task_info])
- end
- it 'do not include task of the destroyed taskbar' do
- taskbar_1
- taskbar_2.destroy!
- expect(taskbar_2.send(:collect_related_tasks))
- .to eq([taskbar_1.preferences_task_info])
- end
- end
- describe '#reduce_related_tasks' do
- let(:elem) { { user_id: 123, changed: { desktop: false } } }
- let(:memo) { {} }
- it 'adds new task details' do
- taskbar = create(:taskbar)
- taskbar.send(:reduce_related_tasks, elem, memo)
- expect(memo).to include(elem[:user_id] => include(changed: include(desktop: false)))
- end
- it 'extends existing task details with additional apps' do
- taskbar = create(:taskbar)
- another_elem = { user_id: 123, changed: { mobile: true } }
- taskbar.send(:reduce_related_tasks, elem, memo)
- taskbar.send(:reduce_related_tasks, another_elem, memo)
- expect(memo).to include(elem[:user_id] => include(changed: include(desktop: false, mobile: true)))
- end
- end
- describe '#update_related_taskbars' do
- let(:key) { Random.hex }
- let(:taskbar_1) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_2) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_3) { create(:taskbar, user: taskbar_1.user) }
- before { taskbar_1 && taskbar_2 && taskbar_3 }
- it 'updates related taskbars' do
- taskbar_1.send(:update_related_taskbars, { a: 1 })
- expect(taskbar_2.reload).to have_attributes(preferences: { a: 1 })
- expect(taskbar_3.reload).not_to have_attributes(preferences: { a: 1 })
- end
- end
- describe '#related_taskbars' do
- let(:key) { Random.hex }
- let(:taskbar_1) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_2) { create(:taskbar, key: key, user: taskbar_1.user, app: 'mobile') }
- let(:taskbar_3) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_4) { create(:taskbar, user: create(:user)) }
- it 'calls related_taskbars scope' do
- taskbar = create(:taskbar)
- allow(described_class).to receive(:related_taskbars)
- taskbar.related_taskbars
- expect(described_class).to have_received(:related_taskbars).with(taskbar)
- end
- end
- describe '.related_taskbars' do
- let(:key) { Random.hex }
- let(:taskbar_1) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_2) { create(:taskbar, key: key, user: taskbar_1.user, app: 'mobile') }
- let(:taskbar_3) { create(:taskbar, key: key, user: create(:user)) }
- let(:taskbar_4) { create(:taskbar, user: create(:user)) }
- before { taskbar_1 && taskbar_2 && taskbar_3 && taskbar_4 }
- it 'returns all taskbars with the same key except given taskbars' do
- expect(described_class.related_taskbars(taskbar_1)).to contain_exactly(taskbar_2, taskbar_3)
- end
- end
- end
|