X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/d3b76845c740935f7474f535d308303c748b0b4a..e2149a153e3432c24320b7574934a5f1f4040df7:/services/api/app/models/container.rb diff --git a/services/api/app/models/container.rb b/services/api/app/models/container.rb index d6a44c8023..3e3f73b838 100644 --- a/services/api/app/models/container.rb +++ b/services/api/app/models/container.rb @@ -23,6 +23,7 @@ class Container < ArvadosModel attribute :runtime_status, :jsonbHash, default: {} attribute :runtime_auth_scopes, :jsonbArray, default: [] attribute :output_storage_classes, :jsonbArray, default: lambda { Rails.configuration.DefaultStorageClasses } + attribute :output_properties, :jsonbHash, default: {} serialize :environment, Hash serialize :mounts, Hash @@ -81,6 +82,9 @@ class Container < ArvadosModel t.add :gateway_address t.add :interactive_session_started t.add :output_storage_classes + t.add :output_properties + t.add :cost + t.add :subrequests_cost end # Supported states for a container @@ -289,7 +293,21 @@ class Container < ArvadosModel candidates = candidates.where('secret_mounts_md5 = ?', secret_mounts_md5) log_reuse_info(candidates) { "after filtering on secret_mounts_md5 #{secret_mounts_md5.inspect}" } - candidates = candidates.where_serialized(:runtime_constraints, resolve_runtime_constraints(attrs[:runtime_constraints]), md5: true) + if attrs[:runtime_constraints]['cuda'].nil? + attrs[:runtime_constraints]['cuda'] = { + 'device_count' => 0, + 'driver_version' => '', + 'hardware_capability' => '', + } + end + resolved_runtime_constraints = [resolve_runtime_constraints(attrs[:runtime_constraints])] + if resolved_runtime_constraints[0]['cuda']['device_count'] == 0 + # If no CUDA requested, extend search to include older container + # records that don't have a 'cuda' section in runtime_constraints + resolved_runtime_constraints << resolved_runtime_constraints[0].except('cuda') + end + + candidates = candidates.where_serialized(:runtime_constraints, resolved_runtime_constraints, md5: true, multivalue: true) log_reuse_info(candidates) { "after filtering on runtime_constraints #{attrs[:runtime_constraints].inspect}" } log_reuse_info { "checking for state=Complete with readable output and log..." } @@ -462,8 +480,9 @@ class Container < ArvadosModel def validate_change permitted = [:state] - progress_attrs = [:progress, :runtime_status, :log, :output] - final_attrs = [:exit_code, :finished_at] + final_attrs = [:finished_at] + progress_attrs = [:progress, :runtime_status, :subrequests_cost, :cost, + :log, :output, :output_properties, :exit_code] if self.new_record? permitted.push(:owner_uuid, :command, :container_image, :cwd, @@ -482,9 +501,9 @@ class Container < ArvadosModel permitted.push :priority when Running - permitted.push :priority, *progress_attrs + permitted.push :priority, :output_properties, :gateway_address, *progress_attrs if self.state_changed? - permitted.push :started_at, :gateway_address + permitted.push :started_at end if !self.interactive_session_started_was permitted.push :interactive_session_started @@ -500,7 +519,7 @@ class Container < ArvadosModel when Running permitted.push :finished_at, *progress_attrs when Queued, Locked - permitted.push :finished_at, :log, :runtime_status + permitted.push :finished_at, :log, :runtime_status, :cost end else @@ -703,6 +722,7 @@ class Container < ArvadosModel cr.with_lock do leave_modified_by_user_alone do # Use row locking because this increments container_count + cr.cumulative_cost += self.cost + self.subrequests_cost cr.container_uuid = c.uuid cr.save! end