X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/ec56eaa573a3b46d5cb1c1c2f3e4374c3b30f866..50b746d9246c19c1ad2cf506bb18a0eb8ddd0755:/services/api/app/models/job_task.rb diff --git a/services/api/app/models/job_task.rb b/services/api/app/models/job_task.rb index d7aa09157c..7d568e952a 100644 --- a/services/api/app/models/job_task.rb +++ b/services/api/app/models/job_task.rb @@ -2,13 +2,35 @@ class JobTask < ArvadosModel include AssignUuid include KindAndEtag include CommonApiTemplate + serialize :parameters, Hash + after_update :delete_created_job_tasks_if_failed + after_update :assign_created_job_tasks_qsequence_if_succeeded - api_accessible :superuser, :extend => :common do |t| + api_accessible :user, extend: :common do |t| t.add :job_uuid + t.add :created_by_job_task_uuid t.add :sequence + t.add :qsequence t.add :parameters t.add :output t.add :progress t.add :success end + + protected + + def delete_created_job_tasks_if_failed + if self.success == false and self.success != self.success_was + JobTask.delete_all ['created_by_job_task_uuid = ?', self.uuid] + end + end + + def assign_created_job_tasks_qsequence_if_succeeded + if self.success == false and self.success != self.success_was + # xxx qsequence should be sequential as advertised; for now at + # least it's non-decreasing. + JobTask.update_all(['qsequence = ?', (Time.now.to_f*10000000).to_i], + ['created_by_job_task_uuid = ?', self.uuid]) + end + end end