katello 3.18.0.rc2.1 → 4.0.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/stylesheets/katello/katello.scss +0 -72
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +0 -19
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +1 -3
- data/app/controllers/katello/api/v2/api_controller.rb +1 -2
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +2 -2
- data/app/controllers/katello/api/v2/content_credentials_controller.rb +24 -24
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +98 -0
- data/app/controllers/katello/api/v2/content_exports_controller.rb +88 -0
- data/app/controllers/katello/api/v2/content_imports_controller.rb +59 -0
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +56 -94
- data/app/controllers/katello/api/v2/content_views_controller.rb +2 -2
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_packages_controller.rb +6 -6
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +2 -3
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +3 -2
- data/app/controllers/katello/api/v2/repositories_controller.rb +5 -19
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +34 -0
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +8 -4
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +1 -1
- data/app/helpers/katello/sync_management_helper.rb +0 -2
- data/app/lib/actions/candlepin/environment/create.rb +1 -1
- data/app/lib/actions/candlepin/environment/set_content.rb +1 -1
- data/app/lib/actions/katello/activation_key/create.rb +9 -11
- data/app/lib/actions/katello/agent/dispatch_history_presenter.rb +64 -0
- data/app/lib/actions/katello/agent_action.rb +107 -0
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +6 -2
- data/app/lib/actions/katello/bulk_agent_action.rb +21 -0
- data/app/lib/actions/katello/capsule_content/sync.rb +8 -8
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +16 -2
- data/app/lib/actions/katello/check_matching_content.rb +17 -0
- data/app/lib/actions/katello/content_view/environment_create.rb +6 -8
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +1 -1
- data/app/lib/actions/katello/content_view/publish.rb +2 -2
- data/app/lib/actions/katello/content_view_version/import.rb +2 -1
- data/app/lib/actions/katello/content_view_version/import_library.rb +17 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +30 -10
- data/app/lib/actions/katello/host/erratum/applicable_errata_install.rb +1 -1
- data/app/lib/actions/katello/host/erratum/install.rb +8 -26
- data/app/lib/actions/katello/host/hypervisors_update.rb +4 -4
- data/app/lib/actions/katello/host/package/install.rb +8 -21
- data/app/lib/actions/katello/host/package/remove.rb +8 -20
- data/app/lib/actions/katello/host/package/update.rb +9 -22
- data/app/lib/actions/katello/host/package_group/install.rb +8 -21
- data/app/lib/actions/katello/host/package_group/remove.rb +8 -20
- data/app/lib/actions/katello/host/update_system_purpose.rb +1 -1
- data/app/lib/actions/katello/organization/create.rb +3 -5
- data/app/lib/actions/katello/organization/destroy.rb +1 -1
- data/app/lib/actions/katello/organization/manifest_delete.rb +3 -5
- data/app/lib/actions/katello/organization/manifest_import.rb +1 -1
- data/app/lib/actions/katello/organization/manifest_refresh.rb +1 -1
- data/app/lib/actions/katello/repository/check_matching_content.rb +3 -1
- data/app/lib/actions/katello/repository/clone_contents.rb +8 -11
- data/app/lib/actions/katello/repository/create.rb +0 -8
- data/app/lib/actions/katello/repository/filtered_index_content.rb +3 -0
- data/app/lib/actions/katello/repository/index_content.rb +1 -0
- data/app/lib/actions/katello/repository/multi_clone_contents.rb +9 -12
- data/app/lib/actions/katello/repository/update.rb +0 -8
- data/app/lib/actions/middleware/execute_if_contents_changed.rb +4 -1
- data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +24 -4
- data/app/lib/actions/pulp/consumer.rb +0 -11
- data/app/lib/actions/pulp/orchestration/repository/refresh_repos.rb +0 -6
- data/app/lib/actions/pulp3/capsule_content/refresh_distribution.rb +3 -3
- data/app/lib/actions/pulp3/content_migration.rb +10 -0
- data/app/lib/actions/pulp3/content_migration_presenter.rb +59 -0
- data/app/lib/actions/pulp3/content_view/delete_repository_references.rb +1 -1
- data/app/lib/actions/pulp3/content_view_version/export.rb +3 -2
- data/app/lib/actions/pulp3/import_migration.rb +6 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +2 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +17 -13
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +60 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +0 -4
- data/app/lib/actions/pulp3/orchestration/repository/import_upload.rb +16 -3
- data/app/lib/actions/pulp3/orchestration/repository/refresh_repos.rb +1 -6
- data/app/lib/actions/pulp3/repository/copy_content.rb +1 -1
- data/app/lib/actions/pulp3/repository/delete.rb +1 -1
- data/app/lib/actions/pulp3/repository/save_version.rb +1 -1
- data/app/lib/actions/pulp3/repository/upload_tag.rb +18 -0
- data/app/lib/katello/agent/base_message.rb +38 -0
- data/app/lib/katello/agent/client_message_handler.rb +60 -0
- data/app/lib/katello/agent/connection.rb +24 -0
- data/app/lib/katello/agent/install_errata_message.rb +25 -0
- data/app/lib/katello/agent/install_package_group_message.rb +25 -0
- data/app/lib/katello/agent/install_package_message.rb +28 -0
- data/app/lib/katello/agent/remove_package_group_message.rb +25 -0
- data/app/lib/katello/agent/remove_package_message.rb +28 -0
- data/app/lib/katello/agent/update_package_message.rb +25 -0
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +8 -0
- data/app/lib/katello/event_daemon/monitor.rb +53 -0
- data/app/lib/katello/event_daemon/runner.rb +99 -0
- data/app/lib/katello/event_daemon/services/agent_event_receiver.rb +62 -0
- data/app/lib/katello/logging.rb +32 -0
- data/app/lib/katello/messaging/connection.rb +1 -7
- data/app/lib/katello/messaging/received_message.rb +1 -1
- data/app/lib/katello/qpid/connection.rb +130 -0
- data/app/lib/katello/validators/content_view_puppet_module_validator.rb +1 -1
- data/app/models/katello/activation_key.rb +2 -2
- data/app/models/katello/agent/dispatch_history.rb +17 -0
- data/app/models/katello/authorization/content_view_version.rb +25 -2
- data/app/models/katello/authorization/content_view_version_export_history.rb +1 -1
- data/app/models/katello/authorization/organization.rb +8 -0
- data/app/models/katello/candlepin/repository_mapper.rb +1 -1
- data/app/models/katello/concerns/host_managed_extensions.rb +3 -0
- data/app/models/katello/concerns/operatingsystem_extensions.rb +2 -0
- data/app/models/katello/concerns/organization_extensions.rb +2 -2
- data/app/models/katello/concerns/pulp_database_unit.rb +7 -0
- data/app/models/katello/concerns/redhat_extensions.rb +2 -2
- data/app/models/katello/concerns/smart_proxy_extensions.rb +31 -5
- data/app/models/katello/content_migration_progress.rb +4 -0
- data/app/models/katello/content_view.rb +10 -1
- data/app/models/katello/content_view_environment.rb +2 -2
- data/app/models/katello/content_view_history.rb +2 -1
- data/app/models/katello/content_view_package_filter.rb +1 -1
- data/app/models/katello/content_view_puppet_environment.rb +2 -2
- data/app/models/katello/content_view_version.rb +2 -1
- data/app/models/katello/content_view_version_export_history.rb +26 -1
- data/app/models/katello/erratum.rb +3 -1
- data/app/models/katello/events/delete_host_agent_queue.rb +19 -0
- data/app/models/katello/glue/candlepin/pool.rb +2 -0
- data/app/models/katello/glue/pulp/repo.rb +0 -6
- data/app/models/katello/glue/pulp/repos.rb +1 -22
- data/app/models/katello/host/subscription_facet.rb +4 -0
- data/app/models/katello/ping.rb +12 -4
- data/app/models/katello/pool.rb +5 -0
- data/app/models/katello/product.rb +3 -3
- data/app/models/katello/repository.rb +10 -3
- data/app/models/katello/subscription_status.rb +3 -2
- data/app/models/setting/content.rb +0 -2
- data/app/presenters/katello/host_subscription_presenter.rb +3 -4
- data/app/presenters/katello/host_subscriptions_presenter.rb +24 -0
- data/app/services/katello/agent/dispatcher.rb +66 -0
- data/app/services/katello/applicability/applicable_content_helper.rb +44 -15
- data/app/services/katello/candlepin_event_listener.rb +12 -19
- data/app/services/katello/event_monitor/poller_thread.rb +3 -11
- data/app/services/katello/pulp/smart_proxy_repository.rb +0 -15
- data/app/services/katello/pulp3/api/docker.rb +4 -0
- data/app/services/katello/pulp3/content_view_version/export.rb +63 -5
- data/app/services/katello/pulp3/content_view_version/import.rb +40 -0
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +0 -16
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +26 -49
- data/app/services/katello/pulp3/docker_manifest.rb +1 -0
- data/app/services/katello/pulp3/docker_tag.rb +1 -0
- data/app/services/katello/pulp3/migration.rb +44 -9
- data/app/services/katello/pulp3/repository.rb +13 -4
- data/app/services/katello/pulp3/repository/docker.rb +5 -0
- data/app/services/katello/pulp3/repository/yum.rb +15 -9
- data/app/services/katello/pulp3/task.rb +4 -0
- data/app/services/katello/pulp3/task_group.rb +4 -0
- data/app/services/katello/registration_manager.rb +10 -0
- data/app/services/katello/repository_type.rb +1 -1
- data/app/views/foreman/smart_proxies/_content_tab.html.erb +4 -47
- data/app/views/foreman/smart_proxies/show.html.erb +1 -1
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +22 -25
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +1 -0
- data/app/views/katello/api/v2/content_views/show.json.rabl +6 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -9
- data/app/views/katello/layouts/react.html.erb +3 -2
- data/app/views/katello/sync_management/_products.html.erb +1 -1
- data/app/views/overrides/activation_keys/_host_tab_pane.html.erb +1 -5
- data/app/views/overrides/organizations/_edit_override.html.erb +1 -4
- data/app/views/overrides/smart_proxies/_environment_tab.html.erb +1 -1
- data/app/views/overrides/smart_proxies/_environment_tab_pane.html.erb +1 -1
- data/config/katello.yaml.example +0 -3
- data/config/routes/api/v2.rb +31 -13
- data/db/migrate/20150930183738_migrate_content_hosts.rb +1 -1
- data/db/migrate/20191204214919_add_content_view_version_counts.rb +0 -1
- data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +5 -2
- data/db/migrate/20201119211133_pulp3_migration_progress.rb +9 -0
- data/db/migrate/20210119162528_delete_puppet_and_ostree_repos.rb +56 -0
- data/db/migrate/20210122200618_create_katello_agent_dispatch_history.rb +11 -0
- data/db/migrate/20210125161911_delete_erratum_install_batch_size_setting.rb +5 -0
- data/db/migrate/20210128231228_add_type_and_from_cvv_to_cvv_export_history.rb +14 -0
- data/db/migrate/20210201163238_migrate_background_download_policy_to_migrate.rb +7 -0
- data/db/migrate/20210208213920_add_available_module_stream_context.rb +8 -0
- data/db/seeds.d/104-proxy.rb +1 -1
- data/db/seeds.d/111-upgrade_tasks.rb +2 -1
- data/engines/bastion/app/assets/javascripts/bastion/auth/authorization.service.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/views/katello-agent-notice.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +35 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-os-client.directive.js +17 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-client.html +12 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-deb-client.html +38 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-oracle-client.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-sles-client.html +28 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register.html +14 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +8 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +9 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +78 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +17 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +17 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +1292 -1170
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +17 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +858 -807
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +18 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +17 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +17 -18
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +986 -971
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +19 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +9 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/download-policy.service.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.controller.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscription-start-date.directive.js +21 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscription-type.directive.js +16 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/subscription-start-date.html +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/subscription-type.html +18 -0
- data/lib/katello/engine.rb +12 -6
- data/lib/katello/middleware/event_daemon.rb +1 -1
- data/lib/katello/permission_creator.rb +26 -5
- data/lib/katello/plugin.rb +3 -2
- data/lib/katello/tasks/delete_orphaned_content.rake +1 -3
- data/lib/katello/tasks/jenkins.rake +1 -1
- data/lib/katello/tasks/pulp3_content_switchover.rake +1 -1
- data/lib/katello/tasks/pulp3_migration.rake +18 -6
- data/lib/katello/tasks/pulp3_migration_abort.rake +7 -2
- data/lib/katello/tasks/pulp3_migration_stats.rake +28 -8
- data/lib/katello/tasks/pulp3_post_migration_check.rake +1 -3
- data/lib/katello/tasks/receptor/extract_orgs.rake +1 -1
- data/lib/katello/tasks/reimport.rake +1 -1
- data/lib/katello/tasks/repository.rake +3 -5
- data/lib/katello/tasks/reset.rake +0 -15
- data/lib/katello/tasks/upgrades/4.0/remove_ostree_puppet_content.rake +16 -0
- data/lib/katello/version.rb +1 -1
- data/lib/proxy_api/container_gateway.rb +21 -0
- data/locale/action_names.rb +51 -51
- data/locale/bn/katello.edit.po +8538 -0
- data/locale/bn/katello.po +136 -51
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/cs/katello.edit.po +8440 -0
- data/locale/cs/katello.po +136 -49
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/katello.edit.po +8344 -0
- data/locale/de/katello.po +136 -48
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/katello.edit.po +8161 -0
- data/locale/en/katello.po +136 -48
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/katello.edit.po +8306 -0
- data/locale/es/katello.po +136 -48
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/katello.edit.po +8356 -0
- data/locale/fr/katello.po +136 -48
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/katello.edit.po +8540 -0
- data/locale/gu/katello.po +136 -51
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/katello.edit.po +8537 -0
- data/locale/hi/katello.po +136 -51
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/katello.edit.po +8293 -0
- data/locale/it/katello.po +136 -48
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/katello.edit.po +8322 -0
- data/locale/ja/katello.po +136 -48
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +941 -767
- data/locale/kn/katello.edit.po +8538 -0
- data/locale/kn/katello.po +136 -51
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/katello.edit.po +8289 -0
- data/locale/ko/katello.po +136 -48
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/katello.edit.po +8502 -0
- data/locale/mr/katello.po +136 -51
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/katello.edit.po +8538 -0
- data/locale/or/katello.po +136 -51
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/katello.edit.po +8524 -0
- data/locale/pa/katello.po +136 -51
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/katello.edit.po +8255 -0
- data/locale/pt/katello.po +136 -51
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/katello.edit.po +8289 -0
- data/locale/pt_BR/katello.po +136 -48
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/katello.edit.po +8309 -0
- data/locale/ru/katello.po +136 -48
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/katello.edit.po +8536 -0
- data/locale/ta/katello.po +136 -51
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/katello.edit.po +8536 -0
- data/locale/te/katello.po +136 -51
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/katello.edit.po +8288 -0
- data/locale/zh_CN/katello.po +136 -48
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/katello.edit.po +8420 -0
- data/locale/zh_TW/katello.po +136 -48
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/package.json +1 -1
- data/webpack/__mocks__/foremanReact/Root/Context/ForemanContext.js +0 -1
- data/webpack/__mocks__/foremanReact/components/Pagination/PaginationHooks.js +2 -0
- data/webpack/__mocks__/foremanReact/components/common/dates/LongDateTime.js +5 -0
- data/webpack/{scenes/ContentViews/Details/Repositories → components/SelectableDropdown}/SelectableDropdown.js +20 -3
- data/webpack/components/SelectableDropdown/__tests__/SelectableDropdown.test.js +45 -0
- data/webpack/components/SelectableDropdown/index.js +3 -0
- data/webpack/components/Table/TableWrapper.js +2 -1
- data/webpack/components/Table/helpers.js +14 -0
- data/webpack/components/TypeAhead/TypeAhead.js +2 -1
- data/webpack/components/TypeAhead/pf3Search/TypeAheadSearch.js +2 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +0 -1
- data/webpack/containers/Application/overrides.scss +6 -0
- data/webpack/index.js +6 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +5 -5
- data/webpack/scenes/ContentViews/ContentViewsActions.js +31 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +5 -1
- data/webpack/scenes/ContentViews/Copy/ContentViewCopySelectors.js +16 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +77 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +44 -0
- data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +42 -0
- data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +39 -0
- data/webpack/scenes/ContentViews/Copy/index.js +4 -0
- data/webpack/scenes/ContentViews/Create/ContentViewCreateSelectors.js +16 -0
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +58 -0
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +175 -0
- data/webpack/scenes/ContentViews/Create/CreateContentViewModal.js +27 -0
- data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +42 -0
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +92 -0
- data/webpack/scenes/ContentViews/Create/index.js +4 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +16 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +20 -1
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +17 -7
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +19 -13
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +40 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +124 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.fixtures.json +134 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +92 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +44 -25
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +17 -7
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +24 -0
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +53 -3
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +4 -3
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +41 -0
- data/webpack/scenes/ContentViews/helpers.js +13 -0
- data/webpack/scenes/SmartProxy/Content.js +17 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +11 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentConstants.js +3 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentSelectors.js +16 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +152 -0
- data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentResult.fixtures.json +140 -0
- data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentTest.js +38 -0
- data/webpack/scenes/SmartProxy/index.js +4 -0
- data/webpack/scenes/Subscriptions/Manifest/ManifestActions.js +3 -3
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManifestActions.test.js +2 -2
- data/webpack/scenes/Subscriptions/Manifest/__tests__/SimpleContentAccess.test.js +2 -2
- data/webpack/test-utils/react-testing-lib-wrapper.js +5 -2
- data/webpack/utils/helpers.js +3 -0
- metadata +160 -40
- data/app/controllers/katello/api/v2/gpg_keys_controller.rb +0 -114
- data/app/lib/actions/pulp/consumer/abstract_content_action.rb +0 -71
- data/app/lib/actions/pulp/consumer/content_install.rb +0 -43
- data/app/lib/actions/pulp/consumer/content_uninstall.rb +0 -26
- data/app/lib/actions/pulp/consumer/content_update.rb +0 -32
- data/app/overrides/disable_turbolinks_on_proxies_index.rb +0 -5
- data/app/services/katello/event_daemon.rb +0 -135
- data/app/services/katello/pulp/content_counts_calculator.rb +0 -60
- data/db/functions/empty_v01.sql +0 -7
- data/db/functions/evr_trigger_v01.sql +0 -9
- data/db/functions/isalpha_v01.sql +0 -11
- data/db/functions/isalphanum_v01.sql +0 -12
- data/db/functions/isdigit_v01.sql +0 -10
- data/db/functions/rpmver_array_v01.sql +0 -60
- data/lib/katello/tasks/common.rake +0 -7
- data/lib/katello/tasks/reports.rake +0 -4
- data/lib/katello/tasks/upgrades/3.10/update_gpg_key_urls.rake +0 -32
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.scss +0 -5
- data/webpack/scenes/ContentViews/Table/actionResolver.js +0 -28
@@ -0,0 +1,42 @@
|
|
1
|
+
{
|
2
|
+
"content_host_count": 0,
|
3
|
+
"composite": false,
|
4
|
+
"component_ids": [],
|
5
|
+
"default": false,
|
6
|
+
"force_puppet_environment": false,
|
7
|
+
"version_count": 0,
|
8
|
+
"latest_version": null,
|
9
|
+
"auto_publish": false,
|
10
|
+
"solve_dependencies": false,
|
11
|
+
"import_only": false,
|
12
|
+
"repository_ids": [],
|
13
|
+
"id": 34,
|
14
|
+
"name": "copy cv",
|
15
|
+
"label": "copy_cv",
|
16
|
+
"description": "",
|
17
|
+
"organization_id": 1,
|
18
|
+
"organization": {
|
19
|
+
"name": "Default Organization",
|
20
|
+
"label": "Default_Organization",
|
21
|
+
"id": 1
|
22
|
+
},
|
23
|
+
"created_at": "2020-12-14 12:45:59 -0500",
|
24
|
+
"updated_at": "2020-12-14 12:45:59 -0500",
|
25
|
+
"environments": [],
|
26
|
+
"repositories": [],
|
27
|
+
"puppet_modules": [],
|
28
|
+
"versions": [],
|
29
|
+
"components": [],
|
30
|
+
"content_view_components": [],
|
31
|
+
"activation_keys": [],
|
32
|
+
"next_version": "1.0",
|
33
|
+
"last_published": null,
|
34
|
+
"permissions": {
|
35
|
+
"view_content_views": true,
|
36
|
+
"edit_content_views": true,
|
37
|
+
"destroy_content_views": true,
|
38
|
+
"publish_content_views": true,
|
39
|
+
"promote_or_remove_content_views": true
|
40
|
+
},
|
41
|
+
"duplicate_repositories_to_publish": []
|
42
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
|
3
|
+
|
4
|
+
import { nockInstance, assertNockRequest } from '../../../../test-utils/nockWrapper';
|
5
|
+
import api from '../../../../services/api';
|
6
|
+
import CopyContentViewForm from '../CopyContentViewForm';
|
7
|
+
|
8
|
+
const cvCopyData = require('./contentViewCopyResult.fixtures.json');
|
9
|
+
|
10
|
+
const cvId = '1';
|
11
|
+
const cvCopyPath = api.getApiUrl(`/content_views/${cvId}/copy`);
|
12
|
+
const setModalOpen = jest.fn();
|
13
|
+
|
14
|
+
const copyParams = {
|
15
|
+
id: cvId,
|
16
|
+
name: 'cv copy',
|
17
|
+
};
|
18
|
+
|
19
|
+
const copiedCVDetails = { ...cvCopyData };
|
20
|
+
|
21
|
+
const form = <CopyContentViewForm cvId={cvId} setModalOpen={setModalOpen} />;
|
22
|
+
|
23
|
+
test('Can copy content view from form', async (done) => {
|
24
|
+
const copyscope = nockInstance
|
25
|
+
.post(cvCopyPath, copyParams)
|
26
|
+
.reply(201, copiedCVDetails);
|
27
|
+
const { queryByText, getByLabelText } = renderWithRedux(form);
|
28
|
+
expect(queryByText('Name')).toBeInTheDocument();
|
29
|
+
|
30
|
+
fireEvent.change(getByLabelText('input_name'), { target: { value: 'cv copy' } });
|
31
|
+
|
32
|
+
getByLabelText('copy_content_view').click();
|
33
|
+
// Form closes it self on success
|
34
|
+
await patientlyWaitFor(() => {
|
35
|
+
expect(queryByText('Name')).not.toBeInTheDocument();
|
36
|
+
});
|
37
|
+
|
38
|
+
assertNockRequest(copyscope, done);
|
39
|
+
});
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import {
|
2
|
+
selectAPIStatus,
|
3
|
+
selectAPIError,
|
4
|
+
selectAPIResponse,
|
5
|
+
} from 'foremanReact/redux/API/APISelectors';
|
6
|
+
import { STATUS } from 'foremanReact/constants';
|
7
|
+
import { CREATE_CONTENT_VIEW_KEY } from '../ContentViewsConstants';
|
8
|
+
|
9
|
+
export const selectCreateContentViews = state =>
|
10
|
+
selectAPIResponse(state, CREATE_CONTENT_VIEW_KEY) || {};
|
11
|
+
|
12
|
+
export const selectCreateContentViewStatus = state =>
|
13
|
+
selectAPIStatus(state, CREATE_CONTENT_VIEW_KEY) || STATUS.PENDING;
|
14
|
+
|
15
|
+
export const selectCreateContentViewError = state =>
|
16
|
+
selectAPIError(state, CREATE_CONTENT_VIEW_KEY);
|
@@ -0,0 +1,58 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
3
|
+
import { OutlinedQuestionCircleIcon } from '@patternfly/react-icons';
|
4
|
+
import { Tooltip, TooltipPosition, Flex, FlexItem } from '@patternfly/react-core';
|
5
|
+
import { autoPublishHelpText, dependenciesHelpText, importOnlyHelpText } from '../helpers';
|
6
|
+
import ContentViewIcon from '../components/ContentViewIcon';
|
7
|
+
|
8
|
+
const HelpToolTip = tooltip => (
|
9
|
+
<span className="foreman-spaced-icon">
|
10
|
+
<Tooltip
|
11
|
+
position={TooltipPosition.top}
|
12
|
+
content={tooltip}
|
13
|
+
>
|
14
|
+
<OutlinedQuestionCircleIcon />
|
15
|
+
</Tooltip>
|
16
|
+
</span>
|
17
|
+
);
|
18
|
+
|
19
|
+
export const LabelComposite = () => (
|
20
|
+
<Flex>
|
21
|
+
<FlexItem spacer={{ default: 'spacerNone' }}><ContentViewIcon composite /></FlexItem>
|
22
|
+
<FlexItem>{__('Composite Content View')}</FlexItem>
|
23
|
+
</Flex>
|
24
|
+
);
|
25
|
+
|
26
|
+
export const LabelComponent = () => (
|
27
|
+
<Flex>
|
28
|
+
<FlexItem spacer={{ default: 'spacerNone' }}><ContentViewIcon composite={false} /></FlexItem>
|
29
|
+
<FlexItem>{__('Component Content View')}</FlexItem>
|
30
|
+
</Flex>
|
31
|
+
);
|
32
|
+
|
33
|
+
export const LabelDependencies = () => (
|
34
|
+
<Flex>
|
35
|
+
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Solve Dependencies')}</FlexItem>
|
36
|
+
<FlexItem>
|
37
|
+
{HelpToolTip(dependenciesHelpText)}
|
38
|
+
</FlexItem>
|
39
|
+
</Flex>
|
40
|
+
);
|
41
|
+
|
42
|
+
export const LabelAutoPublish = () => (
|
43
|
+
<Flex>
|
44
|
+
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Auto Publish')}</FlexItem>
|
45
|
+
<FlexItem>
|
46
|
+
{HelpToolTip(autoPublishHelpText)}
|
47
|
+
</FlexItem>
|
48
|
+
</Flex>
|
49
|
+
);
|
50
|
+
|
51
|
+
export const LabelImportOnly = () => (
|
52
|
+
<Flex>
|
53
|
+
<FlexItem spacer={{ default: 'spacerSm' }}>{__('Import Only')}</FlexItem>
|
54
|
+
<FlexItem>
|
55
|
+
{HelpToolTip(importOnlyHelpText)}
|
56
|
+
</FlexItem>
|
57
|
+
</Flex>
|
58
|
+
);
|
@@ -0,0 +1,175 @@
|
|
1
|
+
import { STATUS } from 'foremanReact/constants';
|
2
|
+
import React, { useState, useEffect } from 'react';
|
3
|
+
import PropTypes from 'prop-types';
|
4
|
+
import { useDispatch, useSelector } from 'react-redux';
|
5
|
+
import { Redirect } from 'react-router-dom';
|
6
|
+
import { Form, FormGroup, TextInput, TextArea, Checkbox, ActionGroup, Button, Tile, Grid, GridItem } from '@patternfly/react-core';
|
7
|
+
import { createContentView } from '../ContentViewsActions';
|
8
|
+
import { selectCreateContentViews, selectCreateContentViewStatus, selectCreateContentViewError } from './ContentViewCreateSelectors';
|
9
|
+
import { LabelDependencies, LabelAutoPublish, LabelImportOnly } from './ContentViewFormComponents';
|
10
|
+
import ContentViewIcon from '../components/ContentViewIcon';
|
11
|
+
|
12
|
+
const CreateContentViewForm = ({ setModalOpen }) => {
|
13
|
+
const dispatch = useDispatch();
|
14
|
+
const [name, setName] = useState('');
|
15
|
+
const [label, setLabel] = useState('');
|
16
|
+
const [description, setDescription] = useState('');
|
17
|
+
const [composite, setComposite] = useState(false);
|
18
|
+
const [component, setComponent] = useState(true);
|
19
|
+
const [autoPublish, setAutoPublish] = useState(false);
|
20
|
+
const [importOnly, setImportOnly] = useState(false);
|
21
|
+
const [dependencies, setDependencies] = useState(false);
|
22
|
+
const [redirect, setRedirect] = useState(false);
|
23
|
+
const [saving, setSaving] = useState(false);
|
24
|
+
|
25
|
+
const response = useSelector(selectCreateContentViews);
|
26
|
+
const status = useSelector(selectCreateContentViewStatus);
|
27
|
+
const error = useSelector(selectCreateContentViewError);
|
28
|
+
|
29
|
+
useEffect(() => {
|
30
|
+
const { id } = response;
|
31
|
+
if (id && status === STATUS.RESOLVED) {
|
32
|
+
setSaving(false);
|
33
|
+
setRedirect(true);
|
34
|
+
} else if (status === STATUS.ERROR) {
|
35
|
+
setSaving(false);
|
36
|
+
}
|
37
|
+
}, [JSON.stringify(response), status, error]);
|
38
|
+
|
39
|
+
const onSave = () => {
|
40
|
+
setSaving(true);
|
41
|
+
dispatch(createContentView({
|
42
|
+
name,
|
43
|
+
label,
|
44
|
+
description,
|
45
|
+
composite,
|
46
|
+
solve_dependencies: dependencies,
|
47
|
+
auto_publish: (autoPublish && composite),
|
48
|
+
import_only: importOnly,
|
49
|
+
}));
|
50
|
+
};
|
51
|
+
|
52
|
+
useEffect(
|
53
|
+
() => {
|
54
|
+
setLabel(name.replace(/ /g, '_'));
|
55
|
+
},
|
56
|
+
[name],
|
57
|
+
);
|
58
|
+
|
59
|
+
if (redirect) {
|
60
|
+
const { id } = response;
|
61
|
+
return (<Redirect to={`/labs/content_views/${id}`} />);
|
62
|
+
}
|
63
|
+
|
64
|
+
return (
|
65
|
+
<Form>
|
66
|
+
<FormGroup label="Name" isRequired fieldId="name">
|
67
|
+
<TextInput
|
68
|
+
isRequired
|
69
|
+
type="text"
|
70
|
+
id="name"
|
71
|
+
aria-label="input_name"
|
72
|
+
name="name"
|
73
|
+
value={name}
|
74
|
+
onChange={value => setName(value)}
|
75
|
+
/>
|
76
|
+
</FormGroup>
|
77
|
+
<FormGroup label="Label" isRequired fieldId="label">
|
78
|
+
<TextInput
|
79
|
+
isRequired
|
80
|
+
type="text"
|
81
|
+
id="label"
|
82
|
+
aria-label="input_label"
|
83
|
+
name="label"
|
84
|
+
value={label}
|
85
|
+
onChange={value => setLabel(value)}
|
86
|
+
/>
|
87
|
+
</FormGroup>
|
88
|
+
<FormGroup label="Description" fieldId="description">
|
89
|
+
<TextArea
|
90
|
+
isRequired
|
91
|
+
type="text"
|
92
|
+
id="description"
|
93
|
+
name="description"
|
94
|
+
aria-label="input_description"
|
95
|
+
value={description}
|
96
|
+
onChange={value => setDescription(value)}
|
97
|
+
/>
|
98
|
+
</FormGroup>
|
99
|
+
<FormGroup isInline fieldId="type" label="Type">
|
100
|
+
<Grid hasGutter>
|
101
|
+
<GridItem span={6}>
|
102
|
+
<Tile
|
103
|
+
isStacked
|
104
|
+
aria-label="component_tile"
|
105
|
+
icon={<ContentViewIcon composite={false} />}
|
106
|
+
id="component"
|
107
|
+
title="Component content view"
|
108
|
+
onClick={() => { setComponent(true); setComposite(false); }}
|
109
|
+
isSelected={component}
|
110
|
+
>
|
111
|
+
Single content view consisting of repositories
|
112
|
+
</Tile>
|
113
|
+
</GridItem>
|
114
|
+
<GridItem span={6}>
|
115
|
+
<Tile
|
116
|
+
isStacked
|
117
|
+
aria-label="composite_tile"
|
118
|
+
icon={<ContentViewIcon composite />}
|
119
|
+
id="composite"
|
120
|
+
title="Composite content view"
|
121
|
+
onClick={() => { setComposite(true); setComponent(false); }}
|
122
|
+
isSelected={composite}
|
123
|
+
>
|
124
|
+
Consists of component content views
|
125
|
+
</Tile>
|
126
|
+
</GridItem>
|
127
|
+
</Grid>
|
128
|
+
</FormGroup>
|
129
|
+
{!composite &&
|
130
|
+
<FormGroup isInline fieldId="dependencies">
|
131
|
+
<Checkbox
|
132
|
+
id="dependencies"
|
133
|
+
name="dependencies"
|
134
|
+
label={LabelDependencies()}
|
135
|
+
isChecked={dependencies}
|
136
|
+
onChange={checked => setDependencies(checked)}
|
137
|
+
/>
|
138
|
+
</FormGroup>}
|
139
|
+
{!composite &&
|
140
|
+
<FormGroup isInline fieldId="importOnly">
|
141
|
+
<Checkbox
|
142
|
+
id="importOnly"
|
143
|
+
name="importOnly"
|
144
|
+
label={LabelImportOnly()}
|
145
|
+
isChecked={importOnly}
|
146
|
+
onChange={checked => setImportOnly(checked)}
|
147
|
+
/>
|
148
|
+
</FormGroup>}
|
149
|
+
{composite &&
|
150
|
+
<FormGroup isInline fieldId="autoPublish">
|
151
|
+
<Checkbox
|
152
|
+
id="autoPublish"
|
153
|
+
name="autoPublish"
|
154
|
+
label={LabelAutoPublish()}
|
155
|
+
isChecked={autoPublish}
|
156
|
+
onChange={checked => setAutoPublish(checked)}
|
157
|
+
/>
|
158
|
+
</FormGroup>}
|
159
|
+
<ActionGroup>
|
160
|
+
<Button aria-label="create_content_view" variant="primary" isDisabled={saving} onClick={() => onSave()}>Create content view</Button>
|
161
|
+
<Button variant="link" onClick={() => setModalOpen(false)}>Cancel</Button>
|
162
|
+
</ActionGroup>
|
163
|
+
</Form>
|
164
|
+
);
|
165
|
+
};
|
166
|
+
|
167
|
+
CreateContentViewForm.propTypes = {
|
168
|
+
setModalOpen: PropTypes.func,
|
169
|
+
};
|
170
|
+
|
171
|
+
CreateContentViewForm.defaultProps = {
|
172
|
+
setModalOpen: null,
|
173
|
+
};
|
174
|
+
|
175
|
+
export default CreateContentViewForm;
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { Modal, ModalVariant } from '@patternfly/react-core';
|
4
|
+
import CreateContentViewForm from './CreateContentViewForm';
|
5
|
+
|
6
|
+
const CreateContentViewModal = ({ show, setIsOpen }) => (
|
7
|
+
<Modal
|
8
|
+
title="Create content view"
|
9
|
+
variant={ModalVariant.small}
|
10
|
+
isOpen={show}
|
11
|
+
onClose={() => { setIsOpen(false); }}
|
12
|
+
appendTo={document.body}
|
13
|
+
><CreateContentViewForm setModalOpen={setIsOpen} />
|
14
|
+
</Modal>
|
15
|
+
);
|
16
|
+
|
17
|
+
CreateContentViewModal.propTypes = {
|
18
|
+
show: PropTypes.bool,
|
19
|
+
setIsOpen: PropTypes.func,
|
20
|
+
};
|
21
|
+
|
22
|
+
CreateContentViewModal.defaultProps = {
|
23
|
+
show: false,
|
24
|
+
setIsOpen: null,
|
25
|
+
};
|
26
|
+
|
27
|
+
export default CreateContentViewModal;
|
@@ -0,0 +1,42 @@
|
|
1
|
+
{
|
2
|
+
"content_host_count": 0,
|
3
|
+
"composite": false,
|
4
|
+
"component_ids": [],
|
5
|
+
"default": false,
|
6
|
+
"force_puppet_environment": false,
|
7
|
+
"version_count": 0,
|
8
|
+
"latest_version": null,
|
9
|
+
"auto_publish": false,
|
10
|
+
"solve_dependencies": false,
|
11
|
+
"import_only": false,
|
12
|
+
"repository_ids": [],
|
13
|
+
"id": 34,
|
14
|
+
"name": "1232123",
|
15
|
+
"label": "1232123",
|
16
|
+
"description": "",
|
17
|
+
"organization_id": 1,
|
18
|
+
"organization": {
|
19
|
+
"name": "Default Organization",
|
20
|
+
"label": "Default_Organization",
|
21
|
+
"id": 1
|
22
|
+
},
|
23
|
+
"created_at": "2020-12-14 12:45:59 -0500",
|
24
|
+
"updated_at": "2020-12-14 12:45:59 -0500",
|
25
|
+
"environments": [],
|
26
|
+
"repositories": [],
|
27
|
+
"puppet_modules": [],
|
28
|
+
"versions": [],
|
29
|
+
"components": [],
|
30
|
+
"content_view_components": [],
|
31
|
+
"activation_keys": [],
|
32
|
+
"next_version": "1.0",
|
33
|
+
"last_published": null,
|
34
|
+
"permissions": {
|
35
|
+
"view_content_views": true,
|
36
|
+
"edit_content_views": true,
|
37
|
+
"destroy_content_views": true,
|
38
|
+
"publish_content_views": true,
|
39
|
+
"promote_or_remove_content_views": true
|
40
|
+
},
|
41
|
+
"duplicate_repositories_to_publish": []
|
42
|
+
}
|
@@ -0,0 +1,92 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
|
3
|
+
|
4
|
+
import { nockInstance, assertNockRequest } from '../../../../test-utils/nockWrapper';
|
5
|
+
import api from '../../../../services/api';
|
6
|
+
import CreateContentViewForm from '../CreateContentViewForm';
|
7
|
+
|
8
|
+
const cvCreateData = require('./contentViewCreateResult.fixtures.json');
|
9
|
+
|
10
|
+
const cvCreatePath = api.getApiUrl('/content_views');
|
11
|
+
|
12
|
+
const setModalOpen = jest.fn();
|
13
|
+
|
14
|
+
const createDetails = {
|
15
|
+
name: '1232123',
|
16
|
+
label: '1232123',
|
17
|
+
description: '',
|
18
|
+
composite: false,
|
19
|
+
solve_dependencies: false,
|
20
|
+
auto_publish: false,
|
21
|
+
import_only: false,
|
22
|
+
};
|
23
|
+
|
24
|
+
const createdCVDetails = { ...cvCreateData };
|
25
|
+
|
26
|
+
const form = <CreateContentViewForm setModalOpen={setModalOpen} />;
|
27
|
+
|
28
|
+
test('Can save content view from form', async (done) => {
|
29
|
+
const createscope = nockInstance
|
30
|
+
.post(cvCreatePath, createDetails)
|
31
|
+
.reply(201, createdCVDetails);
|
32
|
+
const { queryByText, getByLabelText } = renderWithRedux(form);
|
33
|
+
expect(queryByText('Description')).toBeInTheDocument();
|
34
|
+
|
35
|
+
fireEvent.change(getByLabelText('input_name'), { target: { value: '1232123' } });
|
36
|
+
|
37
|
+
await patientlyWaitFor(() => { expect(getByLabelText('input_label')).toHaveAttribute('value', '1232123'); });
|
38
|
+
|
39
|
+
getByLabelText('create_content_view').click();
|
40
|
+
|
41
|
+
assertNockRequest(createscope, done);
|
42
|
+
});
|
43
|
+
|
44
|
+
test('Form closes itself upon save', async (done) => {
|
45
|
+
const createscope = nockInstance
|
46
|
+
.post(cvCreatePath, createDetails)
|
47
|
+
.reply(201, createdCVDetails);
|
48
|
+
const { getByText, queryByText, getByLabelText } = renderWithRedux(form);
|
49
|
+
expect(getByText('Description')).toBeInTheDocument();
|
50
|
+
expect(getByText('Name')).toBeInTheDocument();
|
51
|
+
expect(getByText('Label')).toBeInTheDocument();
|
52
|
+
|
53
|
+
fireEvent.change(getByLabelText('input_name'), { target: { value: '1232123' } });
|
54
|
+
|
55
|
+
await patientlyWaitFor(() => { expect(getByLabelText('input_label')).toHaveAttribute('value', '1232123'); });
|
56
|
+
|
57
|
+
getByLabelText('create_content_view').click();
|
58
|
+
// Form closes it self on success
|
59
|
+
await patientlyWaitFor(() => {
|
60
|
+
expect(queryByText('Description')).not.toBeInTheDocument();
|
61
|
+
});
|
62
|
+
|
63
|
+
assertNockRequest(createscope, done);
|
64
|
+
});
|
65
|
+
|
66
|
+
test('Displays dependent fields correctly', () => {
|
67
|
+
const { getByText, queryByText, getByLabelText } = renderWithRedux(form);
|
68
|
+
expect(getByText('Description')).toBeInTheDocument();
|
69
|
+
expect(getByText('Name')).toBeInTheDocument();
|
70
|
+
expect(getByText('Label')).toBeInTheDocument();
|
71
|
+
expect(getByText('Composite content view')).toBeInTheDocument();
|
72
|
+
expect(getByText('Component content view')).toBeInTheDocument();
|
73
|
+
expect(getByText('Solve Dependencies')).toBeInTheDocument();
|
74
|
+
expect(queryByText('Auto Publish')).not.toBeInTheDocument();
|
75
|
+
expect(getByText('Import Only')).toBeInTheDocument();
|
76
|
+
|
77
|
+
// label auto_set
|
78
|
+
fireEvent.change(getByLabelText('input_name'), { target: { value: '123 2123' } });
|
79
|
+
expect(getByLabelText('input_label')).toHaveAttribute('value', '123_2123');
|
80
|
+
|
81
|
+
// display Auto Publish when Composite CV
|
82
|
+
fireEvent.click(getByLabelText('composite_tile'));
|
83
|
+
expect(queryByText('Solve Dependencies')).not.toBeInTheDocument();
|
84
|
+
expect(getByText('Auto Publish')).toBeInTheDocument();
|
85
|
+
expect(queryByText('Import Only')).not.toBeInTheDocument();
|
86
|
+
|
87
|
+
// display Solve Dependencies when Component CV
|
88
|
+
fireEvent.click(getByLabelText('component_tile'));
|
89
|
+
expect(getByText('Solve Dependencies')).toBeInTheDocument();
|
90
|
+
expect(queryByText('Auto Publish')).not.toBeInTheDocument();
|
91
|
+
expect(getByText('Import Only')).toBeInTheDocument();
|
92
|
+
});
|