katello 4.16.1 → 4.17.0.rc1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/katello/hosts/host_and_hostgroup_edit.js +5 -3
- data/app/assets/javascripts/katello/locale/bn/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/bn_IN/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ca/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/cs/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/cs_CZ/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/de/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/de_AT/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/de_DE/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/el/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/en/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/en_GB/katello.js +84 -33
- data/app/assets/javascripts/katello/locale/en_US/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/es/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/et_EE/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/fr/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/gl/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/gu/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/he_IL/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/hi/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/id/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/it/katello.js +84 -33
- data/app/assets/javascripts/katello/locale/ja/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/ka/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/kn/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ko/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ml_IN/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/mr/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/nl_NL/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/or/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/pa/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/pl/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/pl_PL/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/pt/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/pt_BR/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ro/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ro_RO/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ru/katello.js +84 -33
- data/app/assets/javascripts/katello/locale/sl/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/sv_SE/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/ta/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/ta_IN/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/te/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/tr/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/vi/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/vi_VN/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/zh/katello.js +82 -31
- data/app/assets/javascripts/katello/locale/zh_CN/katello.js +83 -32
- data/app/assets/javascripts/katello/locale/zh_TW/katello.js +84 -33
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +19 -3
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +6 -6
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +3 -0
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +6 -0
- data/app/controllers/katello/api/v2/content_views_controller.rb +12 -1
- data/app/controllers/katello/api/v2/exports_controller.rb +3 -0
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +12 -14
- data/app/controllers/katello/api/v2/organizations_controller.rb +10 -10
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +8 -2
- data/app/lib/actions/helpers/rolling_cv_repos.rb +25 -0
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +6 -1
- data/app/lib/actions/katello/content_view/add_rolling_repo_clone.rb +39 -0
- data/app/lib/actions/katello/content_view/create.rb +3 -0
- data/app/lib/actions/katello/content_view/refresh_rolling_repo.rb +40 -0
- data/app/lib/actions/katello/content_view/remove.rb +8 -4
- data/app/lib/actions/katello/content_view/remove_rolling_repo_clone.rb +28 -0
- data/app/lib/actions/katello/content_view/update.rb +8 -0
- data/app/lib/actions/katello/repository/check_matching_content.rb +1 -8
- data/app/lib/actions/katello/repository/import_upload.rb +5 -0
- data/app/lib/actions/katello/repository/sync.rb +8 -4
- data/app/lib/actions/katello/repository/upload_files.rb +7 -1
- data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +3 -2
- data/app/lib/actions/pulp3/orphan_cleanup/delete_orphan_repository_versions.rb +8 -1
- data/app/lib/katello/errors.rb +8 -0
- data/app/lib/katello/validators/container_image_name_validator.rb +3 -2
- data/app/models/katello/authorization/repository.rb +11 -1
- data/app/models/katello/concerns/host_managed_extensions.rb +2 -2
- data/app/models/katello/concerns/pulp_database_unit.rb +12 -42
- data/app/models/katello/concerns/smart_proxy_extensions.rb +8 -0
- data/app/models/katello/content_view.rb +14 -1
- data/app/models/katello/content_view_component.rb +4 -0
- data/app/models/katello/content_view_environment.rb +1 -0
- data/app/models/katello/content_view_version.rb +3 -2
- data/app/models/katello/host/content_facet.rb +18 -5
- data/app/models/katello/product_content.rb +3 -1
- data/app/models/katello/repository.rb +3 -3
- data/app/services/katello/content_unit_indexer.rb +1 -1
- data/app/services/katello/pulp3/api/content_guard.rb +1 -1
- data/app/services/katello/pulp3/api/core.rb +6 -0
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +58 -1
- data/app/services/katello/pulp3/smart_proxy_repository.rb +67 -3
- data/app/services/katello/smart_proxy_helper.rb +6 -1
- data/app/views/foreman/job_templates/install_errata_-_katello_ansible_default.erb +15 -1
- data/app/views/foreman/job_templates/install_errata_by_search_query_-_katello_ansible_default.erb +15 -1
- data/app/views/foreman/job_templates/install_group_-_katello_ansible_default.erb +15 -2
- data/app/views/foreman/job_templates/install_packages_by_search_query_-_katello_ansible_default.erb +21 -2
- data/app/views/foreman/job_templates/remove_group_-_katello_ansible_default.erb +15 -1
- data/app/views/foreman/job_templates/remove_packages_by_search_query_-_katello_ansible_default.erb +20 -1
- data/app/views/foreman/job_templates/update_group_-_katello_ansible_default.erb +15 -2
- data/app/views/foreman/job_templates/update_packages_by_search_query_-_katello_ansible_default.erb +17 -1
- data/app/views/katello/api/v2/activation_keys/base.json.rabl +1 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +2 -1
- data/app/views/katello/api/v2/content_facet/base.json.rabl +2 -0
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +12 -0
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
- data/app/views/katello/api/v2/environments/show.json.rabl +14 -0
- data/app/views/katello/api/v2/hosts/base.json.rabl +1 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +2 -0
- data/app/views/katello/api/v2/repositories/base.json.rabl +2 -1
- data/db/migrate/20190930192813_add_pulp3_hrefs_to_content_types.rb +1 -1
- data/db/migrate/20241022122325_add_rolling_to_katello_content_views.rb +5 -0
- data/db/migrate/20241025151105_remove_pulp3_migrated_hrefs_from_content_tables.rb +1 -1
- data/db/migrate/20250215143303_drop_katello_yum_metadata_file.rb +5 -0
- data/db/migrate/20250409120843_fix_file_download_policy.rb +11 -0
- data/db/migrate/20250410155300_change_ansible_templates_category.rb +22 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/bn.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/bn_IN.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ca.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/cs_CZ.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +93 -60
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de_AT.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de_DE.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/el.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/en_GB.po +94 -35
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/en_US.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +93 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/et_EE.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +254 -192
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/gl.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/gu.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/he_IL.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/hi.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/id.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +90 -35
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +113 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ka.po +93 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/kn.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +101 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ml_IN.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/mr.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/nl_NL.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/or.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pa.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pl.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pl_PL.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +93 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ro.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ro_RO.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +91 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/sl.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/sv_SE.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ta.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ta_IN.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/te.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/tr.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/vi.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/vi_VN.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh.po +90 -31
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +99 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +92 -33
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +14 -14
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repository-types.service.js +3 -0
- data/lib/katello/engine.rb +9 -1
- data/lib/katello/repository_types/python.rb +1 -1
- data/lib/katello/tasks/repository.rake +1 -1
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +186 -0
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/bn/katello.po +82 -31
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/bn_IN/LC_MESSAGES/katello.mo +0 -0
- data/locale/bn_IN/katello.po +82 -31
- data/locale/bn_IN/katello.po.time_stamp +0 -0
- data/locale/ca/LC_MESSAGES/katello.mo +0 -0
- data/locale/ca/katello.po +82 -31
- data/locale/ca/katello.po.time_stamp +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/katello.po +82 -31
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/cs_CZ/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs_CZ/katello.po +83 -32
- data/locale/cs_CZ/katello.po.time_stamp +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/katello.po +82 -31
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/de_AT/LC_MESSAGES/katello.mo +0 -0
- data/locale/de_AT/katello.po +82 -31
- data/locale/de_AT/katello.po.time_stamp +0 -0
- data/locale/de_DE/LC_MESSAGES/katello.mo +0 -0
- data/locale/de_DE/katello.po +82 -31
- data/locale/de_DE/katello.po.time_stamp +0 -0
- data/locale/el/LC_MESSAGES/katello.mo +0 -0
- data/locale/el/katello.po +82 -31
- data/locale/el/katello.po.time_stamp +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/katello.po +82 -31
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/en_GB/LC_MESSAGES/katello.mo +0 -0
- data/locale/en_GB/katello.po +84 -33
- data/locale/en_GB/katello.po.time_stamp +0 -0
- data/locale/en_US/LC_MESSAGES/katello.mo +0 -0
- data/locale/en_US/katello.po +82 -31
- data/locale/en_US/katello.po.time_stamp +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/katello.po +82 -31
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/et_EE/LC_MESSAGES/katello.mo +0 -0
- data/locale/et_EE/katello.po +82 -31
- data/locale/et_EE/katello.po.time_stamp +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/katello.po +83 -32
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gl/LC_MESSAGES/katello.mo +0 -0
- data/locale/gl/katello.po +82 -31
- data/locale/gl/katello.po.time_stamp +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/katello.po +84 -33
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/he_IL/LC_MESSAGES/katello.mo +0 -0
- data/locale/he_IL/katello.po +82 -31
- data/locale/he_IL/katello.po.time_stamp +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/katello.po +82 -31
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/id/LC_MESSAGES/katello.mo +0 -0
- data/locale/id/katello.po +82 -31
- data/locale/id/katello.po.time_stamp +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/katello.po +85 -34
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/katello.po +83 -32
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/ka/LC_MESSAGES/katello.mo +0 -0
- data/locale/ka/katello.po +82 -31
- data/locale/ka/katello.po.time_stamp +0 -0
- data/locale/katello.pot +1232 -1140
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/katello.po +82 -31
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/katello.po +82 -31
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/ml_IN/LC_MESSAGES/katello.mo +0 -0
- data/locale/ml_IN/katello.po +82 -31
- data/locale/ml_IN/katello.po.time_stamp +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/katello.po +82 -31
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/nl_NL/LC_MESSAGES/katello.mo +0 -0
- data/locale/nl_NL/katello.po +82 -31
- data/locale/nl_NL/katello.po.time_stamp +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/katello.po +82 -31
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/katello.po +82 -31
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pl/LC_MESSAGES/katello.mo +0 -0
- data/locale/pl/katello.po +84 -33
- data/locale/pl/katello.po.time_stamp +0 -0
- data/locale/pl_PL/LC_MESSAGES/katello.mo +0 -0
- data/locale/pl_PL/katello.po +82 -31
- data/locale/pl_PL/katello.po.time_stamp +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/katello.po +82 -31
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/katello.po +82 -31
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ro/LC_MESSAGES/katello.mo +0 -0
- data/locale/ro/katello.po +82 -31
- data/locale/ro/katello.po.time_stamp +0 -0
- data/locale/ro_RO/LC_MESSAGES/katello.mo +0 -0
- data/locale/ro_RO/katello.po +82 -31
- data/locale/ro_RO/katello.po.time_stamp +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/katello.po +85 -34
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/sl/LC_MESSAGES/katello.mo +0 -0
- data/locale/sl/katello.po +82 -31
- data/locale/sl/katello.po.time_stamp +0 -0
- data/locale/sv_SE/LC_MESSAGES/katello.mo +0 -0
- data/locale/sv_SE/katello.po +84 -33
- data/locale/sv_SE/katello.po.time_stamp +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/katello.po +82 -31
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/ta_IN/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta_IN/katello.po +82 -31
- data/locale/ta_IN/katello.po.time_stamp +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/katello.po +82 -31
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/tr/LC_MESSAGES/katello.mo +0 -0
- data/locale/tr/katello.po +82 -31
- data/locale/tr/katello.po.time_stamp +0 -0
- data/locale/vi/LC_MESSAGES/katello.mo +0 -0
- data/locale/vi/katello.po +82 -31
- data/locale/vi/katello.po.time_stamp +0 -0
- data/locale/vi_VN/LC_MESSAGES/katello.mo +0 -0
- data/locale/vi_VN/katello.po +82 -31
- data/locale/vi_VN/katello.po.time_stamp +0 -0
- data/locale/zh/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh/katello.po +82 -31
- data/locale/zh/katello.po.time_stamp +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/katello.po +83 -32
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/katello.po +85 -34
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/webpack/ForemanColumnExtensions/index.js +12 -4
- data/webpack/components/ActivationKeysSearch/index.js +6 -7
- data/webpack/components/Bookmark/AddBookmarkModal.js +3 -3
- data/webpack/components/Bookmark/Bookmark.scss +3 -3
- data/webpack/components/Bookmark/index.js +7 -2
- data/webpack/components/EditableSwitch.js +1 -1
- data/webpack/components/EditableTextInput/EditableTextInput.js +1 -1
- data/webpack/components/EditableTextInput/editableTextInput.scss +1 -1
- data/webpack/components/Errata/index.js +1 -24
- data/webpack/components/Loading.js +10 -6
- data/webpack/components/Packages/index.js +2 -1
- data/webpack/components/SelectAllCheckbox/index.js +7 -3
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +21 -3
- data/webpack/components/Table/EmptyStateMessage.js +12 -14
- data/webpack/components/Table/MainTable.js +8 -7
- data/webpack/components/Table/MainTable.scss +4 -4
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +4 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +1 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +9 -6
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +2 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +4 -1
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +23 -6
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +1 -1
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +5 -3
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.scss +3 -3
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +1 -1
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +25 -10
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +5 -2
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +2 -2
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +5 -4
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +6 -3
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +19 -12
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +1 -1
- data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +1 -4
- data/webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js +1 -4
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +1 -4
- data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/HwPropertiesCard.test.js +63 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/ImageModeCard.test.js +73 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/InstalledProductsCard.test.js +45 -0
- data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebInstallModal.js +12 -2
- data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebInstallModal.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebsTab.js +10 -13
- data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebsTab.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +46 -21
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +15 -7
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +13 -3
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +34 -20
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +8 -6
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +5 -3
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.scss +1 -1
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +12 -13
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +16 -6
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/debsInstallModal.test.js +10 -5
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/debsTab.test.js +48 -22
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +123 -47
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +14 -7
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +10 -5
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +41 -24
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +50 -25
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +50 -25
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +3 -0
- data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/04_Review.js +16 -2
- data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/04_ReviewFooter.js +6 -2
- data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/BulkErrataWizard.js +5 -1
- data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/04_Review.js +16 -2
- data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/04_ReviewFooter.js +6 -2
- data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/BulkPackagesWizard.js +15 -2
- data/webpack/components/extensions/Hosts/BulkActions/HostReview.js +1 -1
- data/webpack/components/extensions/Hosts/BulkActions/__tests__/bulkChangeHostCVModal.test.js +2 -1
- data/webpack/components/extensions/Hosts/FontAwesomeImageModeIcon.js +1 -1
- data/webpack/components/extensions/Hosts/ImageModeHostAlert.js +14 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +14 -17
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +1 -1
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +1 -1
- data/webpack/components/extensions/RegistrationCommands/fields/ActivationKeys.js +38 -49
- data/webpack/containers/Application/overrides.scss +7 -7
- data/webpack/ouia_id_check.js +15 -11
- data/webpack/redux/actions/RedHatRepositories/helpers.js +0 -2
- data/webpack/scenes/ActivationKeys/Details/__tests__/activationKeyDetails.test.js +12 -6
- data/webpack/scenes/ActivationKeys/Details/components/DeleteMenu.js +12 -2
- data/webpack/scenes/ActivationKeys/Details/components/EditModal.js +3 -3
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +3 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +3 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +12 -6
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +1 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +22 -7
- data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +2 -2
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +1 -1
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +6 -3
- data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +25 -15
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +9 -6
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +2 -2
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +1 -1
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +33 -7
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +10 -5
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +4 -2
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +10 -8
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +4 -2
- data/webpack/scenes/BootedContainerImages/BootedContainerImagesPage.js +5 -5
- data/webpack/scenes/Content/Details/__tests__/contentDetail.test.js +8 -4
- data/webpack/scenes/Content/__tests__/contentTable.test.js +4 -2
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +1 -1
- data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +2 -1
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +86 -31
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.scss +10 -2
- data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +10 -4
- data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +3 -1
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeleteEnvironmentsSelection.js +6 -6
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignActivationKeysForm.js +7 -2
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignHostsForm.js +7 -2
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReview.js +3 -3
- data/webpack/scenes/ContentViews/Delete/Steps/CVEnvironmentSelectionForm.scss +1 -1
- data/webpack/scenes/ContentViews/Delete/__tests__/CvData.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/Delete/__tests__/affectedHosts.fixtures.json +3 -2
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +10 -8
- data/webpack/scenes/ContentViews/Delete/__tests__/cvDetails.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +16 -5
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +19 -5
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentEnvironments.js +1 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +11 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/compositeCVDetails.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +69 -27
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/publishedContentViewDetails.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +22 -29
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +6 -2
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +20 -7
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +4 -2
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositorySelection.js +5 -2
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +3 -1
- data/webpack/scenes/ContentViews/Details/Filters/ArtifactsWithNoErrata.js +1 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +4 -2
- data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +13 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +23 -7
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +23 -5
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +15 -3
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +15 -3
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +13 -1
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +6 -4
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +11 -1
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +4 -2
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/matchContentModal.scss +1 -1
- data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +2 -2
- data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +4 -4
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +18 -12
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +7 -11
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +81 -70
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewErrataByDateDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +4 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +52 -38
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataDateFilterContent.test.js +9 -4
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +18 -12
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErratumFilterDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailModuleAffectedRepos.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailWithAffectedRepos.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterFixutre.fixture.json +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +77 -67
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilterDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterDetail.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +2 -2
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +4 -2
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +1 -1
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +7 -5
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +6 -3
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +3 -2
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +3 -1
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +2 -2
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +3 -1
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +3 -1
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +11 -11
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +15 -5
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionEnvironments.js +1 -1
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +13 -3
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +3 -1
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVEnvironmentSelectionForm.js +17 -13
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignActivationKeysForm.js +12 -7
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignHostsForm.js +64 -7
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +52 -21
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +30 -16
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.scss +7 -7
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +5 -3
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +4 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +6 -3
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +2 -1
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +6 -6
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +35 -4
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewRollingDetail.test.js +197 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewRollingDetails.fixtures.json +82 -0
- data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +3 -7
- data/webpack/scenes/ContentViews/Publish/CVPublishForm.js +2 -2
- data/webpack/scenes/ContentViews/Publish/CVPublishReview.js +6 -5
- data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +3 -1
- data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +15 -7
- data/webpack/scenes/ContentViews/Publish/cvPublishForm.scss +4 -4
- data/webpack/scenes/ContentViews/Table/ContentViewVersionCell.js +6 -4
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +14 -3
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +3 -0
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +1 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +89 -2
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +85 -14
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +20 -6
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelect.js +4 -1
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelectOption.js +11 -2
- data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +27 -7
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +2 -2
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +6 -2
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +4 -1
- data/webpack/scenes/ContentViews/components/FiltersAppliedIcon.js +4 -2
- data/webpack/scenes/ContentViews/components/NeedsPublishIcon.js +7 -6
- data/webpack/scenes/ContentViews/components/NeedsPublishIcon.scss +2 -2
- data/webpack/scenes/ContentViews/components/contentViewIcon.scss +16 -3
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +6 -1
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +3 -3
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +2 -1
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceForm.js +5 -3
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceTemplate.js +3 -2
- data/webpack/scenes/Hosts/ChangeContentSource/components/FormField.js +1 -1
- data/webpack/scenes/Hosts/ChangeContentSource/components/HostsModal.js +1 -1
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepositoryContent.js +1 -1
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/__snapshots__/EnabledRepositoryContent.test.js.snap +1 -1
- data/webpack/scenes/RedHatRepositories/index.scss +1 -1
- data/webpack/scenes/SmartProxy/ExpandableCvDetails.js +27 -7
- data/webpack/scenes/SmartProxy/ExpandedSmartProxyRepositories.js +51 -2
- data/webpack/scenes/SmartProxy/SmartProxyExpandableTable.js +2 -2
- data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentTest.js +14 -9
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationForm.scss +1 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CustomCdnTypeForm.js +2 -2
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/NetworkSyncForm.js +6 -6
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CdnTypeForm.test.js +2 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CustomCdnTypeForm.test.js +2 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/ExportSyncForm.test.js +2 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/NetworkSyncForm.test.js +2 -1
- metadata +125 -53
- data/app/models/katello/yum_metadata_file.rb +0 -22
- data/app/services/katello/pulp3/yum_metadata_file.rb +0 -20
@@ -4,10 +4,8 @@ import {
|
|
4
4
|
EmptyStateBody,
|
5
5
|
EmptyStateIcon,
|
6
6
|
EmptyStateVariant,
|
7
|
-
EmptyStateSecondaryActions,
|
8
7
|
Bullseye,
|
9
|
-
|
10
|
-
Button,
|
8
|
+
Button, EmptyStateActions, EmptyStateHeader, EmptyStateFooter,
|
11
9
|
} from '@patternfly/react-core';
|
12
10
|
import PropTypes from 'prop-types';
|
13
11
|
import { translate as __ } from 'foremanReact/common/I18n';
|
@@ -77,7 +75,7 @@ const EmptyStateMessage = ({
|
|
77
75
|
return (
|
78
76
|
<Bullseye>
|
79
77
|
<EmptyState
|
80
|
-
variant={happy ? EmptyStateVariant.xl : EmptyStateVariant.
|
78
|
+
variant={happy ? EmptyStateVariant.xl : EmptyStateVariant.sm}
|
81
79
|
>
|
82
80
|
<KatelloEmptyStateIcon
|
83
81
|
error={!!error}
|
@@ -85,15 +83,14 @@ const EmptyStateMessage = ({
|
|
85
83
|
customIcon={PlusCircleIcon}
|
86
84
|
happyIcon={happy}
|
87
85
|
/>
|
88
|
-
<
|
89
|
-
{emptyStateTitle}
|
90
|
-
</Title>
|
86
|
+
<EmptyStateHeader titleText={<>{emptyStateTitle}</>} headingLevel="h2" />
|
91
87
|
<EmptyStateBody>
|
92
88
|
{emptyStateBody}
|
93
89
|
</EmptyStateBody>
|
94
|
-
|
95
|
-
|
96
|
-
|
90
|
+
<EmptyStateFooter>
|
91
|
+
{showPrimaryAction && actionButton}
|
92
|
+
{showSecondaryActionAnchor &&
|
93
|
+
<EmptyStateActions>
|
97
94
|
<Button variant="link" ouiaId="empty-state-secondary-action-link">
|
98
95
|
{extraTableProps.secondaryActionTargetBlank ? (
|
99
96
|
<a href={secondaryActionLink} target="_blank" rel="noreferrer" style={{ textDecoration: 'none' }} >{secondaryActionTitle}</a>
|
@@ -101,17 +98,18 @@ const EmptyStateMessage = ({
|
|
101
98
|
<a href={secondaryActionLink} style={{ textDecoration: 'none' }} >{secondaryActionTitle}</a>
|
102
99
|
)}
|
103
100
|
</Button>
|
104
|
-
</
|
101
|
+
</EmptyStateActions>
|
105
102
|
}
|
106
103
|
|
107
|
-
|
104
|
+
{(!showSecondaryActionAnchor &&
|
108
105
|
(showSecondaryActionButton || searchIsActive || !!filtersAreActive)) &&
|
109
|
-
<
|
106
|
+
<EmptyStateActions>
|
110
107
|
<Button variant="link" onClick={handleClick} ouiaId="empty-state-secondary-action-router-link">
|
111
108
|
{secondaryActionText}
|
112
109
|
</Button>
|
113
|
-
</
|
110
|
+
</EmptyStateActions>
|
114
111
|
}
|
112
|
+
</EmptyStateFooter>
|
115
113
|
</EmptyState>
|
116
114
|
</Bullseye>
|
117
115
|
);
|
@@ -1,11 +1,12 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { translate as __ } from 'foremanReact/common/I18n';
|
3
|
+
|
3
4
|
import {
|
4
|
-
Table,
|
5
|
+
Table as TableDeprecated,
|
5
6
|
TableHeader,
|
6
7
|
TableBody,
|
7
|
-
|
8
|
-
} from '@patternfly/react-table';
|
8
|
+
Table,
|
9
|
+
} from '@patternfly/react-table/deprecated';
|
9
10
|
import { STATUS } from 'foremanReact/constants';
|
10
11
|
import { isEqual } from 'lodash';
|
11
12
|
import PropTypes from 'prop-types';
|
@@ -96,18 +97,18 @@ const MainTable = ({
|
|
96
97
|
const tableProps = { cells, rows, ...extraTableProps };
|
97
98
|
if (children) {
|
98
99
|
return (
|
99
|
-
<
|
100
|
+
<Table
|
100
101
|
ouiaId="content-view-table-composable"
|
101
102
|
aria-label="Content View Table"
|
102
103
|
className="katello-pf4-table"
|
103
104
|
{...extraTableProps}
|
104
105
|
>
|
105
106
|
{children}
|
106
|
-
</
|
107
|
+
</Table>
|
107
108
|
);
|
108
109
|
}
|
109
110
|
return (
|
110
|
-
<
|
111
|
+
<TableDeprecated
|
111
112
|
ouiaId="Content-View-table"
|
112
113
|
aria-label="Content View Table"
|
113
114
|
className="katello-pf4-table"
|
@@ -115,7 +116,7 @@ const MainTable = ({
|
|
115
116
|
>
|
116
117
|
<TableHeader />
|
117
118
|
<TableBody />
|
118
|
-
</
|
119
|
+
</TableDeprecated>
|
119
120
|
);
|
120
121
|
};
|
121
122
|
|
@@ -1,18 +1,18 @@
|
|
1
1
|
.katello-pf4-table {
|
2
|
-
.pf-c-dropdown.pf-m-align-right {
|
2
|
+
.pf-v5-c-dropdown.pf-m-align-right {
|
3
3
|
width: 100%;
|
4
4
|
justify-content: flex-end;
|
5
5
|
display: flex;
|
6
6
|
}
|
7
7
|
|
8
|
-
.pf-c-dropdown__menu {
|
8
|
+
.pf-v5-c-dropdown__menu {
|
9
9
|
min-width: 0;
|
10
10
|
}
|
11
|
-
.pf-c-wizard__footer {
|
11
|
+
.pf-v5-c-wizard__footer {
|
12
12
|
z-index: 1;
|
13
13
|
}
|
14
14
|
|
15
|
-
.pf-c-table tbody tr td {
|
15
|
+
.pf-v5-c-table tbody tr td {
|
16
16
|
vertical-align: inherit;
|
17
17
|
}
|
18
18
|
|
@@ -1,6 +1,9 @@
|
|
1
1
|
import React, { useContext } from 'react';
|
2
2
|
import { useSelector, useDispatch } from 'react-redux';
|
3
|
-
import {
|
3
|
+
import {
|
4
|
+
DropdownItem,
|
5
|
+
DropdownSeparator,
|
6
|
+
} from '@patternfly/react-core/deprecated';
|
4
7
|
import { CubeIcon, UndoIcon, RedoIcon } from '@patternfly/react-icons';
|
5
8
|
|
6
9
|
import { translate as __ } from 'foremanReact/common/I18n';
|
data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js
CHANGED
@@ -229,7 +229,7 @@ const ChangeHostCVModal = ({
|
|
229
229
|
</TextContent>
|
230
230
|
<Checkbox
|
231
231
|
isChecked={forceProfileUpload}
|
232
|
-
onChange={setForceProfileUpload}
|
232
|
+
onChange={(_event, val) => setForceProfileUpload(val)}
|
233
233
|
label={__('Update the host immediately via remote execution')}
|
234
234
|
id="force-profile-upload-checkbox"
|
235
235
|
ouiaId="force-profile-upload-checkbox"
|
@@ -4,15 +4,17 @@ import {
|
|
4
4
|
CardHeader,
|
5
5
|
CardTitle,
|
6
6
|
CardBody,
|
7
|
-
Dropdown,
|
8
|
-
DropdownItem,
|
9
7
|
Flex,
|
10
8
|
FlexItem,
|
11
9
|
GridItem,
|
12
|
-
KebabToggle,
|
13
10
|
Label,
|
14
11
|
Tooltip,
|
15
12
|
} from '@patternfly/react-core';
|
13
|
+
import {
|
14
|
+
Dropdown,
|
15
|
+
DropdownItem,
|
16
|
+
KebabToggle,
|
17
|
+
} from '@patternfly/react-core/deprecated';
|
16
18
|
import { FormattedMessage } from 'react-intl';
|
17
19
|
|
18
20
|
import { urlBuilder } from 'foremanReact/common/urlHelpers';
|
@@ -59,15 +61,15 @@ export const ContentViewEnvironmentDisplay = ({
|
|
59
61
|
}}
|
60
62
|
/>}
|
61
63
|
>
|
62
|
-
<Label
|
64
|
+
<Label color="purple" href={`/lifecycle_environments/${lifecycleEnvironment.id}`} style={{ marginRight: '2px' }}>{lifecycleEnvironment.name}</Label>
|
63
65
|
</Tooltip>
|
64
|
-
<ContentViewIcon composite={contentView.composite} style={{ marginRight: '2px' }} position="left" />
|
66
|
+
<ContentViewIcon composite={contentView.composite} rolling={contentViewDefault || contentView.rolling} style={{ marginRight: '2px' }} position="left" />
|
65
67
|
{contentViewDefault ? <span>{contentView.name}</span> :
|
66
68
|
<a style={{ fontSize: '14px' }} href={`/content_views/${contentView.id}`}>
|
67
69
|
{truncate(contentView.name)}
|
68
70
|
</a>
|
69
71
|
}
|
70
|
-
{!contentViewDefault &&
|
72
|
+
{!(contentViewDefault || contentView.rolling) &&
|
71
73
|
<FlexItem>
|
72
74
|
<a style={{ fontSize: '14px' }} href={urlBuilder(`content_views/${contentView.id}/versions/${contentViewVersionId}`, '')}>
|
73
75
|
<FormattedMessage
|
@@ -89,6 +91,7 @@ ContentViewEnvironmentDisplay.propTypes = {
|
|
89
91
|
name: PropTypes.string,
|
90
92
|
id: PropTypes.number,
|
91
93
|
composite: PropTypes.bool,
|
94
|
+
rolling: PropTypes.bool,
|
92
95
|
}).isRequired,
|
93
96
|
lifecycleEnvironment: PropTypes.shape({
|
94
97
|
name: PropTypes.string,
|
@@ -126,6 +126,7 @@ test('Select an env > call CV API > select a CV > Save button is enabled', async
|
|
126
126
|
expect(saveButton).toBeInTheDocument();
|
127
127
|
expect(saveButton).toHaveAttribute('aria-disabled', 'false');
|
128
128
|
|
129
|
-
assertNockRequest(contentViewsScope
|
129
|
+
assertNockRequest(contentViewsScope);
|
130
|
+
done();
|
130
131
|
act(done);
|
131
132
|
});
|
@@ -14,6 +14,7 @@
|
|
14
14
|
"results": [
|
15
15
|
{
|
16
16
|
"composite": false,
|
17
|
+
"rolling": false,
|
17
18
|
"component_ids": [],
|
18
19
|
"default": true,
|
19
20
|
"version_count": 1,
|
@@ -92,6 +93,7 @@
|
|
92
93
|
},
|
93
94
|
{
|
94
95
|
"composite": true,
|
96
|
+
"rolling": false,
|
95
97
|
"component_ids": [
|
96
98
|
3
|
97
99
|
],
|
@@ -317,6 +319,7 @@
|
|
317
319
|
},
|
318
320
|
{
|
319
321
|
"composite": false,
|
322
|
+
"rolling": false,
|
320
323
|
"component_ids": [],
|
321
324
|
"default": false,
|
322
325
|
"version_count": 2,
|
@@ -440,4 +443,4 @@
|
|
440
443
|
}
|
441
444
|
}
|
442
445
|
]
|
443
|
-
}
|
446
|
+
}
|
@@ -8,13 +8,15 @@ import {
|
|
8
8
|
FlexItem,
|
9
9
|
GridItem,
|
10
10
|
ToggleGroup,
|
11
|
+
ToggleGroupItem,
|
12
|
+
Tooltip,
|
11
13
|
} from '@patternfly/react-core';
|
12
14
|
import { ExclamationTriangleIcon } from '@patternfly/react-icons';
|
13
15
|
import { translate as __ } from 'foremanReact/common/I18n';
|
14
16
|
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
15
17
|
import PropTypes from 'prop-types';
|
16
|
-
import { ChartPie } from '@patternfly/react-charts';
|
17
|
-
import { ErrataMapper
|
18
|
+
import { ChartPie, ChartTooltip } from '@patternfly/react-charts';
|
19
|
+
import { ErrataMapper } from '../../../../components/Errata';
|
18
20
|
import { hostIsRegistered } from '../hostDetailsHelpers';
|
19
21
|
import { TranslatedAnchor } from '../../../Table/components/TranslatedPlural';
|
20
22
|
import EmptyStateMessage from '../../../Table/EmptyStateMessage';
|
@@ -85,6 +87,9 @@ function HostInstallableErrata({
|
|
85
87
|
}}
|
86
88
|
width={250}
|
87
89
|
height={130}
|
90
|
+
labelComponent={
|
91
|
+
<ChartTooltip constrainToVisibleArea renderInPortal={false} />
|
92
|
+
}
|
88
93
|
/>
|
89
94
|
</div>
|
90
95
|
</div>
|
@@ -120,20 +125,32 @@ const ErrataOverviewCard = ({ hostDetails }) => {
|
|
120
125
|
<CardTitle>{__('Errata')}</CardTitle>
|
121
126
|
{neededErrata &&
|
122
127
|
<ToggleGroup isCompact>
|
123
|
-
<
|
128
|
+
<ToggleGroupItem
|
124
129
|
text={__('Applicable')}
|
125
130
|
aria-label="Show applicable errata chart"
|
126
|
-
|
131
|
+
buttonId="applicableToggle"
|
127
132
|
isSelected={errataCategory === 'applicable'}
|
128
133
|
onChange={selected => selected && setErrataCategory('applicable')}
|
129
134
|
/>
|
130
|
-
<
|
135
|
+
<ToggleGroupItem
|
131
136
|
text={__('Installable')}
|
132
137
|
aria-label="Show installable errata chart"
|
133
|
-
|
138
|
+
buttonId="installableToggle"
|
134
139
|
isSelected={errataCategory === 'installable'}
|
135
140
|
onChange={selected => selected && setErrataCategory('installable')}
|
136
141
|
/>
|
142
|
+
<Tooltip
|
143
|
+
content={__('Applicable errata apply to at least one package installed on the host.')}
|
144
|
+
position="top"
|
145
|
+
enableFlip
|
146
|
+
triggerRef={() => document.getElementById('applicableToggle')}
|
147
|
+
/>
|
148
|
+
<Tooltip
|
149
|
+
content={__('Installable errata are applicable errata that are available in the host\'s assigned content view environments.')}
|
150
|
+
position="top"
|
151
|
+
enableFlip
|
152
|
+
triggerRef={() => document.getElementById('installableToggle')}
|
153
|
+
/>
|
137
154
|
</ToggleGroup>
|
138
155
|
}
|
139
156
|
</Flex>
|
data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js
CHANGED
@@ -6,14 +6,16 @@ import {
|
|
6
6
|
CardHeader,
|
7
7
|
CardTitle,
|
8
8
|
CardBody,
|
9
|
-
Dropdown,
|
10
9
|
ExpandableSection,
|
11
|
-
KebabToggle,
|
12
10
|
Flex,
|
13
11
|
FlexItem,
|
14
12
|
GridItem,
|
15
|
-
DropdownItem,
|
16
13
|
} from '@patternfly/react-core';
|
14
|
+
import {
|
15
|
+
Dropdown,
|
16
|
+
KebabToggle,
|
17
|
+
DropdownItem,
|
18
|
+
} from '@patternfly/react-core/deprecated';
|
17
19
|
import { PlusCircleIcon } from '@patternfly/react-icons';
|
18
20
|
import { translate as __ } from 'foremanReact/common/I18n';
|
19
21
|
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.scss
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
.host-collection-card-body {
|
2
|
-
.pf-l-bullseye {
|
2
|
+
.pf-v5-l-bullseye {
|
3
3
|
position: relative;
|
4
4
|
top: -20px;
|
5
5
|
}
|
6
|
-
.pf-c-empty-state__icon {
|
6
|
+
.pf-v5-c-empty-state__icon {
|
7
7
|
font-size: 2em;
|
8
8
|
}
|
9
9
|
.pf-m-lg {
|
10
10
|
margin: -20px;
|
11
11
|
}
|
12
|
-
.pf-c-empty-state__body {
|
12
|
+
.pf-v5-c-empty-state__body {
|
13
13
|
font-size: smaller;
|
14
14
|
margin-top: 1.4em;
|
15
15
|
margin-bottom: 1em;
|
data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js
CHANGED
@@ -192,7 +192,7 @@ export const HostCollectionsModal = ({
|
|
192
192
|
<Tr key={id} ouiaId={`row-${id}`}>
|
193
193
|
<Td
|
194
194
|
select={{
|
195
|
-
|
195
|
+
isDisabled,
|
196
196
|
isSelected: isSelected(id),
|
197
197
|
onSelect: (_event, selected) => selectOne(selected, id, hostCollection),
|
198
198
|
rowIndex,
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import React from 'react';
|
2
|
-
import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
|
2
|
+
import { renderWithRedux, patientlyWaitFor, fireEvent, act, waitFor } from 'react-testing-lib-wrapper';
|
3
3
|
import mockAvailableHostCollections from './availableHostCollections.fixtures.json';
|
4
4
|
import mockRemovableHostCollections from './removableHostCollections.fixtures.json';
|
5
5
|
import { REMOVABLE_HOST_COLLECTIONS_KEY } from '../HostCollectionsConstants';
|
6
|
-
import { assertNockRequest, mockAutocomplete, nockInstance } from '../../../../../../test-utils/nockWrapper';
|
6
|
+
import nock, { assertNockRequest, mockAutocomplete, nockInstance } from '../../../../../../test-utils/nockWrapper';
|
7
7
|
import katelloApi, { foremanApi } from '../../../../../../services/api';
|
8
8
|
import { HostCollectionsAddModal, HostCollectionsRemoveModal } from '../HostCollectionsModal';
|
9
9
|
|
@@ -44,6 +44,10 @@ describe('HostCollectionsAddModal', () => {
|
|
44
44
|
const { results } = mockAvailableHostCollections;
|
45
45
|
[firstHostCollection] = results;
|
46
46
|
});
|
47
|
+
afterEach(() => {
|
48
|
+
nock.cleanAll(); // Removes all interceptors
|
49
|
+
nock.restore(); // Restores HTTP to normal behavior
|
50
|
+
});
|
47
51
|
|
48
52
|
test('Calls API with available_for=host on page load', async (done) => {
|
49
53
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
@@ -65,7 +69,8 @@ describe('HostCollectionsAddModal', () => {
|
|
65
69
|
await patientlyWaitFor(() =>
|
66
70
|
expect(getAllByText(firstHostCollection.name)[0]).toBeInTheDocument());
|
67
71
|
assertNockRequest(autocompleteScope);
|
68
|
-
assertNockRequest(scope
|
72
|
+
assertNockRequest(scope);
|
73
|
+
act(done);
|
69
74
|
});
|
70
75
|
|
71
76
|
test('Calls alterHostCollections with combined list of existing and new host collections', async (done) => {
|
@@ -107,6 +112,7 @@ describe('HostCollectionsAddModal', () => {
|
|
107
112
|
assertNockRequest(autocompleteScope);
|
108
113
|
assertNockRequest(scope);
|
109
114
|
assertNockRequest(alterScope);
|
115
|
+
await waitFor(() => expect(hostDetailsScope.isDone()).toBe(true));
|
110
116
|
assertNockRequest(hostDetailsScope, done);
|
111
117
|
});
|
112
118
|
test('Host collections whose host limit is exceeded are disabled', async (done) => {
|
@@ -136,7 +142,8 @@ describe('HostCollectionsAddModal', () => {
|
|
136
142
|
expect(disabledCheckboxes).toHaveLength(maxedOutHostCollections.length);
|
137
143
|
|
138
144
|
assertNockRequest(autocompleteScope);
|
139
|
-
assertNockRequest(scope
|
145
|
+
assertNockRequest(scope);
|
146
|
+
act(done); // Pass jest callback to confirm test is done
|
140
147
|
});
|
141
148
|
});
|
142
149
|
|
@@ -146,6 +153,10 @@ describe('HostCollectionsRemoveModal', () => {
|
|
146
153
|
[firstHostCollection] = results;
|
147
154
|
});
|
148
155
|
|
156
|
+
afterEach(() => {
|
157
|
+
nock.cleanAll(); // Removes all interceptors
|
158
|
+
nock.restore(); // Restores HTTP to normal behavior
|
159
|
+
});
|
149
160
|
test('Calls API without available_for=host on page load', async (done) => {
|
150
161
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
151
162
|
|
@@ -168,7 +179,8 @@ describe('HostCollectionsRemoveModal', () => {
|
|
168
179
|
expect(getAllByText(firstHostCollection.name)[0]).toBeInTheDocument());
|
169
180
|
// Assert request was made and completed, see helper function
|
170
181
|
assertNockRequest(autocompleteScope);
|
171
|
-
assertNockRequest(scope
|
182
|
+
assertNockRequest(scope);
|
183
|
+
act(done); // Pass jest callback to confirm test is done
|
172
184
|
});
|
173
185
|
|
174
186
|
test('Calls alterHostCollections with host collections being removed filtered out from the list', async (done) => {
|
@@ -204,16 +216,19 @@ describe('HostCollectionsRemoveModal', () => {
|
|
204
216
|
await patientlyWaitFor(() =>
|
205
217
|
expect(getAllByText(firstRemovableHostCollection.name)[0]).toBeInTheDocument());
|
206
218
|
const checkbox = getByRole('checkbox', { name: 'Select row 0' });
|
207
|
-
|
219
|
+
await act(async () => {
|
220
|
+
fireEvent.click(checkbox);
|
221
|
+
});
|
208
222
|
expect(getAllByText('1 selected')).toHaveLength(1);
|
209
223
|
const removeButton = getByRole('button', { name: 'Remove' });
|
210
224
|
expect(removeButton).toHaveAttribute('aria-disabled', 'false');
|
211
|
-
|
212
|
-
|
225
|
+
await act(async () => {
|
226
|
+
fireEvent.click(removeButton);
|
227
|
+
});
|
213
228
|
assertNockRequest(autocompleteScope);
|
214
229
|
assertNockRequest(scope);
|
215
230
|
assertNockRequest(alterScope);
|
216
|
-
assertNockRequest(hostDetailsScope
|
231
|
+
assertNockRequest(hostDetailsScope);
|
232
|
+
act(done);
|
217
233
|
});
|
218
234
|
});
|
219
|
-
|
@@ -20,6 +20,7 @@ import {
|
|
20
20
|
Tooltip,
|
21
21
|
Skeleton,
|
22
22
|
CardExpandableContent,
|
23
|
+
Icon,
|
23
24
|
} from '@patternfly/react-core';
|
24
25
|
import { OutlinedQuestionCircleIcon } from '@patternfly/react-icons';
|
25
26
|
import { translate as __ } from 'foremanReact/common/I18n';
|
@@ -101,14 +102,16 @@ const SystemPurposeCard = ({ hostDetails, akDetails }) => {
|
|
101
102
|
enableFlip
|
102
103
|
isContentLeftAligned
|
103
104
|
>
|
104
|
-
<
|
105
|
+
<Icon color="gray">
|
106
|
+
<OutlinedQuestionCircleIcon style={{ marginTop: '7px' }} />
|
107
|
+
</Icon>
|
105
108
|
</Tooltip>
|
106
109
|
</FlexItem>
|
107
110
|
</Flex>
|
108
111
|
</FlexItem>
|
109
112
|
{showEditButton && (
|
110
113
|
<FlexItem>
|
111
|
-
<Button variant="link"
|
114
|
+
<Button variant="link" size="sm" ouiaId="syspurpose-edit-button" onClick={() => setEditing(val => !val)}>{__('Edit')}</Button>
|
112
115
|
</FlexItem>)
|
113
116
|
}
|
114
117
|
</Flex>
|
data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js
CHANGED
@@ -11,6 +11,7 @@ import {
|
|
11
11
|
FormSelect,
|
12
12
|
FormSelectOption,
|
13
13
|
} from '@patternfly/react-core';
|
14
|
+
|
14
15
|
import { FormattedMessage } from 'react-intl';
|
15
16
|
import { translate as __ } from 'foremanReact/common/I18n';
|
16
17
|
import {
|
@@ -183,7 +184,7 @@ const SystemPurposeEditModal = ({
|
|
183
184
|
name="role"
|
184
185
|
ouiaId="role-select"
|
185
186
|
value={selectedRole}
|
186
|
-
onChange={setSelectedRole}
|
187
|
+
onChange={(_event, val) => setSelectedRole(val)}
|
187
188
|
>
|
188
189
|
{roleOptions.map(option => (
|
189
190
|
<FormSelectOption
|
@@ -200,7 +201,7 @@ const SystemPurposeEditModal = ({
|
|
200
201
|
name="serviceLevel"
|
201
202
|
ouiaId="service-level-select"
|
202
203
|
value={selectedServiceLevel}
|
203
|
-
onChange={setSelectedServiceLevel}
|
204
|
+
onChange={(_event, val) => setSelectedServiceLevel(val)}
|
204
205
|
>
|
205
206
|
{serviceLevelOptions.map(option => (
|
206
207
|
<FormSelectOption
|
@@ -217,7 +218,7 @@ const SystemPurposeEditModal = ({
|
|
217
218
|
name="usage"
|
218
219
|
ouiaId="usage-select"
|
219
220
|
value={selectedUsage}
|
220
|
-
onChange={setSelectedUsage}
|
221
|
+
onChange={(_event, val) => setSelectedUsage(val)}
|
221
222
|
>
|
222
223
|
{usageOptions.map(option => (
|
223
224
|
<FormSelectOption
|
@@ -234,7 +235,7 @@ const SystemPurposeEditModal = ({
|
|
234
235
|
name="release_version"
|
235
236
|
ouiaId="release-version-select"
|
236
237
|
value={selectedReleaseVersion}
|
237
|
-
onChange={setSelectedReleaseVersion}
|
238
|
+
onChange={(_event, val) => setSelectedReleaseVersion(val)}
|
238
239
|
>
|
239
240
|
{releaseVersionOptions.map(option => (
|
240
241
|
<FormSelectOption
|
@@ -63,7 +63,8 @@ test('shows system purpose details for a host', async (done) => {
|
|
63
63
|
expect(getByText('8')).toBeInTheDocument();
|
64
64
|
|
65
65
|
assertNockRequest(orgScope);
|
66
|
-
assertNockRequest(availableReleaseVersionsScope
|
66
|
+
assertNockRequest(availableReleaseVersionsScope);
|
67
|
+
done();
|
67
68
|
});
|
68
69
|
|
69
70
|
test('shows system purpose details for an activation key', () => {
|
@@ -93,7 +94,8 @@ test('shows edit button for a user with edit_hosts permission', async (done) =>
|
|
93
94
|
expect(queryByText('Edit')).toBeInTheDocument();
|
94
95
|
|
95
96
|
assertNockRequest(orgScope);
|
96
|
-
assertNockRequest(availableReleaseVersionsScope
|
97
|
+
assertNockRequest(availableReleaseVersionsScope);
|
98
|
+
done();
|
97
99
|
});
|
98
100
|
|
99
101
|
test('does not show edit button for a user without edit_hosts permission', (done) => {
|
@@ -118,6 +120,7 @@ test('does not show edit button for a user without edit_hosts permission', (done
|
|
118
120
|
expect(queryByText('Edit')).not.toBeInTheDocument();
|
119
121
|
|
120
122
|
assertNockRequest(orgScope);
|
121
|
-
assertNockRequest(availableReleaseVersionsScope
|
123
|
+
assertNockRequest(availableReleaseVersionsScope);
|
124
|
+
done();
|
122
125
|
act(done);
|
123
126
|
});
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
3
|
-
import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
|
3
|
+
import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
|
4
4
|
import HOST_DETAILS from '../../../HostDetailsConstants';
|
5
5
|
import SystemPurposeEditModal from '../SystemPurposeEditModal';
|
6
6
|
import { assertNockRequest, nockInstance } from '../../../../../../test-utils/nockWrapper';
|
@@ -87,7 +87,8 @@ describe('SystemPurposeEditModal', () => {
|
|
87
87
|
expect(getByText('8')).toBeInTheDocument();
|
88
88
|
|
89
89
|
assertNockRequest(orgScope);
|
90
|
-
assertNockRequest(availableReleaseVersionsScope
|
90
|
+
assertNockRequest(availableReleaseVersionsScope);
|
91
|
+
done();
|
91
92
|
});
|
92
93
|
|
93
94
|
test('Shows blank options as (unset)', () => {
|
@@ -159,8 +160,9 @@ describe('SystemPurposeEditModal', () => {
|
|
159
160
|
|
160
161
|
// Save button should now be enabled
|
161
162
|
expect(saveButton).toHaveAttribute('aria-disabled', 'false');
|
162
|
-
|
163
|
-
|
163
|
+
await act(async () => {
|
164
|
+
fireEvent.click(saveButton);
|
165
|
+
});
|
164
166
|
await patientlyWaitFor(() => {
|
165
167
|
expect(baseAttributes.closeModal).toHaveBeenCalled();
|
166
168
|
});
|
@@ -168,7 +170,8 @@ describe('SystemPurposeEditModal', () => {
|
|
168
170
|
[orgScope, availableReleaseVersionsScope, hostEditScope].forEach((scope) => {
|
169
171
|
assertNockRequest(scope);
|
170
172
|
});
|
171
|
-
assertNockRequest(hostDetailsScope
|
173
|
+
assertNockRequest(hostDetailsScope);
|
174
|
+
done();
|
172
175
|
});
|
173
176
|
test('Calls API and changes syspurpose values for activation key', async (done) => {
|
174
177
|
const orgScope = nockInstance
|
@@ -212,8 +215,9 @@ describe('SystemPurposeEditModal', () => {
|
|
212
215
|
|
213
216
|
// Save button should now be enabled
|
214
217
|
expect(saveButton).toHaveAttribute('aria-disabled', 'false');
|
215
|
-
|
216
|
-
|
218
|
+
await act(async () => {
|
219
|
+
fireEvent.click(saveButton);
|
220
|
+
});
|
217
221
|
await patientlyWaitFor(() => {
|
218
222
|
expect(baseAttributes.closeModal).toHaveBeenCalled();
|
219
223
|
});
|
@@ -221,7 +225,8 @@ describe('SystemPurposeEditModal', () => {
|
|
221
225
|
[orgScope, availableReleaseVersionsScope, akEditScope].forEach((scope) => {
|
222
226
|
assertNockRequest(scope);
|
223
227
|
});
|
224
|
-
assertNockRequest(akDetailsScope
|
228
|
+
assertNockRequest(akDetailsScope);
|
229
|
+
done();
|
225
230
|
});
|
226
231
|
test('Retrieves available release versions for host', async (done) => {
|
227
232
|
const orgScope = nockInstance
|
@@ -241,8 +246,9 @@ describe('SystemPurposeEditModal', () => {
|
|
241
246
|
/>, renderOptions());
|
242
247
|
|
243
248
|
const releaseVersionDropdown = getByLabelText('Release version');
|
244
|
-
|
245
|
-
|
249
|
+
await act(async () => {
|
250
|
+
fireEvent.click(releaseVersionDropdown);
|
251
|
+
});
|
246
252
|
await patientlyWaitFor(() => {
|
247
253
|
expect(getByText('8')).toBeInTheDocument();
|
248
254
|
expect(getByText('9')).toBeInTheDocument();
|
@@ -271,8 +277,9 @@ describe('SystemPurposeEditModal', () => {
|
|
271
277
|
/>, renderOptions(ACTIVATION_KEY));
|
272
278
|
|
273
279
|
const releaseVersionDropdown = getByLabelText('Release version');
|
274
|
-
|
275
|
-
|
280
|
+
await act(async () => {
|
281
|
+
fireEvent.click(releaseVersionDropdown);
|
282
|
+
});
|
276
283
|
await patientlyWaitFor(() => {
|
277
284
|
expect(getByText('8')).toBeInTheDocument();
|
278
285
|
expect(getByText('9')).toBeInTheDocument();
|