123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'browser_test_helper'
- class CustomerTicketCreateTest < TestCase
- def test_customer_ticket_create_and_verify_state_after_update
- @browser = browser_instance
- login(
- username: 'nicole.braun@zammad.org',
- password: 'test',
- url: browser_url,
- )
- # customer ticket create
- click(css: 'a[href="#new"]', only_if_exists: true)
- click(css: 'a[href="#customer_ticket_new"]')
- sleep 2
- select(
- css: '.newTicket input[name="group_id"]',
- value: 'Users',
- )
- set(
- css: '.newTicket input[name="title"]',
- value: 'some subject 123äöü',
- )
- set(
- css: '.newTicket [data-name="body"]',
- value: 'some body 123äöü',
- )
- exists_not(
- css: '.newTicket input[name="customer_id"]',
- )
- exists_not(
- css: '.newTicket input[name="priority_id"]',
- )
- click(css: '.newTicket button.js-submit')
- sleep 5
- # check if ticket is shown
- location_check(url: '#ticket/zoom/')
- match(
- css: '.active div.ticket-article',
- value: 'some body 123äöü',
- no_quote: true,
- )
- # verify if the state has changed to open
- match(
- css: '.content.active .sidebar [name="state_id"]',
- value: 'new',
- )
- # update ticket
- set(
- css: '.content.active [data-name="body"]',
- value: 'some body 1234 äöüß',
- no_click: true,
- )
- task_type(
- type: 'stayOnTab',
- )
- click(css: '.content.active .js-submit')
- watch_for(
- css: '.content.active div.ticket-article',
- value: 'some body 1234 äöüß',
- )
- # check if the ticket state is new after update by customer
- match(
- css: '.content.active .sidebar [name="state_id"]',
- value: 'new',
- )
- # 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',
- )
- end
- def test_customer_ticket_create_relogin_with_agent_ticket_create
- @browser = browser_instance
- login(
- username: 'nicole.braun@zammad.org',
- password: 'test',
- url: browser_url,
- )
- # customer ticket create
- click(css: 'a[href="#new"]', only_if_exists: true)
- click(css: 'a[href="#customer_ticket_new"]')
- sleep 2
- select(
- css: '.newTicket input[name="group_id"]',
- value: 'Users',
- )
- set(
- css: '.newTicket input[name="title"]',
- value: 'relogin - customer - agent - test 1',
- )
- set(
- css: '.newTicket [data-name="body"]',
- value: 'relogin - customer - agent - test 1',
- )
- click(css: '.newTicket button.js-submit')
- sleep 5
- # check if ticket is shown
- location_check(url: '#ticket/zoom/')
- match(
- css: '.active div.ticket-article',
- value: 'relogin - customer - agent - test 1',
- no_quote: true,
- )
- logout
- # verify if we still can create new tickets as agent
- login(
- username: 'admin@example.com',
- password: 'test',
- url: browser_url,
- )
- tasks_close_all
- ticket_create(
- data: {
- customer: 'nico',
- group: 'Users',
- title: 'relogin - customer - agent - test 2',
- body: 'relogin - customer - agent - test 2',
- state: 'closed',
- },
- )
- end
- def test_customer_disable_ticket_creation
- @browser = browser_instance
- # disable ticket creation
- login(
- username: 'admin@example.com',
- password: 'test',
- url: browser_url,
- )
- click(css: 'a[href="#manage"]')
- click(css: 'a[href="#channels/web"]')
- @browser.find_element(css: 'select[name=customer_ticket_create]').find_element(css: 'option[value=false]').click
- click(css: '#customer_ticket_create .btn')
- sleep(1)
- logout
- # check if new ticket button is not visible
- login(
- username: 'nicole.braun@zammad.org',
- password: 'test',
- url: browser_url,
- )
- assert(exists_not(css: 'a[href="#customer_ticket_new"]'))
- logout
- # enable ticket creation
- login(
- username: 'admin@example.com',
- password: 'test',
- url: browser_url,
- )
- click(css: 'a[href="#manage"]')
- click(css: 'a[href="#channels/web"]')
- @browser.find_element(css: 'select[name=customer_ticket_create]').find_element(css: 'option[value=true]').click
- click(css: '#customer_ticket_create .btn')
- sleep(1)
- logout
- # check if new ticket button is visible
- login(
- username: 'nicole.braun@zammad.org',
- password: 'test',
- url: browser_url,
- )
- assert(exists(css: 'a[href="#customer_ticket_new"]'))
- end
- end
|