Kaynağa Gözat

Fix selenium chrome options so files are downloaded to tmp/downloads in system tests (#34119).

Patch by Jens Krämer.


git-svn-id: http://svn.redmine.org/redmine/trunk@20549 e93f8b46-1217-0410-a6f0-8f06a7374b81
tags/4.2.0
Go MAEDA 3 yıl önce
ebeveyn
işleme
b42e8c2040

+ 3
- 6
test/application_system_test_case.rb Dosyayı Görüntüle

@@ -30,7 +30,7 @@ class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
# Allow running tests using a remote Selenium hub
options[:url] = ENV['SELENIUM_REMOTE_URL'] if ENV['SELENIUM_REMOTE_URL']
options[:desired_capabilities] = Selenium::WebDriver::Remote::Capabilities.chrome(
'chromeOptions' => {
'goog:chromeOptions' => {
'prefs' => {
'download.default_directory' => DOWNLOADS_PATH,
'download.prompt_for_download' => false,
@@ -76,14 +76,11 @@ class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
end

def clear_downloaded_files
# https://github.com/SeleniumHQ/selenium/issues/5292
FileUtils.rm downloaded_files if Redmine::Platform.mswin?
FileUtils.rm downloaded_files
end

def downloaded_files(filename='*')
# https://github.com/SeleniumHQ/selenium/issues/5292
downloaded_path = Redmine::Platform.mswin? ? DOWNLOADS_PATH : "#{ENV['HOME']}/Downloads"
Dir.glob("#{downloaded_path}/#{filename}").
Dir.glob("#{DOWNLOADS_PATH}/#{filename}").
reject{|f| f=~/\.(tmp|crdownload)$/}.sort_by{|f| File.mtime(f)}
end


+ 1
- 3
test/system/issues_test.rb Dosyayı Görüntüle

@@ -519,9 +519,7 @@ class IssuesSystemTest < ApplicationSystemTestCase
click_on 'CSV'
click_on 'Export'

# https://github.com/SeleniumHQ/selenium/issues/5292
# if issues.csv exists, Chrome creates issues (1).csv, issues (2).csv ...
csv = CSV.read(downloaded_file("issues*.csv"))
csv = CSV.read(downloaded_file("issues.csv"))
subject_index = csv.shift.index('Subject')
subjects = csv.map {|row| row[subject_index]}
assert_equal subjects.sort, subjects

Loading…
İptal
Kaydet