katello 4.4.2.2 → 4.5.0.rc1

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.

Files changed (444) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +5 -1
  3. data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +98 -0
  4. data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +39 -3
  5. data/app/controllers/katello/api/v2/content_exports_controller.rb +19 -0
  6. data/app/controllers/katello/api/v2/content_imports_controller.rb +13 -16
  7. data/app/controllers/katello/api/v2/content_view_versions_controller.rb +0 -12
  8. data/app/controllers/katello/api/v2/content_views_controller.rb +13 -0
  9. data/app/controllers/katello/api/v2/environments_controller.rb +1 -1
  10. data/app/controllers/katello/api/v2/host_module_streams_controller.rb +8 -2
  11. data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +25 -3
  12. data/app/controllers/katello/api/v2/organizations_controller.rb +4 -2
  13. data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
  14. data/app/controllers/katello/api/v2/repositories_controller.rb +9 -3
  15. data/app/controllers/katello/api/v2/repository_sets_controller.rb +40 -7
  16. data/app/controllers/katello/api/v2/subscriptions_controller.rb +2 -2
  17. data/app/controllers/katello/concerns/api/v2/hosts_controller_extensions.rb +1 -1
  18. data/app/helpers/katello/concerns/smart_proxy_helper_extensions.rb +4 -0
  19. data/app/helpers/katello/hosts_and_hostgroups_helper.rb +21 -3
  20. data/app/lib/actions/katello/alternate_content_source/create.rb +24 -0
  21. data/app/lib/actions/katello/alternate_content_source/destroy.rb +27 -0
  22. data/app/lib/actions/katello/alternate_content_source/update.rb +41 -0
  23. data/app/lib/actions/katello/cdn_configuration/update.rb +2 -2
  24. data/app/lib/actions/katello/content_view/destroy.rb +2 -1
  25. data/app/lib/actions/katello/content_view/incremental_updates.rb +7 -3
  26. data/app/lib/actions/katello/content_view/publish.rb +7 -9
  27. data/app/lib/actions/katello/content_view_version/auto_create_products.rb +4 -4
  28. data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +6 -4
  29. data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +6 -4
  30. data/app/lib/actions/katello/content_view_version/import.rb +25 -22
  31. data/app/lib/actions/katello/content_view_version/import_library.rb +0 -1
  32. data/app/lib/actions/katello/content_view_version/import_repository.rb +21 -0
  33. data/app/lib/actions/katello/content_view_version/incremental_update.rb +85 -93
  34. data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +2 -2
  35. data/app/lib/actions/katello/product/content_create.rb +10 -8
  36. data/app/lib/actions/katello/repository/destroy.rb +36 -12
  37. data/app/lib/actions/katello/repository_set/disable_repository.rb +8 -3
  38. data/app/lib/actions/pulp3/alternate_content_source/create.rb +20 -0
  39. data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +20 -0
  40. data/app/lib/actions/pulp3/alternate_content_source/delete.rb +16 -0
  41. data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +16 -0
  42. data/app/lib/actions/pulp3/alternate_content_source/update.rb +16 -0
  43. data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +17 -0
  44. data/app/lib/actions/pulp3/content_view_version/{import.rb → create_import.rb} +5 -5
  45. data/app/lib/actions/pulp3/content_view_version/create_importer.rb +4 -3
  46. data/app/lib/actions/pulp3/content_view_version/destroy_importer.rb +12 -1
  47. data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +18 -0
  48. data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +23 -0
  49. data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +18 -0
  50. data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +1 -1
  51. data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +51 -0
  52. data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +5 -2
  53. data/app/lib/actions/pulp3/repository/refresh_distribution.rb +4 -1
  54. data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -0
  55. data/app/lib/katello/api/v2/error_handling.rb +1 -0
  56. data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -1
  57. data/app/lib/katello/util/errata.rb +2 -3
  58. data/app/lib/katello/validators/alternate_content_source_path_validator.rb +29 -0
  59. data/app/lib/katello/validators/content_default_http_proxy_setting_validator.rb +12 -0
  60. data/app/lib/katello/validators/content_view_environment_validator.rb +10 -5
  61. data/app/models/katello/alternate_content_source.rb +66 -0
  62. data/app/models/katello/authorization/alternate_content_source.rb +33 -0
  63. data/app/models/katello/authorization/repository.rb +3 -3
  64. data/app/models/katello/candlepin/repository_mapper.rb +13 -6
  65. data/app/models/katello/cdn_configuration.rb +15 -15
  66. data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -0
  67. data/app/models/katello/concerns/host_managed_extensions.rb +7 -5
  68. data/app/models/katello/concerns/http_proxy_extensions.rb +14 -0
  69. data/app/models/katello/concerns/organization_extensions.rb +4 -2
  70. data/app/models/katello/concerns/setting_extensions.rb +14 -0
  71. data/app/models/katello/concerns/smart_proxy_extensions.rb +2 -1
  72. data/app/models/katello/content.rb +1 -0
  73. data/app/models/katello/content_credential.rb +6 -0
  74. data/app/models/katello/content_override.rb +7 -3
  75. data/app/models/katello/content_view.rb +33 -2
  76. data/app/models/katello/content_view_erratum_filter.rb +26 -12
  77. data/app/models/katello/content_view_filter.rb +4 -0
  78. data/app/models/katello/content_view_version.rb +12 -0
  79. data/app/models/katello/content_view_version_export_history.rb +3 -1
  80. data/app/models/katello/erratum.rb +9 -5
  81. data/app/models/katello/events/delete_latest_content_view_version.rb +40 -0
  82. data/app/models/katello/host/content_facet.rb +14 -0
  83. data/app/models/katello/host_available_module_stream.rb +12 -0
  84. data/app/models/katello/product_content.rb +1 -0
  85. data/app/models/katello/purpose_sla_status.rb +1 -1
  86. data/app/models/katello/purpose_status.rb +2 -2
  87. data/app/models/katello/repository.rb +7 -4
  88. data/app/models/katello/root_repository.rb +1 -1
  89. data/app/models/katello/smart_proxy_alternate_content_source.rb +8 -0
  90. data/app/models/katello/sync_plan.rb +1 -1
  91. data/app/presenters/katello/product_content_presenter.rb +15 -0
  92. data/app/services/katello/applicable_host_queue.rb +1 -1
  93. data/app/services/katello/content_unit_indexer.rb +2 -1
  94. data/app/services/katello/product_content_finder.rb +12 -2
  95. data/app/services/katello/pulp3/alternate_content_source.rb +117 -0
  96. data/app/services/katello/pulp3/api/file.rb +8 -0
  97. data/app/services/katello/pulp3/api/yum.rb +8 -0
  98. data/app/services/katello/pulp3/content_view_version/export.rb +27 -5
  99. data/app/services/katello/pulp3/content_view_version/import.rb +97 -71
  100. data/app/services/katello/pulp3/content_view_version/import_export_common.rb +4 -4
  101. data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +13 -11
  102. data/app/services/katello/pulp3/content_view_version/import_validator.rb +67 -72
  103. data/app/services/katello/pulp3/content_view_version/importable_products.rb +40 -24
  104. data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +88 -39
  105. data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +2 -2
  106. data/app/services/katello/pulp3/content_view_version/metadata_map.rb +117 -0
  107. data/app/services/katello/pulp3/pulp_content_unit.rb +6 -1
  108. data/app/services/katello/pulp3/repository/yum.rb +70 -12
  109. data/app/services/katello/pulp3/repository.rb +7 -91
  110. data/app/services/katello/pulp3/service_common.rb +66 -0
  111. data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +4 -1
  112. data/app/services/katello/ui_notifications/content_view/delete_latest_version_failure.rb +22 -0
  113. data/app/views/foreman/job_templates/change_content_source.erb +1 -1
  114. data/app/views/foreman/job_templates/install_errata.erb +5 -5
  115. data/app/views/foreman/job_templates/install_errata_by_search_query.erb +7 -6
  116. data/app/views/foreman/job_templates/install_group.erb +4 -4
  117. data/app/views/foreman/job_templates/install_package.erb +4 -4
  118. data/app/views/foreman/job_templates/install_packages_by_search_query.erb +3 -3
  119. data/app/views/foreman/job_templates/remove_group.erb +4 -4
  120. data/app/views/foreman/job_templates/remove_package.erb +4 -4
  121. data/app/views/foreman/job_templates/remove_packages_by_search_query.erb +3 -3
  122. data/app/views/foreman/job_templates/resolve_traces.erb +2 -2
  123. data/app/views/foreman/job_templates/restart_services.erb +3 -3
  124. data/app/views/foreman/job_templates/update_group.erb +4 -4
  125. data/app/views/foreman/job_templates/update_package.erb +4 -4
  126. data/app/views/foreman/job_templates/update_packages_by_search_query.erb +3 -3
  127. data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +15 -0
  128. data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +7 -0
  129. data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +3 -0
  130. data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
  131. data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +2 -3
  132. data/app/views/katello/api/v2/content_view_versions/base.json.rabl +1 -1
  133. data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
  134. data/app/views/katello/api/v2/environments/show.json.rabl +2 -0
  135. data/app/views/katello/api/v2/errata/_counts.json.rabl +2 -2
  136. data/app/views/katello/api/v2/host_module_streams/base.json.rabl +2 -2
  137. data/app/views/katello/api/v2/hosts/host_collections.json.rabl +1 -1
  138. data/app/views/katello/api/v2/organizations/show.json.rabl +7 -1
  139. data/app/views/katello/api/v2/repositories/show.json.rabl +2 -1
  140. data/app/views/katello/sync_management/_repo.html.erb +8 -29
  141. data/config/routes/api/v2.rb +7 -0
  142. data/db/migrate/20150930183738_migrate_content_hosts.rb +0 -399
  143. data/db/migrate/20171025163149_remove_use_pulp_oauth_setting.rb +1 -1
  144. data/db/migrate/20171114150937_cleanup_installed_packages.rb +1 -1
  145. data/db/migrate/20180402160223_clean_up_force_post_sync_action_setting.rb +1 -1
  146. data/db/migrate/20211129200124_remove_dependency_solving_algorithm_setting.rb +1 -1
  147. data/db/migrate/20211220185935_clean_duplicate_content_units.rb +10 -12
  148. data/db/migrate/20220110223754_update_disconnected_settings.rb +5 -5
  149. data/db/migrate/20220117151612_add_alternate_content_sources.rb +48 -0
  150. data/db/migrate/20220124191056_add_type_to_cdn_configuration.rb +9 -4
  151. data/db/migrate/20220209203251_add_generated_for_to_content_views.rb +13 -0
  152. data/db/migrate/20220209205137_expand_sync_timeout_settings.rb +7 -7
  153. data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +12 -0
  154. data/db/migrate/20220404190836_delete_old_setting_data.rb +9 -0
  155. data/db/migrate/20220405220616_update_cdn_configuration_type.rb +11 -0
  156. data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +5 -0
  157. data/db/seeds.d/110-content-view-autopublish.rb +13 -0
  158. data/db/seeds.d/150-module_job_templates.rb +1 -1
  159. data/engines/bastion/README.md +1 -0
  160. data/engines/bastion/app/assets/javascripts/bastion/components/bst-modal.directive.js +1 -0
  161. data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -0
  162. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
  163. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +10 -5
  164. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-module-streams.controller.js +1 -0
  165. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +1 -0
  166. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-traces.controller.js +1 -0
  167. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +1 -1
  168. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +1 -1
  169. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +8 -0
  170. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +4 -2
  171. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
  172. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +10 -0
  173. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-deb-repositories.html +26 -0
  174. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-debs.html +27 -0
  175. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
  176. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +22 -0
  177. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +13 -7
  178. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +63 -17
  179. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +7 -8
  180. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +10 -1
  181. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +21 -3
  182. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +8 -9
  183. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +7 -5
  184. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +2 -1
  185. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/discovery-create.controller.js +1 -1
  186. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/views/discovery-create.html +1 -1
  187. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.routes.js +1 -0
  188. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +6 -1
  189. data/lib/katello/engine.rb +1 -5
  190. data/lib/katello/permission_creator.rb +32 -4
  191. data/lib/katello/plugin.rb +378 -4
  192. data/lib/katello/tasks/reset.rake.bak +67 -0
  193. data/lib/katello/tasks/update_content_default_http_proxy.rake +2 -3
  194. data/lib/katello/version.rb +1 -1
  195. data/locale/action_names.rb +47 -41
  196. data/locale/bn/LC_MESSAGES/katello.mo +0 -0
  197. data/locale/bn/katello.po +820 -106
  198. data/locale/bn/katello.po.time_stamp +0 -0
  199. data/locale/cs/LC_MESSAGES/katello.mo +0 -0
  200. data/locale/cs/katello.po +818 -104
  201. data/locale/cs/katello.po.time_stamp +0 -0
  202. data/locale/de/LC_MESSAGES/katello.mo +0 -0
  203. data/locale/de/katello.po +893 -179
  204. data/locale/de/katello.po.time_stamp +0 -0
  205. data/locale/en/LC_MESSAGES/katello.mo +0 -0
  206. data/locale/en/katello.po +817 -103
  207. data/locale/en/katello.po.time_stamp +0 -0
  208. data/locale/es/LC_MESSAGES/katello.mo +0 -0
  209. data/locale/es/katello.po +882 -168
  210. data/locale/es/katello.po.time_stamp +0 -0
  211. data/locale/fr/LC_MESSAGES/katello.mo +0 -0
  212. data/locale/fr/katello.po +1219 -505
  213. data/locale/fr/katello.po.time_stamp +0 -0
  214. data/locale/gu/LC_MESSAGES/katello.mo +0 -0
  215. data/locale/gu/katello.po +826 -112
  216. data/locale/gu/katello.po.time_stamp +0 -0
  217. data/locale/hi/LC_MESSAGES/katello.mo +0 -0
  218. data/locale/hi/katello.po +826 -112
  219. data/locale/hi/katello.po.time_stamp +0 -0
  220. data/locale/it/LC_MESSAGES/katello.mo +0 -0
  221. data/locale/it/katello.po +863 -148
  222. data/locale/it/katello.po.time_stamp +0 -0
  223. data/locale/ja/LC_MESSAGES/katello.mo +0 -0
  224. data/locale/ja/katello.po +1216 -499
  225. data/locale/ja/katello.po.time_stamp +0 -0
  226. data/locale/katello.pot +3847 -2507
  227. data/locale/kn/LC_MESSAGES/katello.mo +0 -0
  228. data/locale/kn/katello.po +826 -112
  229. data/locale/kn/katello.po.time_stamp +0 -0
  230. data/locale/ko/LC_MESSAGES/katello.mo +0 -0
  231. data/locale/ko/katello.po +912 -198
  232. data/locale/ko/katello.po.time_stamp +0 -0
  233. data/locale/mr/LC_MESSAGES/katello.mo +0 -0
  234. data/locale/mr/katello.po +826 -112
  235. data/locale/mr/katello.po.time_stamp +0 -0
  236. data/locale/or/LC_MESSAGES/katello.mo +0 -0
  237. data/locale/or/katello.po +826 -112
  238. data/locale/or/katello.po.time_stamp +0 -0
  239. data/locale/pa/LC_MESSAGES/katello.mo +0 -0
  240. data/locale/pa/katello.po +826 -112
  241. data/locale/pa/katello.po.time_stamp +0 -0
  242. data/locale/pt/LC_MESSAGES/katello.mo +0 -0
  243. data/locale/pt/katello.po +817 -103
  244. data/locale/pt/katello.po.time_stamp +0 -0
  245. data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
  246. data/locale/pt_BR/katello.po +879 -165
  247. data/locale/pt_BR/katello.po.time_stamp +0 -0
  248. data/locale/ru/LC_MESSAGES/katello.mo +0 -0
  249. data/locale/ru/katello.po +927 -213
  250. data/locale/ru/katello.po.time_stamp +0 -0
  251. data/locale/ta/LC_MESSAGES/katello.mo +0 -0
  252. data/locale/ta/katello.po +820 -106
  253. data/locale/ta/katello.po.time_stamp +0 -0
  254. data/locale/te/LC_MESSAGES/katello.mo +0 -0
  255. data/locale/te/katello.po +826 -112
  256. data/locale/te/katello.po.time_stamp +0 -0
  257. data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
  258. data/locale/zh_CN/katello.po +1202 -486
  259. data/locale/zh_CN/katello.po.time_stamp +0 -0
  260. data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
  261. data/locale/zh_TW/katello.po +856 -142
  262. data/locale/zh_TW/katello.po.time_stamp +0 -0
  263. data/webpack/components/EditableTextInput/EditableTextInput.js +20 -5
  264. data/webpack/components/Errata/index.js +38 -8
  265. data/webpack/components/Packages/index.js +1 -4
  266. data/webpack/components/Search/Search.js +18 -3
  267. data/webpack/components/SelectAllCheckbox/index.js +1 -0
  268. data/webpack/components/SelectableDropdown/SelectableDropdown.js +4 -2
  269. data/webpack/components/Table/EmptyStateMessage.js +21 -7
  270. data/webpack/components/Table/MainTable.js +29 -4
  271. data/webpack/components/Table/TableHooks.js +63 -19
  272. data/webpack/components/Table/TableWrapper.js +4 -2
  273. data/webpack/components/Table/components/SortableColumnHeaders.js +19 -0
  274. data/webpack/components/Table/components/TranslatedPlural.js +57 -0
  275. data/webpack/components/TypeAhead/TypeAhead.js +8 -0
  276. data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +13 -11
  277. data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +5 -2
  278. data/webpack/components/extensions/HostDetails/ActionsBar/index.js +27 -0
  279. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +256 -0
  280. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +202 -0
  281. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewActions.js +19 -0
  282. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewConstants.js +2 -0
  283. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +131 -0
  284. data/webpack/components/extensions/HostDetails/Cards/{__tests__ → ContentViewDetailsCard/__tests__}/contentViewDetailsCard.test.js +22 -0
  285. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +443 -0
  286. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/envPaths.fixtures.json +320 -0
  287. data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +57 -33
  288. data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +3 -0
  289. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsActions.js +30 -0
  290. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +187 -0
  291. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsConstants.js +7 -0
  292. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +227 -0
  293. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsSelectors.js +18 -0
  294. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/availableHostCollections.fixtures.json +106 -0
  295. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +110 -0
  296. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +235 -0
  297. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/removableHostCollections.fixtures.json +45 -0
  298. data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +33 -8
  299. data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +44 -0
  300. data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +107 -0
  301. data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +38 -0
  302. data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +62 -39
  303. data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/HostErrataActions.js +1 -7
  304. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsActions.js +1 -3
  305. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsConstants.js +28 -0
  306. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +486 -116
  307. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/moduleStreamsTab.test.js +147 -1
  308. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/modules.fixtures.json +6 -3
  309. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesActions.js +1 -7
  310. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +2 -1
  311. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +48 -19
  312. data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +35 -47
  313. data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +1 -0
  314. data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsActions.js +33 -54
  315. data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsConstants.js +20 -0
  316. data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +269 -132
  317. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +47 -11
  318. data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +30 -42
  319. data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +36 -1
  320. data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +94 -46
  321. data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +18 -2
  322. data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +6 -0
  323. data/webpack/containers/Application/config.js +5 -0
  324. data/webpack/global_index.js +30 -7
  325. data/webpack/global_test_setup.js +13 -0
  326. data/webpack/redux/actions/RedHatRepositories/enabled.js +2 -1
  327. data/webpack/redux/actions/RedHatRepositories/helpers.js +9 -8
  328. data/webpack/scenes/AlternateContentSources/ACSActions.js +53 -0
  329. data/webpack/scenes/AlternateContentSources/ACSConstants.js +4 -0
  330. data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +23 -0
  331. data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -0
  332. data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +152 -0
  333. data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +91 -0
  334. data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +67 -0
  335. data/webpack/scenes/AlternateContentSources/index.js +4 -0
  336. data/webpack/scenes/Content/Details/ContentRepositories.js +1 -0
  337. data/webpack/scenes/Content/Table/ContentTable.js +1 -0
  338. data/webpack/scenes/ContentViews/ContentViewsActions.js +6 -2
  339. data/webpack/scenes/ContentViews/ContentViewsConstants.js +11 -3
  340. data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +2 -1
  341. data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +10 -1
  342. data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +4 -3
  343. data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +1 -1
  344. data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +7 -5
  345. data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionFinish.js +29 -21
  346. data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +15 -8
  347. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +3 -3
  348. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +4 -4
  349. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +3 -1
  350. data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +4 -4
  351. data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +34 -8
  352. data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +33 -29
  353. data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +130 -79
  354. data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +17 -3
  355. data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +2 -1
  356. data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +2 -1
  357. data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +6 -1
  358. data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +41 -21
  359. data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +38 -20
  360. data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +2 -0
  361. data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +8 -1
  362. data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +9 -1
  363. data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +2 -1
  364. data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +1 -0
  365. data/webpack/scenes/ContentViews/Details/Filters/Rules/ContainerTag/AddEditContainerTagRuleModal.js +27 -12
  366. data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +39 -17
  367. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +27 -10
  368. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +46 -23
  369. data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +3 -2
  370. data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +5 -2
  371. data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +161 -108
  372. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +7 -7
  373. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
  374. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +58 -0
  375. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteContextWrapper.js +45 -0
  376. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteHelpers.js +30 -0
  377. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +56 -0
  378. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +126 -0
  379. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/FinishBulkDelete.js +61 -0
  380. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +196 -0
  381. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +220 -0
  382. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +104 -0
  383. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +122 -0
  384. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteVersions.fixtures.json +600 -0
  385. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentView.fixtures.json +1504 -0
  386. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentViewVersion.fixtures.json +936 -0
  387. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/environmentPaths.fixtures.json +261 -0
  388. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/hosts.fixtures.json +163 -0
  389. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/bulkDeleteSteps.js +79 -0
  390. data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +192 -167
  391. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +2 -5
  392. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionDeleteFinish.js +38 -53
  393. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +1 -1
  394. data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +6 -12
  395. data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +1 -0
  396. data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +1 -0
  397. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +1 -0
  398. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +8 -20
  399. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +23 -13
  400. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +3 -0
  401. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.fixtures.json +4 -4
  402. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +0 -3
  403. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +4 -4
  404. data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +12 -14
  405. data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
  406. data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +96 -117
  407. data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +13 -19
  408. data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +9 -20
  409. data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +165 -148
  410. data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +2 -0
  411. data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +4 -4
  412. data/webpack/scenes/ContentViews/components/ContentViewIcon.js +14 -3
  413. data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +1 -1
  414. data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
  415. data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +9 -5
  416. data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +6 -1
  417. data/webpack/scenes/ContentViews/components/TaskPresenter/TaskPresenter.js +40 -35
  418. data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +2 -2
  419. data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +1 -1
  420. data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +4 -4
  421. data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +1 -1
  422. data/webpack/scenes/ContentViews/helpers.js +3 -0
  423. data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +5 -0
  424. data/webpack/scenes/RedHatRepositories/RedHatRepositoriesPage.js +3 -3
  425. data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepository.js +2 -1
  426. data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/EnabledRepository.test.js +2 -0
  427. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +3 -3
  428. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +2 -0
  429. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{AirGappedTypeForm.js → ExportSyncForm.js} +7 -6
  430. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{UpstreamServerTypeForm.js → NetworkSyncForm.js} +15 -7
  431. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{AirGappedTypeForm.test.js → ExportSyncForm.test.js} +4 -4
  432. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{UpstreamServerTypeForm.test.js → NetworkSyncForm.test.js} +8 -8
  433. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +11 -11
  434. data/webpack/scenes/Subscriptions/SubscriptionConstants.js +1 -0
  435. data/webpack/scenes/Subscriptions/SubscriptionsPage.js +8 -7
  436. data/webpack/scenes/Tasks/TaskActions.js +6 -0
  437. data/webpack/scenes/Tasks/TaskSelectors.js +11 -0
  438. data/webpack/scenes/Tasks/helpers.js +33 -5
  439. data/webpack/utils/helpers.js +2 -0
  440. metadata +158 -40
  441. data/app/models/setting/content.rb +0 -201
  442. data/webpack/components/Table/__test__/useBulkSelect.test.js +0 -99
  443. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +0 -96
  444. data/webpack/scenes/ContentViews/Details/DetailsContainer.js +0 -36
@@ -1,65 +1,57 @@
1
1
  import { STATUS } from 'foremanReact/constants';
2
- import React, { useState, useEffect, useCallback } from 'react';
2
+ import React, { useState } from 'react';
3
3
  import useDeepCompareEffect from 'use-deep-compare-effect';
4
4
  import PropTypes from 'prop-types';
5
5
  import { useDispatch, useSelector, shallowEqual } from 'react-redux';
6
- import { Bullseye, Button, Grid, GridItem,
6
+ import { useHistory } from 'react-router-dom';
7
+ import {
8
+ Bullseye, Button, Grid, GridItem,
7
9
  Progress, ProgressSize, ProgressMeasureLocation,
8
10
  ProgressVariant, EmptyState, EmptyStateIcon, EmptyStateVariant,
9
- Title } from '@patternfly/react-core';
11
+ Title,
12
+ } from '@patternfly/react-core';
10
13
  import { ExternalLinkAltIcon, InProgressIcon } from '@patternfly/react-icons';
11
14
  import { translate as __ } from 'foremanReact/common/I18n';
12
15
  import {
13
16
  selectPublishContentViewsError, selectPublishContentViews,
14
17
  selectPublishContentViewStatus,
15
18
  } from './ContentViewPublishSelectors';
16
- import { selectPublishTaskPoll, selectPublishTaskPollStatus } from '../Details/ContentViewDetailSelectors';
17
- import getContentViews, { publishContentView } from '../ContentViewsActions';
19
+ import { selectTaskPoll, selectTaskPollStatus } from '../Details/ContentViewDetailSelectors';
20
+ import { publishContentView } from '../ContentViewsActions';
18
21
  import Loading from '../../../components/Loading';
19
22
  import EmptyStateMessage from '../../../components/Table/EmptyStateMessage';
20
- import { cvVersionPublishKey } from '../ContentViewsConstants';
21
- import { startPollingTask, stopPollingTask, toastTaskFinished } from '../../Tasks/TaskActions';
23
+ import { cvVersionTaskPollingKey } from '../ContentViewsConstants';
24
+ import { clearPollTaskData, startPollingTask, stopPollingTask, toastTaskFinished } from '../../Tasks/TaskActions';
22
25
  import getContentViewDetails from '../Details/ContentViewDetailActions';
23
26
 
24
27
  const CVPublishFinish = ({
25
28
  cvId,
26
- userCheckedItems, setUserCheckedItems,
27
- forcePromote, description, setDescription,
28
- setIsOpen, versionCount, currentStep, setCurrentStep,
29
+ userCheckedItems,
30
+ forcePromote, description,
31
+ onClose, versionCount, currentStep,
29
32
  }) => {
30
33
  const dispatch = useDispatch();
34
+ const history = useHistory();
31
35
  const [publishDispatched, setPublishDispatched] = useState(false);
32
36
  const [saving, setSaving] = useState(true);
33
- const [polling, setPolling] = useState(false);
37
+ const POLLING_TASK_KEY = cvVersionTaskPollingKey(cvId);
34
38
  const [taskErrored, setTaskErrored] = useState(false);
35
39
  const response = useSelector(state => selectPublishContentViews(state, cvId, versionCount));
36
40
  const status = useSelector(state => selectPublishContentViewStatus(state, cvId, versionCount));
37
41
  const error = useSelector(state => selectPublishContentViewsError(state, cvId, versionCount));
42
+
38
43
  const pollResponse = useSelector(state =>
39
- selectPublishTaskPoll(state, cvVersionPublishKey(cvId, versionCount)), shallowEqual);
44
+ selectTaskPoll(state, POLLING_TASK_KEY), shallowEqual);
40
45
  const pollResponseStatus = useSelector(state =>
41
- selectPublishTaskPollStatus(state, cvVersionPublishKey(cvId, versionCount)), shallowEqual);
46
+ selectTaskPollStatus(state, POLLING_TASK_KEY), shallowEqual);
42
47
 
43
- const progressCompleted = () => (pollResponse.progress ? pollResponse.progress * 100 : 0);
44
-
45
- const handleEndTask = useCallback(({ taskComplete }) => {
46
- if (currentStep !== 1) {
47
- dispatch(stopPollingTask(cvVersionPublishKey(cvId, versionCount)));
48
- setCurrentStep(1);
49
- setIsOpen(false);
50
- dispatch(getContentViewDetails(cvId));
51
- dispatch(getContentViews);
52
- if (taskComplete) {
53
- dispatch(toastTaskFinished(pollResponse));
54
- }
55
- }
56
- }, [currentStep, cvId, dispatch, pollResponse, setCurrentStep, setIsOpen, versionCount]);
48
+ const { input: { content_view_version_id: cvvID } = {} } = response;
57
49
 
50
+ const progressCompleted = pollResponse.progress ? pollResponse.progress * 100 : 0;
58
51
 
59
- useEffect(() => {
60
- if (currentStep !== 3 && !publishDispatched) {
61
- setCurrentStep(3);
62
- setSaving(true);
52
+ // Fire this on load
53
+ useDeepCompareEffect(() => {
54
+ if (currentStep === 3 && !publishDispatched) {
63
55
  setPublishDispatched(true);
64
56
  dispatch(publishContentView({
65
57
  id: cvId,
@@ -67,101 +59,91 @@ const CVPublishFinish = ({
67
59
  description,
68
60
  environment_ids: userCheckedItems.map(item => item.id),
69
61
  is_force_promote: (forcePromote.length > 0),
70
- }));
71
- setDescription('');
72
- setUserCheckedItems([]);
62
+ }, ({ data: task }) => {
63
+ // First callback
64
+ dispatch(startPollingTask(
65
+ POLLING_TASK_KEY, task,
66
+ () => {
67
+ // Second Callback
68
+ setSaving(false);
69
+ },
70
+ ));
71
+ }, () => { setSaving(false); }));
73
72
  }
74
- }, [dispatch, setSaving, publishDispatched, setPublishDispatched,
75
- setDescription, setUserCheckedItems, currentStep, setCurrentStep,
76
- cvId, versionCount, description, forcePromote, userCheckedItems]);
77
-
78
- useDeepCompareEffect(() => {
79
- if (!response) return;
80
- const pollPublishTask = (cvPublishVersionKey, task) => {
81
- if (!polling) dispatch(startPollingTask(cvPublishVersionKey, task));
82
- };
83
-
84
- setSaving(true);
85
- const { id } = response;
86
- if (id && status === STATUS.RESOLVED) {
87
- setSaving(false);
88
- pollPublishTask(cvVersionPublishKey(cvId, versionCount), response);
89
- setPolling(true);
90
- } else if (status === STATUS.ERROR) {
91
- setSaving(false);
92
- }
93
- }, [response, status, error, cvId, versionCount,
94
- dispatch, polling, setPolling, setSaving]);
95
-
73
+ }, [POLLING_TASK_KEY, currentStep, cvId, description, dispatch, forcePromote,
74
+ publishDispatched, userCheckedItems, versionCount]);
96
75
 
97
76
  useDeepCompareEffect(() => {
98
77
  const { state, result } = pollResponse;
78
+ if (!state || !result || !publishDispatched || saving) return;
99
79
  if (state === 'paused' || result === 'error') {
100
80
  setTaskErrored(true);
101
- setTimeout(() => {
102
- handleEndTask({ taskComplete: true });
103
- }, 500);
104
81
  }
105
82
  if (state === 'stopped' && result === 'success') {
106
- setTimeout(() => {
107
- handleEndTask({ taskComplete: true });
108
- }, 500);
83
+ dispatch(stopPollingTask(POLLING_TASK_KEY));
84
+ dispatch(clearPollTaskData(POLLING_TASK_KEY));
85
+ dispatch(getContentViewDetails(cvId));
86
+ dispatch(toastTaskFinished(pollResponse));
87
+ history.push(`/content_views/${cvId}#/versions/${cvvID || ''}`);
88
+ onClose();
109
89
  }
110
- }, [pollResponse, dispatch, setTaskErrored,
111
- setPolling, setIsOpen, pollResponseStatus, handleEndTask]);
90
+ }, [pollResponse, dispatch, setTaskErrored, pollResponseStatus,
91
+ POLLING_TASK_KEY, cvId, history, taskErrored, cvvID, onClose,
92
+ publishDispatched, saving]);
112
93
 
113
- if (saving) {
94
+ if (saving || status === STATUS.PENDING) {
114
95
  return <Loading />;
115
96
  }
116
- if (polling && pollResponse) {
117
- return (
118
- <>
119
- <EmptyState style={{ marginTop: '10px' }} variant={EmptyStateVariant.large}>
120
- <EmptyStateIcon icon={InProgressIcon} />
121
- <Title headingLevel="h2" size="lg">
122
- {__('Publishing content view')}
123
- </Title>
124
- </EmptyState>
125
- <Grid hasGutter>
126
- <GridItem span={12} rowSpan={19}>
127
- <Progress
128
- value={progressCompleted()}
129
- title={__('In progress')}
130
- measureLocation={ProgressMeasureLocation.outside}
131
- variant={taskErrored ? ProgressVariant.danger : ProgressVariant.default}
132
- size={ProgressSize.lg}
133
- />
134
- </GridItem>
135
- <GridItem style={{ marginTop: '10px' }} span={12} rowSpan={1}>
136
- <Bullseye>
137
- <Button
138
- onClick={() => {
139
- handleEndTask({ taskComplete: false });
140
- }}
141
- variant="primary"
142
- aria-label="publish_content_view"
143
- >
144
- {__('Close')}
145
- </Button>
146
- <Button
147
- component="a"
148
- aria-label="view tasks button"
149
- href={`/foreman_tasks/tasks/${pollResponse.id}`}
150
- target="_blank"
151
- variant="link"
152
- >
153
- {__(' View task details ')}
154
- <ExternalLinkAltIcon />
155
- </Button>
156
- </Bullseye>
157
- </GridItem>
158
- </Grid>
159
- </>
160
- );
161
- }
162
- if (status === STATUS.PENDING) return (<Loading />);
97
+
163
98
  if (status === STATUS.ERROR) return (<EmptyStateMessage error={error} />);
164
- return <Loading />;
99
+
100
+ return (
101
+ <>
102
+ <EmptyState style={{ marginTop: '10px' }} variant={EmptyStateVariant.large}>
103
+ <EmptyStateIcon icon={InProgressIcon} />
104
+ <Title headingLevel="h2" size="lg">
105
+ {__('Publishing content view')}
106
+ </Title>
107
+ </EmptyState>
108
+ <Grid hasGutter>
109
+ <GridItem span={12} rowSpan={19}>
110
+ <Progress
111
+ value={progressCompleted}
112
+ title={__('In progress')}
113
+ measureLocation={ProgressMeasureLocation.outside}
114
+ variant={taskErrored ? ProgressVariant.danger : ProgressVariant.default}
115
+ size={ProgressSize.lg}
116
+ />
117
+ </GridItem>
118
+ <GridItem style={{ marginTop: '10px' }} span={12} rowSpan={1}>
119
+ <Bullseye>
120
+ <Button
121
+ ouiaId="publish-wizard-close"
122
+ onClick={() => {
123
+ dispatch(stopPollingTask(POLLING_TASK_KEY));
124
+ onClose(true);
125
+ }}
126
+ variant="primary"
127
+ aria-label="publish_content_view"
128
+ >
129
+ {__('Close')}
130
+ </Button>
131
+ <Button
132
+ ouiaId="publish-wizard-view-task-button"
133
+ component="a"
134
+ aria-label="view tasks button"
135
+ href={`/foreman_tasks/tasks/${pollResponse.id}`}
136
+ target="_blank"
137
+ variant="link"
138
+ >
139
+ {__(' View task details ')}
140
+ <ExternalLinkAltIcon />
141
+ </Button>
142
+ </Bullseye>
143
+ </GridItem>
144
+ </Grid>
145
+ </>
146
+ );
165
147
  };
166
148
 
167
149
  CVPublishFinish.propTypes = {
@@ -171,13 +153,10 @@ CVPublishFinish.propTypes = {
171
153
  ]).isRequired,
172
154
  forcePromote: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
173
155
  description: PropTypes.string.isRequired,
174
- setDescription: PropTypes.func.isRequired,
175
156
  userCheckedItems: PropTypes.arrayOf(PropTypes.shape({})).isRequired,
176
- setUserCheckedItems: PropTypes.func.isRequired,
177
- setIsOpen: PropTypes.func.isRequired,
157
+ onClose: PropTypes.func.isRequired,
178
158
  versionCount: PropTypes.number.isRequired,
179
159
  currentStep: PropTypes.number.isRequired,
180
- setCurrentStep: PropTypes.func.isRequired,
181
160
  };
182
161
 
183
162
 
@@ -12,19 +12,19 @@ import {
12
12
  selectEnvironmentPaths,
13
13
  selectEnvironmentPathsStatus,
14
14
  } from '../components/EnvironmentPaths/EnvironmentPathSelectors';
15
- import getContentViews from '../ContentViewsActions';
16
- import getContentViewDetails from '../Details/ContentViewDetailActions';
17
15
  import { stopPollingTask } from '../../Tasks/TaskActions';
18
- import { cvVersionPublishKey } from '../ContentViewsConstants';
16
+ import { cvVersionTaskPollingKey } from '../ContentViewsConstants';
19
17
 
20
18
  const PublishContentViewWizard = ({
21
- details, show, setIsOpen, currentStep, setCurrentStep,
19
+ details, show, onClose,
22
20
  }) => {
23
21
  const { name, id: cvId, version_count: versionCount } = details;
22
+ const POLLING_TASK_KEY = cvVersionTaskPollingKey(cvId);
24
23
  const [description, setDescription] = useState('');
25
24
  const [userCheckedItems, setUserCheckedItems] = useState([]);
26
25
  const [promote, setPromote] = useState(false);
27
26
  const [forcePromote, setForcePromote] = useState([]);
27
+ const [currentStep, setCurrentStep] = useState(1);
28
28
  const dispatch = useDispatch();
29
29
  const environmentPathResponse = useSelector(selectEnvironmentPaths);
30
30
  const environmentPathStatus = useSelector(selectEnvironmentPathsStatus);
@@ -61,9 +61,8 @@ const PublishContentViewWizard = ({
61
61
  cvId={cvId}
62
62
  versionCount={versionCount}
63
63
  show={show}
64
- setIsOpen={setIsOpen}
64
+ onClose={onClose}
65
65
  currentStep={currentStep}
66
- setCurrentStep={setCurrentStep}
67
66
  />,
68
67
  isFinishedStep: true,
69
68
  },
@@ -109,18 +108,15 @@ const PublishContentViewWizard = ({
109
108
  description={currentStep === 3 ? __(`Publishing ${name}`) : __(`Determining settings for ${name}`)}
110
109
  steps={steps}
111
110
  startAtStep={currentStep}
111
+ // Let the wizard handle step change
112
+ onGoToStep={({ id }) => setCurrentStep(id)}
113
+ onNext={({ id }) => setCurrentStep(id)}
114
+ onBack={({ id }) => setCurrentStep(id)}
112
115
  onClose={() => {
113
- setDescription('');
114
- setUserCheckedItems([]);
115
- setPromote(false);
116
- setForcePromote([]);
117
116
  if (currentStep === 3) {
118
- setCurrentStep(1);
119
- dispatch(getContentViewDetails(cvId));
120
- dispatch(getContentViews);
121
- dispatch(stopPollingTask(cvVersionPublishKey(cvId, versionCount)));
122
- }
123
- setIsOpen(false);
117
+ dispatch(stopPollingTask(POLLING_TASK_KEY));
118
+ onClose(true);
119
+ } else onClose();
124
120
  }}
125
121
  isOpen={show}
126
122
  />
@@ -129,9 +125,7 @@ const PublishContentViewWizard = ({
129
125
 
130
126
  PublishContentViewWizard.propTypes = {
131
127
  show: PropTypes.bool.isRequired,
132
- setIsOpen: PropTypes.func.isRequired,
133
- currentStep: PropTypes.number.isRequired,
134
- setCurrentStep: PropTypes.func.isRequired,
128
+ onClose: PropTypes.func.isRequired,
135
129
  details: PropTypes.shape({
136
130
  id: PropTypes.oneOfType([
137
131
  PropTypes.number,
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import * as reactRedux from 'react-redux';
3
- import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
3
+ import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
4
4
  import { nockInstance, assertNockRequest } from '../../../../test-utils/nockWrapper';
5
5
  import api from '../../../../services/api';
6
6
  import PublishContentViewWizard from '../PublishContentViewWizard';
@@ -23,9 +23,7 @@ test('Can call API and show Wizard', async (done) => {
23
23
  const { getByText } = renderWithRedux(<PublishContentViewWizard
24
24
  details={cvDetailData}
25
25
  show
26
- setIsOpen={() => { }}
27
- currentStep={1}
28
- setCurrentStep={() => { }}
26
+ onClose={() => { }}
29
27
  />);
30
28
 
31
29
  await patientlyWaitFor(() => expect(getByText('Publish new version - 6.0')).toBeInTheDocument());
@@ -44,9 +42,7 @@ test('Can show Wizard and show environment paths', async (done) => {
44
42
  const { getByText, getByLabelText } = renderWithRedux(<PublishContentViewWizard
45
43
  details={cvDetailData}
46
44
  show
47
- setIsOpen={() => { }}
48
- currentStep={1}
49
- setCurrentStep={() => { }}
45
+ onClose={() => { }}
50
46
  />);
51
47
 
52
48
  await patientlyWaitFor(() => expect(getByText('Publish new version - 6.0')).toBeInTheDocument());
@@ -75,9 +71,7 @@ test('Can show and hide force promotion alert', async (done) => {
75
71
  } = renderWithRedux(<PublishContentViewWizard
76
72
  details={cvDetailData}
77
73
  show
78
- setIsOpen={() => { }}
79
- currentStep={1}
80
- setCurrentStep={() => { }}
74
+ onClose={() => { }}
81
75
  />);
82
76
 
83
77
  await patientlyWaitFor(() => expect(getByText('Publish new version - 6.0')).toBeInTheDocument());
@@ -128,9 +122,7 @@ test('Can show Wizard form and move to review', async (done) => {
128
122
  const { getByText } = renderWithRedux(<PublishContentViewWizard
129
123
  details={cvDetailData}
130
124
  show
131
- setIsOpen={() => { }}
132
- currentStep={1}
133
- setCurrentStep={() => { }}
125
+ onClose={() => { }}
134
126
  />);
135
127
  const useSelectorMock = jest.spyOn(reactRedux, 'useSelector');
136
128
  useSelectorMock.mockReturnValue(environmentPathsData);
@@ -156,7 +148,6 @@ test('Can move to Finish step and publish CV', async (done) => {
156
148
  const cvPublishParams = {
157
149
  id: 1, versionCount: 5, description: '', environment_ids: [], is_force_promote: false,
158
150
  };
159
-
160
151
  const publishScope = nockInstance
161
152
  .post(cvPublishPath, cvPublishParams)
162
153
  .reply(202, publishResponseData);
@@ -164,19 +155,17 @@ test('Can move to Finish step and publish CV', async (done) => {
164
155
  const { getByText } = renderWithRedux(<PublishContentViewWizard
165
156
  details={cvDetailData}
166
157
  show
167
- setIsOpen={() => { }}
168
- currentStep={1}
169
- setCurrentStep={() => { }}
158
+ onClose={() => { }}
170
159
  />);
171
- const useSelectorMock = jest.spyOn(reactRedux, 'useSelector');
172
- useSelectorMock.mockReturnValue(environmentPathsData);
160
+
173
161
  fireEvent.click(getByText('Next'));
174
162
  // Test the review page
175
163
  await patientlyWaitFor(() => {
176
164
  expect(getByText('Finish')).toBeInTheDocument();
177
165
  });
178
166
  fireEvent.click(getByText('Finish'));
179
- useSelectorMock.mockClear();
167
+
180
168
  assertNockRequest(scope);
181
169
  assertNockRequest(publishScope, done);
170
+ act(done); // stop listening for nocks
182
171
  });