X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/6386f2aca83b477210bda19a3284ea31463d2efc..a87fd176c3248699cbaaa45b815c8a34b3f5f11b:/apps/workbench/app/models/job.rb diff --git a/apps/workbench/app/models/job.rb b/apps/workbench/app/models/job.rb index 309cadeb69..73f1f63be4 100644 --- a/apps/workbench/app/models/job.rb +++ b/apps/workbench/app/models/job.rb @@ -7,12 +7,8 @@ class Job < ArvadosBase "#{script} job" end - def attribute_editable? attr, *args - false - end - - def self.creatable? - false + def editable_attributes + %w(description) end def default_name @@ -34,24 +30,31 @@ class Job < ArvadosBase arvados_api_client.api "jobs/#{self.uuid}/", "cancel", {} end - def state - Job::state(self) + def self.queue_size + arvados_api_client.api("jobs/", "queue_size", {"_method"=> "GET"})[:queue_size] rescue 0 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 + 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