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
@@ -41,7 +41,11 @@ const ContentViewTable = () => {
|
|
41
41
|
const [actionableCvName, setActionableCvName] = useState('');
|
42
42
|
const dispatch = useDispatch();
|
43
43
|
const metadata = omit(response, ['results']);
|
44
|
-
const {
|
44
|
+
const {
|
45
|
+
can_create: canCreate = false,
|
46
|
+
can_view: canView = false,
|
47
|
+
results,
|
48
|
+
} = response;
|
45
49
|
const columnHeaders = [
|
46
50
|
__('Type'),
|
47
51
|
__('Name'),
|
@@ -126,9 +130,10 @@ const ContentViewTable = () => {
|
|
126
130
|
);
|
127
131
|
|
128
132
|
const emptyContentTitle = __("You currently don't have any Content views.");
|
129
|
-
const emptyContentBody = __('A content view can be added by using the "Create content view" button
|
133
|
+
const emptyContentBody = __('A content view can be added by using the "Create content view" button below.');
|
130
134
|
const emptySearchTitle = __('No matching content views found');
|
131
135
|
const emptySearchBody = __('Try changing your search settings.');
|
136
|
+
const showPrimaryAction = true;
|
132
137
|
const {
|
133
138
|
id,
|
134
139
|
latest_version_id: latestVersionId,
|
@@ -137,7 +142,6 @@ const ContentViewTable = () => {
|
|
137
142
|
environments,
|
138
143
|
versions,
|
139
144
|
} = actionableCvDetails;
|
140
|
-
|
141
145
|
return (
|
142
146
|
<TableWrapper
|
143
147
|
{...{
|
@@ -150,23 +154,34 @@ const ContentViewTable = () => {
|
|
150
154
|
searchQuery,
|
151
155
|
updateSearchQuery,
|
152
156
|
fetchItems,
|
157
|
+
showPrimaryAction,
|
153
158
|
}}
|
159
|
+
hideSearch={!canView}
|
154
160
|
ouiaId="content-views-table"
|
155
161
|
additionalListeners={[activeSortColumn, activeSortDirection]}
|
156
162
|
bookmarkController="katello_content_views"
|
157
163
|
variant={TableVariant.compact}
|
158
164
|
status={status}
|
159
|
-
autocompleteEndpoint="/content_views
|
165
|
+
autocompleteEndpoint="/katello/api/v2/content_views"
|
166
|
+
primaryActionButton={canCreate ? (
|
167
|
+
<Button
|
168
|
+
ouiaId="create-content-view"
|
169
|
+
onClick={openForm}
|
170
|
+
variant="primary"
|
171
|
+
aria-label="create_content_view"
|
172
|
+
> {__('Create content view')}
|
173
|
+
</Button >) : undefined}
|
160
174
|
actionButtons={
|
161
175
|
<>
|
162
|
-
{canCreate &&
|
176
|
+
{results?.length !== 0 && canCreate &&
|
163
177
|
<Button ouiaId="create-content-view" onClick={openForm} variant="primary" aria-label="create_content_view">
|
164
178
|
{__('Create content view')}
|
165
179
|
</Button>
|
166
180
|
}
|
167
181
|
<CreateContentViewModal show={isModalOpen} setIsOpen={setIsModalOpen} aria-label="create_content_view_modal" />
|
168
182
|
<CopyContentViewModal cvId={actionableCvId} cvName={actionableCvName} show={copy} setIsOpen={setCopy} aria-label="copy_content_view_modal" />
|
169
|
-
{
|
183
|
+
{
|
184
|
+
isPublishModalOpen &&
|
170
185
|
<PublishContentViewWizard
|
171
186
|
details={actionableCvDetails}
|
172
187
|
show={isPublishModalOpen}
|
@@ -179,7 +194,8 @@ const ContentViewTable = () => {
|
|
179
194
|
aria-label="publish_content_view_modal"
|
180
195
|
/>
|
181
196
|
}
|
182
|
-
{
|
197
|
+
{
|
198
|
+
isPromoteModalOpen &&
|
183
199
|
<ContentViewVersionPromote
|
184
200
|
cvId={id && Number(id)}
|
185
201
|
versionIdToPromote={latestVersionId}
|
@@ -188,7 +204,8 @@ const ContentViewTable = () => {
|
|
188
204
|
setIsOpen={setIsPromoteModalOpen}
|
189
205
|
/>
|
190
206
|
}
|
191
|
-
{
|
207
|
+
{
|
208
|
+
isDeleteModalOpen &&
|
192
209
|
<ContentViewDeleteWizard
|
193
210
|
cvId={id && Number(id)}
|
194
211
|
cvEnvironments={environments}
|
@@ -196,12 +213,13 @@ const ContentViewTable = () => {
|
|
196
213
|
show={isDeleteModalOpen}
|
197
214
|
setIsOpen={setIsDeleteModalOpen}
|
198
215
|
aria-label="delete_content_view_modal"
|
199
|
-
/>
|
216
|
+
/>
|
217
|
+
}
|
200
218
|
</>
|
201
219
|
}
|
202
220
|
>
|
203
221
|
<Thead>
|
204
|
-
<Tr>
|
222
|
+
<Tr ouiaId="cvTableHeaderRow">
|
205
223
|
<Th key="expand-carat" />
|
206
224
|
{columnHeaders.map(col => (
|
207
225
|
<Th
|
@@ -214,80 +232,82 @@ const ContentViewTable = () => {
|
|
214
232
|
<Th key="action-menu" />
|
215
233
|
</Tr>
|
216
234
|
</Thead>
|
217
|
-
{
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
<
|
239
|
-
<
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
<
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
<
|
270
|
-
<
|
271
|
-
<
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
<
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
235
|
+
{
|
236
|
+
results?.map((cvInfo, rowIndex) => {
|
237
|
+
const {
|
238
|
+
composite,
|
239
|
+
name,
|
240
|
+
id: cvId,
|
241
|
+
last_published: lastPublished,
|
242
|
+
latest_version: latestVersion,
|
243
|
+
latest_version_id: cvLatestVersionId,
|
244
|
+
latest_version_environments: cvLatestVersionEnvironments,
|
245
|
+
last_task: lastTask,
|
246
|
+
activation_keys: activationKeys,
|
247
|
+
hosts,
|
248
|
+
related_cv_count: relatedCVCount,
|
249
|
+
related_composite_cvs: relatedCompositeCVs,
|
250
|
+
description,
|
251
|
+
createdAt,
|
252
|
+
} = cvInfo;
|
253
|
+
const { last_sync_words: lastSyncWords, started_at: startedAt } = lastTask ?? {};
|
254
|
+
const isExpanded = tableRowIsExpanded(cvId);
|
255
|
+
return (
|
256
|
+
<Tbody isExpanded={isExpanded} key={`${cvId}_${createdAt}`}>
|
257
|
+
<Tr key={cvId} ouiaId={`ContentViewTableRow-${cvId}`}>
|
258
|
+
<Td
|
259
|
+
expand={{
|
260
|
+
rowIndex,
|
261
|
+
isExpanded,
|
262
|
+
onToggle: (_event, _rInx, isOpen) =>
|
263
|
+
expandedTableRows.onToggle(isOpen, cvId),
|
264
|
+
}}
|
265
|
+
/>
|
266
|
+
<Td><ContentViewIcon position="right" composite={composite} /></Td>
|
267
|
+
<Td><Link to={`${urlBuilder('content_views', '')}${cvId}`}>{name}</Link></Td>
|
268
|
+
<Td>{lastPublished ? <LongDateTime date={lastPublished} showRelativeTimeTooltip /> : <InactiveText text={__('Not yet published')} />}</Td>
|
269
|
+
<Td><LastSync startedAt={startedAt} lastSync={lastTask} lastSyncWords={lastSyncWords} emptyMessage="N/A" /></Td>
|
270
|
+
<Td>{latestVersion ?
|
271
|
+
<ContentViewVersionCell {...{
|
272
|
+
id: cvId,
|
273
|
+
latestVersion,
|
274
|
+
latestVersionId: cvLatestVersionId,
|
275
|
+
latestVersionEnvironments: cvLatestVersionEnvironments,
|
276
|
+
}}
|
277
|
+
/> :
|
278
|
+
<InactiveText style={{ marginTop: '0.5em', marginBottom: '0.5em' }} text={__('Not yet published')} />}
|
279
|
+
</Td>
|
280
|
+
<Td
|
281
|
+
key={`rowActions-${id}`}
|
282
|
+
actions={{
|
283
|
+
items: actionsWithPermissions(cvInfo),
|
284
|
+
}}
|
285
|
+
/>
|
286
|
+
</Tr>
|
287
|
+
<Tr key="child_row" ouiaId={`ContentViewTableRowChild-${cvId}`} isExpanded={isExpanded}>
|
288
|
+
<Td colSpan={2}>
|
289
|
+
<ExpandableRowContent>
|
290
|
+
<DetailsExpansion
|
291
|
+
cvId={cvId}
|
292
|
+
cvName={name}
|
293
|
+
cvComposite={composite}
|
294
|
+
{...{
|
295
|
+
activationKeys, hosts, relatedCVCount, relatedCompositeCVs,
|
296
|
+
}}
|
297
|
+
/>
|
298
|
+
</ExpandableRowContent>
|
299
|
+
</Td>
|
300
|
+
<Td colSpan={4}>
|
301
|
+
<ExpandableRowContent>
|
302
|
+
{description || <InactiveText text={__('No description')} />}
|
303
|
+
</ExpandableRowContent>
|
304
|
+
</Td>
|
305
|
+
</Tr>
|
306
|
+
</Tbody>
|
307
|
+
);
|
308
|
+
})
|
309
|
+
}
|
310
|
+
</TableWrapper >
|
291
311
|
);
|
292
312
|
};
|
293
313
|
|
@@ -5,8 +5,8 @@ import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-
|
|
5
5
|
import CONTENT_VIEWS_KEY from '../ContentViewsConstants';
|
6
6
|
import ContentViewsPage from '../../ContentViews';
|
7
7
|
import api from '../../../services/api';
|
8
|
-
import
|
9
|
-
nockInstance, assertNockRequest, mockAutocomplete,
|
8
|
+
import {
|
9
|
+
nockInstance, assertNockRequest, mockAutocomplete,
|
10
10
|
} from '../../../test-utils/nockWrapper';
|
11
11
|
import createBasicCVs from './basicContentViews.fixtures';
|
12
12
|
import cvIndexData from './contentViewList.fixtures.json';
|
@@ -14,30 +14,19 @@ import cvIndexData from './contentViewList.fixtures.json';
|
|
14
14
|
const cvIndexPath = api.getApiUrl('/content_views');
|
15
15
|
const autocompleteUrl = '/content_views/auto_complete_search';
|
16
16
|
const renderOptions = { apiNamespace: CONTENT_VIEWS_KEY };
|
17
|
+
const autocompleteQuery = {
|
18
|
+
organization_id: 1,
|
19
|
+
search: '',
|
20
|
+
};
|
17
21
|
|
18
22
|
let firstCV;
|
19
|
-
let searchDelayScope;
|
20
|
-
let autoSearchScope;
|
21
|
-
let scopeBookmark;
|
22
23
|
beforeEach(() => {
|
23
24
|
const { results } = cvIndexData;
|
24
25
|
[firstCV] = results;
|
25
|
-
scopeBookmark = nockInstance
|
26
|
-
.get('/api/v2/bookmarks')
|
27
|
-
.query(true)
|
28
|
-
.reply(200, {});
|
29
|
-
searchDelayScope = mockSetting(nockInstance, 'autosearch_delay', 0);
|
30
|
-
autoSearchScope = mockSetting(nockInstance, 'autosearch_while_typing');
|
31
|
-
});
|
32
|
-
|
33
|
-
afterEach(() => {
|
34
|
-
nock.cleanAll();
|
35
|
-
assertNockRequest(searchDelayScope);
|
36
|
-
assertNockRequest(autoSearchScope);
|
37
26
|
});
|
38
27
|
|
39
28
|
test('Can call API for CVs and show on screen on page load', async (done) => {
|
40
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
29
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
41
30
|
const scope = nockInstance
|
42
31
|
.get(cvIndexPath)
|
43
32
|
.query(true)
|
@@ -55,13 +44,12 @@ test('Can call API for CVs and show on screen on page load', async (done) => {
|
|
55
44
|
});
|
56
45
|
|
57
46
|
|
58
|
-
assertNockRequest(scopeBookmark);
|
59
47
|
assertNockRequest(autocompleteScope);
|
60
48
|
assertNockRequest(scope, done);
|
61
49
|
});
|
62
50
|
|
63
51
|
test('Can show last task and link to it', async (done) => {
|
64
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
52
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
65
53
|
const scope = nockInstance
|
66
54
|
.get(cvIndexPath)
|
67
55
|
.query(true)
|
@@ -80,13 +68,12 @@ test('Can show last task and link to it', async (done) => {
|
|
80
68
|
expect(queryByText('N/A')).toBeTruthy();
|
81
69
|
});
|
82
70
|
|
83
|
-
assertNockRequest(scopeBookmark);
|
84
71
|
assertNockRequest(autocompleteScope);
|
85
72
|
assertNockRequest(scope, done); // Pass jest callback to confirm test is done
|
86
73
|
});
|
87
74
|
|
88
75
|
test('Can show latest version and link to it', async (done) => {
|
89
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
76
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
90
77
|
const scope = nockInstance
|
91
78
|
.get(cvIndexPath)
|
92
79
|
.query(true)
|
@@ -113,13 +100,12 @@ test('Can show latest version and link to it', async (done) => {
|
|
113
100
|
expect(getByText('dev').closest('a'))
|
114
101
|
.toHaveAttribute('href', '/lifecycle_environments/2');
|
115
102
|
});
|
116
|
-
assertNockRequest(scopeBookmark);
|
117
103
|
assertNockRequest(autocompleteScope);
|
118
104
|
assertNockRequest(scope, done); // Pass jest callback to confirm test is done
|
119
105
|
});
|
120
106
|
|
121
107
|
test('Can expand cv and show activation keys and hosts', async (done) => {
|
122
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
108
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
123
109
|
const scope = nockInstance
|
124
110
|
.get(cvIndexPath)
|
125
111
|
.query(true)
|
@@ -157,14 +143,14 @@ test('Can expand cv and show activation keys and hosts', async (done) => {
|
|
157
143
|
});
|
158
144
|
|
159
145
|
test('Can handle no Content Views being present', async (done) => {
|
160
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
161
|
-
|
162
146
|
const noResults = {
|
163
147
|
total: 0,
|
164
148
|
subtotal: 0,
|
165
149
|
page: 1,
|
166
150
|
per_page: 20,
|
167
151
|
results: [],
|
152
|
+
can_view: true,
|
153
|
+
can_create: true,
|
168
154
|
};
|
169
155
|
const scope = nockInstance
|
170
156
|
.get(cvIndexPath)
|
@@ -174,12 +160,10 @@ test('Can handle no Content Views being present', async (done) => {
|
|
174
160
|
|
175
161
|
expect(queryByText(firstCV.name)).toBeNull();
|
176
162
|
await patientlyWaitFor(() => expect(queryByText(/don't have any Content views/i)).toBeInTheDocument());
|
177
|
-
assertNockRequest(autocompleteScope);
|
178
163
|
assertNockRequest(scope, done);
|
179
164
|
});
|
180
165
|
|
181
166
|
test('Can handle errored response', async (done) => {
|
182
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
183
167
|
const scope = nockInstance
|
184
168
|
.get(cvIndexPath)
|
185
169
|
.query(true)
|
@@ -189,7 +173,6 @@ test('Can handle errored response', async (done) => {
|
|
189
173
|
|
190
174
|
expect(queryByText(firstCV.name)).toBeNull();
|
191
175
|
await patientlyWaitFor(() => expect(queryByText(/Something went wrong! Please check server logs!/i)).toBeInTheDocument());
|
192
|
-
assertNockRequest(autocompleteScope);
|
193
176
|
assertNockRequest(scope, done);
|
194
177
|
});
|
195
178
|
|
@@ -197,7 +180,7 @@ test('Can handle unpublished Content Views', async (done) => {
|
|
197
180
|
const { results } = cvIndexData;
|
198
181
|
const unpublishedCVs = results.map(cv => ({ ...cv, last_published: null }));
|
199
182
|
const unpublishedCVData = { ...cvIndexData, results: unpublishedCVs };
|
200
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
183
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
201
184
|
const scope = nockInstance
|
202
185
|
.get(cvIndexPath)
|
203
186
|
.query(true)
|
@@ -215,7 +198,7 @@ test('Can handle pagination', async (done) => {
|
|
215
198
|
const { results } = cvIndexLarge;
|
216
199
|
const cvIndexFirstPage = { ...cvIndexLarge, ...{ results: results.slice(0, 20) } };
|
217
200
|
const cvIndexSecondPage = { ...cvIndexLarge, page: 2, results: results.slice(20, 40) };
|
218
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
201
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
219
202
|
|
220
203
|
// Match first page API request
|
221
204
|
const firstPageScope = nockInstance
|
@@ -256,23 +239,37 @@ test('Can handle pagination', async (done) => {
|
|
256
239
|
|
257
240
|
test('Can search for specific Content View', async (done) => {
|
258
241
|
const cvname = 'composite one';
|
259
|
-
const
|
260
|
-
|
261
|
-
|
262
|
-
...cvIndexData,
|
263
|
-
...{ total: 1, subtotal: 1, results: results.slice(-1) },
|
242
|
+
const matchQuery = {
|
243
|
+
organization_id: 1,
|
244
|
+
search: `name = ${firstCV.name}`,
|
264
245
|
};
|
246
|
+
const searchResults = [
|
247
|
+
{
|
248
|
+
completed: 'name = cv1',
|
249
|
+
part: 'and',
|
250
|
+
label: 'name = cv1 and',
|
251
|
+
category: 'Operators',
|
252
|
+
},
|
253
|
+
{
|
254
|
+
completed: 'name = cv1',
|
255
|
+
part: 'or',
|
256
|
+
label: 'name = cv1 or',
|
257
|
+
category: 'Operators',
|
258
|
+
},
|
259
|
+
];
|
260
|
+
|
261
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
262
|
+
const withSearchScope = mockAutocomplete(
|
263
|
+
nockInstance,
|
264
|
+
autocompleteUrl,
|
265
|
+
matchQuery,
|
266
|
+
searchResults,
|
267
|
+
);
|
265
268
|
|
266
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
267
|
-
const withSearchScope = mockAutocomplete(nockInstance, autocompleteUrl, matchQuery);
|
268
269
|
const initialScope = nockInstance
|
269
270
|
.get(cvIndexPath)
|
270
271
|
.query(true)
|
271
272
|
.reply(200, cvIndexData);
|
272
|
-
const searchResultScope = nockInstance
|
273
|
-
.get(cvIndexPath)
|
274
|
-
.query(matchQuery)
|
275
|
-
.reply(200, searchResults);
|
276
273
|
|
277
274
|
const {
|
278
275
|
getByLabelText,
|
@@ -282,63 +279,62 @@ test('Can search for specific Content View', async (done) => {
|
|
282
279
|
|
283
280
|
await patientlyWaitFor(() => expect(getByText(firstCV.name)).toBeInTheDocument());
|
284
281
|
|
285
|
-
const searchInput = getByLabelText(
|
282
|
+
const searchInput = getByLabelText('Search input');
|
286
283
|
expect(searchInput).toBeInTheDocument();
|
287
|
-
|
284
|
+
searchInput.focus();
|
285
|
+
fireEvent.change(searchInput, { target: { value: `name = ${firstCV.name}` } });
|
288
286
|
|
289
287
|
await patientlyWaitFor(() => {
|
290
|
-
expect(getByText(
|
291
|
-
expect(queryByText(
|
288
|
+
expect(getByText(`name = ${firstCV.name} and`)).toBeInTheDocument();
|
289
|
+
expect(queryByText(`name = ${cvname} and`)).not.toBeInTheDocument();
|
292
290
|
});
|
293
291
|
|
294
292
|
assertNockRequest(autocompleteScope);
|
295
293
|
assertNockRequest(initialScope);
|
296
|
-
assertNockRequest(withSearchScope);
|
297
|
-
assertNockRequest(searchResultScope, done);
|
294
|
+
assertNockRequest(withSearchScope, done);
|
298
295
|
});
|
299
296
|
|
300
|
-
test('
|
297
|
+
test('Nothing is shown for empty search', async (done) => {
|
301
298
|
const cvname = 'notanactualname';
|
302
299
|
const query = `name = \"${cvname}\"`;
|
303
|
-
const matchQuery =
|
304
|
-
|
305
|
-
|
300
|
+
const matchQuery = {
|
301
|
+
organization_id: 1,
|
302
|
+
search: query,
|
306
303
|
};
|
307
304
|
|
308
|
-
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
|
305
|
+
const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
|
309
306
|
const withSearchScope = mockAutocomplete(nockInstance, autocompleteUrl, matchQuery);
|
310
307
|
const initialScope = nockInstance
|
311
308
|
.get(cvIndexPath)
|
312
309
|
.query(true)
|
313
310
|
.reply(200, cvIndexData);
|
314
|
-
const searchResultScope = nockInstance
|
315
|
-
.get(cvIndexPath)
|
316
|
-
.query(matchQuery)
|
317
|
-
.reply(200, emptyResults);
|
318
311
|
|
319
|
-
const {
|
312
|
+
const {
|
313
|
+
getByLabelText,
|
314
|
+
getByText,
|
315
|
+
queryByText,
|
316
|
+
} = renderWithRedux(<ContentViewsPage />, renderOptions);
|
320
317
|
|
321
318
|
await patientlyWaitFor(() => expect(getByText(firstCV.name)).toBeInTheDocument());
|
322
319
|
|
323
|
-
|
320
|
+
getByLabelText('Search input').focus();
|
321
|
+
fireEvent.change(getByLabelText('Search input'), { target: { value: query } });
|
324
322
|
|
325
|
-
await patientlyWaitFor(() => expect(
|
323
|
+
await patientlyWaitFor(() => expect(queryByText(`${query} and`)).not.toBeInTheDocument());
|
326
324
|
|
327
325
|
assertNockRequest(autocompleteScope);
|
328
326
|
assertNockRequest(initialScope);
|
329
|
-
assertNockRequest(withSearchScope);
|
330
|
-
assertNockRequest(searchResultScope, done);
|
327
|
+
assertNockRequest(withSearchScope, done);
|
331
328
|
});
|
332
329
|
|
333
330
|
test('Displays Create Content View and opens modal with Form', async () => {
|
334
|
-
mockAutocomplete(nockInstance, autocompleteUrl);
|
335
|
-
|
336
331
|
const noResults = {
|
337
332
|
total: 0,
|
338
333
|
subtotal: 0,
|
339
334
|
page: 1,
|
340
335
|
per_page: 20,
|
341
336
|
can_create: true,
|
337
|
+
can_view: true,
|
342
338
|
results: [],
|
343
339
|
};
|
344
340
|
nockInstance
|
@@ -1,10 +1,15 @@
|
|
1
1
|
{
|
2
2
|
"label": "mock_details",
|
3
3
|
"permissions": {
|
4
|
-
|
4
|
+
"view_content_views": true,
|
5
5
|
"edit_content_views": true,
|
6
6
|
"destroy_content_views": true,
|
7
7
|
"publish_content_views": true,
|
8
8
|
"promote_or_remove_content_views": true
|
9
|
-
}
|
9
|
+
},
|
10
|
+
"name": "mock_details",
|
11
|
+
"composite": false,
|
12
|
+
"next_version": "1.0",
|
13
|
+
"id": "5",
|
14
|
+
"version_count": 0
|
10
15
|
}
|
@@ -101,7 +101,7 @@ const CVBreadcrumb = () => {
|
|
101
101
|
filterDetails, filterDetailsStatus, breadcrumbItems, setBreadcrumbItems]);
|
102
102
|
|
103
103
|
return (
|
104
|
-
<Breadcrumb className="margin-bottom-24">
|
104
|
+
<Breadcrumb ouiaId="cv-breadcrumb" className="margin-bottom-24">
|
105
105
|
{
|
106
106
|
Object.keys(breadcrumbItems)?.sort()?.map(key => (
|
107
107
|
<BreadcrumbItem
|
@@ -0,0 +1,40 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
3
|
+
import { Select, SelectVariant } from '@patternfly/react-core';
|
4
|
+
import PropTypes from 'prop-types';
|
5
|
+
|
6
|
+
const ContentViewSelect = ({
|
7
|
+
headerText,
|
8
|
+
children,
|
9
|
+
onClear,
|
10
|
+
...pfSelectProps
|
11
|
+
}) => (
|
12
|
+
<div style={{ marginTop: '1em' }}>
|
13
|
+
<h3>{headerText}</h3>
|
14
|
+
<Select
|
15
|
+
variant={SelectVariant.typeahead}
|
16
|
+
onClear={onClear}
|
17
|
+
maxHeight="20rem"
|
18
|
+
menuAppendTo="parent"
|
19
|
+
ouiaId="select-content-view"
|
20
|
+
id="selectCV"
|
21
|
+
name="selectCV"
|
22
|
+
aria-label="selectCV"
|
23
|
+
{...pfSelectProps}
|
24
|
+
>
|
25
|
+
{children}
|
26
|
+
</Select>
|
27
|
+
</div>
|
28
|
+
);
|
29
|
+
|
30
|
+
ContentViewSelect.propTypes = {
|
31
|
+
headerText: PropTypes.string,
|
32
|
+
onClear: PropTypes.func.isRequired,
|
33
|
+
children: PropTypes.node.isRequired,
|
34
|
+
};
|
35
|
+
|
36
|
+
ContentViewSelect.defaultProps = {
|
37
|
+
headerText: __('Select content view'),
|
38
|
+
};
|
39
|
+
|
40
|
+
export default ContentViewSelect;
|