katello 4.5.1 → 4.8.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/katello/common/vendor.js +0 -1
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +8 -22
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +10 -0
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +16 -10
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +9 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +59 -24
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +5 -4
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +22 -81
- data/app/controllers/katello/api/v2/content_exports_controller.rb +11 -80
- data/app/controllers/katello/api/v2/content_imports_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_views_controller.rb +1 -1
- data/app/controllers/katello/api/v2/debs_controller.rb +42 -10
- data/app/controllers/katello/api/v2/exports_controller.rb +130 -0
- data/app/controllers/katello/api/v2/host_collections_controller.rb +5 -1
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -0
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +9 -1
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +17 -10
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +9 -5
- data/app/controllers/katello/api/v2/organizations_controller.rb +7 -1
- data/app/controllers/katello/api/v2/package_groups_controller.rb +0 -52
- data/app/controllers/katello/api/v2/products_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +86 -30
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +25 -14
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +10 -2
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +1 -1
- data/app/controllers/katello/concerns/api/v2/bulk_hosts_extensions.rb +4 -6
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +7 -3
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +34 -11
- data/app/controllers/katello/concerns/api/v2/smart_proxies_controller_extensions.rb +1 -0
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +4 -1
- data/app/controllers/katello/concerns/content_facet_hosts_controller_extensions.rb +24 -0
- data/app/controllers/katello/concerns/hosts_controller_extensions.rb +14 -12
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +7 -16
- data/app/helpers/katello/content_source_helper.rb +11 -0
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +88 -21
- data/app/helpers/katello/katello_urls_helper.rb +0 -15
- data/app/helpers/katello/sync_management_helper.rb +0 -4
- data/app/lib/actions/candlepin/abstract_async_task.rb +7 -3
- data/app/lib/actions/candlepin/environment/set_content.rb +7 -1
- data/app/lib/actions/candlepin/owner/destroy_imports.rb +1 -1
- data/app/lib/actions/candlepin/owner/{upstream_export.rb → retrieve_upstream_export.rb} +3 -3
- data/app/lib/actions/candlepin/owner/start_upstream_export.rb +24 -0
- data/app/lib/actions/candlepin/upstream_abstract_async_task.rb +30 -0
- data/app/lib/actions/katello/activation_key/destroy.rb +1 -0
- data/app/lib/actions/katello/agent_action.rb +1 -0
- data/app/lib/actions/katello/alternate_content_source/alternate_content_source_common.rb +16 -0
- data/app/lib/actions/katello/alternate_content_source/create.rb +13 -5
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +3 -4
- data/app/lib/actions/katello/alternate_content_source/refresh.rb +3 -5
- data/app/lib/actions/katello/alternate_content_source/update.rb +59 -13
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +2 -2
- data/app/lib/actions/katello/capsule_content/sync.rb +10 -6
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +1 -2
- data/app/lib/actions/katello/cdn_configuration/update.rb +1 -1
- data/app/lib/actions/katello/content_view/promote.rb +1 -0
- data/app/lib/actions/katello/content_view/publish.rb +11 -4
- data/app/lib/actions/katello/content_view/remove.rb +8 -2
- data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +7 -3
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +4 -2
- data/app/lib/actions/katello/content_view_version/destroy.rb +1 -1
- data/app/lib/actions/katello/content_view_version/import.rb +22 -10
- data/app/lib/actions/katello/environment/destroy.rb +8 -2
- data/app/lib/actions/katello/host/reassign.rb +4 -2
- data/app/lib/actions/katello/organization/manifest_refresh.rb +20 -11
- data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +1 -9
- data/app/lib/actions/katello/orphan_cleanup/remove_orphans.rb +0 -1
- data/app/lib/actions/katello/product/destroy.rb +3 -2
- data/app/lib/actions/katello/repository/create.rb +9 -0
- data/app/lib/actions/katello/repository/destroy.rb +24 -3
- data/app/lib/actions/katello/repository/errata_mail.rb +9 -6
- data/app/lib/actions/katello/repository/filtered_index_content.rb +2 -10
- data/app/lib/actions/katello/repository/import_upload.rb +0 -1
- data/app/lib/actions/katello/repository/refresh_repository.rb +3 -0
- data/app/lib/actions/katello/repository/sync.rb +15 -9
- data/app/lib/actions/katello/repository/update.rb +39 -3
- data/app/lib/actions/katello/repository/update_redhat_repository.rb +1 -1
- data/app/lib/actions/katello/repository/upload_files.rb +0 -1
- data/app/lib/actions/katello/repository_set/enable_repository.rb +6 -2
- data/app/lib/actions/middleware/propagate_candlepin_errors.rb +6 -1
- data/app/lib/actions/pulp3/abstract.rb +0 -6
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh_remote.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +5 -5
- data/app/lib/actions/pulp3/capsule_content/reclaim_space.rb +1 -0
- data/app/lib/actions/pulp3/content_view/delete_repository_references.rb +1 -2
- data/app/lib/actions/pulp3/content_view_version/create_syncable_export_history.rb +4 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +6 -7
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +3 -2
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +12 -11
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +17 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/syncable_export.rb +7 -4
- data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +1 -0
- data/app/lib/actions/pulp3/orchestration/repository/copy_all_units.rb +1 -0
- data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +1 -1
- data/app/lib/actions/pulp3/orphan_cleanup/delete_orphan_alternate_content_sources.rb +16 -0
- data/app/lib/actions/pulp3/repository/reclaim_space.rb +1 -1
- data/app/lib/actions/pulp3/repository/refresh_distribution.rb +1 -2
- data/app/lib/actions/pulp3/repository/repair.rb +1 -1
- data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -2
- data/app/lib/katello/api/v2/error_handling.rb +12 -2
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +8 -4
- data/app/lib/katello/concerns/renderer_extensions.rb +3 -2
- data/app/lib/katello/errors.rb +4 -3
- data/app/lib/katello/event_daemon/runner.rb +12 -9
- data/app/lib/katello/resources/candlepin/consumer.rb +9 -6
- data/app/lib/katello/resources/candlepin/owner.rb +10 -3
- data/app/lib/katello/resources/candlepin/upstream_consumer.rb +4 -5
- data/app/lib/katello/resources/candlepin/upstream_job.rb +28 -0
- data/app/lib/katello/resources/candlepin.rb +11 -5
- data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -13
- data/app/lib/katello/resources/cdn.rb +14 -9
- data/app/lib/katello/util/candlepin_repository_checker.rb +75 -0
- data/app/lib/katello/util/errata.rb +12 -10
- data/app/lib/katello/util/search.rb +0 -1
- data/app/lib/katello/validators/alternate_content_source_products_validator.rb +17 -0
- data/app/lib/katello/validators/content_view_environment_org_validator.rb +5 -2
- data/app/lib/katello/validators/content_view_environment_validator.rb +1 -2
- data/app/lib/katello/validators/generated_content_view_validator.rb +16 -0
- data/app/mailers/katello/errata_mailer.rb +4 -2
- data/app/models/katello/activation_key.rb +12 -1
- data/app/models/katello/alternate_content_source.rb +107 -11
- data/app/models/katello/alternate_content_source_product.rb +13 -0
- data/app/models/katello/authorization/repository.rb +2 -2
- data/app/models/katello/cdn_configuration.rb +12 -3
- data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -14
- data/app/models/katello/concerns/host_managed_extensions.rb +61 -13
- data/app/models/katello/concerns/http_proxy_extensions.rb +5 -10
- data/app/models/katello/concerns/organization_extensions.rb +4 -4
- data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
- data/app/models/katello/concerns/redhat_extensions.rb +16 -6
- data/app/models/katello/concerns/smart_proxy_extensions.rb +36 -34
- data/app/models/katello/concerns/subscription_facet_host_extensions.rb +1 -0
- data/app/models/katello/content.rb +16 -1
- data/app/models/katello/content_credential.rb +8 -9
- data/app/models/katello/content_view.rb +42 -11
- data/app/models/katello/content_view_component.rb +4 -0
- data/app/models/katello/content_view_deb_filter.rb +51 -0
- data/app/models/katello/content_view_deb_filter_rule.rb +24 -0
- data/app/models/katello/content_view_environment.rb +11 -2
- data/app/models/katello/content_view_environment_content_facet.rb +9 -0
- data/app/models/katello/content_view_erratum_filter.rb +5 -4
- data/app/models/katello/content_view_filter.rb +10 -3
- data/app/models/katello/content_view_version.rb +11 -6
- data/app/models/katello/erratum.rb +12 -3
- data/app/models/katello/glue/candlepin/owner.rb +4 -1
- data/app/models/katello/glue/candlepin/pool.rb +6 -0
- data/app/models/katello/glue/candlepin/product.rb +7 -1
- data/app/models/katello/glue/candlepin/subscription.rb +5 -0
- data/app/models/katello/glue/provider.rb +55 -45
- data/app/models/katello/host/content_facet.rb +121 -21
- data/app/models/katello/host/info_provider.rb +25 -21
- data/app/models/katello/host/subscription_facet.rb +18 -14
- data/app/models/katello/installed_package.rb +1 -0
- data/app/models/katello/kt_environment.rb +12 -7
- data/app/models/katello/package_group.rb +0 -12
- data/app/models/katello/pool.rb +4 -1
- data/app/models/katello/product.rb +14 -1
- data/app/models/katello/repository.rb +28 -12
- data/app/models/katello/root_repository.rb +8 -3
- data/app/models/katello/rpm.rb +1 -0
- data/app/models/katello/smart_proxy_alternate_content_source.rb +6 -0
- data/app/models/katello/task_status.rb +0 -18
- data/app/overrides/add_smart_proxy_form.rb +5 -0
- data/app/presenters/katello/content_view_version_compare_presenter.rb +5 -0
- data/app/presenters/katello/host_package_presenter.rb +4 -4
- data/app/services/cert/certs.rb +8 -16
- data/app/services/katello/bulk_items_helper.rb +3 -3
- data/app/services/katello/candlepin/consumer.rb +2 -2
- data/app/services/katello/host/package_profile_uploader.rb +1 -1
- data/app/services/katello/organization_creator.rb +4 -4
- data/app/services/katello/product_content_finder.rb +11 -8
- data/app/services/katello/product_content_importer.rb +61 -5
- data/app/services/katello/pulp3/alternate_content_source.rb +36 -10
- data/app/services/katello/pulp3/ansible_collection.rb +10 -7
- data/app/services/katello/pulp3/api/apt.rb +12 -0
- data/app/services/katello/pulp3/api/core.rb +2 -2
- data/app/services/katello/pulp3/api/generic.rb +0 -4
- data/app/services/katello/pulp3/content_view_version/export.rb +36 -63
- data/app/services/katello/pulp3/content_view_version/export_validation_error.rb +7 -0
- data/app/services/katello/pulp3/content_view_version/export_validator.rb +121 -0
- data/app/services/katello/pulp3/content_view_version/import.rb +2 -0
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +21 -5
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +12 -2
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +38 -9
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +12 -5
- data/app/services/katello/pulp3/content_view_version/metadata_map.rb +13 -2
- data/app/services/katello/pulp3/content_view_version/syncable_format_export.rb +12 -2
- data/app/services/katello/pulp3/docker_manifest.rb +2 -1
- data/app/services/katello/pulp3/docker_manifest_list.rb +2 -1
- data/app/services/katello/pulp3/erratum.rb +1 -0
- data/app/services/katello/pulp3/module_stream.rb +26 -11
- data/app/services/katello/pulp3/pulp_content_unit.rb +3 -0
- data/app/services/katello/pulp3/repository/apt.rb +192 -2
- data/app/services/katello/pulp3/repository/yum.rb +7 -4
- data/app/services/katello/pulp3/repository.rb +26 -11
- data/app/services/katello/pulp3/repository_mirror.rb +1 -0
- data/app/services/katello/pulp3/service_common.rb +1 -1
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +24 -2
- data/app/services/katello/pulp3/task_group.rb +18 -1
- data/app/services/katello/registration_manager.rb +46 -26
- data/app/services/katello/repository_type.rb +7 -10
- data/app/services/katello/repository_type_manager.rb +4 -3
- data/app/services/katello/simple_package.rb +22 -0
- data/app/views/dashboard/_content_views_widget.html.erb +1 -1
- data/app/views/foreman/job_templates/change_content_source.erb +6 -0
- data/app/views/foreman/job_templates/update_packages_by_search_query.erb +7 -1
- data/app/views/foreman/smart_proxies/_content_sync.html.erb +2 -1
- data/app/views/foreman/smart_proxies/_reclaim_space.html.erb +1 -0
- data/app/views/foreman/smart_proxies/show.html.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +19 -4
- data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +1 -0
- data/app/views/katello/api/v2/alternate_content_sources/permissions.rabl +11 -0
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +20 -0
- data/app/views/katello/api/v2/ansible_collections/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_credentials/show.json.rabl +12 -0
- data/app/views/katello/api/v2/content_facet/base.json.rabl +23 -2
- data/app/views/katello/api/v2/content_facet/show.json.rabl +11 -8
- data/app/views/katello/api/v2/content_view_filters/base.json.rabl +5 -0
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -1
- data/app/views/katello/api/v2/content_views/permissions.rabl +1 -0
- data/app/views/katello/api/v2/host_packages/base.json.rabl +1 -1
- data/app/views/katello/api/v2/hosts/base.json.rabl +22 -2
- data/app/views/katello/api/v2/module_streams/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/module_streams/show.json.rabl +7 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repositories/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/api/v2/smart_proxies/pulp_info.json.rabl +1 -0
- data/app/views/katello/hosts/_errata_counts.html.erb +46 -0
- data/app/views/katello/layouts/foreman_with_bastion.html.erb +1 -1
- data/app/views/katello/layouts/react.html.erb +1 -1
- data/app/views/overrides/activation_keys/_host_environment_select.html.erb +2 -2
- data/app/views/overrides/activation_keys/_host_synced_content_select.html.erb +1 -0
- data/app/views/overrides/organizations/_edit_override.html.erb +5 -8
- data/app/views/overrides/organizations/_index_row_override.html.erb +1 -1
- data/app/views/overrides/organizations/_step_1_override.html.erb +5 -0
- data/app/views/overrides/smart_proxies/_acs_http_proxy.html.erb +6 -0
- data/ca/redhat-uep.pem +18 -23
- data/config/katello.yaml.example +0 -2
- data/config/routes/api/registry.rb +8 -7
- data/config/routes/api/v2.rb +4 -2
- data/config/routes/overrides.rb +1 -0
- data/config/routes.rb +6 -0
- data/db/migrate/20200429153103_installed_package_bad_nvrea.rb +1 -1
- data/db/migrate/20201116161820_create_content_view_deb_filter_rules.rb +17 -0
- data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +7 -3
- data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +1 -1
- data/db/migrate/20220524132259_remove_last_refreshed_from_katello_alternate_content_sources.rb +5 -0
- data/db/migrate/20220601163911_add_vendor_to_katello_installed_packages.rb +5 -0
- data/db/migrate/20220610165621_add_repositories_and_products_to_acs.rb +23 -0
- data/db/migrate/20220730033504_update_custom_cdn.rb +13 -0
- data/db/migrate/20220920173656_add_http_proxy_to_smart_proxy.rb +7 -0
- data/db/migrate/20220920180858_remove_http_proxy_from_katello_alternate_content_sources.rb +6 -0
- data/db/migrate/20220929204746_add_content_view_environment_content_facet.rb +52 -0
- data/db/migrate/20221123212341_remove_pulp_docker_registry_port_setting.rb +5 -0
- data/db/migrate/20221206170122_update_ignore_srpm_to_false_for_mirror_complete.rb +5 -0
- data/db/migrate/20230119003859_ensure_repo_username_password_nil_not_blank.rb +9 -0
- data/db/migrate/20230203141353_set_new_acs_verify_ssl_default.rb +5 -0
- data/db/seeds.d/111-upgrade_tasks.rb +3 -1
- data/engines/bastion/app/assets/javascripts/bastion/components/notification.service.js +1 -1
- data/engines/bastion/app/assets/stylesheets/bastion/bastion.scss +4 -0
- data/engines/bastion/app/views/bastion/layouts/application.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/application_ie.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +7 -6
- data/engines/bastion/vendor/assets/javascripts/bastion/angular/angular.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/content-credential.factory.js +17 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/content-credentials.routes.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-acs.controller.js +36 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-details.controller.js +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/views/content-credential-acs.html +38 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/views/content-credential-details.html +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/views/content-credentials.html +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-errata-modal.controller.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +5 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment-content.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/apply-errata.controller.js +11 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-hosts-list.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +28 -1403
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +5485 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +5397 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +5658 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +5284 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ka.po +5231 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +5275 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +5389 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +5212 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +5145 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +9 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/katello-features.run.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/bulk/views/products-bulk-advanced-sync-modal.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +7 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-advanced-sync-options.html +4 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +7 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.routes.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +2 -2
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +0 -1
- data/lib/katello/engine.rb +4 -3
- data/lib/katello/permission_creator.rb +5 -6
- data/lib/katello/permissions/host_permissions.rb +1 -0
- data/lib/katello/permissions/registry_permissions.rb +5 -5
- data/lib/katello/plugin.rb +58 -33
- data/lib/katello/repository_types/README.md +136 -19
- data/lib/katello/repository_types/deb.rb +1 -2
- data/lib/katello/repository_types/docker.rb +3 -3
- data/lib/katello/repository_types/file.rb +0 -1
- data/lib/katello/repository_types/python.rb +3 -3
- data/lib/katello/repository_types/yum.rb +0 -4
- data/lib/katello/tasks/check_candlepin_content.rake +16 -0
- data/lib/katello/tasks/clean_candlepin_orphaned_products.rake +38 -0
- data/lib/katello/tasks/clean_orphaned_facets.rb +20 -0
- data/lib/katello/tasks/refresh_repos.rake +8 -0
- data/lib/katello/tasks/reimport.rake +1 -2
- data/lib/katello/tasks/repository.rake +1 -22
- data/lib/katello/tasks/reset.rake +2 -1
- data/lib/katello/tasks/upgrades/4.8/fix_incorrect_providers.rake +29 -0
- data/lib/katello/tasks/upgrades/4.8/regenerate_imported_repository_metadata.rake +33 -0
- data/lib/katello/version.rb +1 -1
- data/lib/katello.rb +0 -5
- data/locale/action_names.rb +65 -62
- data/locale/bn/katello.po +816 -128
- data/locale/cs/katello.po +817 -129
- data/locale/de/katello.po +889 -200
- data/locale/en/katello.po +815 -127
- data/locale/es/katello.po +1161 -469
- data/locale/fr/katello.po +1313 -615
- data/locale/gu/katello.po +816 -128
- data/locale/hi/katello.po +817 -129
- data/locale/it/katello.po +827 -137
- data/locale/ja/katello.po +1315 -623
- data/locale/ka/katello.po +8872 -0
- data/locale/katello.pot +3358 -2013
- data/locale/kn/katello.po +816 -128
- data/locale/ko/katello.po +859 -170
- data/locale/mr/katello.po +817 -129
- data/locale/or/katello.po +817 -129
- data/locale/pa/katello.po +817 -129
- data/locale/pt/katello.po +817 -128
- data/locale/pt_BR/katello.po +1265 -573
- data/locale/ru/katello.po +836 -148
- data/locale/ta/katello.po +816 -128
- data/locale/te/katello.po +816 -128
- data/locale/zh_CN/katello.po +1311 -619
- data/locale/zh_TW/katello.po +830 -142
- data/package.json +0 -3
- data/webpack/components/Bookmark/index.js +5 -1
- data/webpack/components/Content/ContentPage.js +51 -35
- data/webpack/components/Content/Details/ContentDetails.js +1 -1
- data/webpack/components/Content/Details/__tests__/__snapshots__/ContentDetails.test.js.snap +6 -0
- data/webpack/components/Content/__tests__/ContentPage.test.js +2 -4
- data/webpack/components/Content/__tests__/__snapshots__/ContentPage.test.js.snap +22 -3
- data/webpack/components/EditableSwitch.js +1 -0
- data/webpack/components/EditableTextInput/EditableTextInput.js +6 -19
- data/webpack/components/EditableTextInput/PencilEditButton.js +33 -0
- data/webpack/components/Errata/errataHelpers.js +33 -0
- data/webpack/components/Errata/index.js +56 -8
- data/webpack/components/Loading.js +19 -9
- data/webpack/components/Packages/index.js +8 -24
- data/webpack/components/RoutedTabs/index.js +8 -28
- data/webpack/components/Search/Search.js +20 -3
- data/webpack/components/Search/__tests__/search.test.js +4 -5
- data/webpack/components/SelectAllCheckbox/index.js +7 -4
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +1 -0
- data/webpack/components/Table/EmptyStateMessage.js +83 -5
- data/webpack/components/Table/MainTable.js +78 -15
- data/webpack/components/Table/PageControls.js +1 -0
- data/webpack/components/Table/TableHooks.js +12 -4
- data/webpack/components/Table/TableWrapper.js +45 -36
- data/webpack/components/Table/__test__/emptyStateMessage.test.js +51 -0
- data/webpack/components/TypeAhead/TypeAhead.js +26 -11
- data/webpack/components/TypeAhead/pf3Search/TypeAheadItems.js +1 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +2 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadItems.js +2 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +1 -1
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +8 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +19 -84
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +2 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +2 -2
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +128 -71
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +5 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +30 -4
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.scss +23 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +15 -9
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +25 -10
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +1 -17
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeActions.js +37 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +175 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeConstants.js +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +307 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeSelectors.js +25 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +109 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +161 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +155 -42
- data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +103 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +1 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +5 -2
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +84 -5
- data/webpack/components/extensions/HostDetails/HostDetailsConstants.js +3 -1
- data/webpack/components/extensions/HostDetails/HostDetailsReducer.js +14 -0
- data/webpack/components/extensions/HostDetails/HostDetailsSelectors.js +8 -2
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/constants.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/index.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +97 -27
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +54 -9
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +10 -6
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +147 -25
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.scss +6 -1
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +9 -8
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +135 -27
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +7 -2
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +23 -6
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +60 -61
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +3 -30
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +3 -12
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packages.fixtures.json +3 -3
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +8 -24
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +3 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +12 -20
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +4 -27
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +4 -4
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +1 -1
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +7 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +2 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +2 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/LifeCycleEnvironment.test.js.snap +1 -0
- data/webpack/components/extensions/RegistrationCommands/index.js +49 -17
- data/webpack/containers/Application/config.js +6 -11
- data/webpack/containers/Application/overrides.scss +25 -1
- data/webpack/global_index.js +21 -7
- data/webpack/global_test_setup.js +33 -3
- data/webpack/ouia_id_check.js +93 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +8 -8
- data/webpack/redux/reducers/index.js +2 -4
- data/webpack/scenes/AlternateContentSources/ACSActions.js +72 -8
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +5 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +1 -1
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +21 -12
- data/webpack/scenes/AlternateContentSources/Acs.scss +3 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +96 -49
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +49 -17
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +31 -4
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSProducts.js +44 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +73 -48
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +30 -3
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +42 -18
- data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +1 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +92 -23
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +273 -18
- data/webpack/scenes/AlternateContentSources/Create/__tests__/products.fixtures.json +92 -0
- data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +514 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +356 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +106 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditProducts.js +121 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +152 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +143 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +245 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +109 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsDetails.fixtures.json +49 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsProducts.fixtures.json +95 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/simplifiedAcsDetails.fixtures.json +39 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +401 -97
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.scss +3 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +5 -1
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +10 -16
- data/webpack/scenes/AlternateContentSources/helpers.js +26 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +5 -4
- data/webpack/scenes/Content/Details/__tests__/contentDetail.test.js +1 -12
- data/webpack/scenes/Content/Table/ContentTable.js +2 -1
- data/webpack/scenes/Content/__tests__/contentTable.test.js +1 -15
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +16 -4
- data/webpack/scenes/ContentViews/ContentViewsPage.js +1 -1
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +1 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +1 -0
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +17 -7
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +30 -7
- data/webpack/scenes/ContentViews/Create/CreateContentViewModal.js +1 -0
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +21 -6
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeleteEnvironmentsSelection.js +3 -3
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignActivationKeysForm.js +10 -9
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignHostsForm.js +10 -9
- data/webpack/scenes/ContentViews/Delete/__tests__/CvData.fixtures.json +2 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +7 -32
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +3 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +4 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentVersion.js +1 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +6 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +44 -32
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +127 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +99 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +4 -1
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +37 -9
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +13 -3
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositorySelection.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +6 -1
- data/webpack/scenes/ContentViews/Details/Filters/ArtifactsWithNoErrata.js +9 -8
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +48 -29
- data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +241 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +24 -8
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +25 -12
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +10 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +15 -9
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +15 -4
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +27 -13
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +70 -10
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +37 -23
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVDebMatchContentModal.js +97 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +4 -3
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +35 -34
- data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +128 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +98 -42
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +124 -36
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +71 -11
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +37 -22
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +71 -24
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +7 -21
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +7 -23
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVContainerImageFilterContent.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVPackageFilterRules.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyContentViewFilters.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +4 -3
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -11
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +2 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +9 -3
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +1 -11
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +9 -10
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +13 -10
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.js +151 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +82 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareConfig.js +409 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +184 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareTable.js +109 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/AnsibleCollectionsCompareAllContentData.fixtures.json +63 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionCompare.test.js +679 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionEmptyContentCompareData.fixtures.json +14 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ContainerTagsCompareAllContentData.fixtures.json +95 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/DebPackagesCompareAllContentData.fixtures.json +87 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareAllContentData.fixtures.json +319 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareThreeContentTypesData.fixtures.json +131 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareThreeContentTypesData.fixtures.json +48 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ModuleStreamsCompareAllContentData.fixtures.json +239 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PackageGroupsCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PythonPackagesCompareAllContentData.fixtures.json +315 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareAllContentData.fixtures.json +470 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareThreeContentTypesData.fixtures.json +475 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewDetails.fixtures.json +160 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionOneDetials.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionThreeDetails.fixtures.json +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionTwoDetails.fixtures.json +211 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersions.fixtures.json +1013 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/cvCompareRepositories.fixtures.json +175 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionOneDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionTwoDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +111 -39
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVEnvironmentSelectionForm.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignActivationKeysForm.js +18 -17
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignHostsForm.js +11 -6
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +7 -22
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +3 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +37 -13
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +4 -1
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +9 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +30 -15
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +113 -40
- data/webpack/scenes/ContentViews/Publish/CVPublishForm.js +5 -1
- data/webpack/scenes/ContentViews/Publish/CVPublishReview.js +3 -3
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +104 -84
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +2 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +60 -64
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +7 -2
- data/webpack/scenes/ContentViews/components/CVBreadCrumb.js +1 -1
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelect.js +40 -0
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelectOption.js +87 -0
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +2 -1
- data/webpack/scenes/ContentViews/components/InactiveText.js +9 -1
- data/webpack/scenes/ContentViews/components/WizardHeader.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +4 -2
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +4 -3
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +8 -1
- data/webpack/scenes/Hosts/ChangeContentSource/actions.js +18 -12
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceForm.js +176 -30
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceTemplate.js +13 -17
- data/webpack/scenes/Hosts/ChangeContentSource/components/FormField.js +3 -4
- data/webpack/scenes/Hosts/ChangeContentSource/components/Hosts.js +55 -0
- data/webpack/scenes/Hosts/ChangeContentSource/components/HostsModal.js +59 -0
- data/webpack/scenes/Hosts/ChangeContentSource/constants.js +1 -0
- data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +2 -5
- data/webpack/scenes/Hosts/ChangeContentSource/index.js +118 -74
- data/webpack/scenes/Hosts/ChangeContentSource/selectors.js +9 -5
- data/webpack/scenes/Hosts/ChangeContentSource/styles.scss +10 -2
- data/webpack/scenes/ModuleStreams/Details/ModuleDetailsSchema.js +10 -1
- data/webpack/scenes/ModuleStreams/Details/ModuleStreamDetails.js +1 -1
- data/webpack/scenes/ModuleStreams/Details/__tests__/__snapshots__/ModuleStreamDetails.test.js.snap +97 -2
- data/webpack/scenes/ModuleStreams/ModuleStreamsPage.js +3 -9
- data/webpack/scenes/ModuleStreams/__tests__/__snapshots__/ModuleStreamPage.test.js.snap +7 -1
- data/webpack/scenes/Organizations/OrganizationSelectors.js +1 -0
- data/webpack/scenes/RedHatRepositories/components/Search.js +22 -16
- data/webpack/scenes/RedHatRepositories/index.scss +20 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +1 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +12 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +2 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +11 -26
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CustomCdnTypeForm.js +154 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/ExportSyncForm.js +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/NetworkSyncForm.js +59 -44
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CdnTypeForm.test.js +3 -28
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CustomCdnTypeForm.test.js +97 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/ExportSyncForm.test.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/NetworkSyncForm.test.js +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +23 -10
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +1 -31
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +2 -1
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +25 -23
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/UpstreamSubscriptionsPage.js +3 -3
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/__tests__/__snapshots__/UpstreamSubscriptionsPage.test.js.snap +2 -2
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsPage.test.js.snap +37 -4
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/SubscriptionsToolbar.js +23 -10
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/SubscriptionsToolbar.test.js +0 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/__snapshots__/SubscriptionsToolbar.test.js.snap +65 -15
- data/webpack/scenes/Tasks/helpers.js +14 -7
- data/webpack/test-utils/nockWrapper.js +7 -0
- metadata +158 -272
- data/app/lib/actions/katello/pulp_selector.rb +0 -24
- data/app/lib/actions/katello/repository/correct_checksum.rb +0 -24
- data/app/lib/actions/katello/repository/destroy_package_group.rb +0 -26
- data/app/lib/actions/katello/repository/upload_package_group.rb +0 -24
- data/app/lib/actions/pulp/abstract.rb +0 -37
- data/app/lib/actions/pulp/abstract_async_task.rb +0 -154
- data/app/lib/actions/pulp/abstract_async_task_group.rb +0 -94
- data/app/lib/actions/pulp/consumer/sync_capsule.rb +0 -45
- data/app/lib/actions/pulp/consumer/unassociate_units.rb +0 -20
- data/app/lib/actions/pulp/expect_one_task.rb +0 -11
- data/app/lib/actions/pulp/orchestration/orphan_cleanup/remove_orphans.rb +0 -16
- data/app/lib/actions/pulp/orchestration/repository/copy_all_units.rb +0 -19
- data/app/lib/actions/pulp/orchestration/repository/delete.rb +0 -15
- data/app/lib/actions/pulp/orchestration/repository/refresh.rb +0 -14
- data/app/lib/actions/pulp/orchestration/repository/refresh_if_needed.rb +0 -13
- data/app/lib/actions/pulp/orchestration/repository/refresh_repos.rb +0 -19
- data/app/lib/actions/pulp/orchestration/repository/remove_units.rb +0 -14
- data/app/lib/actions/pulp/orchestration/repository/smart_proxy_sync.rb +0 -34
- data/app/lib/actions/pulp/orchestration/repository/sync.rb +0 -18
- data/app/lib/actions/pulp/orchestration/repository/upload_content.rb +0 -37
- data/app/lib/actions/pulp/orphan_cleanup/remove_orphans.rb +0 -15
- data/app/lib/actions/pulp/orphan_cleanup/remove_unneeded_repos.rb +0 -16
- data/app/lib/actions/pulp/repository/abstract_copy_content.rb +0 -45
- data/app/lib/actions/pulp/repository/abstract_remove_content.rb +0 -32
- data/app/lib/actions/pulp/repository/clear.rb +0 -18
- data/app/lib/actions/pulp/repository/copy_all_units.rb +0 -30
- data/app/lib/actions/pulp/repository/copy_units.rb +0 -25
- data/app/lib/actions/pulp/repository/create.rb +0 -28
- data/app/lib/actions/pulp/repository/create_in_plan.rb +0 -15
- data/app/lib/actions/pulp/repository/create_upload_request.rb +0 -20
- data/app/lib/actions/pulp/repository/delete_upload_request.rb +0 -19
- data/app/lib/actions/pulp/repository/destroy.rb +0 -28
- data/app/lib/actions/pulp/repository/distributor_publish.rb +0 -25
- data/app/lib/actions/pulp/repository/download.rb +0 -16
- data/app/lib/actions/pulp/repository/import_upload.rb +0 -19
- data/app/lib/actions/pulp/repository/presenters/abstract_sync_presenter.rb +0 -47
- data/app/lib/actions/pulp/repository/presenters/deb_presenter.rb +0 -95
- data/app/lib/actions/pulp/repository/presenters/docker_presenter.rb +0 -103
- data/app/lib/actions/pulp/repository/presenters/file_unit_presenter.rb +0 -42
- data/app/lib/actions/pulp/repository/presenters/yum_presenter.rb +0 -131
- data/app/lib/actions/pulp/repository/refresh.rb +0 -21
- data/app/lib/actions/pulp/repository/regenerate_applicability.rb +0 -21
- data/app/lib/actions/pulp/repository/remove_distribution.rb +0 -11
- data/app/lib/actions/pulp/repository/remove_units.rb +0 -44
- data/app/lib/actions/pulp/repository/sync.rb +0 -99
- data/app/lib/actions/pulp/repository/upload_file.rb +0 -28
- data/app/lib/actions/pulp/repository_group/create.rb +0 -31
- data/app/lib/actions/pulp/repository_group/delete.rb +0 -17
- data/app/lib/actions/pulp/repository_group/export.rb +0 -51
- data/app/lib/katello/util/package_clause_generator.rb +0 -77
- data/app/models/katello/glue/pulp/pulp_errors.rb +0 -9
- data/app/models/katello/glue/pulp/repo.rb +0 -353
- data/app/models/katello/pulp_sync_status.rb +0 -165
- data/app/models/katello/pulp_task_status.rb +0 -63
- data/app/services/katello/candlepin/upstream_consumer.rb +0 -28
- data/app/services/katello/pulp/content.rb +0 -24
- data/app/services/katello/pulp/importer_comparison.rb +0 -28
- data/app/services/katello/pulp/repository/deb.rb +0 -61
- data/app/services/katello/pulp/repository/docker.rb +0 -82
- data/app/services/katello/pulp/repository/file.rb +0 -52
- data/app/services/katello/pulp/repository/yum.rb +0 -205
- data/app/services/katello/pulp/repository.rb +0 -327
- data/app/services/katello/pulp/server.rb +0 -35
- data/app/services/katello/pulp/simple_package.rb +0 -24
- data/app/services/katello/pulp/smart_proxy_repository.rb +0 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -751
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-deletion.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-confirm.controller.js +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +0 -82
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +0 -160
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-activation-keys.html +0 -94
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-confirm.html +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +0 -88
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-component.factory.js +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite.html +0 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-deb-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-repositories.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-deb-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-promotion.controller.js +0 -129
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-publish.controller.js +0 -46
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories-list.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories.service.js +0 -91
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +0 -240
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +0 -115
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-module-stream-filter.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/date-type-errata-filter.controller.js +0 -77
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/docker-tag-filter.controller.js +0 -137
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/edit-filter.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter-list.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-content-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-details.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-helper.service.js +0 -30
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-repositories.controller.js +0 -86
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-rule-matching-package-modal.controller.js +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter.factory.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filters.controller.js +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/module-stream-list-filter.controller.js +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/new-filter.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-filter.controller.js +0 -179
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-group-list-filter.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/rule.factory.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata-filter.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata.html +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-tag-filter-details.html +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/edit-filter.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter.html +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-details.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-repositories.html +0 -121
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-rule-matching-package-modal.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter-details.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/new-filter.html +0 -62
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +0 -182
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter-details.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/partials/filter-repositories-count.html +0 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.controller.js +0 -47
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.factory.js +0 -22
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/views/content-view-history.html +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-copy.html +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-deb-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details-tasks.html +0 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +0 -144
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +0 -114
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-promotion.html +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +0 -116
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -126
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +0 -127
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +0 -138
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version.controller.js +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-apt.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-components.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-deb.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +0 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-docker.html +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-errata.html +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-module-streams.html +0 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-package-groups.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-packages.html +0 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-yum.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -83
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +0 -74
- data/locale/zanata.xml +0 -28
- data/vendor/assets/javascripts/katello/jquery.trunk8.js +0 -203
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +0 -30
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsPage.js +0 -80
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsReducer.js +0 -39
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +0 -60
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTables.scss +0 -0
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetails.js +0 -94
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +0 -23
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsReducer.js +0 -30
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionsSchema.js +0 -35
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js +0 -16
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js +0 -25
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.test.js +0 -27
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +0 -41
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js +0 -33
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailInfo.test.js.snap +0 -83
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetails.test.js.snap +0 -190
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsActions.test.js.snap +0 -58
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsReducer.test.js.snap +0 -50
- data/webpack/scenes/AnsibleCollections/Details/index.js +0 -17
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionPage.test.js +0 -23
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollections.fixtures.js +0 -52
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsActions.test.js +0 -48
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsReducer.test.js +0 -46
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +0 -25
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionPage.test.js.snap +0 -73
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionsTable.test.js.snap +0 -81
- data/webpack/scenes/AnsibleCollections/index.js +0 -17
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentSearch.fixtures.json +0 -33
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +0 -123
@@ -1,7 +1,7 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { Route } from 'react-router-dom';
|
3
3
|
import { renderWithRedux, patientlyWaitFor } from 'react-testing-lib-wrapper';
|
4
|
-
import { nockInstance, assertNockRequest, mockAutocomplete
|
4
|
+
import { nockInstance, assertNockRequest, mockAutocomplete } from '../../../../test-utils/nockWrapper';
|
5
5
|
import api from '../../../../services/api';
|
6
6
|
import { CONTENT_ID_KEY } from '../../ContentConstants';
|
7
7
|
import ContentDetails from '../ContentDetails';
|
@@ -17,9 +17,6 @@ const contentRepositoryDetailsPath = api.getApiUrl('/repositories');
|
|
17
17
|
|
18
18
|
const withContentRoute = component => <Route path="/content/:content_type([a-z_]+)/:id([0-9]+)">{component}</Route>;
|
19
19
|
|
20
|
-
let searchDelayScope;
|
21
|
-
let autoSearchScope;
|
22
|
-
|
23
20
|
jest.mock('react-intl', () => ({ addLocaleData: () => { }, FormattedDate: () => 'mocked' }));
|
24
21
|
|
25
22
|
test('Can call API for Python package details and show details tab on page load', async (done) => {
|
@@ -59,8 +56,6 @@ test('Can call API for Python package details and show details tab on page load'
|
|
59
56
|
test('Can call API for Python package repository details and show repositories tab', async (done) => {
|
60
57
|
const autocompleteUrl = '/repositories/auto_complete_search';
|
61
58
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
62
|
-
searchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
63
|
-
autoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
64
59
|
|
65
60
|
const results = pythonPackageRepositoryDetailsResponse.results[0];
|
66
61
|
const repoName = results.name;
|
@@ -84,8 +79,6 @@ test('Can call API for Python package repository details and show repositories t
|
|
84
79
|
expect(getAllByText(contentCountWords)[0]).toBeInTheDocument();
|
85
80
|
});
|
86
81
|
|
87
|
-
assertNockRequest(autoSearchScope);
|
88
|
-
assertNockRequest(searchDelayScope);
|
89
82
|
assertNockRequest(autocompleteScope);
|
90
83
|
assertNockRequest(pythonPackageRepositoryDetailsScope, done);
|
91
84
|
});
|
@@ -122,8 +115,6 @@ test('Can call API for Ansible collection details and show details tab on page l
|
|
122
115
|
test('Can call API for Ansible collection repository details and show repositories tab', async (done) => {
|
123
116
|
const autocompleteUrl = '/repositories/auto_complete_search';
|
124
117
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
125
|
-
searchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
126
|
-
autoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
127
118
|
|
128
119
|
const results = ansibleCollectionRepositoryDetailsResponse.results[0];
|
129
120
|
const repoName = results.name;
|
@@ -147,8 +138,6 @@ test('Can call API for Ansible collection repository details and show repositori
|
|
147
138
|
expect(getAllByText(contentCountWords)[0]).toBeInTheDocument();
|
148
139
|
});
|
149
140
|
|
150
|
-
assertNockRequest(autoSearchScope);
|
151
|
-
assertNockRequest(searchDelayScope);
|
152
141
|
assertNockRequest(autocompleteScope);
|
153
142
|
assertNockRequest(ansibleCollectionRepositoryDetailsScope, done);
|
154
143
|
});
|
@@ -33,7 +33,8 @@ const ContentTable = ({
|
|
33
33
|
ouiaId="content-table"
|
34
34
|
key={selectedContentType}
|
35
35
|
variant={TableVariant.compact}
|
36
|
-
autocompleteEndpoint={
|
36
|
+
autocompleteEndpoint={`/katello/api/v2/${contentTypes[selectedContentType][1]}`}
|
37
|
+
bookmarkController="katello_generic_content_units"
|
37
38
|
emptyContentTitle={__(`You currently don't have any ${selectedContentType}.`)}
|
38
39
|
emptySearchTitle={__(`No matching ${selectedContentType} found`)}
|
39
40
|
emptyContentBody={__(`${selectedContentType} will appear here when created.`)}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { renderWithRedux, patientlyWaitFor } from 'react-testing-lib-wrapper';
|
3
|
-
import
|
3
|
+
import { nockInstance, assertNockRequest, mockAutocomplete } from '../../../test-utils/nockWrapper';
|
4
4
|
import api from '../../../services/api';
|
5
5
|
import ContentPage from '../ContentPage';
|
6
6
|
import ansibleCollectionsResponse from './ansibleCollections.fixtures';
|
@@ -12,20 +12,6 @@ const contentTypesPath = api.getApiUrl('/repositories/content_types');
|
|
12
12
|
const pythonPackagesPath = api.getApiUrl('/python_packages');
|
13
13
|
const ansibleCollectionsPath = api.getApiUrl('/ansible_collections');
|
14
14
|
|
15
|
-
let searchDelayScope;
|
16
|
-
let autoSearchScope;
|
17
|
-
|
18
|
-
beforeEach(() => {
|
19
|
-
searchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
20
|
-
autoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
21
|
-
});
|
22
|
-
|
23
|
-
afterEach(() => {
|
24
|
-
nock.cleanAll();
|
25
|
-
assertNockRequest(autoSearchScope);
|
26
|
-
assertNockRequest(searchDelayScope);
|
27
|
-
});
|
28
|
-
|
29
15
|
test('Can call API for Python Packages and show table on page load', async (done) => {
|
30
16
|
const autocompleteUrl = '/python_packages/auto_complete_search';
|
31
17
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
@@ -2,6 +2,13 @@ import { translate as __ } from 'foremanReact/common/I18n';
|
|
2
2
|
import { toUpper } from 'lodash';
|
3
3
|
|
4
4
|
const CONTENT_VIEWS_KEY = 'CONTENT_VIEWS';
|
5
|
+
const PACKAGES_KEY = 'PACKAGES';
|
6
|
+
const PACKAGE_GROUPS_KEY = 'PACKAGE_GROUPS';
|
7
|
+
const ERRATA_KEY = 'ERRATA';
|
8
|
+
const MODULE_STREAMS_KEY = 'MODULE_STREAMS';
|
9
|
+
const DEB_PACKAGES_KEY = 'DEB_PACKAGES';
|
10
|
+
const DOCKER_TAGS_KEY = 'DOCKER_TAGS';
|
11
|
+
const FILES_KEY = 'FILES';
|
5
12
|
export const CREATE_CONTENT_VIEW_KEY = 'CONTENT_VIEW_CREATE';
|
6
13
|
export const COPY_CONTENT_VIEW_KEY = 'CONTENT_VIEW_COPY';
|
7
14
|
export const CREATE_CONTENT_VIEW_FILTER_KEY = 'CONTENT_VIEW_FILTER_CREATE';
|
@@ -51,12 +58,17 @@ export const cvVersionPublishKey = (cvId, versionCount) => `${PUBLISH_CONTENT_VI
|
|
51
58
|
export const cvVersionTaskPollingKey = cvId => `CONTENT_VIEW_VERSION_POLLING_${cvId}`;
|
52
59
|
export const cvAddComponentKey = cvId => `${CONTENT_VIEWS_KEY}_ADD_COMPONENT_${cvId}`;
|
53
60
|
export const cvRemoveComponentKey = cvId => `${CONTENT_VIEWS_KEY}_REMOVE_COMPONENT_${cvId}`;
|
54
|
-
|
55
61
|
export const removeComponentSuccessMessage = size => (size === 1 ? __('Removed component from content view') : __('Removed components from content view'));
|
56
|
-
|
57
62
|
export const addComponentSuccessMessage = component => (component ? __('Updated component details') : __('Added component to content view'));
|
58
|
-
|
59
|
-
|
63
|
+
export const genericContentCompareKey = (pluralLabel, versionOne, versionTwo, viewBy) => `${toUpper(pluralLabel)}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
64
|
+
export const cvPackageGroupsCompareKey = (versionOne, versionTwo, viewBy) => `${PACKAGE_GROUPS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
65
|
+
export const cvRPMPackagesCompareKey = (versionOne, versionTwo, viewBy) => `${PACKAGES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
66
|
+
export const cvRepositoriesCompareKey = (versionOne, versionTwo, viewBy) => `REPOSITORIES_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
67
|
+
export const cvErrataCompareKey = (versionOne, versionTwo, viewBy) => `${ERRATA_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
68
|
+
export const cvModuleStreamsCompareKey = (versionOne, versionTwo, viewBy) => `${MODULE_STREAMS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
69
|
+
export const cvDebPackagesCompareKey = (versionOne, versionTwo, viewBy) => `${DEB_PACKAGES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
70
|
+
export const cvDockerTagsCompareKey = (versionOne, versionTwo, viewBy) => `${DOCKER_TAGS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
71
|
+
export const filesCompareKey = (versionOne, versionTwo, viewBy) => `${FILES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
60
72
|
// Repo added to content view status display and key
|
61
73
|
export const ADDED = __('Added');
|
62
74
|
export const NOT_ADDED = __('Not added');
|
@@ -9,7 +9,7 @@ const ContentViewsPage = () => (
|
|
9
9
|
<Grid className="margin-24">
|
10
10
|
<GridItem span={12}>
|
11
11
|
<TextContent>
|
12
|
-
<Text component={TextVariants.h1}>{__('Content views')}</Text>
|
12
|
+
<Text ouiaId="cvPageHeaderText" component={TextVariants.h1}>{__('Content views')}</Text>
|
13
13
|
</TextContent>
|
14
14
|
</GridItem>
|
15
15
|
<GridItem span={12} className="margin-top-8">
|
@@ -1,15 +1,16 @@
|
|
1
1
|
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
2
3
|
import { translate as __ } from 'foremanReact/common/I18n';
|
3
4
|
import { OutlinedQuestionCircleIcon } from '@patternfly/react-icons';
|
4
5
|
import { Tooltip, TooltipPosition, Flex, FlexItem } from '@patternfly/react-core';
|
5
6
|
import { autoPublishHelpText, dependenciesHelpText, importOnlyHelpText, generatedContentViewHelpText } from '../helpers';
|
6
7
|
import ContentViewIcon from '../components/ContentViewIcon';
|
7
8
|
|
8
|
-
const HelpToolTip =
|
9
|
-
<span className=
|
9
|
+
export const HelpToolTip = props => (
|
10
|
+
<span className={props.className ?? 'foreman-spaced-icon'}>
|
10
11
|
<Tooltip
|
11
12
|
position={TooltipPosition.top}
|
12
|
-
content={tooltip}
|
13
|
+
content={props.tooltip}
|
13
14
|
>
|
14
15
|
<OutlinedQuestionCircleIcon />
|
15
16
|
</Tooltip>
|
@@ -34,7 +35,7 @@ export const LabelDependencies = () => (
|
|
34
35
|
<Flex>
|
35
36
|
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Solve dependencies')}</FlexItem>
|
36
37
|
<FlexItem>
|
37
|
-
{
|
38
|
+
<HelpToolTip tooltip={dependenciesHelpText} />
|
38
39
|
</FlexItem>
|
39
40
|
</Flex>
|
40
41
|
);
|
@@ -43,7 +44,7 @@ export const LabelAutoPublish = () => (
|
|
43
44
|
<Flex>
|
44
45
|
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Auto publish')}</FlexItem>
|
45
46
|
<FlexItem>
|
46
|
-
{
|
47
|
+
<HelpToolTip tooltip={autoPublishHelpText} />
|
47
48
|
</FlexItem>
|
48
49
|
</Flex>
|
49
50
|
);
|
@@ -52,7 +53,7 @@ export const LabelImportOnly = () => (
|
|
52
53
|
<Flex>
|
53
54
|
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Import only')}</FlexItem>
|
54
55
|
<FlexItem>
|
55
|
-
{
|
56
|
+
<HelpToolTip tooltip={importOnlyHelpText} />
|
56
57
|
</FlexItem>
|
57
58
|
</Flex>
|
58
59
|
);
|
@@ -61,7 +62,16 @@ export const LabelGenerated = () => (
|
|
61
62
|
<Flex>
|
62
63
|
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Generated')}</FlexItem>
|
63
64
|
<FlexItem>
|
64
|
-
{
|
65
|
+
<HelpToolTip tooltip={generatedContentViewHelpText} />
|
65
66
|
</FlexItem>
|
66
67
|
</Flex>
|
67
68
|
);
|
69
|
+
|
70
|
+
HelpToolTip.propTypes = {
|
71
|
+
tooltip: PropTypes.string.isRequired,
|
72
|
+
className: PropTypes.string,
|
73
|
+
};
|
74
|
+
|
75
|
+
HelpToolTip.defaultProps = {
|
76
|
+
className: null,
|
77
|
+
};
|
@@ -4,7 +4,6 @@ import { STATUS } from 'foremanReact/constants';
|
|
4
4
|
import { translate as __ } from 'foremanReact/common/I18n';
|
5
5
|
import PropTypes from 'prop-types';
|
6
6
|
import { useDispatch, useSelector } from 'react-redux';
|
7
|
-
import { Redirect } from 'react-router-dom';
|
8
7
|
import { Form, FormGroup, TextInput, TextArea, Checkbox, ActionGroup, Button, Tile, Grid, GridItem } from '@patternfly/react-core';
|
9
8
|
import { createContentView } from '../ContentViewsActions';
|
10
9
|
import { selectCreateContentViews, selectCreateContentViewStatus, selectCreateContentViewError } from './ContentViewCreateSelectors';
|
@@ -25,6 +24,18 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
25
24
|
const [redirect, setRedirect] = useState(false);
|
26
25
|
const [saving, setSaving] = useState(false);
|
27
26
|
|
27
|
+
const [labelValidated, setLabelValidated] = useState('default');
|
28
|
+
const handleLabelChange = (newLabel, _event) => {
|
29
|
+
setLabel(newLabel);
|
30
|
+
if (newLabel === '') {
|
31
|
+
setLabelValidated('default');
|
32
|
+
} else if (/^[\w-]+$/.test(newLabel)) {
|
33
|
+
setLabelValidated('success');
|
34
|
+
} else {
|
35
|
+
setLabelValidated('error');
|
36
|
+
}
|
37
|
+
};
|
38
|
+
|
28
39
|
const response = useSelector(selectCreateContentViews);
|
29
40
|
const status = useSelector(selectCreateContentViewStatus);
|
30
41
|
const error = useSelector(selectCreateContentViewError);
|
@@ -54,18 +65,17 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
54
65
|
|
55
66
|
useEffect(
|
56
67
|
() => {
|
57
|
-
setLabel(name.replace(/
|
68
|
+
setLabel(name.replace(/[^A-Za-z0-9_-]/g, '_'));
|
58
69
|
},
|
59
70
|
[name],
|
60
71
|
);
|
61
72
|
|
62
73
|
if (redirect) {
|
63
74
|
const { id } = response;
|
64
|
-
if (composite) {
|
65
|
-
return (<Redirect to={`/content_views/${id}#/repositories`} />);
|
75
|
+
if (composite) { window.location.assign(`/content_views/${id}#/contentviews`); } else { window.location.assign(`/content_views/${id}#/repositories`); }
|
66
76
|
}
|
67
77
|
|
68
|
-
const submitDisabled = !name?.length || !label?.length || saving;
|
78
|
+
const submitDisabled = !name?.length || !label?.length || saving || redirect || labelValidated === 'error';
|
69
79
|
|
70
80
|
return (
|
71
81
|
<Form onSubmit={(e) => {
|
@@ -79,20 +89,29 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
79
89
|
type="text"
|
80
90
|
id="name"
|
81
91
|
aria-label="input_name"
|
92
|
+
ouiaId="input_name"
|
82
93
|
name="name"
|
83
94
|
value={name}
|
84
95
|
onChange={value => setName(value)}
|
85
96
|
/>
|
86
97
|
</FormGroup>
|
87
|
-
<FormGroup
|
98
|
+
<FormGroup
|
99
|
+
label={__('Label')}
|
100
|
+
isRequired
|
101
|
+
fieldId="label"
|
102
|
+
helperTextInvalid="Must be Ascii alphanumeric, '_' or '-'"
|
103
|
+
validated={labelValidated}
|
104
|
+
>
|
88
105
|
<TextInput
|
89
106
|
isRequired
|
90
107
|
type="text"
|
91
108
|
id="label"
|
92
109
|
aria-label="input_label"
|
110
|
+
ouiaId="input_label"
|
93
111
|
name="label"
|
94
112
|
value={label}
|
95
|
-
|
113
|
+
validated={labelValidated}
|
114
|
+
onChange={handleLabelChange}
|
96
115
|
/>
|
97
116
|
</FormGroup>
|
98
117
|
<FormGroup label={__('Description')} fieldId="description">
|
@@ -142,6 +161,7 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
142
161
|
<FormGroup isInline fieldId="dependencies">
|
143
162
|
<Checkbox
|
144
163
|
id="dependencies"
|
164
|
+
ouiaId="dependencies"
|
145
165
|
name="dependencies"
|
146
166
|
label={LabelDependencies()}
|
147
167
|
isChecked={dependencies}
|
@@ -152,6 +172,7 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
152
172
|
<FormGroup isInline fieldId="importOnly">
|
153
173
|
<Checkbox
|
154
174
|
id="importOnly"
|
175
|
+
ouiaId="importOnly"
|
155
176
|
name="importOnly"
|
156
177
|
label={LabelImportOnly()}
|
157
178
|
isChecked={importOnly}
|
@@ -162,6 +183,7 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
162
183
|
<FormGroup isInline fieldId="autoPublish">
|
163
184
|
<Checkbox
|
164
185
|
id="autoPublish"
|
186
|
+
ouiaId="autoPublish"
|
165
187
|
name="autoPublish"
|
166
188
|
label={LabelAutoPublish()}
|
167
189
|
isChecked={autoPublish}
|
@@ -174,6 +196,7 @@ const CreateContentViewForm = ({ setModalOpen }) => {
|
|
174
196
|
aria-label="create_content_view"
|
175
197
|
variant="primary"
|
176
198
|
isDisabled={submitDisabled}
|
199
|
+
isLoading={saving || redirect}
|
177
200
|
type="submit"
|
178
201
|
>
|
179
202
|
{__('Create content view')}
|
@@ -8,7 +8,14 @@ import cvCreateData from './contentViewCreateResult.fixtures.json';
|
|
8
8
|
|
9
9
|
const cvCreatePath = api.getApiUrl('/content_views');
|
10
10
|
|
11
|
-
const
|
11
|
+
const mockFn = jest.fn();
|
12
|
+
|
13
|
+
delete window.location;
|
14
|
+
window.location = { assign: mockFn };
|
15
|
+
|
16
|
+
afterEach(() => {
|
17
|
+
mockFn.mockClear();
|
18
|
+
});
|
12
19
|
|
13
20
|
const createDetails = {
|
14
21
|
name: '1232123',
|
@@ -22,7 +29,7 @@ const createDetails = {
|
|
22
29
|
|
23
30
|
const createdCVDetails = { ...cvCreateData };
|
24
31
|
|
25
|
-
const form = <CreateContentViewForm setModalOpen={
|
32
|
+
const form = <CreateContentViewForm setModalOpen={mockFn} />;
|
26
33
|
|
27
34
|
test('Can save content view from form', async (done) => {
|
28
35
|
const createscope = nockInstance
|
@@ -44,7 +51,7 @@ test('Form closes itself upon save', async (done) => {
|
|
44
51
|
const createscope = nockInstance
|
45
52
|
.post(cvCreatePath, createDetails)
|
46
53
|
.reply(201, createdCVDetails);
|
47
|
-
const { getByText,
|
54
|
+
const { getByText, getByLabelText } = renderWithRedux(form);
|
48
55
|
expect(getByText('Description')).toBeInTheDocument();
|
49
56
|
expect(getByText('Name')).toBeInTheDocument();
|
50
57
|
expect(getByText('Label')).toBeInTheDocument();
|
@@ -52,11 +59,11 @@ test('Form closes itself upon save', async (done) => {
|
|
52
59
|
fireEvent.change(getByLabelText('input_name'), { target: { value: '1232123' } });
|
53
60
|
|
54
61
|
await patientlyWaitFor(() => { expect(getByLabelText('input_label')).toHaveAttribute('value', '1232123'); });
|
55
|
-
|
62
|
+
jest.spyOn(window.location, 'assign');
|
56
63
|
getByLabelText('create_content_view').click();
|
57
|
-
// Form closes it self on success
|
64
|
+
// Form closes it self on success by calling location.assign()
|
58
65
|
await patientlyWaitFor(() => {
|
59
|
-
expect(
|
66
|
+
expect(window.location.assign).toHaveBeenCalled();
|
60
67
|
});
|
61
68
|
|
62
69
|
assertNockRequest(createscope, done);
|
@@ -89,3 +96,11 @@ test('Displays dependent fields correctly', () => {
|
|
89
96
|
expect(queryByText('Auto publish')).not.toBeInTheDocument();
|
90
97
|
expect(getByText('Import only')).toBeInTheDocument();
|
91
98
|
});
|
99
|
+
|
100
|
+
test('Validates label field', () => {
|
101
|
+
const { getByText, getByLabelText } = renderWithRedux(form);
|
102
|
+
expect(getByText('Label')).toBeInTheDocument();
|
103
|
+
|
104
|
+
fireEvent.change(getByLabelText('input_label'), { target: { value: '123 2123' } });
|
105
|
+
expect(getByText('Must be Ascii alphanumeric, \'_\' or \'-\'')).toBeInTheDocument();
|
106
|
+
});
|
@@ -64,9 +64,9 @@ const CVDeleteEnvironmentSelection = () => {
|
|
64
64
|
isExpanded={versionExpanded[index]}
|
65
65
|
>
|
66
66
|
{(version?.environments.length !== 0) ?
|
67
|
-
<TableComposable variant={TableVariant.compact}>
|
67
|
+
<TableComposable ouiaId="cv-delete-env-select-table" variant={TableVariant.compact}>
|
68
68
|
<Thead>
|
69
|
-
<Tr>
|
69
|
+
<Tr ouiaId="cv-delete-env-select-table-header">
|
70
70
|
<Th />
|
71
71
|
{columnHeaders.map(col =>
|
72
72
|
<Th key={col}>{col}</Th>)}
|
@@ -78,7 +78,7 @@ const CVDeleteEnvironmentSelection = () => {
|
|
78
78
|
id, name, activation_key_count: akCount, host_count: hostCount,
|
79
79
|
} = env;
|
80
80
|
return (
|
81
|
-
<Tr key={`${name}_${id}`}>
|
81
|
+
<Tr ouiaId={`${name}_${id}`} key={`${name}_${id}`}>
|
82
82
|
<Td
|
83
83
|
key={`${name}__${id}_select`}
|
84
84
|
select={{
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import React, { useContext, useState } from 'react';
|
2
2
|
import { useDispatch, useSelector } from 'react-redux';
|
3
3
|
import useDeepCompareEffect from 'use-deep-compare-effect';
|
4
|
-
import { ExpandableSection,
|
4
|
+
import { ExpandableSection, SelectOption } from '@patternfly/react-core';
|
5
5
|
import { translate as __ } from 'foremanReact/common/I18n';
|
6
6
|
import { STATUS } from 'foremanReact/constants';
|
7
7
|
import getContentViews from '../../ContentViewsActions';
|
@@ -9,6 +9,7 @@ import { selectContentViewError, selectContentViews, selectContentViewStatus } f
|
|
9
9
|
import CVDeleteContext from '../CVDeleteContext';
|
10
10
|
import EnvironmentPaths from '../../components/EnvironmentPaths/EnvironmentPaths';
|
11
11
|
import AffectedActivationKeys from '../../Details/Versions/Delete/affectedActivationKeys';
|
12
|
+
import ContentViewSelect from '../../components/ContentViewSelect/ContentViewSelect';
|
12
13
|
|
13
14
|
const CVDeletionReassignActivationKeysForm = () => {
|
14
15
|
const dispatch = useDispatch();
|
@@ -66,6 +67,11 @@ const CVDeletionReassignActivationKeysForm = () => {
|
|
66
67
|
return results?.filter(cv => cv.id === id)[0]?.name;
|
67
68
|
};
|
68
69
|
|
70
|
+
const onClear = () => {
|
71
|
+
setSelectedCVForAK(null);
|
72
|
+
setSelectedCVNameForAK(null);
|
73
|
+
};
|
74
|
+
|
69
75
|
const onSelect = (_event, selection) => {
|
70
76
|
setSelectedCVForAK(selection);
|
71
77
|
setSelectedCVNameForAK(fetchSelectedCVName(selection));
|
@@ -82,22 +88,17 @@ const CVDeletionReassignActivationKeysForm = () => {
|
|
82
88
|
multiSelect={false}
|
83
89
|
/>
|
84
90
|
{!cvInEnvLoading && selectedEnvForAK.length > 0 &&
|
85
|
-
|
86
|
-
<h3>{__('Select content view')}</h3>
|
87
|
-
<Select
|
91
|
+
<ContentViewSelect
|
88
92
|
selections={selectedCVForAK}
|
89
93
|
onSelect={onSelect}
|
94
|
+
onClear={onClear}
|
90
95
|
isOpen={cvSelectOpen}
|
91
96
|
isDisabled={cvSelectOptions.length === 0}
|
92
97
|
onToggle={isExpanded => setCVSelectOpen(isExpanded)}
|
93
|
-
id="selectCV"
|
94
|
-
name="selectCV"
|
95
|
-
aria-label="selectCV"
|
96
98
|
placeholderText={(cvSelectOptions.length === 0) ? __('No content views available') : __('Select a content view')}
|
97
99
|
>
|
98
100
|
{cvSelectOptions}
|
99
|
-
</
|
100
|
-
</div>
|
101
|
+
</ContentViewSelect>
|
101
102
|
}
|
102
103
|
<ExpandableSection
|
103
104
|
toggleText={showActivationKeys ?
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import React, { useState, useContext } from 'react';
|
2
2
|
import { useDispatch, useSelector } from 'react-redux';
|
3
3
|
import useDeepCompareEffect from 'use-deep-compare-effect';
|
4
|
-
import { ExpandableSection,
|
4
|
+
import { ExpandableSection, SelectOption } from '@patternfly/react-core';
|
5
5
|
import { translate as __ } from 'foremanReact/common/I18n';
|
6
6
|
import { STATUS } from 'foremanReact/constants';
|
7
7
|
import getContentViews from '../../ContentViewsActions';
|
@@ -9,6 +9,7 @@ import { selectContentViewError, selectContentViews, selectContentViewStatus } f
|
|
9
9
|
import CVDeleteContext from '../CVDeleteContext';
|
10
10
|
import EnvironmentPaths from '../../components/EnvironmentPaths/EnvironmentPaths';
|
11
11
|
import AffectedHosts from '../../Details/Versions/Delete/affectedHosts';
|
12
|
+
import ContentViewSelect from '../../components/ContentViewSelect/ContentViewSelect';
|
12
13
|
|
13
14
|
|
14
15
|
const CVDeletionReassignHostsForm = () => {
|
@@ -67,6 +68,11 @@ const CVDeletionReassignHostsForm = () => {
|
|
67
68
|
return results?.filter(cv => cv.id === id)[0]?.name;
|
68
69
|
};
|
69
70
|
|
71
|
+
const onClear = () => {
|
72
|
+
setSelectedCVForHosts(null);
|
73
|
+
setSelectedCVNameForHosts(null);
|
74
|
+
};
|
75
|
+
|
70
76
|
const onSelect = (_event, selection) => {
|
71
77
|
setSelectedCVForHosts(selection);
|
72
78
|
setSelectedCVNameForHosts(fetchSelectedCVName(selection));
|
@@ -83,22 +89,17 @@ const CVDeletionReassignHostsForm = () => {
|
|
83
89
|
multiSelect={false}
|
84
90
|
/>
|
85
91
|
{selectedEnvForHost.length > 0 &&
|
86
|
-
|
87
|
-
<h3>{__('Select content view')}</h3>
|
88
|
-
<Select
|
92
|
+
<ContentViewSelect
|
89
93
|
selections={selectedCVForHosts}
|
90
94
|
onSelect={onSelect}
|
95
|
+
onClear={onClear}
|
91
96
|
isOpen={cvSelectOpen}
|
92
97
|
isDisabled={cvSelectOptions.length === 0}
|
93
98
|
onToggle={isExpanded => setCVSelectOpen(isExpanded)}
|
94
|
-
id="selectCV"
|
95
|
-
name="selectCV"
|
96
|
-
aria-label="selectCV"
|
97
99
|
placeholderText={(cvSelectOptions.length === 0) ? __('No content views available') : __('Select a content view')}
|
98
100
|
>
|
99
101
|
{cvSelectOptions}
|
100
|
-
</
|
101
|
-
</div>
|
102
|
+
</ContentViewSelect>
|
102
103
|
}
|
103
104
|
<ExpandableSection
|
104
105
|
toggleText={showHosts ? 'Hide hosts' : 'Show hosts'}
|
@@ -2,8 +2,8 @@
|
|
2
2
|
import React from 'react';
|
3
3
|
import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
|
4
4
|
import api, { foremanApi } from '../../../../services/api';
|
5
|
-
import
|
6
|
-
nockInstance, assertNockRequest, mockAutocomplete,
|
5
|
+
import {
|
6
|
+
nockInstance, assertNockRequest, mockAutocomplete, mockForemanAutocomplete,
|
7
7
|
} from '../../../../test-utils/nockWrapper';
|
8
8
|
import CONTENT_VIEWS_KEY from '../../ContentViewsConstants';
|
9
9
|
import ContentViewsPage from '../../ContentViewsPage.js';
|
@@ -37,25 +37,10 @@ const baseQuery = {
|
|
37
37
|
sort_order: 'asc',
|
38
38
|
};
|
39
39
|
|
40
|
-
let scopeBookmark;
|
41
40
|
let firstCV;
|
42
|
-
let searchDelayScope;
|
43
|
-
let autoSearchScope;
|
44
41
|
beforeEach(() => {
|
45
42
|
const { results } = cvIndexData;
|
46
43
|
[firstCV] = results;
|
47
|
-
scopeBookmark = nockInstance
|
48
|
-
.get('/api/v2/bookmarks')
|
49
|
-
.query(true)
|
50
|
-
.reply(200, {});
|
51
|
-
searchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
52
|
-
autoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
53
|
-
});
|
54
|
-
|
55
|
-
afterEach(() => {
|
56
|
-
nock.cleanAll();
|
57
|
-
assertNockRequest(searchDelayScope);
|
58
|
-
assertNockRequest(autoSearchScope);
|
59
44
|
});
|
60
45
|
|
61
46
|
test('Can call API for CVs and show Delete Wizard for the row', async (done) => {
|
@@ -94,7 +79,6 @@ test('Can call API for CVs and show Delete Wizard for the row', async (done) =>
|
|
94
79
|
await patientlyWaitFor(() => expect(getAllByText('Remove versions from environments')[1]).toBeInTheDocument());
|
95
80
|
|
96
81
|
assertNockRequest(scope);
|
97
|
-
assertNockRequest(scopeBookmark);
|
98
82
|
assertNockRequest(autocompleteScope);
|
99
83
|
assertNockRequest(envPathDeleteScope);
|
100
84
|
assertNockRequest(cvDetailsScope);
|
@@ -104,12 +88,8 @@ test('Can call API for CVs and show Delete Wizard for the row', async (done) =>
|
|
104
88
|
test('Can open Delete wizard and delete CV with all steps', async (done) => {
|
105
89
|
const hostAutocompleteUrl = '/hosts/auto_complete_search';
|
106
90
|
const hostAutocompleteScope = mockForemanAutocomplete(nockInstance, hostAutocompleteUrl);
|
107
|
-
const hostSearchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
108
|
-
const hostAutoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
109
91
|
const akAutocompleteUrl = '/activation_keys/auto_complete_search';
|
110
92
|
const akAutocompleteScope = mockAutocomplete(nockInstance, akAutocompleteUrl);
|
111
|
-
const akSearchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
112
|
-
const akAutoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
113
93
|
|
114
94
|
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
115
95
|
|
@@ -166,7 +146,7 @@ test('Can open Delete wizard and delete CV with all steps', async (done) => {
|
|
166
146
|
.reply(200, cVDropDownOptionsData);
|
167
147
|
|
168
148
|
const {
|
169
|
-
getByText, getByLabelText, getAllByLabelText, getAllByText, queryByText,
|
149
|
+
getByText, getByLabelText, getAllByLabelText, getAllByText, queryByText, getByPlaceholderText,
|
170
150
|
} =
|
171
151
|
renderWithRedux(<ContentViewsPage />, renderOptions);
|
172
152
|
expect(queryByText(firstCV.name)).toBeNull();
|
@@ -192,9 +172,9 @@ test('Can open Delete wizard and delete CV with all steps', async (done) => {
|
|
192
172
|
fireEvent.click(getByLabelText('test1'));
|
193
173
|
await patientlyWaitFor(() => {
|
194
174
|
expect(getByText('Select content view')).toBeInTheDocument();
|
195
|
-
expect(
|
175
|
+
expect(getByPlaceholderText('Select a content view')).toBeInTheDocument();
|
196
176
|
});
|
197
|
-
fireEvent.click(
|
177
|
+
fireEvent.click(getByPlaceholderText('Select a content view'));
|
198
178
|
await patientlyWaitFor(() => {
|
199
179
|
expect(getByText('cv2')).toBeInTheDocument();
|
200
180
|
});
|
@@ -211,9 +191,9 @@ test('Can open Delete wizard and delete CV with all steps', async (done) => {
|
|
211
191
|
fireEvent.click(getByLabelText('test1'));
|
212
192
|
await patientlyWaitFor(() => {
|
213
193
|
expect(getByText('Select content view')).toBeInTheDocument();
|
214
|
-
expect(
|
194
|
+
expect(getByPlaceholderText('Select a content view')).toBeInTheDocument();
|
215
195
|
});
|
216
|
-
fireEvent.click(
|
196
|
+
fireEvent.click(getByPlaceholderText('Select a content view'));
|
217
197
|
await patientlyWaitFor(() => {
|
218
198
|
expect(getByText('cv2')).toBeInTheDocument();
|
219
199
|
});
|
@@ -232,19 +212,14 @@ test('Can open Delete wizard and delete CV with all steps', async (done) => {
|
|
232
212
|
fireEvent.click(getAllByText('Delete')[0]);
|
233
213
|
|
234
214
|
assertNockRequest(scope);
|
235
|
-
assertNockRequest(scopeBookmark);
|
236
215
|
assertNockRequest(autocompleteScope);
|
237
216
|
assertNockRequest(envPathDeleteScope);
|
238
217
|
assertNockRequest(cvDetailsScope);
|
239
218
|
assertNockRequest(cvVersionsScope);
|
240
219
|
assertNockRequest(hostAutocompleteScope);
|
241
|
-
assertNockRequest(hostSearchDelayScope);
|
242
|
-
assertNockRequest(hostAutoSearchScope);
|
243
220
|
assertNockRequest(hostScope);
|
244
221
|
assertNockRequest(cVDropDownOptionsScope);
|
245
222
|
assertNockRequest(akAutocompleteScope);
|
246
|
-
assertNockRequest(akSearchDelayScope);
|
247
|
-
assertNockRequest(akAutoSearchScope);
|
248
223
|
assertNockRequest(activationKeysScope);
|
249
224
|
assertNockRequest(cVDropDownOptionsScope);
|
250
225
|
assertNockRequest(cvDeleteScope);
|