rosa-build/app/models/product_build_list.rb

181 lines
5.4 KiB
Ruby
Raw Normal View History

2012-01-30 20:39:34 +00:00
# -*- encoding : utf-8 -*-
class ProductBuildList < ActiveRecord::Base
2012-11-06 14:13:16 +00:00
include Modules::Models::CommitAndVersion
include Modules::Models::TimeLiving
include Modules::Models::FileStoreClean
include Modules::Models::UrlHelper
include AbfWorker::ModelHelper
2012-11-07 14:32:46 +00:00
delegate :url_helpers, to: 'Rails.application.routes'
2012-11-06 14:13:16 +00:00
LIVE_TIME = 2.week # for autostart
MAX_LIVE_TIME = 3.month # for manual start;
BUILD_COMPLETED = 0
BUILD_FAILED = 1
BUILD_PENDING = 2
BUILD_STARTED = 3
BUILD_CANCELED = 4
BUILD_CANCELING = 5
STATUSES = [ BUILD_STARTED,
BUILD_COMPLETED,
BUILD_FAILED,
2012-11-19 16:38:08 +00:00
BUILD_PENDING,
2012-11-19 15:41:59 +00:00
BUILD_CANCELED,
BUILD_CANCELING
2013-04-04 12:27:51 +01:00
].freeze
HUMAN_STATUSES = { BUILD_STARTED => :build_started,
BUILD_COMPLETED => :build_completed,
BUILD_FAILED => :build_failed,
2012-11-19 16:38:08 +00:00
BUILD_PENDING => :build_pending,
2012-11-19 15:41:59 +00:00
BUILD_CANCELED => :build_canceled,
BUILD_CANCELING => :build_canceling
2013-04-04 12:27:51 +01:00
}.freeze
belongs_to :product
2012-11-06 14:13:16 +00:00
belongs_to :project
belongs_to :arch
belongs_to :user
2012-11-06 14:13:16 +00:00
# see: Issue #6
before_validation lambda { self.arch_id = Arch.find_by_name('x86_64').id }, :on => :create
# field "not_delete" can be changed only if build has been completed
before_validation lambda { self.not_delete = false unless build_completed?; true }
validates :product_id,
:status,
:project_id,
:main_script,
:arch_id, :presence => true
validates :status, :inclusion => { :in => STATUSES }
validates :main_script, :params, :length => { :maximum => 255 }
attr_accessor :base_url
2012-11-13 09:27:39 +00:00
attr_accessible :status,
:base_url,
:branch,
:project_id,
:main_script,
:params,
:project_version,
:commit_hash,
:product_id,
:not_delete
attr_readonly :product_id
2012-11-08 21:39:42 +00:00
serialize :results, Array
2013-02-28 15:27:50 +00:00
scope :default_order, order("#{table_name}.updated_at DESC")
scope :for_status, lambda {|status| where(:status => status) }
scope :for_user, lambda { |user| where(:user_id => user.id) }
scope :scoped_to_product_name, lambda {|product_name| joins(:product).where('products.name LIKE ?', "%#{product_name}%")}
scope :recent, order("#{table_name}.updated_at DESC")
scope :outdated, where(:not_delete => false).
where("(#{table_name}.created_at < ? AND #{table_name}.autostarted is TRUE) OR #{table_name}.created_at < ?", Time.now - LIVE_TIME, Time.now - MAX_LIVE_TIME)
after_create :add_job_to_abf_worker_queue
before_destroy :can_destroy?
state_machine :status, :initial => :build_pending do
event :start_build do
transition :build_pending => :build_started
end
event :cancel do
transition [:build_pending, :build_started] => :build_canceling
end
2013-01-24 06:33:16 +00:00
after_transition :on => :cancel, :do => :cancel_job
# :build_canceling => :build_canceled - canceling from UI
# :build_started => :build_canceled - canceling from worker by time-out (time_living has been expired)
event :build_canceled do
2012-12-07 09:10:38 +00:00
transition [:build_canceling, :build_started] => :build_canceled
end
2013-02-05 12:10:10 +00:00
# :build_canceling => :build_completed - Worker hasn't time to cancel building because build had been already completed
event :build_success do
2013-02-05 11:44:06 +00:00
transition [:build_started, :build_canceling] => :build_completed
end
2013-02-05 12:10:10 +00:00
# :build_canceling => :build_failed - Worker hasn't time to cancel building because build had been already failed
event :build_error do
2013-02-05 12:05:02 +00:00
transition [:build_started, :build_canceling] => :build_failed
end
HUMAN_STATUSES.each do |code,name|
state name, :value => code
end
end
2012-11-09 17:42:25 +00:00
def build_started?
status == BUILD_STARTED
end
2012-11-19 15:41:59 +00:00
def build_canceling?
status == BUILD_CANCELING
end
def can_cancel?
[BUILD_STARTED, BUILD_PENDING].include? status
end
def event_log_message
{:product => product.name}.inspect
end
def self.human_status(status)
I18n.t("layout.product_build_lists.statuses.#{HUMAN_STATUSES[status]}")
end
def human_status
self.class.human_status(status)
end
def can_destroy?
2012-11-19 16:38:08 +00:00
[BUILD_COMPLETED, BUILD_FAILED, BUILD_CANCELED].include? status
end
def sha1_of_file_store_files
(results || []).map{ |r| r['sha1'] }.compact
end
protected
2012-12-28 14:00:37 +00:00
def abf_worker_priority
''
2012-12-28 14:00:37 +00:00
end
def abf_worker_base_queue
'iso_worker'
end
def abf_worker_args
file_name = "#{project.name}-#{commit_hash}"
opts = default_url_options
opts.merge!({:user => user.authentication_token, :password => ''}) if user.present?
2012-11-08 13:04:02 +00:00
srcpath = url_helpers.archive_url(
project.owner,
project.name,
file_name,
'tar.gz',
opts
2012-11-08 13:04:02 +00:00
)
{
2012-11-07 14:32:46 +00:00
:id => id,
2012-11-12 09:41:41 +00:00
# TODO: remove comment
2012-11-19 15:48:14 +00:00
# :srcpath => 'http://dl.dropbox.com/u/945501/avokhmin-test-iso-script-5d9b463d4e9c06ea8e7c89e1b7ff5cb37e99e27f.tar.gz',
:srcpath => srcpath,
2012-11-07 14:32:46 +00:00
:params => params,
:time_living => time_living,
:main_script => main_script,
:platform => {
:type => product.platform.distrib_type,
:name => product.platform.name,
:arch => arch.name
},
:user => {:uname => user.try(:uname), :email => user.try(:email)}
2012-11-07 14:32:46 +00:00
}
end
end