X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/5d0474c43296f2bac56c5b40e1d50ab0022a28b1..d65b1921a9aeffd6906b95aa927a07a48f013b32:/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..3abbf6f6ac 100644 --- a/apps/workbench/test/integration/collections_test.rb +++ b/apps/workbench/test/integration/collections_test.rb @@ -147,4 +147,96 @@ 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") + # make sure that we actually are looking at the collections + # page and not e.g. a fiddlesticks + assert page.has_text?("multilevel_collection_1") + assert page.has_text?(col['portable_data_hash']) + + # 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_text?('could not be parsed as a regular expression') + assert page.has_no_text?("file1") + assert page.has_no_text?("file2") + assert page.has_no_text?("file3") + end end