X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2b0a7c3f635bc2340956d670c6aeda417dd11cec..d77bf0c67422a259afacc17660698729328a1ed3:/apps/workbench/app/models/job.rb diff --git a/apps/workbench/app/models/job.rb b/apps/workbench/app/models/job.rb index d3d38b0b2d..6566aeb7cd 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,31 +34,23 @@ class Job < ArvadosBase arvados_api_client.api("jobs/", "queue_size", {"_method"=> "GET"})[:queue_size] rescue 0 end - def self.queue + def self.queue arvados_api_client.unpack_api_response arvados_api_client.api("jobs/", "queue", {"_method"=> "GET"}) end - def self.state job - if job.respond_to? :state and job.state - return job.state - end + def textile_attributes + [ 'description' ] + 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 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 textile_attributes - [ 'description' ] + def stderr_log_lines(limit=2000) + stderr_log_query(limit).results.reverse. + flat_map { |log| log.properties[:text].split("\n") rescue [] } end end