2017-11-23 08:09:44 +00:00
|
|
|
|
2012-12-14 10:14:48 +00:00
|
|
|
require 'browser_test_helper'
|
2013-02-12 00:56:23 +00:00
|
|
|
|
2013-02-23 22:54:48 +00:00
|
|
|
class CustomerTicketCreateTest < TestCase
|
|
|
|
def test_customer_ticket_create
|
2015-02-22 22:20:05 +00:00
|
|
|
@browser = browser_instance
|
|
|
|
login(
|
2015-04-27 13:42:53 +00:00
|
|
|
username: 'nicole.braun@zammad.org',
|
|
|
|
password: 'test',
|
|
|
|
url: browser_url,
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
2013-02-21 21:09:36 +00:00
|
|
|
|
2015-02-22 22:20:05 +00:00
|
|
|
# customer ticket create
|
2018-03-06 05:30:12 +00:00
|
|
|
click(css: 'a[href="#new"]', only_if_exists: true)
|
2016-03-22 12:58:48 +00:00
|
|
|
click(css: 'a[href="#customer_ticket_new"]')
|
2015-02-22 22:20:05 +00:00
|
|
|
sleep 2
|
2013-02-21 21:09:36 +00:00
|
|
|
|
2015-02-22 22:20:05 +00:00
|
|
|
select(
|
2015-04-27 13:42:53 +00:00
|
|
|
css: '.newTicket select[name="group_id"]',
|
|
|
|
value: 'Users',
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
set(
|
2015-04-27 13:42:53 +00:00
|
|
|
css: '.newTicket input[name="title"]',
|
|
|
|
value: 'some subject 123äöü',
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
|
|
|
set(
|
2015-04-27 13:42:53 +00:00
|
|
|
css: '.newTicket [data-name="body"]',
|
|
|
|
value: 'some body 123äöü',
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
2017-01-03 09:57:05 +00:00
|
|
|
exists_not(
|
|
|
|
css: '.newTicket input[name="customer_id"]',
|
|
|
|
)
|
|
|
|
exists_not(
|
|
|
|
css: '.newTicket input[name="priority_id"]',
|
|
|
|
)
|
|
|
|
|
2016-03-22 12:58:48 +00:00
|
|
|
click(css: '.newTicket button.js-submit')
|
2015-02-22 22:20:05 +00:00
|
|
|
sleep 5
|
|
|
|
|
|
|
|
# check if ticket is shown
|
2016-03-22 12:58:48 +00:00
|
|
|
location_check(url: '#ticket/zoom/')
|
2015-02-22 22:20:05 +00:00
|
|
|
|
|
|
|
match(
|
2015-04-27 13:42:53 +00:00
|
|
|
css: '.active div.ticket-article',
|
|
|
|
value: 'some body 123äöü',
|
|
|
|
no_quote: true,
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# update ticket
|
|
|
|
set(
|
2017-01-03 09:57:05 +00:00
|
|
|
css: '.content.active [data-name="body"]',
|
2015-04-27 13:42:53 +00:00
|
|
|
value: 'some body 1234 äöüß',
|
2015-12-05 19:44:43 +00:00
|
|
|
no_click: true,
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
2015-11-06 01:43:26 +00:00
|
|
|
|
|
|
|
task_type(
|
|
|
|
type: 'stayOnTab',
|
|
|
|
)
|
|
|
|
|
2017-01-03 09:57:05 +00:00
|
|
|
click(css: '.content.active .js-submit')
|
2015-02-22 22:20:05 +00:00
|
|
|
|
|
|
|
watch_for(
|
2017-01-03 09:57:05 +00:00
|
|
|
css: '.content.active div.ticket-article',
|
2015-04-27 13:42:53 +00:00
|
|
|
value: 'some body 1234 äöüß',
|
2015-02-22 22:20:05 +00:00
|
|
|
)
|
2018-02-07 10:46:17 +00:00
|
|
|
|
|
|
|
# now we want to verify the default followup state
|
|
|
|
# for this case we close the ticket first and then
|
|
|
|
# write a new article. If the content is written
|
|
|
|
# then the state should change initially to open
|
|
|
|
|
|
|
|
# close the ticket
|
|
|
|
select(
|
|
|
|
css: '.content.active [name="state_id"]',
|
|
|
|
value: 'closed',
|
|
|
|
)
|
|
|
|
|
|
|
|
set(
|
|
|
|
css: '.content.active [data-name="body"]',
|
|
|
|
value: 'close #1',
|
|
|
|
no_click: true,
|
|
|
|
)
|
|
|
|
|
|
|
|
click(css: '.content.active .js-submit')
|
|
|
|
watch_for(
|
|
|
|
css: '.content.active div.ticket-article',
|
|
|
|
value: 'close #1',
|
|
|
|
)
|
|
|
|
|
|
|
|
# check if the ticket is closed
|
|
|
|
match(
|
|
|
|
css: '.content.active .sidebar [name="state_id"]',
|
|
|
|
value: 'closed',
|
|
|
|
)
|
|
|
|
|
|
|
|
# type in new content into rte to trigger the default follow up state
|
|
|
|
set(
|
|
|
|
css: '.content.active [data-name="body"]',
|
|
|
|
value: 'some body blublub default followup for reopen check',
|
|
|
|
no_click: true,
|
|
|
|
)
|
|
|
|
|
|
|
|
# verify if the state has changed to open
|
|
|
|
watch_for(
|
|
|
|
css: '.content.active .sidebar [name="state_id"]',
|
|
|
|
value: 'open',
|
|
|
|
)
|
|
|
|
|
|
|
|
# no we verify the reverse way:
|
|
|
|
# if the body get changed to empty again then
|
|
|
|
# the default follow up state should get unset and
|
|
|
|
# will change to the the default ticket state.
|
|
|
|
|
|
|
|
# remove content from rte
|
|
|
|
set(
|
|
|
|
css: '.content.active [data-name="body"]',
|
|
|
|
value: '',
|
|
|
|
no_click: true,
|
|
|
|
)
|
|
|
|
|
|
|
|
# check if state changed to closed again
|
|
|
|
watch_for(
|
|
|
|
css: '.content.active .sidebar [name="state_id"]',
|
|
|
|
value: 'closed',
|
|
|
|
)
|
|
|
|
|
|
|
|
# type in new content into rte to trigger the default follow up state
|
|
|
|
set(
|
|
|
|
css: '.content.active [data-name="body"]',
|
|
|
|
value: 'some body blublub default followup for reopen check',
|
|
|
|
no_click: true,
|
|
|
|
)
|
|
|
|
|
|
|
|
# verify if the state has changed to open
|
|
|
|
watch_for(
|
|
|
|
css: '.content.active .sidebar [name="state_id"]',
|
|
|
|
value: 'open',
|
|
|
|
)
|
|
|
|
|
|
|
|
# submit and reload to check if the new state is set
|
|
|
|
click(css: '.content.active .js-submit')
|
|
|
|
|
|
|
|
watch_for(
|
|
|
|
css: '.content.active div.ticket-article',
|
|
|
|
value: 'some body blublub default followup for reopen check',
|
|
|
|
)
|
|
|
|
|
|
|
|
# verify if the state has changed to open
|
|
|
|
match(
|
|
|
|
css: '.content.active .sidebar [name="state_id"]',
|
|
|
|
value: 'open',
|
|
|
|
)
|
2012-12-14 10:14:48 +00:00
|
|
|
end
|
2015-04-27 14:15:29 +00:00
|
|
|
end
|