123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890 |
- # encoding: utf-8
- require 'test_helper'
- class TicketSelectorTest < ActiveSupport::TestCase
- # create base
- group = Group.create_or_update(
- name: 'SelectorTest',
- updated_at: '2015-02-05 16:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- roles = Role.where(name: 'Agent')
- agent1 = User.create_or_update(
- login: 'ticket-selector-agent1@example.com',
- firstname: 'Notification',
- lastname: 'Agent1',
- email: 'ticket-selector-agent1@example.com',
- password: 'agentpw',
- active: true,
- roles: roles,
- groups: [group],
- updated_at: '2015-02-05 16:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- agent2 = User.create_or_update(
- login: 'ticket-selector-agent2@example.com',
- firstname: 'Notification',
- lastname: 'Agent2',
- email: 'ticket-selector-agent2@example.com',
- password: 'agentpw',
- active: true,
- roles: roles,
- #groups: groups,
- updated_at: '2015-02-05 16:38:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- roles = Role.where(name: 'Customer')
- organization1 = Organization.create_if_not_exists(
- name: 'Selector Org',
- updated_at: '2015-02-05 16:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- customer1 = User.create_or_update(
- login: 'ticket-selector-customer1@example.com',
- firstname: 'Notification',
- lastname: 'Customer1',
- email: 'ticket-selector-customer1@example.com',
- password: 'customerpw',
- active: true,
- organization_id: organization1.id,
- roles: roles,
- updated_at: '2015-02-05 16:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- customer2 = User.create_or_update(
- login: 'ticket-selector-customer2@example.com',
- firstname: 'Notification',
- lastname: 'Customer2',
- email: 'ticket-selector-customer2@example.com',
- password: 'customerpw',
- active: true,
- organization_id: nil,
- roles: roles,
- updated_at: '2015-02-05 16:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- Ticket.where(group_id: group.id).destroy_all
- test 'ticket create' do
- Ticket.destroy_all
- ticket1 = Ticket.create(
- title: 'some title1',
- group: group,
- customer_id: customer1.id,
- owner_id: agent1.id,
- state: Ticket::State.lookup(name: 'new'),
- priority: Ticket::Priority.lookup(name: '2 normal'),
- created_at: '2015-02-05 16:37:00',
- #updated_at: '2015-02-05 17:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- assert(ticket1, 'ticket created')
- assert_equal(ticket1.customer.id, customer1.id)
- assert_equal(ticket1.organization.id, organization1.id)
- sleep 1
- ticket2 = Ticket.create(
- title: 'some title2',
- group: group,
- customer_id: customer2.id,
- state: Ticket::State.lookup(name: 'new'),
- priority: Ticket::Priority.lookup(name: '2 normal'),
- created_at: '2015-02-05 16:37:00',
- #updated_at: '2015-02-05 17:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- assert(ticket2, 'ticket created')
- assert_equal(ticket2.customer.id, customer2.id)
- assert_equal(ticket2.organization_id, nil)
- sleep 1
- ticket3 = Ticket.create(
- title: 'some title3',
- group: group,
- customer_id: customer2.id,
- state: Ticket::State.lookup(name: 'open'),
- priority: Ticket::Priority.lookup(name: '2 normal'),
- escalation_time: '2015-02-06 10:00:00',
- created_at: '2015-02-05 16:37:00',
- #updated_at: '2015-02-05 17:37:00',
- updated_by_id: 1,
- created_by_id: 1,
- )
- assert(ticket3, 'ticket created')
- assert_equal(ticket3.customer.id, customer2.id)
- assert_equal(ticket3.organization_id, nil)
- sleep 1
- # search not matching
- condition = {
- 'ticket.state_id' => {
- operator: 'is',
- value: [99],
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- # search matching
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.state_id' => {
- operator: 'is',
- value: [Ticket::State.lookup(name: 'new').id],
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 1)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.state_id' => {
- operator: 'is not',
- value: [Ticket::State.lookup(name: 'open').id],
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 1)
- condition = {
- 'ticket.escalation_time' => {
- operator: 'is not',
- value: nil,
- }
- }
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 1)
- # search - created_at
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'after (absolute)', # before (absolute)
- value: '2015-02-05T16:00:00.000Z',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'after (absolute)', # before (absolute)
- value: '2015-02-05T18:00:00.000Z',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'before (absolute)',
- value: '2015-02-05T18:00:00.000Z',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'before (absolute)',
- value: '2015-02-05T16:00:00.000Z',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'before (relative)',
- range: 'day', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'within next (relative)',
- range: 'year', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.created_at' => {
- operator: 'within last (relative)',
- range: 'year', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- # search - updated_at
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'before (absolute)',
- value: (Time.zone.now + 1.day).iso8601,
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'before (absolute)',
- value: (Time.zone.now - 1.day).iso8601,
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'after (absolute)',
- value: (Time.zone.now + 1.day).iso8601,
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'after (absolute)',
- value: (Time.zone.now - 1.day).iso8601,
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'before (relative)',
- range: 'day', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'within next (relative)',
- range: 'year', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.updated_at' => {
- operator: 'within last (relative)',
- range: 'year', # minute|hour|day|month|
- value: '10',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- # invalid conditions
- assert_raise RuntimeError do
- ticket_count, tickets = Ticket.selectors(nil, 10)
- end
- # search with customers
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'customer.email' => {
- operator: 'contains',
- value: 'ticket-selector-customer1',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'customer.email' => {
- operator: 'contains not',
- value: 'ticket-selector-customer1-not_existing',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 3)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- # search with organizations
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'organization.name' => {
- operator: 'contains',
- value: 'selector',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- # search with organizations
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'organization.name' => {
- operator: 'contains',
- value: 'selector',
- },
- 'customer.email' => {
- operator: 'contains',
- value: 'ticket-selector-customer1',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'organization.name' => {
- operator: 'contains',
- value: 'selector',
- },
- 'customer.email' => {
- operator: 'contains not',
- value: 'ticket-selector-customer1',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- # with owner/customer/org
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.owner_id' => {
- operator: 'is',
- pre_condition: 'specific',
- value: agent1.id,
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.owner_id' => {
- operator: 'is',
- pre_condition: 'set',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.owner_id' => {
- operator: 'is not',
- pre_condition: 'set',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- UserInfo.current_user_id = agent1.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.owner_id' => {
- operator: 'is',
- pre_condition: 'current_user.id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- UserInfo.current_user_id = agent2.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.owner_id' => {
- operator: 'is',
- pre_condition: 'current_user.id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- UserInfo.current_user_id = customer1.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.customer_id' => {
- operator: 'is',
- pre_condition: 'current_user.id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- UserInfo.current_user_id = customer2.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.customer_id' => {
- operator: 'is',
- pre_condition: 'current_user.id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 2)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 2)
- UserInfo.current_user_id = customer1.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.organization_id' => {
- operator: 'is',
- pre_condition: 'current_user.organization_id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- UserInfo.current_user_id = customer2.id
- condition = {
- 'ticket.group_id' => {
- operator: 'is',
- value: group.id,
- },
- 'ticket.organization_id' => {
- operator: 'is',
- pre_condition: 'current_user.organization_id',
- },
- }
- ticket_count, tickets = Ticket.selectors(condition, 10, agent1)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, agent2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer1)
- assert_equal(ticket_count, 1)
- ticket_count, tickets = Ticket.selectors(condition, 10, customer2)
- assert_equal(ticket_count, 0)
- ticket_count, tickets = Ticket.selectors(condition, 10)
- assert_equal(ticket_count, 0)
- end
- end
|