trabajo-afectivo/spec/lib/import/otrs/state_factory_spec.rb

180 lines
5 KiB
Ruby
Raw Normal View History

require 'rails_helper'
require 'lib/import/transaction_factory_examples'
RSpec.describe Import::OTRS::StateFactory do
it_behaves_like 'Import::TransactionFactory'
it 'creates a state backup in the pre_import_hook' do
expect(described_class).to receive(:backup)
described_class.pre_import_hook([])
end
def load_state_json(file)
json_fixture("import/otrs/state/#{file}")
end
it 'updates ObjectManager Ticket state_id and pending_time filter' do
states = %w(new open merged pending_reminder pending_auto_close_p pending_auto_close_n pending_auto_close_p closed_successful closed_unsuccessful closed_successful removed)
state_backend_param = []
states.each do |state|
state_backend_param.push(load_state_json(state))
end
ticket_state_id = ::ObjectManager::Attribute.get(
object: 'Ticket',
name: 'state_id',
)
ticket_pending_time = ::ObjectManager::Attribute.get(
object: 'Ticket',
name: 'pending_time',
)
expect do
described_class.import(state_backend_param)
# sync changes
ticket_state_id.reload
ticket_pending_time.reload
end.to change {
ticket_state_id.data_option
}.and change {
ticket_state_id.screens
}.and change {
ticket_pending_time.data_option
}
end
it "doesn't update ObjectManager Ticket state_id and pending_time filter in diff import" do
ticket_state_id = ::ObjectManager::Attribute.get(
object: 'Ticket',
name: 'state_id',
)
ticket_pending_time = ::ObjectManager::Attribute.get(
object: 'Ticket',
name: 'pending_time',
)
expect(Import::OTRS).to receive(:diff?).and_return(true)
expect do
described_class.update_attribute_settings
# sync changes
ticket_state_id.reload
ticket_pending_time.reload
end.to not_change {
ticket_state_id.data_option
}.and not_change {
ticket_state_id.screens
}.and not_change {
ticket_pending_time.data_option
}
end
it 'sets default create and update State' do
state = ::Ticket::State.first
state.default_create = false
state.default_follow_up = false
state.callback_loop = true
state.save
expect(Import::OTRS::SysConfigFactory).to receive(:postmaster_default_lookup).with(:state_default_create).and_return(state.name)
expect(Import::OTRS::SysConfigFactory).to receive(:postmaster_default_lookup).with(:state_default_follow_up).and_return(state.name)
described_class.update_attribute
state.reload
expect(state.default_create).to be true
expect(state.default_follow_up).to be true
end
it "doesn't set default create and update State in diff import" do
state = ::Ticket::State.first
state.default_create = false
state.default_follow_up = false
state.callback_loop = true
state.save
expect(Import::OTRS).to receive(:diff?).and_return(true)
described_class.update_attribute_settings
state.reload
expect(state.default_create).to be false
expect(state.default_follow_up).to be false
end
context 'changing Ticket::State IDs' do
let(:state_backend_param) do
states = %w(new open merged pending_reminder pending_auto_close_p pending_auto_close_n pending_auto_close_p closed_successful closed_unsuccessful closed_successful removed)
state_backend_param = []
states.each do |state|
state_backend_param.push(load_state_json(state))
end
state_backend_param
end
it 'updates Overviews' do
name = 'My pending reached Tickets'
overview = Overview.find_by(name: name)
expect do
described_class.import(state_backend_param)
overview = Overview.find_by(name: name)
end.to change {
overview.id
}.and change {
overview.condition['ticket.state_id'][:value]
}
end
it 'updates Macros' do
name = 'Close & Tag as Spam'
macro = Macro.find_by(name: name)
expect do
described_class.import(state_backend_param)
macro = Macro.find_by(name: name)
end.to change {
macro.id
}.and change {
macro.perform['ticket.state_id'][:value]
}
end
it 'updates Triggers' do
name = 'auto reply (on new tickets)'
trigger = Trigger.find_by(name: name)
expect do
described_class.import(state_backend_param)
trigger = Trigger.find_by(name: name)
end.to change {
trigger.id
}.and change {
trigger.condition['ticket.state_id'][:value]
}
end
it 'updates ObjectManager::Attributes' do
attribute = ObjectManager::Attribute.get(
object: 'Ticket',
name: 'pending_time',
)
expect do
described_class.import(state_backend_param)
attribute = ObjectManager::Attribute.get(
object: 'Ticket',
name: 'pending_time',
)
end.to change {
attribute.data_option[:required_if][:state_id]
}
end
end
end