2012-01-30 20:39:34 +00:00
|
|
|
# -*- encoding : utf-8 -*-
|
2011-04-07 14:20:21 +01:00
|
|
|
class BuildList < ActiveRecord::Base
|
2012-11-06 14:13:16 +00:00
|
|
|
include Modules::Models::CommitAndVersion
|
2013-01-22 14:34:16 +00:00
|
|
|
include Modules::Models::FileStoreClean
|
2012-12-06 14:41:24 +00:00
|
|
|
include AbfWorker::ModelHelper
|
2013-06-27 15:37:41 +01:00
|
|
|
include Modules::Observers::ActivityFeed::BuildList
|
2012-11-06 14:13:16 +00:00
|
|
|
|
2011-04-07 14:20:21 +01:00
|
|
|
belongs_to :project
|
|
|
|
belongs_to :arch
|
2013-10-17 19:00:15 +01:00
|
|
|
belongs_to :save_to_platform, :class_name => 'Platform'
|
2012-07-27 17:01:26 +01:00
|
|
|
belongs_to :save_to_repository, :class_name => 'Repository'
|
2012-05-04 18:12:51 +01:00
|
|
|
belongs_to :build_for_platform, :class_name => 'Platform'
|
2011-12-20 17:09:29 +00:00
|
|
|
belongs_to :user
|
2013-10-17 19:00:15 +01:00
|
|
|
belongs_to :builder, :class_name => 'User'
|
|
|
|
belongs_to :publisher, :class_name => 'User'
|
2012-05-04 18:12:51 +01:00
|
|
|
belongs_to :advisory
|
2012-06-22 16:10:44 +01:00
|
|
|
belongs_to :mass_build, :counter_cache => true
|
2012-05-14 20:08:31 +01:00
|
|
|
has_many :items, :class_name => "BuildList::Item", :dependent => :destroy
|
|
|
|
has_many :packages, :class_name => "BuildList::Package", :dependent => :destroy
|
2013-07-04 19:25:07 +01:00
|
|
|
has_many :source_packages, :class_name => "BuildList::Package", :conditions => {:package_type => 'source'}
|
2012-05-04 18:12:51 +01:00
|
|
|
|
2013-05-30 09:49:21 +01:00
|
|
|
UPDATE_TYPES = %w[bugfix security enhancement recommended newpackage]
|
|
|
|
RELEASE_UPDATE_TYPES = %w[bugfix security]
|
2013-09-20 19:21:23 +01:00
|
|
|
EXTRA_PARAMS = %w[cfg_options build_src_rpm build_rpm]
|
2013-10-17 19:00:15 +01:00
|
|
|
EXTERNAL_NODES = %w[owned everything]
|
2012-05-04 18:12:51 +01:00
|
|
|
|
2012-07-27 17:01:26 +01:00
|
|
|
validates :project_id, :project_version, :arch, :include_repos,
|
|
|
|
:build_for_platform_id, :save_to_platform_id, :save_to_repository_id, :presence => true
|
2012-05-14 20:08:31 +01:00
|
|
|
validates_numericality_of :priority, :greater_than_or_equal_to => 0
|
2013-10-17 19:00:15 +01:00
|
|
|
validates :external_nodes, :inclusion => {:in => EXTERNAL_NODES}, :allow_blank => true
|
2012-05-04 18:12:51 +01:00
|
|
|
validates :update_type, :inclusion => UPDATE_TYPES,
|
2012-07-06 00:05:47 +01:00
|
|
|
:unless => Proc.new { |b| b.advisory.present? }
|
2012-05-24 11:21:57 +01:00
|
|
|
validates :update_type, :inclusion => {:in => RELEASE_UPDATE_TYPES, :message => I18n.t('flash.build_list.frozen_platform')},
|
2012-07-06 00:05:47 +01:00
|
|
|
:if => Proc.new { |b| b.advisory.present? }
|
2012-05-24 11:21:57 +01:00
|
|
|
validate lambda {
|
2013-02-04 09:09:43 +00:00
|
|
|
errors.add(:build_for_platform, I18n.t('flash.build_list.wrong_platform')) if save_to_platform.main? && save_to_platform_id != build_for_platform_id
|
2011-10-22 16:28:41 +01:00
|
|
|
}
|
2012-11-20 16:14:51 +00:00
|
|
|
validate lambda {
|
2013-02-04 09:09:43 +00:00
|
|
|
errors.add(:build_for_platform, I18n.t('flash.build_list.wrong_build_for_platform')) unless build_for_platform.main?
|
2012-11-20 16:14:51 +00:00
|
|
|
}
|
2012-07-27 17:01:26 +01:00
|
|
|
validate lambda {
|
2013-07-05 09:18:39 +01:00
|
|
|
errors.add(:save_to_repository, I18n.t('flash.build_list.wrong_repository')) if save_to_repository.platform_id != save_to_platform.id
|
2012-07-30 20:25:57 +01:00
|
|
|
}
|
2012-09-04 13:44:28 +01:00
|
|
|
validate lambda {
|
2013-07-05 09:18:39 +01:00
|
|
|
errors.add(:save_to_repository, I18n.t('flash.build_list.wrong_include_repos')) if build_for_platform.repositories.where(:id => include_repos).count != include_repos.size
|
2012-09-04 13:44:28 +01:00
|
|
|
}
|
2012-12-26 13:06:17 +00:00
|
|
|
validate lambda {
|
|
|
|
errors.add(:save_to_repository, I18n.t('flash.build_list.wrong_project')) unless save_to_repository.projects.exists?(project_id)
|
|
|
|
}
|
2013-07-09 11:36:35 +01:00
|
|
|
before_validation lambda { self.include_repos = include_repos.uniq if include_repos.present? }, :on => :create
|
2013-02-22 11:04:14 +00:00
|
|
|
before_validation :prepare_extra_repositories, :on => :create
|
|
|
|
before_validation :prepare_extra_build_lists, :on => :create
|
2013-09-20 19:21:23 +01:00
|
|
|
before_validation :prepare_extra_params, :on => :create
|
2013-10-17 19:00:15 +01:00
|
|
|
before_validation lambda { self.auto_publish = false if external_nodes.present?; true }, :on => :create
|
2012-12-26 13:06:17 +00:00
|
|
|
|
2012-12-25 03:09:26 +00:00
|
|
|
attr_accessible :include_repos, :auto_publish, :build_for_platform_id, :commit_hash,
|
|
|
|
:arch_id, :project_id, :save_to_repository_id, :update_type,
|
2013-05-27 19:13:00 +01:00
|
|
|
:save_to_platform_id, :project_version, :auto_create_container,
|
2013-10-17 19:00:15 +01:00
|
|
|
:extra_repositories, :extra_build_lists, :extra_params, :external_nodes
|
2012-10-11 11:55:06 +01:00
|
|
|
LIVE_TIME = 4.week # for unpublished
|
2012-08-06 16:35:11 +01:00
|
|
|
MAX_LIVE_TIME = 3.month # for published
|
2012-05-11 18:44:19 +01:00
|
|
|
|
2013-01-24 11:32:00 +00:00
|
|
|
SUCCESS = 0
|
|
|
|
ERROR = 1
|
|
|
|
|
|
|
|
PROJECT_SOURCE_ERROR = 6
|
|
|
|
DEPENDENCIES_ERROR = 555
|
|
|
|
BUILD_ERROR = 666
|
|
|
|
BUILD_STARTED = 3000
|
|
|
|
BUILD_CANCELED = 5000
|
|
|
|
WAITING_FOR_RESPONSE = 4000
|
|
|
|
BUILD_PENDING = 2000
|
|
|
|
BUILD_PUBLISHED = 6000
|
|
|
|
BUILD_PUBLISH = 7000
|
|
|
|
FAILED_PUBLISH = 8000
|
|
|
|
REJECTED_PUBLISH = 9000
|
|
|
|
BUILD_CANCELING = 10000
|
2013-02-05 18:49:26 +00:00
|
|
|
TESTS_FAILED = 11000
|
2011-04-11 17:37:09 +01:00
|
|
|
|
2011-12-12 12:34:20 +00:00
|
|
|
STATUSES = [ WAITING_FOR_RESPONSE,
|
|
|
|
BUILD_CANCELED,
|
|
|
|
BUILD_PENDING,
|
|
|
|
BUILD_PUBLISHED,
|
2012-12-06 14:41:24 +00:00
|
|
|
BUILD_CANCELING,
|
2011-12-22 00:53:55 +00:00
|
|
|
BUILD_PUBLISH,
|
|
|
|
FAILED_PUBLISH,
|
2012-04-17 19:18:39 +01:00
|
|
|
REJECTED_PUBLISH,
|
2013-01-24 11:32:00 +00:00
|
|
|
SUCCESS,
|
|
|
|
BUILD_STARTED,
|
|
|
|
BUILD_ERROR,
|
2013-02-05 18:49:26 +00:00
|
|
|
TESTS_FAILED
|
2013-04-04 12:12:07 +01:00
|
|
|
].freeze
|
2011-04-07 15:56:28 +01:00
|
|
|
|
2011-12-12 12:34:20 +00:00
|
|
|
HUMAN_STATUSES = { WAITING_FOR_RESPONSE => :waiting_for_response,
|
2011-12-12 16:16:05 +00:00
|
|
|
BUILD_CANCELED => :build_canceled,
|
2012-12-06 14:41:24 +00:00
|
|
|
BUILD_CANCELING => :build_canceling,
|
2011-04-07 15:56:28 +01:00
|
|
|
BUILD_PENDING => :build_pending,
|
2011-12-12 12:34:20 +00:00
|
|
|
BUILD_PUBLISHED => :build_published,
|
2011-12-22 00:53:55 +00:00
|
|
|
BUILD_PUBLISH => :build_publish,
|
|
|
|
FAILED_PUBLISH => :failed_publish,
|
2012-04-17 19:18:39 +01:00
|
|
|
REJECTED_PUBLISH => :rejected_publish,
|
2013-01-24 11:32:00 +00:00
|
|
|
BUILD_ERROR => :build_error,
|
|
|
|
BUILD_STARTED => :build_started,
|
|
|
|
SUCCESS => :success,
|
2013-02-05 18:49:26 +00:00
|
|
|
TESTS_FAILED => :tests_failed
|
2013-04-04 12:12:07 +01:00
|
|
|
}.freeze
|
2011-04-07 14:20:21 +01:00
|
|
|
|
2011-12-13 13:00:15 +00:00
|
|
|
scope :recent, order("#{table_name}.updated_at DESC")
|
2013-06-05 14:48:11 +01:00
|
|
|
scope :for_extra_build_lists, lambda {|ids, current_ability, save_to_platform|
|
|
|
|
s = scoped
|
|
|
|
s = s.where(:id => ids).published_container.accessible_by(current_ability, :read)
|
|
|
|
s = s.where(:save_to_platform_id => save_to_platform.id) if save_to_platform && save_to_platform.main?
|
|
|
|
s
|
|
|
|
}
|
2013-07-04 19:25:07 +01:00
|
|
|
scope :for_status, lambda {|status| where(:status => status) if status.present? }
|
2012-03-05 09:11:50 +00:00
|
|
|
scope :for_user, lambda { |user| where(:user_id => user.id) }
|
2013-10-17 19:00:15 +01:00
|
|
|
scope :not_owned_external_nodes, where("#{table_name}.external_nodes is null OR #{table_name}.external_nodes != ?", :owned)
|
|
|
|
scope :external_nodes, lambda { |type| where("#{table_name}.external_nodes = ?", type) }
|
|
|
|
scope :oldest, lambda { where("#{table_name}.updated_at < ?", Time.zone.now - 15.seconds) }
|
2012-08-30 22:20:30 +01:00
|
|
|
scope :for_platform, lambda { |platform| where(:build_for_platform_id => platform) }
|
2013-07-04 19:25:07 +01:00
|
|
|
scope :by_mass_build, lambda { |mass_build| where(:mass_build_id => mass_build) }
|
|
|
|
scope :scoped_to_arch, lambda {|arch| where(:arch_id => arch) if arch.present? }
|
|
|
|
scope :scoped_to_save_platform, lambda {|pl_id| where(:save_to_platform_id => pl_id) if pl_id.present? }
|
|
|
|
scope :scoped_to_project_version, lambda {|project_version| where(:project_version => project_version) if project_version.present? }
|
2011-04-07 15:56:28 +01:00
|
|
|
scope :scoped_to_is_circle, lambda {|is_circle| where(:is_circle => is_circle) }
|
2011-04-07 14:20:21 +01:00
|
|
|
scope :for_creation_date_period, lambda{|start_date, end_date|
|
2012-04-13 23:27:24 +01:00
|
|
|
s = scoped
|
2013-02-28 15:27:50 +00:00
|
|
|
s = s.where(["#{table_name}.created_at >= ?", start_date]) if start_date
|
|
|
|
s = s.where(["#{table_name}.created_at <= ?", end_date]) if end_date
|
2012-04-13 23:27:24 +01:00
|
|
|
s
|
2011-04-07 14:20:21 +01:00
|
|
|
}
|
|
|
|
scope :for_notified_date_period, lambda{|start_date, end_date|
|
2012-04-13 23:27:24 +01:00
|
|
|
s = scoped
|
2013-07-04 19:25:07 +01:00
|
|
|
s = s.where("#{table_name}.updated_at >= ?", start_date) if start_date.present?
|
|
|
|
s = s.where("#{table_name}.updated_at <= ?", end_date) if end_date.present?
|
2012-04-13 23:27:24 +01:00
|
|
|
s
|
2011-04-07 14:20:21 +01:00
|
|
|
}
|
2013-07-04 19:25:07 +01:00
|
|
|
scope :scoped_to_project_name, lambda {|project_name| joins(:project).where('projects.name LIKE ?', "%#{project_name}%") if project_name.present? }
|
2012-12-10 12:15:22 +00:00
|
|
|
scope :scoped_to_new_core, lambda {|new_core| where(:new_core => new_core)}
|
2013-02-28 15:27:50 +00:00
|
|
|
scope :outdated, where("#{table_name}.created_at < ? AND #{table_name}.status <> ? OR #{table_name}.created_at < ?", Time.now - LIVE_TIME, BUILD_PUBLISHED, Time.now - MAX_LIVE_TIME)
|
2013-02-19 14:14:51 +00:00
|
|
|
scope :published_container, where(:container_status => BUILD_PUBLISHED)
|
2012-05-11 18:44:19 +01:00
|
|
|
|
2011-04-11 11:47:57 +01:00
|
|
|
serialize :additional_repos
|
2011-12-21 14:01:50 +00:00
|
|
|
serialize :include_repos
|
2012-11-27 14:22:17 +00:00
|
|
|
serialize :results, Array
|
2013-02-22 11:04:14 +00:00
|
|
|
serialize :extra_repositories, Array
|
|
|
|
serialize :extra_build_lists, Array
|
2013-09-20 19:21:23 +01:00
|
|
|
serialize :extra_params, Hash
|
2012-05-11 18:44:19 +01:00
|
|
|
|
2013-06-05 10:40:36 +01:00
|
|
|
after_commit :place_build, :on => :create
|
2013-01-28 14:44:06 +00:00
|
|
|
after_destroy :remove_container
|
2011-04-11 11:47:57 +01:00
|
|
|
|
2012-05-28 18:47:53 +01:00
|
|
|
state_machine :status, :initial => :waiting_for_response do
|
|
|
|
|
2012-06-29 12:01:40 +01:00
|
|
|
# WTF? around_transition -> infinite loop
|
|
|
|
before_transition do |build_list, transition|
|
2013-01-24 11:32:00 +00:00
|
|
|
status = HUMAN_STATUSES[build_list.status]
|
2012-07-30 15:49:40 +01:00
|
|
|
if build_list.mass_build && MassBuild::COUNT_STATUSES.include?(status)
|
|
|
|
MassBuild.decrement_counter "#{status.to_s}_count", build_list.mass_build_id
|
2012-06-29 12:01:40 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
after_transition do |build_list, transition|
|
2013-01-24 11:32:00 +00:00
|
|
|
status = HUMAN_STATUSES[build_list.status]
|
2012-07-30 15:49:40 +01:00
|
|
|
if build_list.mass_build && MassBuild::COUNT_STATUSES.include?(status)
|
|
|
|
MassBuild.increment_counter "#{status.to_s}_count", build_list.mass_build_id
|
2012-06-22 16:10:44 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-10-17 19:00:15 +01:00
|
|
|
after_transition :on => :place_build, :do => :add_job_to_abf_worker_queue,
|
2013-10-17 19:25:09 +01:00
|
|
|
:if => lambda { |build_list| build_list.external_nodes.blank? }
|
2013-01-28 14:44:06 +00:00
|
|
|
after_transition :on => :published,
|
2013-02-19 08:36:05 +00:00
|
|
|
:do => [:set_version_and_tag, :actualize_packages]
|
2013-03-28 11:58:26 +00:00
|
|
|
after_transition :on => :publish, :do => :set_publisher
|
2013-01-24 06:33:16 +00:00
|
|
|
after_transition :on => :cancel, :do => :cancel_job
|
2012-06-14 14:36:40 +01:00
|
|
|
|
2013-02-11 12:05:19 +00:00
|
|
|
after_transition :on => [:published, :fail_publish, :build_error, :tests_failed], :do => :notify_users
|
2012-09-19 20:52:18 +01:00
|
|
|
after_transition :on => :build_success, :do => :notify_users,
|
2012-09-19 21:54:15 +01:00
|
|
|
:unless => lambda { |build_list| build_list.auto_publish? }
|
2012-06-14 14:36:40 +01:00
|
|
|
|
2012-06-01 11:58:17 +01:00
|
|
|
event :place_build do
|
2013-06-05 10:54:53 +01:00
|
|
|
transition :waiting_for_response => :build_pending
|
2012-06-01 11:58:17 +01:00
|
|
|
end
|
|
|
|
|
2012-06-13 19:33:23 +01:00
|
|
|
event :start_build do
|
2013-06-05 10:40:36 +01:00
|
|
|
transition :build_pending => :build_started
|
2012-06-13 18:24:50 +01:00
|
|
|
end
|
|
|
|
|
2012-05-28 18:47:53 +01:00
|
|
|
event :cancel do
|
2013-01-24 06:33:16 +00:00
|
|
|
transition [:build_pending, :build_started] => :build_canceling
|
2012-12-06 17:34:09 +00:00
|
|
|
end
|
|
|
|
|
2012-12-07 11:47:42 +00:00
|
|
|
# :build_canceling => :build_canceled - canceling from UI
|
|
|
|
# :build_started => :build_canceled - canceling from worker by time-out (time_living has been expired)
|
2012-12-06 17:34:09 +00:00
|
|
|
event :build_canceled do
|
2013-01-24 06:33:16 +00:00
|
|
|
transition [:build_canceling, :build_started] => :build_canceled
|
2012-05-28 18:47:53 +01:00
|
|
|
end
|
|
|
|
|
2012-06-13 18:24:50 +01:00
|
|
|
event :published do
|
|
|
|
transition [:build_publish, :rejected_publish] => :build_published
|
|
|
|
end
|
|
|
|
|
|
|
|
event :fail_publish do
|
|
|
|
transition [:build_publish, :rejected_publish] => :failed_publish
|
|
|
|
end
|
|
|
|
|
2012-05-28 18:47:53 +01:00
|
|
|
event :publish do
|
2013-02-22 10:20:47 +00:00
|
|
|
transition [:success, :failed_publish, :build_published, :tests_failed] => :build_publish
|
2012-05-31 15:35:37 +01:00
|
|
|
transition [:success, :failed_publish] => :failed_publish
|
2012-05-28 18:47:53 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
event :reject_publish do
|
2013-05-30 10:44:58 +01:00
|
|
|
transition [:success, :failed_publish, :tests_failed] => :rejected_publish
|
2012-05-28 18:47:53 +01:00
|
|
|
end
|
|
|
|
|
2012-06-14 14:36:40 +01:00
|
|
|
event :build_success do
|
2012-06-13 18:24:50 +01:00
|
|
|
transition [:build_started, :build_canceled] => :success
|
|
|
|
end
|
|
|
|
|
2013-02-06 13:50:49 +00:00
|
|
|
[:build_error, :tests_failed].each do |kind|
|
|
|
|
event kind do
|
|
|
|
transition [:build_started, :build_canceling] => kind
|
|
|
|
end
|
2013-02-05 18:49:26 +00:00
|
|
|
end
|
|
|
|
|
2012-05-28 18:47:53 +01:00
|
|
|
HUMAN_STATUSES.each do |code,name|
|
|
|
|
state name, :value => code
|
|
|
|
end
|
2012-06-18 17:19:09 +01:00
|
|
|
end
|
2012-05-28 18:47:53 +01:00
|
|
|
|
2012-06-20 00:20:25 +01:00
|
|
|
later :publish, :queue => :clone_build
|
2012-06-19 16:45:38 +01:00
|
|
|
|
2013-01-28 14:44:06 +00:00
|
|
|
|
|
|
|
HUMAN_CONTAINER_STATUSES = { WAITING_FOR_RESPONSE => :waiting_for_publish,
|
|
|
|
BUILD_PUBLISHED => :container_published,
|
|
|
|
BUILD_PUBLISH => :container_publish,
|
|
|
|
FAILED_PUBLISH => :container_failed_publish
|
2013-04-04 12:27:51 +01:00
|
|
|
}.freeze
|
2013-01-28 14:44:06 +00:00
|
|
|
|
|
|
|
state_machine :container_status, :initial => :waiting_for_publish do
|
|
|
|
|
|
|
|
after_transition :on => :publish_container, :do => :create_container
|
|
|
|
after_transition :on => [:fail_publish_container, :destroy_container],
|
|
|
|
:do => :remove_container
|
|
|
|
|
|
|
|
event :publish_container do
|
2013-02-06 13:21:47 +00:00
|
|
|
transition [:waiting_for_publish, :container_failed_publish] => :container_publish,
|
|
|
|
:if => :can_create_container?
|
2013-01-28 14:44:06 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
event :published_container do
|
|
|
|
transition :container_publish => :container_published
|
|
|
|
end
|
|
|
|
|
|
|
|
event :fail_publish_container do
|
|
|
|
transition :container_publish => :container_failed_publish
|
|
|
|
end
|
|
|
|
|
|
|
|
event :destroy_container do
|
2013-01-29 13:17:35 +00:00
|
|
|
transition [:container_failed_publish, :container_published, :waiting_for_publish] => :waiting_for_publish
|
2013-01-28 14:44:06 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
HUMAN_CONTAINER_STATUSES.each do |code,name|
|
|
|
|
state name, :value => code
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-18 17:19:09 +01:00
|
|
|
def set_version_and_tag
|
|
|
|
pkg = self.packages.where(:package_type => 'source', :project_id => self.project_id).first
|
2012-06-27 15:57:30 +01:00
|
|
|
# TODO: remove 'return' after deployment ABF kernel 2.0
|
2012-10-11 11:55:06 +01:00
|
|
|
return if pkg.nil? # For old client that does not sends data about packages
|
2012-06-18 17:19:09 +01:00
|
|
|
self.package_version = "#{pkg.platform.name}-#{pkg.version}-#{pkg.release}"
|
2012-07-17 09:02:56 +01:00
|
|
|
system("cd #{self.project.repo.path} && git tag #{self.package_version} #{self.commit_hash}") # TODO REDO through grit
|
2012-06-18 17:19:09 +01:00
|
|
|
save
|
2012-05-28 18:47:53 +01:00
|
|
|
end
|
|
|
|
|
2012-08-24 16:19:26 +01:00
|
|
|
def actualize_packages
|
|
|
|
ActiveRecord::Base.transaction do
|
2012-12-03 17:43:24 +00:00
|
|
|
# packages from previous build_list
|
2012-12-04 09:59:16 +00:00
|
|
|
self.last_published.limit(2).last.packages.update_all :actual => false
|
2012-12-03 17:43:24 +00:00
|
|
|
self.packages.update_all :actual => true
|
2012-08-24 16:19:26 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-01-28 14:44:06 +00:00
|
|
|
def can_create_container?
|
2013-02-22 10:20:47 +00:00
|
|
|
[SUCCESS, BUILD_PUBLISH, FAILED_PUBLISH, BUILD_PUBLISHED, TESTS_FAILED].include?(status) && [WAITING_FOR_RESPONSE, FAILED_PUBLISH].include?(container_status)
|
2013-01-28 14:44:06 +00:00
|
|
|
end
|
|
|
|
|
2012-05-29 18:28:11 +01:00
|
|
|
#TODO: Share this checking on product owner.
|
|
|
|
def can_cancel?
|
2013-01-24 06:33:16 +00:00
|
|
|
build_started? || build_pending?
|
2012-05-29 18:28:11 +01:00
|
|
|
end
|
|
|
|
|
2013-09-16 15:14:55 +01:00
|
|
|
# Comparison between versions of current and last published build_list
|
2013-09-16 17:35:37 +01:00
|
|
|
# @return [Boolean]
|
2013-09-16 15:14:55 +01:00
|
|
|
# - false if no new packages
|
|
|
|
# - false if version of packages is less than version of pubished packages.
|
|
|
|
# - true if version of packages is equal to version of pubished packages (only if platform is not released).
|
|
|
|
# - true if version of packages is greater than version of pubished packages.
|
2013-09-10 14:58:58 +01:00
|
|
|
def has_new_packages?
|
2013-09-09 20:42:13 +01:00
|
|
|
if last_bl = last_published.joins(:source_packages).where(:build_list_packages => {:actual => true}).last
|
2013-09-09 20:04:56 +01:00
|
|
|
source_packages.each do |nsp|
|
|
|
|
sp = last_bl.source_packages.find{ |sp| nsp.name == sp.name }
|
2013-09-16 15:14:55 +01:00
|
|
|
return true unless sp
|
|
|
|
comparison = nsp.rpmvercmp(sp)
|
|
|
|
return comparison == 1 || (comparison == 0 && !save_to_platform.released?)
|
2013-09-09 19:40:58 +01:00
|
|
|
end
|
|
|
|
else
|
|
|
|
return true # no published packages
|
|
|
|
end
|
|
|
|
return false # no new packages
|
|
|
|
end
|
|
|
|
|
2013-09-10 14:58:58 +01:00
|
|
|
def can_auto_publish?
|
|
|
|
auto_publish? && can_publish? && has_new_packages?
|
|
|
|
end
|
|
|
|
|
2013-02-22 14:29:22 +00:00
|
|
|
def can_publish?
|
2013-02-26 16:49:21 +00:00
|
|
|
[SUCCESS, FAILED_PUBLISH, BUILD_PUBLISHED, TESTS_FAILED].include?(status) && extra_build_lists_published? && save_to_repository.projects.exists?(:id => project_id)
|
2012-06-22 11:33:03 +01:00
|
|
|
end
|
|
|
|
|
2013-02-22 11:04:14 +00:00
|
|
|
def extra_build_lists_published?
|
|
|
|
# All extra build lists should be published before publishing this build list for main platforms!
|
2013-02-22 09:09:37 +00:00
|
|
|
return true unless save_to_platform.main?
|
2013-02-22 11:04:14 +00:00
|
|
|
BuildList.where(:id => extra_build_lists).where('status != ?', BUILD_PUBLISHED).count == 0
|
2013-02-22 09:09:37 +00:00
|
|
|
end
|
|
|
|
|
2013-07-31 14:08:43 +01:00
|
|
|
def human_average_build_time
|
|
|
|
I18n.t('layout.project_statistics.human_average_build_time', {:hours => (average_build_time/3600).to_i, :minutes => (average_build_time%3600/60).to_i})
|
|
|
|
end
|
|
|
|
|
|
|
|
def formatted_average_build_time
|
|
|
|
"%02d:%02d" % [average_build_time / 3600, average_build_time % 3600 / 60]
|
|
|
|
end
|
|
|
|
|
|
|
|
def average_build_time
|
2013-10-03 19:54:11 +01:00
|
|
|
return 0 unless project
|
2013-08-29 18:46:11 +01:00
|
|
|
project.project_statistics.where(:arch_id => arch_id).pluck(:average_build_time).first || 0
|
2013-07-31 14:08:43 +01:00
|
|
|
end
|
|
|
|
|
2012-05-11 19:00:27 +01:00
|
|
|
def self.human_status(status)
|
|
|
|
I18n.t("layout.build_lists.statuses.#{HUMAN_STATUSES[status]}")
|
2011-04-07 14:20:21 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def human_status
|
|
|
|
self.class.human_status(status)
|
|
|
|
end
|
|
|
|
|
2012-06-29 19:31:40 +01:00
|
|
|
def self.status_by_human(human)
|
2013-01-24 11:32:00 +00:00
|
|
|
HUMAN_STATUSES.key human
|
2012-06-29 19:31:40 +01:00
|
|
|
end
|
|
|
|
|
2011-04-11 11:47:57 +01:00
|
|
|
def set_items(items_hash)
|
|
|
|
self.items = []
|
|
|
|
|
|
|
|
items_hash.each do |level, items|
|
|
|
|
items.each do |item|
|
2011-10-29 15:05:40 +01:00
|
|
|
self.items << self.items.build(:name => item['name'], :version => item['version'], :level => level.to_i)
|
2011-04-11 11:47:57 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2011-12-21 23:31:05 +00:00
|
|
|
|
2012-05-17 22:19:57 +01:00
|
|
|
def set_packages(pkg_hash, project_name)
|
|
|
|
prj = Project.joins(:repositories => :platform).where('platforms.id = ?', save_to_platform.id).find_by_name!(project_name)
|
|
|
|
build_package(pkg_hash['srpm'], 'source', prj) {|p| p.save!}
|
2012-05-14 20:08:31 +01:00
|
|
|
pkg_hash['rpm'].each do |rpm_hash|
|
2012-05-17 22:19:57 +01:00
|
|
|
build_package(rpm_hash, 'binary', prj) {|p| p.save!}
|
2012-05-14 20:08:31 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-29 15:50:22 +01:00
|
|
|
def event_log_message
|
2011-11-28 15:41:42 +00:00
|
|
|
{:project => project.name, :version => project_version, :arch => arch.name}.inspect
|
2011-10-29 15:50:22 +01:00
|
|
|
end
|
|
|
|
|
2012-04-12 15:55:32 +01:00
|
|
|
def current_duration
|
2012-04-13 21:49:29 +01:00
|
|
|
(Time.now.utc - started_at.utc).to_i
|
2012-04-12 15:55:32 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def human_current_duration
|
2012-04-13 22:20:56 +01:00
|
|
|
I18n.t("layout.build_lists.human_current_duration", {:hours => (current_duration/3600).to_i, :minutes => (current_duration%3600/60).to_i})
|
2012-04-12 15:55:32 +01:00
|
|
|
end
|
|
|
|
|
2012-04-12 11:29:04 +01:00
|
|
|
def human_duration
|
2013-09-27 14:19:09 +01:00
|
|
|
I18n.t("layout.build_lists.human_duration", {:hours => (duration.to_i/3600).to_i, :minutes => (duration.to_i%3600/60).to_i})
|
2012-04-12 11:29:04 +01:00
|
|
|
end
|
|
|
|
|
2012-04-13 21:49:29 +01:00
|
|
|
def in_work?
|
2013-01-24 11:32:00 +00:00
|
|
|
status == BUILD_STARTED
|
|
|
|
#[WAITING_FOR_RESPONSE, BUILD_PENDING, BUILD_STARTED].include?(status)
|
2012-04-12 11:29:04 +01:00
|
|
|
end
|
|
|
|
|
2012-10-19 08:32:12 +01:00
|
|
|
def associate_and_create_advisory(params)
|
|
|
|
build_advisory(params){ |a| a.update_type = update_type }
|
|
|
|
advisory.attach_build_list(self)
|
|
|
|
end
|
|
|
|
|
2012-10-19 15:03:09 +01:00
|
|
|
def can_attach_to_advisory?
|
2012-10-19 08:32:12 +01:00
|
|
|
!save_to_repository.publish_without_qa &&
|
2012-10-19 15:03:09 +01:00
|
|
|
save_to_platform.main? &&
|
2012-10-19 08:32:12 +01:00
|
|
|
save_to_platform.released &&
|
2012-11-30 13:10:17 +00:00
|
|
|
build_published?
|
2012-10-18 15:17:50 +01:00
|
|
|
end
|
|
|
|
|
2012-11-29 17:56:03 +00:00
|
|
|
def log(load_lines)
|
2013-01-28 14:44:06 +00:00
|
|
|
new_core? ? abf_worker_log : I18n.t('layout.build_lists.log.not_available')
|
2012-10-18 15:17:50 +01:00
|
|
|
end
|
|
|
|
|
2013-01-12 01:36:00 +00:00
|
|
|
def last_published
|
|
|
|
BuildList.where(:project_id => self.project_id,
|
|
|
|
:save_to_repository_id => self.save_to_repository_id)
|
|
|
|
.for_platform(self.build_for_platform_id)
|
|
|
|
.scoped_to_arch(self.arch_id)
|
|
|
|
.for_status(BUILD_PUBLISHED)
|
|
|
|
.recent
|
|
|
|
end
|
|
|
|
|
2013-02-14 21:49:18 +00:00
|
|
|
def sha1_of_file_store_files
|
|
|
|
packages.pluck(:sha1).compact | (results || []).map{ |r| r['sha1'] }.compact
|
|
|
|
end
|
|
|
|
|
2012-05-14 20:08:31 +01:00
|
|
|
protected
|
2011-04-11 17:37:09 +01:00
|
|
|
|
2013-01-28 14:44:06 +00:00
|
|
|
def create_container
|
|
|
|
AbfWorker::BuildListsPublishTaskManager.create_container_for self
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_container
|
|
|
|
system "rm -rf #{save_to_platform.path}/container/#{id}" if save_to_platform
|
|
|
|
end
|
|
|
|
|
2012-12-28 14:00:37 +00:00
|
|
|
def abf_worker_priority
|
|
|
|
mass_build_id ? '' : 'default'
|
|
|
|
end
|
|
|
|
|
|
|
|
def abf_worker_base_queue
|
|
|
|
'rpm_worker'
|
|
|
|
end
|
|
|
|
|
2012-12-06 14:41:24 +00:00
|
|
|
def abf_worker_args
|
2013-02-14 12:50:13 +00:00
|
|
|
repos = include_repos
|
2012-12-06 14:41:24 +00:00
|
|
|
include_repos_hash = {}.tap do |h|
|
2013-02-19 09:42:57 +00:00
|
|
|
Repository.where(:id => (repos | (extra_repositories || [])) ).each do |repo|
|
2013-06-26 10:53:37 +01:00
|
|
|
path, prefix = repo.platform.public_downloads_url(
|
2013-05-16 16:25:03 +01:00
|
|
|
repo.platform.main? ? nil : build_for_platform.name,
|
|
|
|
arch.name,
|
|
|
|
repo.name
|
2013-06-26 10:53:37 +01:00
|
|
|
), "#{repo.platform.name}_#{repo.name}_"
|
|
|
|
h["#{prefix}release"] = insert_token_to_path(path + 'release', repo.platform)
|
|
|
|
h["#{prefix}updates"] = insert_token_to_path(path + 'updates', repo.platform) if repo.platform.main?
|
2012-12-06 14:41:24 +00:00
|
|
|
end
|
|
|
|
end
|
2013-02-19 09:42:57 +00:00
|
|
|
host = EventLog.current_controller.request.host_with_port rescue ::Rosa::Application.config.action_mailer.default_url_options[:host]
|
2013-02-22 11:04:14 +00:00
|
|
|
BuildList.where(:id => extra_build_lists).each do |bl|
|
2013-05-06 18:40:30 +01:00
|
|
|
path = "#{APP_CONFIG['downloads_url']}/#{bl.save_to_platform.name}/container/"
|
2013-02-19 09:42:57 +00:00
|
|
|
path << "#{bl.id}/#{bl.arch.name}/#{bl.save_to_repository.name}/release"
|
2013-06-26 10:53:37 +01:00
|
|
|
include_repos_hash["container_#{bl.id}"] = insert_token_to_path(path, bl.save_to_platform)
|
2013-02-19 09:42:57 +00:00
|
|
|
end
|
2012-12-06 14:41:24 +00:00
|
|
|
|
2013-05-16 19:50:18 +01:00
|
|
|
git_project_address = project.git_project_address user
|
2013-10-17 19:26:47 +01:00
|
|
|
# git_project_address.gsub!(/^http:\/\/(0\.0\.0\.0|localhost)\:[\d]+/, 'https://abf.rosalinux.ru') unless Rails.env.production?
|
2013-09-20 19:43:03 +01:00
|
|
|
|
|
|
|
cmd_params = {
|
|
|
|
'GIT_PROJECT_ADDRESS' => git_project_address,
|
|
|
|
'COMMIT_HASH' => commit_hash,
|
|
|
|
'EXTRA_CFG_OPTIONS' => extra_params['cfg_options'],
|
|
|
|
'EXTRA_BUILD_SRC_RPM_OPTIONS' => extra_params['build_src_rpm'],
|
|
|
|
'EXTRA_BUILD_RPM_OPTIONS' => extra_params['build_rpm']
|
2013-09-20 19:57:52 +01:00
|
|
|
}.map{ |k, v| "#{k}='#{v}'" }.join(' ')
|
2013-09-20 19:43:03 +01:00
|
|
|
|
2012-12-06 14:41:24 +00:00
|
|
|
{
|
2013-02-06 10:18:51 +00:00
|
|
|
:id => id,
|
2013-07-25 08:37:16 +01:00
|
|
|
:time_living => (build_for_platform.platform_arch_settings.by_arch(arch).first.try(:time_living) || PlatformArchSetting::DEFAULT_TIME_LIVING),
|
2013-02-06 10:18:51 +00:00
|
|
|
:distrib_type => build_for_platform.distrib_type,
|
2013-09-20 19:43:03 +01:00
|
|
|
:cmd_params => cmd_params,
|
2013-02-06 10:18:51 +00:00
|
|
|
:include_repos => include_repos_hash,
|
2013-08-12 15:26:57 +01:00
|
|
|
:platform => {
|
|
|
|
:type => build_for_platform.distrib_type,
|
|
|
|
:name => build_for_platform.name,
|
|
|
|
:arch => arch.name
|
|
|
|
},
|
2013-02-06 10:18:51 +00:00
|
|
|
:user => {:uname => user.uname, :email => user.email}
|
2012-12-06 14:41:24 +00:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2013-06-26 10:53:37 +01:00
|
|
|
def insert_token_to_path(path, platform)
|
|
|
|
if platform.hidden?
|
|
|
|
path.gsub(/^http:\/\//, "http://#{user.authentication_token}:@")
|
|
|
|
else
|
|
|
|
path
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-09-19 14:55:17 +01:00
|
|
|
def notify_users
|
|
|
|
unless mass_build_id
|
2013-08-28 16:20:18 +01:00
|
|
|
users = [user, publisher].compact.uniq.select{ |u| u.notifier.can_notify? && u.notifier.new_build? }
|
|
|
|
|
2013-08-28 16:13:11 +01:00
|
|
|
# find associated users
|
|
|
|
users |= project.all_members.select do |u|
|
|
|
|
u.notifier.can_notify? && u.notifier.new_associated_build?
|
|
|
|
end if project
|
|
|
|
users.each{ |u| UserMailer.build_list_notification(self, u).deliver }
|
2012-09-19 14:55:17 +01:00
|
|
|
end
|
|
|
|
end # notify_users
|
|
|
|
|
2012-05-17 22:19:57 +01:00
|
|
|
def build_package(pkg_hash, package_type, prj)
|
2012-05-14 20:08:31 +01:00
|
|
|
packages.create(pkg_hash) do |p|
|
2012-05-17 22:19:57 +01:00
|
|
|
p.project = prj
|
2012-05-14 20:08:31 +01:00
|
|
|
p.platform = save_to_platform
|
|
|
|
p.package_type = package_type
|
|
|
|
yield p
|
|
|
|
end
|
|
|
|
end
|
2013-02-04 11:43:42 +00:00
|
|
|
|
2013-03-28 11:58:26 +00:00
|
|
|
def set_publisher
|
|
|
|
self.publisher ||= user
|
|
|
|
save
|
|
|
|
end
|
|
|
|
|
2013-02-19 14:52:02 +00:00
|
|
|
def current_ability
|
|
|
|
@current_ability ||= Ability.new(user)
|
|
|
|
end
|
|
|
|
|
2013-02-21 14:46:52 +00:00
|
|
|
def prepare_extra_repositories
|
|
|
|
if save_to_platform && save_to_platform.main?
|
|
|
|
self.extra_repositories = nil
|
|
|
|
else
|
2013-05-16 15:48:44 +01:00
|
|
|
self.extra_repositories = Repository.joins(:platform).
|
|
|
|
where(:id => extra_repositories, :platforms => {:platform_type => 'personal'}).
|
2013-02-22 10:27:24 +00:00
|
|
|
accessible_by(current_ability, :read).pluck('repositories.id')
|
2013-02-19 10:06:11 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-22 11:04:14 +00:00
|
|
|
def prepare_extra_build_lists
|
2013-06-05 14:48:11 +01:00
|
|
|
bls = BuildList.for_extra_build_lists(extra_build_lists, current_ability, save_to_platform)
|
2013-06-04 20:59:08 +01:00
|
|
|
if save_to_platform
|
2013-02-21 15:16:16 +00:00
|
|
|
if save_to_platform.distrib_type == 'rhel'
|
|
|
|
bls = bls.where('
|
|
|
|
(build_lists.arch_id = ? AND projects.publish_i686_into_x86_64 is not true) OR
|
|
|
|
(projects.publish_i686_into_x86_64 is true)
|
|
|
|
', arch_id).joins(:project)
|
|
|
|
else
|
|
|
|
bls = bls.where(:arch_id => arch_id)
|
|
|
|
end
|
|
|
|
end
|
2013-02-22 11:04:14 +00:00
|
|
|
self.extra_build_lists = bls.pluck('build_lists.id')
|
2013-02-19 10:06:11 +00:00
|
|
|
end
|
|
|
|
|
2013-09-20 19:21:23 +01:00
|
|
|
def prepare_extra_params
|
|
|
|
if extra_params.present?
|
|
|
|
params = extra_params.slice(*BuildList::EXTRA_PARAMS)
|
|
|
|
params.update(params) do |k,v|
|
|
|
|
v.strip.gsub(I18n.t("activerecord.attributes.build_list.extra_params.#{k}"), '').gsub(/[^\w\s-]/, '')
|
|
|
|
end
|
|
|
|
self.extra_params = params.select{ |k,v| v.present? }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-21 14:46:52 +00:00
|
|
|
end
|