- # Verify that the newly created instance is created in the right
- # project. In case of project_viewer user, since the user cannot
- # write to the project, the pipeline should have been created in
- # the user's Home project.
- assert_not_equal path, current_path, 'Rerun instance path expected to be different'
- assert_text 'Home'
- if in_aproject && (user != 'project_viewer')
- assert_text 'A Project'
- else
- assert_no_text 'A Project'
- end
- end
- end
-
- # Create and run a pipeline for 'Two Part Pipeline Template' in 'A Project'
- def create_and_run_pipeline_in_aproject in_aproject, template_name, collection_fixture, choose_file=false
- # collection in aproject to be used as input
- collection = api_fixture('collections', collection_fixture)
-
- # create a pipeline instance
- find('.btn', text: 'Run a pipeline').click
- within('.modal-dialog') do
- find('.selectable', text: template_name).click
- find('.btn', text: 'Next: choose inputs').click
- end
-
- assert find('p', text: 'Provide a value')
-
- find('div.form-group', text: 'Foo/bar pair').
- find('.btn', text: 'Choose').
- click
-
- within('.modal-dialog') do
- if in_aproject
- assert_selector 'button.dropdown-toggle', text: 'A Project'
- wait_for_ajax
- else
- assert_selector 'button.dropdown-toggle', text: 'Home'
- wait_for_ajax
- click_button "Home"
- click_link "A Project"
- wait_for_ajax
- end
-
- if collection_fixture == 'foo_collection_in_aproject'
- first('span', text: 'foo_tag').click
- elsif collection['name']
- first('span', text: "#{collection['name']}").click
- else
- collection_uuid = collection['uuid']
- find("div[data-object-uuid=#{collection_uuid}]").click
- end
-
- if choose_file
- wait_for_ajax
- find('.preview-selectable', text: 'foo').click
- end
- find('button', text: 'OK').click
- end
-
- # The input, after being specified, should still be displayed (#3382)
- assert find('div.form-group', text: 'Foo/bar pair')
-
- # Ensure that the collection's portable_data_hash, uuid and name
- # are saved in the desired places. (#4015)
- click_link 'Advanced'
- click_link 'API response'
-
- api_response = JSON.parse(find('div#advanced_api_response pre').text)
- input_params = api_response['components']['part-one']['script_parameters']['input']
- assert_equal(input_params['selection_uuid'], collection['uuid'], "Not found expected input param uuid")
- if choose_file
- assert_equal(input_params['value'], collection['portable_data_hash']+'/foo', "Not found expected input file param value")
- assert_equal(input_params['selection_name'], collection['name']+'/foo', "Not found expected input file param name")
- else
- assert_equal(input_params['value'], collection['portable_data_hash'], "Not found expected input param value")
- assert_equal(input_params['selection_name'], collection['name'], "Not found expected input selection name")
- end
-
- # "Run" button present and enabled
- page.assert_no_selector 'a.disabled,button.disabled', text: 'Run'
- first('a,button', text: 'Run').click
-
- # Pipeline is running. We have a "Pause" button instead now.
- page.assert_no_selector 'a,button', text: 'Run'
- page.assert_no_selector 'a.disabled,button.disabled', text: 'Resume'
- page.assert_selector 'a,button', text: 'Pause'
-
- # Since it is test env, no jobs are created to run. So, graph not visible
- assert_not page.has_text? 'Graph'
- end
-
- [
- [1, 0], # run time 0 minutes
- [10, 17*60*60 + 51*60], # run time 17 hours and 51 minutes
- ].each do |index, run_time|
- test "pipeline start and finish time display #{index}" do
- visit page_with_token("user1_with_load", "/pipeline_instances/zzzzz-d1hrv-10pipelines0#{index.to_s.rjust(3, '0')}")
-
- assert page.has_text? 'This pipeline started at'
- page_text = page.text
-
- match = /This pipeline started at (.*)\. It failed after (.*) seconds at (.*)\. Check the Log/.match page_text
- assert_not_nil(match, 'Did not find text - This pipeline started at . . . ')
-
- start_at = match[1]
- finished_at = match[3]
- assert_not_nil(start_at, 'Did not find start_at time')
- assert_not_nil(finished_at, 'Did not find finished_at time')
-
- # start and finished time display is of the format '2:20 PM 10/20/2014'
- start_time = DateTime.strptime(start_at, '%H:%M %p %m/%d/%Y').to_time
- finished_time = DateTime.strptime(finished_at, '%H:%M %p %m/%d/%Y').to_time
- assert_equal(run_time, finished_time-start_time,
- "Time difference did not match for start_at #{start_at}, finished_at #{finished_at}, ran_for #{match[2]}")