Maintenance: Port System > Translations test to capybara.

This commit is contained in:
Martin Gruner 2021-09-24 15:59:07 +02:00 committed by Dominik Klein
parent 59f1824c3a
commit 4f2e7b9e52
6 changed files with 125 additions and 387 deletions

View file

@ -227,10 +227,6 @@ group :development, :test do
# Slack helper for testing
gem 'slack-ruby-client', require: false
# Can be used to detect for example the current
# operating system in tests, to handle things differently.
gem 'os'
end
# Want to extend Zammad with additional gems?

View file

@ -392,7 +392,6 @@ GEM
omniauth (~> 1.5)
omniauth-oauth2 (>= 1.4.0)
openssl (2.2.0)
os (1.1.1)
overcommit (0.58.0)
childprocess (>= 0.6.3, < 5)
iniparse (~> 1.4)
@ -711,7 +710,6 @@ DEPENDENCIES
omniauth-twitter
omniauth-weibo-oauth2
openssl
os
overcommit
pg (= 0.21.0)
pry-rails

View file

@ -67,7 +67,6 @@ if [ "$LEVEL" == '1' ]; then
# test/browser/swich_to_user_test.rb
# test/browser/taskbar_session_test.rb
# test/browser/taskbar_task_test.rb
# test/browser/translation_test.rb
rm test/browser/user_access_permissions_test.rb
rm test/browser/user_switch_cache_test.rb
@ -133,7 +132,6 @@ elif [ "$LEVEL" == '2' ]; then
rm test/browser/switch_to_user_test.rb
rm test/browser/taskbar_session_test.rb
rm test/browser/taskbar_task_test.rb
rm test/browser/translation_test.rb
# test/browser/user_access_permissions_test.rb
# test/browser/user_switch_cache_test.rb
@ -199,7 +197,6 @@ elif [ "$LEVEL" == '3' ]; then
rm test/browser/switch_to_user_test.rb
rm test/browser/taskbar_session_test.rb
rm test/browser/taskbar_task_test.rb
rm test/browser/translation_test.rb
rm test/browser/user_access_permissions_test.rb
rm test/browser/user_switch_cache_test.rb
@ -265,7 +262,6 @@ elif [ "$LEVEL" == '4' ]; then
rm test/browser/switch_to_user_test.rb
rm test/browser/taskbar_session_test.rb
rm test/browser/taskbar_task_test.rb
rm test/browser/translation_test.rb
rm test/browser/user_access_permissions_test.rb
rm test/browser/user_switch_cache_test.rb
@ -330,7 +326,6 @@ elif [ "$LEVEL" == '5' ]; then
rm test/browser/switch_to_user_test.rb
rm test/browser/taskbar_session_test.rb
rm test/browser/taskbar_task_test.rb
rm test/browser/translation_test.rb
rm test/browser/user_access_permissions_test.rb
rm test/browser/user_switch_cache_test.rb
@ -398,7 +393,6 @@ elif [ "$LEVEL" == '6' ]; then
rm test/browser/switch_to_user_test.rb
rm test/browser/taskbar_session_test.rb
rm test/browser/taskbar_task_test.rb
rm test/browser/translation_test.rb
rm test/browser/user_access_permissions_test.rb
rm test/browser/user_switch_cache_test.rb

View file

@ -28,7 +28,7 @@ RSpec.shared_examples 'text modules' do |path:|
# The click is needed to get the focus back to the field for chrome.
find(:richtext).click
if OS.mac?
if Gem::Platform.local.os.eql? 'darwin'
find(:richtext).send_keys(%i[command backspace])
else
find(:richtext).send_keys(%i[control backspace])

View file

@ -17,4 +17,128 @@ RSpec.describe 'System > Translations', type: :system do
modal_disappear # make sure test is not terminated while modal is visible
end
# see https://github.com/zammad/zammad/issues/2056
#
# The purpose of this test is to verify that the Translation admin panel automatically re-renders under certain edge cases:
#
# Clicking into the Translation panel from another admin panel ALWAYS causes a rerender,
# but clicking into it from, e.g., a Ticket or the Dashboard does not.
#
# We want to ensure that in the latter case, the Translation panel rerenders automatically if there are new phrases to translate.
context "when missing translations are found in 'developer_mode'", authenticated_as: :admin_de do
let(:admin_de) { create(:admin, preferences: { locale: 'de-de' }) }
before do
# developer_mode is required to track missing translations in the GUI.
Setting.set('developer_mode', true)
end
it 're-renders the Translation admin panel correctly' do
# The only way to test the edge case describe above
# (i.e., visiting the Translation panel directly from a Ticket or the Dashboard)
# is to first click into the admin settings and visit the Translation panel,
# then leave, then come back.
visit('/#system/translation')
expect(page).to have_text('Inline Übersetzung')
visit('/#dashboard')
new_ui_phrase = 'Charlie bit me!'
page.evaluate_script("App.i18n.translateContent('#{new_ui_phrase}')")
visit('/#system/translation')
expect(page).to have_text(new_ui_phrase)
end
end
context 'when using the source locale', authenticated_as: :admin do
let(:admin) { create(:admin, preferences: { locale: 'en-us' }) }
it 'offers no translations to change' do
visit '/#system/translation'
expect(page).to have_text('English is the source language, so we have nothing to translate')
end
end
context 'when using a translation locale', authenticated_as: :admin_de do
let(:admin_de) { create(:admin, preferences: { locale: 'de-de' }) }
it 'allows translations to be changed locally' do
visit '/#system/translation'
field = find('.content.active input.js-Item[data-source="Translations"]')
field.fill_in(with: 'Übersetzung2')
field.native.send_keys :tab
# Cause nav to re-render
visit '/#dashboard'
visit '/#system/translation'
within :active_content do
expect(find('.sidebar a[href="#system/translation"]').text).to eq('Übersetzung2')
find('input.js-Item[data-source="Translations"]').ancestor('tr').find('.js-Reset').click
# Let find() wait for the field to be updated...
expect(find('input.js-Item[data-source="Translations"][value="Übersetzung"]').value).to eq('Übersetzung')
expect(find('.sidebar a[href="#system/translation"]').text).to eq('Übersetzung2')
end
# Cause nav to re-render
visit '/#dashboard'
visit '/#system/translation'
expect(find('.sidebar a[href="#system/translation"]').text).to eq('Übersetzung')
end
end
context 'when using inline translation', authenticated_as: :admin do
shared_examples 'check inline translations' do |overviews_translated|
it 'allows to use inline translations' do
visit '/#system/translation'
def toggle_inline_translations
if Gem::Platform.local.os.eql? 'darwin'
page.send_keys [:control, :alt, 't']
else
page.send_keys [:control, :shift, 't']
end
end
toggle_inline_translations
span = find '.sidebar span.translation[title="Overviews"]'
# Move cursor to the end of the string.
if Gem::Platform.local.os.eql? 'darwin'
span.send_keys %i[command right], '_modified', :tab
else
span.send_keys %i[control right], '_modified', :tab
end
# Leave the span to be able to turn off inline translations again
visit '/#dashboard'
toggle_inline_translations
visit '/#system/translation'
expect(page).to have_no_css('.sidebar span.translation[title="Overviews"]')
expect(find('a[href="#manage/overviews"]')).to have_text("#{overviews_translated}_modified")
expect(find('.content.active input.js-Item[data-source="Overviews"]').value).to eq("#{overviews_translated}_modified")
end
end
context 'for source locale' do
let(:admin) { create(:admin, preferences: { locale: 'en-us' }) }
# This may seem unexpected: en-us currently offers inline translation changing,
# even though the System > Translations screen says "nothing to translate".
include_examples 'check inline translations', 'Overviews'
end
context 'for translated locale' do
let(:admin) { create(:admin, preferences: { locale: 'de-de' }) }
include_examples 'check inline translations', 'Übersichten'
end
end
end

View file

@ -1,374 +0,0 @@
# Copyright (C) 2012-2021 Zammad Foundation, http://zammad-foundation.org/
require 'browser_test_helper'
class TranslationTest < TestCase
def test_preferences
@browser = browser_instance
login(
username: 'admin@example.com',
password: 'test',
url: browser_url,
)
tasks_close_all
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'English (United States)',
)
click(css: '.content.active button[type="submit"]')
sleep 2
watch_for(
css: 'body',
value: 'Language',
)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
watch_for(
css: '.content.active',
value: 'English is the source language, so we have nothing to translate',
)
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'Deutsch',
)
click(css: '.content.active button[type="submit"]')
watch_for(
css: 'body',
value: 'Sprache',
)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
notify_close(optional: true) # to be not in click area
set(
css: '.content.active input.js-Item[data-source="Translations"]',
value: 'Übersetzung2',
)
sleep 5 # wait until nofify is gone
click(css: '#global-search')
sleep 4 # wait till rerender
click(css: 'a[href="#dashboard"]')
sleep 2 # wait till nav is rendered
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
match(
css: '.content.active .sidebar',
value: 'Übersetzung2',
)
match(
css: '.content.active input.js-Item[data-source="Translations"]',
value: 'Übersetzung2',
)
execute(
js: "$('.js-Item[data-source=Translations]').parents('tr').find('.js-Reset:visible').click()",
)
sleep 5
match(
css: '.content.active .sidebar',
value: 'Übersetzung2',
)
match_not(
css: '.content.active input.js-Item[data-source="Translations"]',
value: 'Übersetzung2',
)
click(css: 'a[href="#dashboard"]')
sleep 4 # wait till rerender
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
sleep 2
match_not(
css: '.content.active .sidebar',
value: 'Übersetzung2',
)
match_not(
css: '.content.active input.js-Item[data-source="Translations"]',
value: 'Übersetzung2',
)
match_not(
css: '.content.active .sidebar',
value: 'Übersetzung2',
)
@browser.action.key_down(:control)
.key_down(:shift)
.send_keys('t')
.key_up(:shift)
.key_up(:control)
.perform
watch_for(
css: 'span.translation[title="Overviews"]',
value: 'Übersichten',
)
set(
css: 'span.translation[title="Overviews"]',
value: 'Übersichten123',
)
sleep 1
click(css: 'a[href="#dashboard"]')
sleep 5
@browser.action.key_down(:control)
.key_down(:shift)
.send_keys('t')
.key_up(:shift)
.key_up(:control)
.perform
sleep 5
exists_not(
css: 'span.translation[title="Overviews"]',
)
match(
css: '.js-menu',
value: 'Übersichten123',
)
reload
exists_not(
css: 'span.translation[title="Overviews"]',
)
match(
css: '.js-menu',
value: 'Übersichten123',
)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
sleep 4
match(
css: '.content.active input.js-Item[data-source="Overviews"]',
value: 'Übersichten123',
)
execute(
js: "$('.js-Item[data-source=Overviews]').parents('tr').find('.js-Reset:visible').click()",
)
sleep 5
click(css: 'a[href="#dashboard"]')
sleep 5
match_not(
css: '.js-menu',
value: 'Übersichten123',
)
match(
css: '.js-menu',
value: 'Übersichten',
)
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'English (United States)',
)
click(css: '.content.active button[type="submit"]')
sleep 2
watch_for(
css: 'body',
value: 'Language',
)
sleep 5
@browser.action.key_down(:control)
.key_down(:shift)
.send_keys('t')
.key_up(:shift)
.key_up(:control)
.perform
watch_for(
css: 'span.translation[title="Overviews"]',
value: 'Overviews',
)
set(
css: 'span.translation[title="Overviews"]',
value: 'Overviews123',
)
sleep 1
click(css: 'a[href="#dashboard"]')
sleep 5
@browser.action.key_down(:control)
.key_down(:shift)
.send_keys('t')
.key_up(:shift)
.key_up(:control)
.perform
sleep 5
exists_not(
css: 'span.translation[title="Overviews"]',
)
match(
css: '.js-menu',
value: 'Overviews123',
)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
sleep 4
match(
css: '.content.active input.js-Item[data-source="Overviews"]',
value: 'Overviews123',
)
match_not(
css: '.content.active',
value: 'English is the source language, so we have nothing to translate',
)
execute(
js: "$('.js-Item[data-source=Overviews]').parents('tr').find('.js-Reset:visible').click()",
)
watch_for(
css: '.content.active',
value: 'English is the source language, so we have nothing to translate',
)
end
def test_admin_sync
@browser = browser_instance
login(
username: 'admin@example.com',
password: 'test',
url: browser_url,
)
tasks_close_all
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'Deutsch',
)
click(css: '.content.active button[type="submit"]')
watch_for(
css: 'body',
value: 'Sprache',
)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
watch_for(
css: '.content.active',
value: 'Inline Übersetzung',
)
click(css: '.content.active .js-syncChanges')
modal_ready
watch_for(
css: '.content.active .modal',
value: 'Letzte Übersetzung laden',
)
modal_disappear(
timeout: 6.minutes,
)
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'English (United States)',
)
click(css: '.content.active button[type="submit"]')
watch_for(
css: 'body',
value: 'Language',
)
end
# see https://github.com/zammad/zammad/issues/2056
#
# The purpose of this test is to verify that
# the Translation admin panel automatically re-renders
# under certain edge cases:
#
# Clicking into the Translation panel from another admin panel ALWAYS causes a rerender,
# but clicking into it from, e.g., a Ticket or the Dashboard does not.
#
# We want to ensure that in the latter case,
# the Translation panel rerenders automatically if there are new phrases to translate.
def test_rerender_when_new_phrases_detected
@browser = browser_instance
login(
username: 'admin@example.com',
password: 'test',
url: browser_url,
)
tasks_close_all
click(css: 'a[href="#current_user"]')
click(css: 'a[href="#profile"]')
click(css: 'a[href="#profile/language"]')
select(
css: '.js-language [name="locale"]',
value: 'Deutsch',
)
click(css: '.content.active button[type="submit"]')
watch_for(
css: 'body',
value: 'Sprache',
)
# The only way to test the edge case describe above
# (i.e., visiting the Translation panel directly from a Ticket or the Dashboard)
# is to first click into the admin settings and visit the Translation panel,
# then leave, then come back.
#
# (/#manage remembers the most-recent admin panel.)
click(css: 'a[href="#manage"]')
click(css: 'a[href="#system/translation"]')
watch_for(
css: '.content.active',
value: 'Inline Übersetzung',
)
click(css: 'a[href="#dashboard"]')
new_ui_phrase = 'Charlie bit me!'
@browser.execute_script("App.i18n.translateContent('#{new_ui_phrase}')")
click(css: 'a[href="#manage"]')
watch_for(
css: %(td[title="#{new_ui_phrase}"]),
value: new_ui_phrase,
timeout: 3
)
end
end