123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe 'Knowledge Base Locale Answer Edit', type: :system do
- include_context 'basic Knowledge Base'
- before do
- published_answer && draft_answer && internal_answer
- end
- it 'wraps long texts' do
- long_string = '3KKFA9DAWE9VJYNNnpYRRtMwfa168O1yvpD2t9QXsfb3cppGV6KZ12q0UUJIy5r4Exfk18GnWPR0A3SoDsjxIHz1Gcu4aCEVzenilSOu4gAfxnB6k3mSBUOGIfdgChEBYhcHGgiCmV2EoXu4gG7GAJxKJhM2d4NUiL5RZttGtMXYYFr2Jsg7MV7xXGcygnsLMYqnwzOJxBK0vH3fzhdIZd6YrqR3fggaY0RyKtVigOBZ2SETC8s238Z9eDL4gfUW'
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{draft_answer.id}/edit"
- within(:active_content) do
- find('.richtext-content').send_keys long_string
- expect(page).to have_css('.js-submit') { |elem| !elem.obscured? }
- expect(page).to have_css('.page-header-title') { |elem| !elem.obscured? }
- end
- end
- context 'when image is added via button' do
- before do
- image = Rszr::Image.load('spec/fixtures/files/image/large.png')
- image.resize!(:auto, 30_000)
- image.save('tmp/really-large.png')
- end
- def open_editor_and_add_image
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{draft_answer.id}/edit"
- find('a[data-action="insert_image"]').click
- within('.popover-content') do
- find('input[name="link"]', visible: :all).set(Rails.root.join('tmp/really-large.png'))
- find('[type=submit]').click
- end
- end
- it 'can use big inline image' do
- open_editor_and_add_image
- click '.js-submit'
- await_empty_ajax_queue
- click_on 'Edit'
- expect(page).to have_css("img[src='/api/v1/attachments/#{draft_answer.reload.translations.first.content.attachments.first.id}']")
- end
- end
- context 'add weblink' do
- def open_editor_and_add_link(input)
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{draft_answer.id}/edit"
- find('a[data-action="link"]').click
- within('.popover-content') do
- find('input').fill_in with: input
- find('[type=submit]').click
- end
- end
- it 'allows mailto links' do
- open_editor_and_add_link 'mailto:test@example.com'
- expect(page).to have_link(href: 'mailto:test@example.com')
- end
- it 'allows link with a protocol' do
- open_editor_and_add_link 'protocol://example.org'
- expect(page).to have_link(href: 'protocol://example.org')
- end
- it 'allows relative link' do
- open_editor_and_add_link '/path'
- expect(page).to have_link(href: '/path')
- end
- it 'allows non-protocol URL and prepends default protocol' do
- open_editor_and_add_link 'example.com'
- expect(page).to have_link(href: 'http://example.com')
- end
- end
- context 'add link to another KB answer' do
- def open_editor_and_add_link(input)
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{draft_answer.id}/edit"
- find('a[data-action="link_answer"]').click
- within('.popover-content') do
- find('input').fill_in with: input
- first('.js-option span', text: input).click
- find('[type=submit]').click
- end
- end
- before do
- published_answer
- end
- it 'adds a link to an answer' do
- open_editor_and_add_link published_answer.translations.first.title
- expect(page).to have_link(href: "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{published_answer.id}/edit")
- end
- end
- context 'embedded video' do
- it 'has adding functionality' do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{published_answer.id}/edit"
- find('a[data-action="embed_video"]').click
- within('.popover-content') do
- find('input').fill_in with: 'https://www.youtube.com/watch?v=vTTzwJsHpU8'
- find('[type=submit]').click
- end
- within('.richtext-content') do
- expect(page).to have_text('( widget: video, provider: youtube, id: vTTzwJsHpU8 )')
- end
- end
- it 'loads stored' do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{published_answer_with_video.id}"
- iframe = find('iframe')
- expect(iframe['src']).to start_with('https://www.youtube.com/embed/')
- end
- end
- context 'tags' do
- before do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{locale_name}/answer/#{published_answer_with_tag.id}/edit"
- end
- let(:new_tag_name) { 'capybara_kb_tag' }
- it 'adds a new tag' do
- within :active_content do
- click '.js-newTagLabel'
- elem = find('.js-newTagInput')
- elem.fill_in with: new_tag_name
- elem.send_keys :return
- wait.until_exists { published_answer_with_tag.reload.tag_list.include? new_tag_name }
- expect(page).to have_link(new_tag_name, href: false, class: ['js-tag'])
- end
- end
- it 'triggers autocomplete after one character' do
- within :active_content do
- click '.js-newTagLabel'
- elem = find('.js-newTagInput')
- elem.fill_in with: 'e'
- expect(page).to have_css('ul.ui-autocomplete > li.ui-menu-item', minimum: 1)
- end
- end
- it 'shows an existing tag' do
- within :active_content do
- expect(page).to have_link(published_answer_tag_name, href: false, class: ['js-tag'])
- end
- end
- it 'deletes a tag' do
- within :active_content do
- find('.list-item', text: published_answer_tag_name)
- .find('.js-delete').click
- expect(page).to have_no_link(published_answer_tag_name, href: false, class: ['js-tag'])
- wait.until_exists { published_answer_with_tag.reload.tag_list.exclude? published_answer_tag_name }
- end
- end
- end
- describe 'linked tickets' do
- let(:ticket) { Ticket.first }
- it 'links a ticket' do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{locale_name}/answer/#{published_answer.id}/edit"
- within '.knowledge-base-sidebar .sidebar-linked-tickets' do
- click '.js-add'
- end
- in_modal do
- fill_in 'ticket_number', with: ticket.number
- click '.js-submit'
- end
- within '.knowledge-base-sidebar .sidebar-linked-tickets' do
- expect(page).to have_text(ticket.title)
- end
- added_link = Link.list(link_object: 'Ticket', link_object_value: ticket.id).last
- expect(added_link).to eq({
- 'link_object' => 'KnowledgeBase::Answer::Translation',
- 'link_object_value' => published_answer.translations.first.id,
- 'link_type' => 'normal',
- })
- end
- context 'when a linked ticket exists' do
- before do
- create(:link, from: ticket, to: published_answer.translations.first)
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{locale_name}/answer/#{published_answer.id}/edit"
- end
- it 'shows a linked ticket' do
- within '.knowledge-base-sidebar .sidebar-linked-tickets' do
- expect(page).to have_text(ticket.title)
- end
- end
- it 'removes a linked ticket' do
- within '.knowledge-base-sidebar .sidebar-linked-tickets' do
- click '.js-delete'
- expect(page).to have_no_text(ticket.title)
- end
- expect(Link.list(link_object: 'Ticket', link_object_value: ticket.id)).to be_blank
- end
- context 'when agent has no acess to ticket', authenticated_as: -> { create(:admin) } do
- it 'does not show a linked ticket' do
- within '.knowledge-base-sidebar .sidebar-linked-tickets' do
- expect(page).to have_no_text(ticket.title)
- end
- end
- end
- end
- end
- context 'deleted by another user' do
- before do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{published_answer.id}/edit"
- end
- it 'shows not available', performs_jobs: true do
- find(:active_content, text: published_answer.translations.first.title)
- perform_enqueued_jobs do
- ActiveRecord::Base.transaction do
- published_answer.destroy
- end
- end
- within :active_content do
- expect(page).to have_text('The page is not available anymore')
- end
- end
- end
- context 'updated by another user' do
- before do
- ensure_websocket do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{published_answer.id}/edit"
- end
- travel 1.minute
- end
- it 'shows new content', performs_jobs: true do
- find(:active_content, text: published_answer.translations.first.title)
- accept_prompt do
- perform_enqueued_jobs do
- Transaction.execute do
- published_answer.translations.first.update! title: 'new title'
- end
- end
- end
- within :active_content do
- expect(page).to have_text('new title')
- end
- end
- end
- describe 'previewing' do
- before do
- visit "#knowledge_base/#{knowledge_base.id}/locale/#{primary_locale.system_locale.locale}/answer/#{draft_answer.id}/edit"
- end
- it 'opens preview' do
- new_window = window_opened_by { click '.icon-external' }
- within_window new_window do
- within '.main--article' do
- expect(page).to have_text(draft_answer.translations.first.title)
- end
- end
- end
- it 'creates a KB preview token' do
- expect { click('.icon-external') }
- .to change { Token.exists?(action: 'KnowledgeBasePreview') }
- .to(true)
- end
- end
- end
|