end
def setup_instance
- if $options[:submit]
- @instance ||= PipelineInstance.
- create(:components => @components,
+ @instance ||= PipelineInstance.
+ create(:components => @components,
:pipeline_template_uuid => @template[:uuid],
- :active => true)
- else
- @instance ||= PipelineInstance.
- create(:components => @components,
- :pipeline_template_uuid => @template[:uuid],
- :state => 'RunningOnClient',
- :active => false)
- end
+ :state => 'RunningOnClient')
self
end
end
def self.queue
- self.where('active = true')
+ self.where("active = true or state = 'RunningOnClient'")
end
protected
end
elsif 'active'.in? changed_attributes
if self.active
- self.state = RunningOnServer
+ if self.state == New || self.state == Ready || self.state == Paused
+ self.state = RunningOnServer
+ end
else
if self.components_look_ready?
self.state = Ready
self.state = New
end
end
- elsif 'components'.in? changed_attributes
- if !self.state || self.state == New || !self.active
- if self.components_look_ready?
- self.state = Ready
- else
- self.state = New
- end
+ end
+
+ if 'components'.in? changed_attributes
+ if self.components_look_ready? && (!self.state || self.state == New)
+ self.state = Ready
end
end
end
def set_state_before_save
- if !self.state || self.state == New
+ if !self.state || self.state == New || self.state == Ready || self.state == Paused
if self.active
self.state = RunningOnServer
- elsif self.components_look_ready?
+ elsif self.components_look_ready? && (!self.state || self.state == New)
self.state = Ready
- else
- self.state = New
end
end
end