diff --git a/app/models/foreman_resource_quota/resource_quota.rb b/app/models/foreman_resource_quota/resource_quota.rb index 509f5ae..fbfab13 100644 --- a/app/models/foreman_resource_quota/resource_quota.rb +++ b/app/models/foreman_resource_quota/resource_quota.rb @@ -26,6 +26,10 @@ class ResourceQuota < ApplicationRecord scoped_search on: :name, complete_value: true scoped_search on: :id, complete_enabled: false, only_explicit: true, validator: ScopedSearch::Validators::INTEGER + def self.permission_name + 'resource_quotas' + end + def number_of_hosts hosts_resources.size end diff --git a/lib/foreman_resource_quota/register.rb b/lib/foreman_resource_quota/register.rb index 63051c3..9e89589 100644 --- a/lib/foreman_resource_quota/register.rb +++ b/lib/foreman_resource_quota/register.rb @@ -9,22 +9,22 @@ # Add permissions security_block :foreman_resource_quota do - permission 'view_foreman_resource_quota/resource_quotas', + permission :view_resource_quotas, { 'foreman_resource_quota/resource_quotas': %i[index welcome auto_complete_search], 'foreman_resource_quota/api/v2/resource_quotas': %i[index show utilization missing_hosts hosts users usergroups auto_complete_search], 'foreman_resource_quota/api/v2/resource_quotas/:resource_quota_id/': %i[utilization missing_hosts hosts users usergroups] }, resource_type: 'ForemanResourceQuota::ResourceQuota' - permission 'create_foreman_resource_quota/resource_quotas', + permission :create_resource_quotas, { 'foreman_resource_quota/resource_quotas': %i[new create], 'foreman_resource_quota/api/v2/resource_quotas': %i[create] }, resource_type: 'ForemanResourceQuota::ResourceQuota' - permission 'edit_foreman_resource_quota/resource_quotas', + permission :edit_resource_quotas, { 'foreman_resource_quota/resource_quotas': %i[edit update], 'foreman_resource_quota/api/v2/resource_quotas': %i[update] }, resource_type: 'ForemanResourceQuota::ResourceQuota' - permission 'destroy_foreman_resource_quota/resource_quotas', + permission :destroy_resource_quotas, { 'foreman_resource_quota/resource_quotas': %i[destroy], 'foreman_resource_quota/api/v2/resource_quotas': %i[destroy] }, resource_type: 'ForemanResourceQuota::ResourceQuota' @@ -33,18 +33,18 @@ end # Add a permissions to default roles (Viewer and Manager) - role 'Resource Quota Manager', ['view_foreman_resource_quota/resource_quotas', - 'create_foreman_resource_quota/resource_quotas', - 'edit_foreman_resource_quota/resource_quotas', - 'destroy_foreman_resource_quota/resource_quotas', - 'view_hosts', - 'edit_hosts', - 'view_users', - 'edit_users'] - role 'Resource Quota User', ['view_foreman_resource_quota/resource_quotas', - 'view_hosts', - 'view_users', - 'view_usergroups'] + role 'Resource Quota Manager', %i[view_resource_quotas + create_resource_quotas + edit_resource_quotas + destroy_resource_quotas + view_hosts + edit_hosts + view_users + edit_users] + role 'Resource Quota User', %i[view_resource_quotas + view_hosts + view_users + view_usergroups] add_all_permissions_to_default_roles # add controller parameter extension diff --git a/test/jobs/refresh_resource_quota_utilization_test.rb b/test/jobs/refresh_resource_quota_utilization_test.rb new file mode 100644 index 0000000..7f8255f --- /dev/null +++ b/test/jobs/refresh_resource_quota_utilization_test.rb @@ -0,0 +1,18 @@ +require 'test_plugin_helper' +require 'foreman_tasks/test_helpers' + +class RefreshResourceQuotaUtilizationTest < ActiveSupport::TestCase + include ForemanTasks::TestHelpers::WithInThreadExecutor + setup do + User.current = User.find_by(login: 'secret_admin') + @quota = FactoryBot.create(:resource_quota) + @host = FactoryBot.create(:resource_quota) + end + + test 'resource quota utilization should be updated' do + @host.host_resources.cpu_cores = 10 + ForemanTasks.sync_task(ForemanResourceQuota::Async::RefreshResourceQuotaUtilization) + @hosts.each(&:reload) + assert_equal InsightsClientReportStatus::NOT_MANAGED, @host4.get_status(InsightsClientReportStatus).status + end +end