X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/136f77bed67bd349fb73053379dcb7bae6a16592..e34135f6779f58852558e03b1b95534c11ca07ae:/apps/workbench/test/integration/collections_test.rb diff --git a/apps/workbench/test/integration/collections_test.rb b/apps/workbench/test/integration/collections_test.rb index f62f28534b..ea42052a3e 100644 --- a/apps/workbench/test/integration/collections_test.rb +++ b/apps/workbench/test/integration/collections_test.rb @@ -147,4 +147,91 @@ class CollectionsTest < ActionDispatch::IntegrationTest headless.stop end end + + test "combine selected collection files from collection subdirectory" do + headless = Headless.new + headless.start + Capybara.current_driver = :selenium + + visit page_with_token('user1_with_load', "/collections/zzzzz-4zz18-filesinsubdir00") + + # now in collection page + input_files = page.all('input[type=checkbox]') + (0..input_files.count-1).each do |i| + input_files[i].click + end + + click_button 'Selection...' + within('.selection-action-container') do + click_link 'Create new collection with selected files' + end + + # now in the newly created collection page + assert(page.has_text?('file_in_subdir1'), 'file not found - file_in_subdir1') + assert(page.has_text?('file1_in_subdir3.txt'), 'file not found - file1_in_subdir3.txt') + assert(page.has_text?('file2_in_subdir3.txt'), 'file not found - file2_in_subdir3.txt') + assert(page.has_text?('file1_in_subdir4.txt'), 'file not found - file1_in_subdir4.txt') + assert(page.has_text?('file2_in_subdir4.txt'), 'file not found - file1_in_subdir4.txt') + + headless.stop + end + + test "Collection portable data hash redirect" do + di = api_fixture('collections')['docker_image'] + visit page_with_token('active', "/collections/#{di['portable_data_hash']}") + + # check redirection + assert current_path.end_with?("/collections/#{di['uuid']}") + assert page.has_text?("docker_image") + assert page.has_text?("Activity") + assert page.has_text?("Sharing and permissions") + end + + test "Collection portable data hash with multiple matches" do + pdh = api_fixture('collections')['baz_file']['portable_data_hash'] + visit page_with_token('admin', "/collections/#{pdh}") + + matches = api_fixture('collections').select {|k,v| v["portable_data_hash"] == pdh} + assert matches.size > 1 + + matches.each do |k,v| + assert page.has_link?(v["name"]), "Page /collections/#{pdh} should contain link '#{v['name']}'" + end + assert page.has_no_text?("Activity") + assert page.has_no_text?("Sharing and permissions") + end + + test "Filtering collection files by regexp" do + col = api_fixture('collections', 'multilevel_collection_1') + visit page_with_token('active', "/collections/#{col['uuid']}") + + # Test when only some files match the regex + page.find_field('file_regex').set('file[12]') + find('button#file_regex_submit').click + assert page.has_text?("file1") + assert page.has_text?("file2") + assert page.has_no_text?("file3") + + # Test all files matching the regex + page.find_field('file_regex').set('file[123]') + find('button#file_regex_submit').click + assert page.has_text?("file1") + assert page.has_text?("file2") + assert page.has_text?("file3") + + # Test no files matching the regex + page.find_field('file_regex').set('file9') + find('button#file_regex_submit').click + assert page.has_no_text?("file1") + assert page.has_no_text?("file2") + assert page.has_no_text?("file3") + + # Syntactically invalid regex + # Page loads, but does not match any files + page.find_field('file_regex').set('file[2') + find('button#file_regex_submit').click + assert page.has_no_text?("file1") + assert page.has_no_text?("file2") + assert page.has_no_text?("file3") + end end