class PipelineInstanceTest < ActiveSupport::TestCase
- test "check active and success for a pipeline in new state" do
- pi = pipeline_instances :new_pipeline
-
- assert_equal 'New', pi.state, 'expected state to be New for :new_pipeline'
-
- # save the pipeline and expect state to be New
- Thread.current[:user] = users(:admin)
-
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::New, pi.state, 'expected state to be New for new pipeline'
- end
-
- test "check active and success for a newly created pipeline" do
- set_user_from_auth :active
-
- pi = PipelineInstance.create(state: 'Ready')
- pi.save
-
- assert pi.valid?, 'expected newly created empty pipeline to be valid ' + pi.errors.messages.to_s
- assert_equal 'Ready', pi.state, 'expected state to be Ready for a new empty pipeline'
- end
-
- test "update attributes for pipeline" do
- Thread.current[:user] = users(:admin)
-
- pi = pipeline_instances :new_pipeline
-
- # add a component with no input and expect state to be New
- component = {'script_parameters' => {"input_not_provided" => {"required" => true}}}
- pi.components['first'] = component
- components = pi.components
- pi.update_attribute 'components', pi.components
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::New, pi.state, 'expected state to be New after adding component with input'
- assert_equal pi.components.size, 1, 'expected one component'
- assert_nil pi.started_at, 'expected started_at to be nil on new pipeline instance'
- assert_nil pi.finished_at, 'expected finished_at to be nil on new pipeline instance'
-
- # add a component with no input not required
- component = {'script_parameters' => {"input_not_provided" => {"required" => false}}}
- pi.components['first'] = component
- components = pi.components
- pi.update_attribute 'components', pi.components
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Ready, pi.state, 'expected state to be Ready after adding component with input'
- assert_equal pi.components.size, 1, 'expected one component'
-
- # add a component with input and expect state to become Ready
- component = {'script_parameters' => {"input" => "yyyad4b39ca5a924e481008009d94e32+210"}}
- pi.components['first'] = component
- components = pi.components
- pi.update_attribute 'components', pi.components
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Ready, pi.state, 'expected state to be Ready after adding component with input'
- assert_equal pi.components.size, 1, 'expected one component'
-
- pi.state = PipelineInstance::RunningOnServer
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::RunningOnServer, pi.state, 'expected state to be RunningOnServer after updating state to RunningOnServer'
- assert_not_nil pi.started_at, 'expected started_at to have a value on a running pipeline instance'
- assert_nil pi.finished_at, 'expected finished_at to be nil on a running pipeline instance'
-
- pi.state = PipelineInstance::Paused
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Paused, pi.state, 'expected state to be Paused after updating state to Paused'
-
- pi.state = PipelineInstance::Complete
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Complete, pi.state, 'expected state to be Complete after updating state to Complete'
- assert_not_nil pi.started_at, 'expected started_at to have a value on a completed pipeline instance'
- assert_not_nil pi.finished_at, 'expected finished_at to have a value on a completed pipeline instance'
-
- pi.state = 'bogus'
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Complete, pi.state, 'expected state to be unchanged with set to a bogus value'
-
- pi.state = PipelineInstance::Failed
- pi.save
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::Failed, pi.state, 'expected state to be Failed after updating state to Failed'
- assert_not_nil pi.started_at, 'expected started_at to have a value on a failed pipeline instance'
- assert_not_nil pi.finished_at, 'expected finished_at to have a value on a failed pipeline instance'
- end
-
- test "update attributes for pipeline with two components" do
- pi = pipeline_instances :new_pipeline
-
- # add two components, one with input and one with no input and expect state to be New
- component1 = {'script_parameters' => {"something" => "xxxad4b39ca5a924e481008009d94e32+210", "input" => "c1bad4b39ca5a924e481008009d94e32+210"}}
- component2 = {'script_parameters' => {"something_else" => "xxxad4b39ca5a924e481008009d94e32+210", "input_missing" => {"required" => true}}}
- pi.components['first'] = component1
- pi.components['second'] = component2
-
- Thread.current[:user] = users(:admin)
- pi.update_attribute 'components', pi.components
-
- pi = PipelineInstance.find_by_uuid 'zzzzz-d1hrv-f4gneyn6br1xize'
- assert_equal PipelineInstance::New, pi.state, 'expected state to be New after adding component with input'
- assert_equal pi.components.size, 2, 'expected two components'
- end
-
[:has_component_with_no_script_parameters,
:has_component_with_empty_script_parameters].each do |pi_name|
test "update pipeline that #{pi_name}" do