Merge branch '3187-start-finish-timestamps-tasks-pipelines' into 3187-pipeline-instan...
[arvados.git] / apps / workbench / app / models / job.rb
index 173d3a06964fb5667b9546aee4bab518baf3c190..309cadeb69554e1aac0a6dbeaa10b92d7adee30f 100644 (file)
@@ -1,8 +1,12 @@
 class Job < ArvadosBase
-  def self.goes_in_folders?
+  def self.goes_in_projects?
     true
   end
 
+  def content_summary
+    "#{script} job"
+  end
+
   def attribute_editable? attr, *args
     false
   end
@@ -11,7 +15,43 @@ class Job < ArvadosBase
     false
   end
 
+  def default_name
+    if script
+      x = "\"#{script}\" job"
+    else
+      x = super
+    end
+    if finished_at
+      x += " finished #{finished_at.strftime('%b %-d')}"
+    elsif started_at
+      x += " started #{started_at.strftime('%b %-d')}"
+    elsif created_at
+      x += " submitted #{created_at.strftime('%b %-d')}"
+    end
+  end
+
   def cancel
     arvados_api_client.api "jobs/#{self.uuid}/", "cancel", {}
   end
+
+  def state
+    Job::state(self)
+  end
+
+  def self.state job
+    if not job[:cancelled_at].nil?
+      "Canceled"
+    elsif not job[:finished_at].nil? or not job[:success].nil?
+      if job[:success]
+        "Completed"
+      else
+        "Failed"
+      end
+    elsif job[:running]
+      "Running"
+    else
+      "Queued"
+    end
+  end
+
 end