debian-mirror-gitlab/qa/lib/gitlab/page/group/settings/usage_quotas.rb
2022-11-25 23:54:43 +05:30

77 lines
2.6 KiB
Ruby

# frozen_string_literal: true
module Gitlab
module Page
module Group
module Settings
class UsageQuotas < Chemlab::Page
# Seats section
link :seats_tab
# Pipelines section
link :pipelines_tab
link :buy_ci_minutes
div :plan_ci_minutes
div :additional_ci_minutes
div :ci_purchase_successful_alert, text: /You have successfully purchased CI minutes/
# Storage section
link :storage_tab
link :purchase_more_storage
div :used_storage_message
div :group_usage_message
div :dependency_proxy_usage
span :dependency_proxy_size
div :container_registry_usage
div :project_storage_used
div :project
div :storage_type_legend
span :container_registry_size
div :purchased_usage_total_free # Different UI for free namespace
span :purchased_usage_total
div :storage_purchase_successful_alert, text: /You have successfully purchased a storage/
h2 :storage_available_alert, text: /purchased storage is available/
def plan_ci_limits
plan_ci_minutes_element.span.text[%r{([^/ ]+)$}]
end
def additional_ci_limits
additional_ci_minutes_element.span.text[%r{([^/ ]+)$}]
end
# Waits and Checks if storage available alert presents on the page
#
# @return [Boolean] True if the alert presents, false if not after 5 second wait
def purchased_storage_available?
storage_available_alert_element.wait_until(timeout: 5, &:present?)
rescue Watir::Wait::TimeoutError
false
end
# Waits and Checks if storage project data loaded
#
# @return [Boolean] True if the alert presents, false if not after 5 second wait
def project_storage_data_available?
storage_type_legend_element.wait_until(timeout: 3, &:present?)
rescue Watir::Wait::TimeoutError
false
end
# Returns total purchased storage value once it's ready on page
#
# @return [Float] Total purchased storage value in GiB
def total_purchased_storage(free_name_space = true)
storage_available_alert_element.wait_until(&:present?)
if free_name_space
purchased_usage_total_free.split('/').last.match(/\d+\.\d+/)[0].to_f
else
purchased_usage_total.to_f
end
end
end
end
end
end
end