2016-12-14 00:19:17 +01:00
|
|
|
describe 'system/delete-department' do
|
|
|
|
request('/user/logout')
|
|
|
|
Scripts.createUser('tranferguy@opensupports.com', 'transfer', 'Transfer Guy')
|
|
|
|
Scripts.login('tranferguy@opensupports.com', 'transfer')
|
2020-10-14 20:08:14 +02:00
|
|
|
$apikey = $database.getRow('apikey',1,'id')
|
|
|
|
|
2016-12-14 00:19:17 +01:00
|
|
|
ticket1 = request('/ticket/create',{
|
|
|
|
title: 'Transferible ticket 1',
|
|
|
|
content: 'The north remembers',
|
|
|
|
departmentId: 4,
|
2016-12-21 05:09:35 +01:00
|
|
|
language: 'en',
|
2016-12-14 00:19:17 +01:00
|
|
|
csrf_userid: $csrf_userid,
|
2020-10-14 20:08:14 +02:00
|
|
|
csrf_token: $csrf_token,
|
|
|
|
apiKey: $apikey['token']
|
2016-12-14 00:19:17 +01:00
|
|
|
})
|
|
|
|
ticket2 =request('/ticket/create',{
|
|
|
|
title: 'Transferible ticket 2',
|
|
|
|
content: 'The north remembers',
|
|
|
|
departmentId: 4,
|
2016-12-21 05:09:35 +01:00
|
|
|
language: 'en',
|
2016-12-14 00:19:17 +01:00
|
|
|
csrf_userid: $csrf_userid,
|
2020-10-14 20:08:14 +02:00
|
|
|
csrf_token: $csrf_token,
|
|
|
|
apiKey: $apikey['token']
|
2016-12-14 00:19:17 +01:00
|
|
|
})
|
|
|
|
ticket3 = request('/ticket/create',{
|
|
|
|
title: 'Transferible ticket 3',
|
|
|
|
content: 'The north remembers',
|
|
|
|
departmentId: 4,
|
2016-12-21 05:09:35 +01:00
|
|
|
language: 'en',
|
2016-12-14 00:19:17 +01:00
|
|
|
csrf_userid: $csrf_userid,
|
2020-10-14 20:08:14 +02:00
|
|
|
csrf_token: $csrf_token,
|
|
|
|
apiKey: $apikey['token']
|
2016-12-14 00:19:17 +01:00
|
|
|
})
|
|
|
|
ticket1 = ticket1['data']['ticketNumber']
|
|
|
|
ticket2 = ticket2['data']['ticketNumber']
|
|
|
|
ticket3 = ticket3['data']['ticketNumber']
|
|
|
|
|
2016-12-12 06:12:17 +01:00
|
|
|
request('/user/logout')
|
|
|
|
Scripts.login($staff[:email], $staff[:password], true)
|
2016-12-14 00:19:17 +01:00
|
|
|
request('/staff/edit', {
|
|
|
|
csrf_userid: $csrf_userid,
|
|
|
|
csrf_token: $csrf_token,
|
|
|
|
departments: '[1, 2, 3, 4]'
|
|
|
|
})
|
|
|
|
request('/staff/assign-ticket', {
|
|
|
|
ticketNumber: ticket3,
|
|
|
|
csrf_userid: $csrf_userid,
|
|
|
|
csrf_token: $csrf_token
|
|
|
|
})
|
|
|
|
|
|
|
|
it 'should fail if departments are the same' do
|
|
|
|
result = request('/system/delete-department', {
|
|
|
|
csrf_userid: $csrf_userid,
|
|
|
|
csrf_token: $csrf_token,
|
|
|
|
departmentId: 4,
|
|
|
|
transferDepartmentId: 4
|
|
|
|
})
|
|
|
|
|
|
|
|
(result['status']).should.equal('fail')
|
|
|
|
(result['message']).should.equal('SAME_DEPARTMENT')
|
|
|
|
end
|
2016-12-12 06:12:17 +01:00
|
|
|
|
2018-11-29 22:37:04 +01:00
|
|
|
it 'should fail if department to transfer is private' do
|
2016-12-14 00:19:17 +01:00
|
|
|
result = request('/system/delete-department', {
|
2016-12-12 06:12:17 +01:00
|
|
|
csrf_userid: $csrf_userid,
|
|
|
|
csrf_token: $csrf_token,
|
2016-12-14 00:19:17 +01:00
|
|
|
departmentId: 4,
|
|
|
|
transferDepartmentId: 2
|
2016-12-12 06:12:17 +01:00
|
|
|
})
|
|
|
|
|
2018-11-29 22:37:04 +01:00
|
|
|
(result['status']).should.equal('fail')
|
|
|
|
(result['message']).should.equal('DEPARTMENT_PRIVATE_TICKETS')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should delete department' do
|
|
|
|
result = request('/system/delete-department', {
|
|
|
|
csrf_userid: $csrf_userid,
|
|
|
|
csrf_token: $csrf_token,
|
|
|
|
departmentId: 4,
|
|
|
|
transferDepartmentId: 3
|
|
|
|
})
|
|
|
|
|
2016-12-12 06:12:17 +01:00
|
|
|
(result['status']).should.equal('success')
|
|
|
|
|
|
|
|
row = $database.getRow('department', 4, 'id')
|
|
|
|
(row).should.equal(nil)
|
2016-12-14 00:19:17 +01:00
|
|
|
|
|
|
|
ticket1 = $database.getRow('ticket', ticket1, 'ticket_number')
|
|
|
|
ticket2 = $database.getRow('ticket', ticket2, 'ticket_number')
|
|
|
|
ticket3 = $database.getRow('ticket', ticket3, 'ticket_number')
|
|
|
|
|
2020-05-13 07:51:51 +02:00
|
|
|
(ticket1['department_id']).should.equal(3)
|
2016-12-14 00:19:17 +01:00
|
|
|
(ticket1['owner_id']).should.equal(nil)
|
|
|
|
|
2020-05-13 07:51:51 +02:00
|
|
|
(ticket2['department_id']).should.equal(3)
|
2016-12-14 00:19:17 +01:00
|
|
|
(ticket2['owner_id']).should.equal(nil)
|
|
|
|
|
2020-05-13 07:51:51 +02:00
|
|
|
(ticket3['department_id']).should.equal(3)
|
|
|
|
(ticket3['owner_id']).should.equal($csrf_userid.to_i)
|
2016-12-29 21:25:45 +01:00
|
|
|
|
|
|
|
lastLog = $database.getLastRow('log')
|
|
|
|
(lastLog['type']).should.equal('DELETE_DEPARTMENT')
|
2016-12-12 06:12:17 +01:00
|
|
|
end
|
2016-12-29 21:25:45 +01:00
|
|
|
end
|