require 'core/spec_helper' describe ZendeskAPI::Ticket do def valid_attributes { :type => "question", :subject => "This is a question?", :comment => { :value => "Indeed it is!" }, :priority => "normal", :requester_id => user.id, :submitter_id => user.id, :collaborator_ids => [agent.id], :tags => ["awesome", "blossom"] } end it_should_be_creatable it_should_be_updatable :subject it_should_be_deletable it_should_be_readable :tickets it_should_be_readable user, :requested_tickets it_should_be_readable agent, :ccd_tickets it_should_be_readable organization, :tickets context "recent tickets" do before(:all) do VCR.use_cassette("visit_recent_ticket") do client.connection.get("/tickets/1") do |req| req.headers[:Accept] = "*/*" end sleep(5) end end it_should_be_readable :tickets, :recent end describe ".incremental_export" do let(:results) { ZendeskAPI::Ticket.incremental_export(client, Time.at(1023059503)) } # ~ 10 years ago around do |example| # 1 request every 5 minutes allowed <-> you can only test 1 call ... VCR.use_cassette("incremental_export") do client.config.retry = false example.call client.config.retry = true end end it "finds tickets after a old date" do expect(results.to_a.first).to be_an_instance_of ZendeskAPI::Ticket end it "is able to do next" do first = results.to_a.first stub_json_request(:get, %r{/api/v2/exports/tickets}, json(:results => [])) results.next expect(results.first).to_not eq(first) end end describe ".import" do it "can import" do VCR.use_cassette("ticket_import_can_import") do old = Time.now - 5*365*24*60*60 ticket = ZendeskAPI::Ticket.import(client, valid_attributes.merge(:created_at => old)) expect(ZendeskAPI::Ticket.find(client, ticket).created_at.year).to eq(old.year) end end it "returns nothing if import fails" do VCR.use_cassette("ticket_import_cannot_import") do silence_logger { expect(ZendeskAPI::Ticket.import(client, {})).to eq(nil) } end end end it "can upload while creating" do VCR.use_cassette("ticket_inline_uploads") do ticket = ZendeskAPI::Ticket.new(client, valid_attributes) ticket.comment.uploads << "spec/fixtures/Argentina.gif" ticket.comment.uploads << File.new("spec/fixtures/Argentina.gif") ticket.save! expect(ticket.changes).to eq({}) # uploads were set before save expect(ticket.comment.attributes[:uploads].map(&:class)).to eq([String, String]) # upload was sent as tokens end end it "can comment while creating" do VCR.use_cassette("ticket_inline_comments") do ticket = ZendeskAPI::Ticket.new(client, valid_attributes) ticket.comment = ZendeskAPI::Ticket::Comment.new(client, :value => "My comment", :public => false) ticket.save! expect(ticket.changes).to eq({}) # comment was set before save expect(ticket.attributes[:comment]).to eq({"value" => "My comment", "public" => false}) end end describe "import race condition" do let(:email) { "test+#{rand(100000)}@test.com" } it "should handle it" do VCR.use_cassette("ticket_import_race") do threads = [] 3.times do threads << Thread.new do client.insert_callback do |response| Thread.current[:response] = response end ZendeskAPI::Ticket.import(client, :requester => { :email => email, :name => "Hello" }, :subject => "Test", :description => "Test") end end threads.map! do |thread| thread.join(5) fail("could not get response in 5 seconds") unless thread[:response] thread[:response][:status] end user = client.users.detect {|user| user.email == email} expect(user).to_not be_nil user.requested_tickets.each(&:destroy) user.destroy expect(threads.all? {|st| [201, 422, 409].include?(st)}).to be(true) end end end end