27b9269032de6af5a5f1317e0db590d1e0c51fea
[arvados.git] / apps / workbench / test / integration / collections_test.rb
1 require 'integration_helper'
2 require 'selenium-webdriver'
3 require 'headless'
4
5 class CollectionsTest < ActionDispatch::IntegrationTest
6   setup do
7     Capybara.current_driver = Capybara.javascript_driver
8   end
9
10   test "Collection page renders name" do
11     uuid = api_fixture('collections')['foo_file']['uuid']
12     coll_name = api_fixture('collections')['foo_file']['name']
13     visit page_with_token('active', "/collections/#{uuid}")
14     assert(page.has_text?(coll_name), "Collection page did not include name")
15     # Now check that the page is otherwise normal, and the collection name
16     # isn't only showing up in an error message.
17     assert(page.has_link?('foo'), "Collection page did not include file link")
18   end
19
20   test "can download an entire collection with a reader token" do
21     Capybara.current_driver = :rack_test
22
23     uuid = api_fixture('collections')['foo_file']['uuid']
24     token = api_fixture('api_client_authorizations')['active_all_collections']['api_token']
25     url_head = "/collections/download/#{uuid}/#{token}/"
26     visit url_head
27     # It seems that Capybara can't inspect tags outside the body, so this is
28     # a very blunt approach.
29     assert_no_match(/<\s*meta[^>]+\bnofollow\b/i, page.html,
30                     "wget prohibited from recursing the collection page")
31     # TODO: When we can test against a Keep server, actually follow links
32     # and check their contents, rather than testing the href directly
33     # (this is too closely tied to implementation details).
34     hrefs = page.all('a').map do |anchor|
35       link = anchor[:href] || ''
36       if link.start_with? url_head
37         link[url_head.size .. -1]
38       elsif link.start_with? '/'
39         nil
40       else
41         link
42       end
43     end
44     assert_equal(['foo'], hrefs.compact.sort,
45                  "download page did provide strictly file links")
46   end
47
48   test "can view empty collection" do
49     uuid = 'd41d8cd98f00b204e9800998ecf8427e+0'
50     visit page_with_token('active', "/collections/#{uuid}")
51     assert page.has_text?('This collection is empty')
52   end
53
54   test "combine selected collections into new collection" do
55     foo_collection_uuid = api_fixture('collections')['foo_file']['uuid']
56     bar_collection_uuid = api_fixture('collections')['bar_file']['uuid']
57
58     visit page_with_token('active', "/collections")
59
60     assert(page.has_text?(foo_collection_uuid), "Collection page did not include foo file")
61     assert(page.has_text?(bar_collection_uuid), "Collection page did not include bar file")
62
63     within('tr', text: foo_collection_uuid) do
64       find('input[type=checkbox]').click
65     end
66
67     within('tr', text: bar_collection_uuid) do
68       find('input[type=checkbox]').click
69     end
70
71     click_button 'Selection...'
72     within('.selection-action-container') do
73       click_link 'Combine selections into a new collection'
74     end
75
76     # back in collections page
77     assert(page.has_text?(foo_collection_uuid), "Collection page did not include foo file")
78     assert(page.has_text?(bar_collection_uuid), "Collection page did not include bar file")
79   end
80
81   test "combine selected collection contents into new collection" do
82     foo_collection = api_fixture('collections')['foo_file']
83    # bar_collection = api_fixture('collections')['bar_file']
84    # pdh_collection = api_fixture('collections')['multilevel_collection_1']
85
86     visit page_with_token('active', "/collections")
87
88     # choose file from foo collection
89     within('tr', text: foo_collection['uuid']) do
90       click_link 'Show'
91     end
92
93     # now in collection page
94     find('input[type=checkbox]').click
95
96     click_button 'Selection...'
97     within('.selection-action-container') do
98       click_link 'Combine selections into a new collection'
99     end
100
101     # go back to collections page
102     visit page_with_token('active', "/collections")
103   end
104 end