Sha256: 2827e7f58ff0389d0f3381f8f1c0cbc0b1995570b56ae56fb9b62b8710371f0c

Contents?: true

Size: 1.3 KB

Versions: 5

Compression:

Stored size: 1.3 KB

Contents

module RailsPerformance
  module Models
    class RakeRecord < BaseRecord
      attr_accessor :task, :duration, :datetime, :datetimei, :status

      # rake|task|["task3"]|datetime|20210416T1254|datetimei|1618602843|status|error|END|1.0.0
      # {"duration":0.00012442}
      def self.from_db(key, value)
        items = key.split("|")

        RakeRecord.new(
          task: JSON.parse(items[2]),
          datetime: items[4],
          datetimei: items[6],
          status: items[8],
          json: value
        )
      end

      def initialize(task:, datetime:, datetimei:, status:, duration: nil, json: "{}")
        @task = Array.wrap(task)
        @datetime = datetime
        @datetimei = datetimei.to_i
        @status = status
        @duration = duration
        @json = json

        @duration ||= value["duration"]
      end

      def record_hash
        {
          task: task,
          datetime: RailsPerformance::Utils.from_datetimei(datetimei),
          datetimei: datetimei,
          duration: duration,
          status: status
        }
      end

      def save
        key = "rake|task|#{task.to_json}|datetime|#{datetime}|datetimei|#{datetimei}|status|#{status}|END|#{RailsPerformance::SCHEMA}"
        value = {duration: duration}
        Utils.save_to_redis(key, value)
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
rails_performance-1.4.1 lib/rails_performance/models/rake_record.rb
rails_performance-1.4.1.alpha1 lib/rails_performance/models/rake_record.rb
rails_performance-1.4.0 lib/rails_performance/models/rake_record.rb
rails_performance-1.4.0.alpha5 lib/rails_performance/models/rake_record.rb
rails_performance-1.4.0.alpha4 lib/rails_performance/models/rake_record.rb