X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/ed413bb7071fe0d58a98828e89be21fef5681200..a95f899d7ac84f29b3d019aa410d265bb40833e5:/apps/workbench/app/models/job.rb diff --git a/apps/workbench/app/models/job.rb b/apps/workbench/app/models/job.rb index a0247ef104..73f1f63be4 100644 --- a/apps/workbench/app/models/job.rb +++ b/apps/workbench/app/models/job.rb @@ -7,16 +7,8 @@ class Job < ArvadosBase "#{script} job" end - def attribute_editable? attr, *args - if attr.to_sym == :description - super && attr.to_sym == :description - else - false - end - end - - def self.creatable? - false + def editable_attributes + %w(description) end def default_name @@ -42,27 +34,27 @@ class Job < ArvadosBase arvados_api_client.api("jobs/", "queue_size", {"_method"=> "GET"})[:queue_size] rescue 0 end - def self.state job - if job.respond_to? :state and job.state - return job.state - end - - if not job[:cancelled_at].nil? - "Cancelled" - 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 + def self.queue + arvados_api_client.unpack_api_response arvados_api_client.api("jobs/", "queue", {"_method"=> "GET"}) end def textile_attributes [ 'description' ] end + + def stderr_log_query(limit=nil) + query = Log.where(event_type: "stderr", object_uuid: self.uuid) + .order("id DESC") + query = query.limit(limit) if limit + query + end + + def stderr_log_lines(limit=2000) + stderr_log_query(limit).results.reverse. + flat_map { |log| log.properties[:text].split("\n") rescue [] } + end + + def work_unit(label=nil) + JobWorkUnit.new(self, label) + end end