katello 4.16.1 → 4.17.0.rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of katello might be problematic. Click here for more details.

Files changed (557) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/katello/hosts/host_and_hostgroup_edit.js +5 -3
  3. data/app/assets/javascripts/katello/locale/bn/katello.js +82 -31
  4. data/app/assets/javascripts/katello/locale/bn_IN/katello.js +82 -31
  5. data/app/assets/javascripts/katello/locale/ca/katello.js +82 -31
  6. data/app/assets/javascripts/katello/locale/cs/katello.js +82 -31
  7. data/app/assets/javascripts/katello/locale/cs_CZ/katello.js +83 -32
  8. data/app/assets/javascripts/katello/locale/de/katello.js +82 -31
  9. data/app/assets/javascripts/katello/locale/de_AT/katello.js +82 -31
  10. data/app/assets/javascripts/katello/locale/de_DE/katello.js +82 -31
  11. data/app/assets/javascripts/katello/locale/el/katello.js +82 -31
  12. data/app/assets/javascripts/katello/locale/en/katello.js +82 -31
  13. data/app/assets/javascripts/katello/locale/en_GB/katello.js +84 -33
  14. data/app/assets/javascripts/katello/locale/en_US/katello.js +82 -31
  15. data/app/assets/javascripts/katello/locale/es/katello.js +82 -31
  16. data/app/assets/javascripts/katello/locale/et_EE/katello.js +82 -31
  17. data/app/assets/javascripts/katello/locale/fr/katello.js +83 -32
  18. data/app/assets/javascripts/katello/locale/gl/katello.js +82 -31
  19. data/app/assets/javascripts/katello/locale/gu/katello.js +83 -32
  20. data/app/assets/javascripts/katello/locale/he_IL/katello.js +82 -31
  21. data/app/assets/javascripts/katello/locale/hi/katello.js +82 -31
  22. data/app/assets/javascripts/katello/locale/id/katello.js +82 -31
  23. data/app/assets/javascripts/katello/locale/it/katello.js +84 -33
  24. data/app/assets/javascripts/katello/locale/ja/katello.js +83 -32
  25. data/app/assets/javascripts/katello/locale/ka/katello.js +82 -31
  26. data/app/assets/javascripts/katello/locale/kn/katello.js +82 -31
  27. data/app/assets/javascripts/katello/locale/ko/katello.js +82 -31
  28. data/app/assets/javascripts/katello/locale/ml_IN/katello.js +82 -31
  29. data/app/assets/javascripts/katello/locale/mr/katello.js +82 -31
  30. data/app/assets/javascripts/katello/locale/nl_NL/katello.js +82 -31
  31. data/app/assets/javascripts/katello/locale/or/katello.js +82 -31
  32. data/app/assets/javascripts/katello/locale/pa/katello.js +82 -31
  33. data/app/assets/javascripts/katello/locale/pl/katello.js +83 -32
  34. data/app/assets/javascripts/katello/locale/pl_PL/katello.js +82 -31
  35. data/app/assets/javascripts/katello/locale/pt/katello.js +82 -31
  36. data/app/assets/javascripts/katello/locale/pt_BR/katello.js +82 -31
  37. data/app/assets/javascripts/katello/locale/ro/katello.js +82 -31
  38. data/app/assets/javascripts/katello/locale/ro_RO/katello.js +82 -31
  39. data/app/assets/javascripts/katello/locale/ru/katello.js +84 -33
  40. data/app/assets/javascripts/katello/locale/sl/katello.js +82 -31
  41. data/app/assets/javascripts/katello/locale/sv_SE/katello.js +83 -32
  42. data/app/assets/javascripts/katello/locale/ta/katello.js +82 -31
  43. data/app/assets/javascripts/katello/locale/ta_IN/katello.js +82 -31
  44. data/app/assets/javascripts/katello/locale/te/katello.js +82 -31
  45. data/app/assets/javascripts/katello/locale/tr/katello.js +82 -31
  46. data/app/assets/javascripts/katello/locale/vi/katello.js +82 -31
  47. data/app/assets/javascripts/katello/locale/vi_VN/katello.js +82 -31
  48. data/app/assets/javascripts/katello/locale/zh/katello.js +82 -31
  49. data/app/assets/javascripts/katello/locale/zh_CN/katello.js +83 -32
  50. data/app/assets/javascripts/katello/locale/zh_TW/katello.js +84 -33
  51. data/app/controllers/katello/api/registry/registry_proxies_controller.rb +19 -3
  52. data/app/controllers/katello/api/v2/content_view_components_controller.rb +6 -6
  53. data/app/controllers/katello/api/v2/content_view_filters_controller.rb +3 -0
  54. data/app/controllers/katello/api/v2/content_view_versions_controller.rb +6 -0
  55. data/app/controllers/katello/api/v2/content_views_controller.rb +12 -1
  56. data/app/controllers/katello/api/v2/exports_controller.rb +3 -0
  57. data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +12 -14
  58. data/app/controllers/katello/api/v2/organizations_controller.rb +10 -10
  59. data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +8 -2
  60. data/app/lib/actions/helpers/rolling_cv_repos.rb +25 -0
  61. data/app/lib/actions/katello/capsule_content/sync_capsule.rb +6 -1
  62. data/app/lib/actions/katello/content_view/add_rolling_repo_clone.rb +39 -0
  63. data/app/lib/actions/katello/content_view/create.rb +3 -0
  64. data/app/lib/actions/katello/content_view/refresh_rolling_repo.rb +40 -0
  65. data/app/lib/actions/katello/content_view/remove.rb +8 -4
  66. data/app/lib/actions/katello/content_view/remove_rolling_repo_clone.rb +28 -0
  67. data/app/lib/actions/katello/content_view/update.rb +8 -0
  68. data/app/lib/actions/katello/repository/check_matching_content.rb +1 -8
  69. data/app/lib/actions/katello/repository/import_upload.rb +5 -0
  70. data/app/lib/actions/katello/repository/sync.rb +8 -4
  71. data/app/lib/actions/katello/repository/upload_files.rb +7 -1
  72. data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +3 -2
  73. data/app/lib/actions/pulp3/orphan_cleanup/delete_orphan_repository_versions.rb +8 -1
  74. data/app/lib/katello/errors.rb +8 -0
  75. data/app/lib/katello/validators/container_image_name_validator.rb +3 -2
  76. data/app/models/katello/authorization/repository.rb +11 -1
  77. data/app/models/katello/concerns/host_managed_extensions.rb +2 -2
  78. data/app/models/katello/concerns/pulp_database_unit.rb +12 -42
  79. data/app/models/katello/concerns/smart_proxy_extensions.rb +8 -0
  80. data/app/models/katello/content_view.rb +14 -1
  81. data/app/models/katello/content_view_component.rb +4 -0
  82. data/app/models/katello/content_view_environment.rb +1 -0
  83. data/app/models/katello/content_view_version.rb +3 -2
  84. data/app/models/katello/host/content_facet.rb +18 -5
  85. data/app/models/katello/product_content.rb +3 -1
  86. data/app/models/katello/repository.rb +3 -3
  87. data/app/services/katello/content_unit_indexer.rb +1 -1
  88. data/app/services/katello/pulp3/api/content_guard.rb +1 -1
  89. data/app/services/katello/pulp3/api/core.rb +6 -0
  90. data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +58 -1
  91. data/app/services/katello/pulp3/smart_proxy_repository.rb +67 -3
  92. data/app/services/katello/smart_proxy_helper.rb +6 -1
  93. data/app/views/foreman/job_templates/install_errata_-_katello_ansible_default.erb +15 -1
  94. data/app/views/foreman/job_templates/install_errata_by_search_query_-_katello_ansible_default.erb +15 -1
  95. data/app/views/foreman/job_templates/install_group_-_katello_ansible_default.erb +15 -2
  96. data/app/views/foreman/job_templates/install_packages_by_search_query_-_katello_ansible_default.erb +21 -2
  97. data/app/views/foreman/job_templates/remove_group_-_katello_ansible_default.erb +15 -1
  98. data/app/views/foreman/job_templates/remove_packages_by_search_query_-_katello_ansible_default.erb +20 -1
  99. data/app/views/foreman/job_templates/update_group_-_katello_ansible_default.erb +15 -2
  100. data/app/views/foreman/job_templates/update_packages_by_search_query_-_katello_ansible_default.erb +17 -1
  101. data/app/views/katello/api/v2/activation_keys/base.json.rabl +1 -0
  102. data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +2 -1
  103. data/app/views/katello/api/v2/content_facet/base.json.rabl +2 -0
  104. data/app/views/katello/api/v2/content_view_versions/base.json.rabl +12 -0
  105. data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
  106. data/app/views/katello/api/v2/environments/show.json.rabl +14 -0
  107. data/app/views/katello/api/v2/hosts/base.json.rabl +1 -0
  108. data/app/views/katello/api/v2/organizations/show.json.rabl +2 -0
  109. data/app/views/katello/api/v2/repositories/base.json.rabl +2 -1
  110. data/db/migrate/20190930192813_add_pulp3_hrefs_to_content_types.rb +1 -1
  111. data/db/migrate/20241022122325_add_rolling_to_katello_content_views.rb +5 -0
  112. data/db/migrate/20241025151105_remove_pulp3_migrated_hrefs_from_content_tables.rb +1 -1
  113. data/db/migrate/20250215143303_drop_katello_yum_metadata_file.rb +5 -0
  114. data/db/migrate/20250409120843_fix_file_download_policy.rb +11 -0
  115. data/db/migrate/20250410155300_change_ansible_templates_category.rb +22 -0
  116. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +4 -0
  117. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/bn.po +90 -31
  118. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/bn_IN.po +90 -31
  119. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ca.po +90 -31
  120. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/cs_CZ.po +90 -31
  121. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +93 -60
  122. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de_AT.po +90 -31
  123. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de_DE.po +90 -31
  124. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/el.po +90 -31
  125. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/en_GB.po +94 -35
  126. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/en_US.po +90 -31
  127. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +93 -40
  128. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/et_EE.po +90 -31
  129. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +254 -192
  130. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/gl.po +90 -31
  131. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/gu.po +90 -31
  132. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/he_IL.po +90 -31
  133. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/hi.po +90 -31
  134. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/id.po +90 -31
  135. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +90 -35
  136. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +113 -52
  137. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ka.po +93 -34
  138. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/kn.po +90 -31
  139. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +101 -40
  140. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ml_IN.po +90 -31
  141. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/mr.po +90 -31
  142. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/nl_NL.po +90 -31
  143. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/or.po +90 -31
  144. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pa.po +90 -31
  145. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pl.po +90 -31
  146. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pl_PL.po +90 -31
  147. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt.po +90 -31
  148. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +93 -40
  149. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ro.po +90 -31
  150. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ro_RO.po +90 -31
  151. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +91 -34
  152. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/sl.po +90 -31
  153. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/sv_SE.po +90 -31
  154. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ta.po +90 -31
  155. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ta_IN.po +90 -31
  156. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/te.po +90 -31
  157. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/tr.po +90 -31
  158. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/vi.po +90 -31
  159. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/vi_VN.po +90 -31
  160. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh.po +90 -31
  161. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +99 -40
  162. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +92 -33
  163. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +14 -14
  164. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repository-types.service.js +3 -0
  165. data/lib/katello/engine.rb +9 -1
  166. data/lib/katello/repository_types/python.rb +1 -1
  167. data/lib/katello/tasks/repository.rake +1 -1
  168. data/lib/katello/version.rb +1 -1
  169. data/locale/action_names.rb +186 -0
  170. data/locale/bn/LC_MESSAGES/katello.mo +0 -0
  171. data/locale/bn/katello.po +82 -31
  172. data/locale/bn/katello.po.time_stamp +0 -0
  173. data/locale/bn_IN/LC_MESSAGES/katello.mo +0 -0
  174. data/locale/bn_IN/katello.po +82 -31
  175. data/locale/bn_IN/katello.po.time_stamp +0 -0
  176. data/locale/ca/LC_MESSAGES/katello.mo +0 -0
  177. data/locale/ca/katello.po +82 -31
  178. data/locale/ca/katello.po.time_stamp +0 -0
  179. data/locale/cs/LC_MESSAGES/katello.mo +0 -0
  180. data/locale/cs/katello.po +82 -31
  181. data/locale/cs/katello.po.time_stamp +0 -0
  182. data/locale/cs_CZ/LC_MESSAGES/katello.mo +0 -0
  183. data/locale/cs_CZ/katello.po +83 -32
  184. data/locale/cs_CZ/katello.po.time_stamp +0 -0
  185. data/locale/de/LC_MESSAGES/katello.mo +0 -0
  186. data/locale/de/katello.po +82 -31
  187. data/locale/de/katello.po.time_stamp +0 -0
  188. data/locale/de_AT/LC_MESSAGES/katello.mo +0 -0
  189. data/locale/de_AT/katello.po +82 -31
  190. data/locale/de_AT/katello.po.time_stamp +0 -0
  191. data/locale/de_DE/LC_MESSAGES/katello.mo +0 -0
  192. data/locale/de_DE/katello.po +82 -31
  193. data/locale/de_DE/katello.po.time_stamp +0 -0
  194. data/locale/el/LC_MESSAGES/katello.mo +0 -0
  195. data/locale/el/katello.po +82 -31
  196. data/locale/el/katello.po.time_stamp +0 -0
  197. data/locale/en/LC_MESSAGES/katello.mo +0 -0
  198. data/locale/en/katello.po +82 -31
  199. data/locale/en/katello.po.time_stamp +0 -0
  200. data/locale/en_GB/LC_MESSAGES/katello.mo +0 -0
  201. data/locale/en_GB/katello.po +84 -33
  202. data/locale/en_GB/katello.po.time_stamp +0 -0
  203. data/locale/en_US/LC_MESSAGES/katello.mo +0 -0
  204. data/locale/en_US/katello.po +82 -31
  205. data/locale/en_US/katello.po.time_stamp +0 -0
  206. data/locale/es/LC_MESSAGES/katello.mo +0 -0
  207. data/locale/es/katello.po +82 -31
  208. data/locale/es/katello.po.time_stamp +0 -0
  209. data/locale/et_EE/LC_MESSAGES/katello.mo +0 -0
  210. data/locale/et_EE/katello.po +82 -31
  211. data/locale/et_EE/katello.po.time_stamp +0 -0
  212. data/locale/fr/LC_MESSAGES/katello.mo +0 -0
  213. data/locale/fr/katello.po +83 -32
  214. data/locale/fr/katello.po.time_stamp +0 -0
  215. data/locale/gl/LC_MESSAGES/katello.mo +0 -0
  216. data/locale/gl/katello.po +82 -31
  217. data/locale/gl/katello.po.time_stamp +0 -0
  218. data/locale/gu/LC_MESSAGES/katello.mo +0 -0
  219. data/locale/gu/katello.po +84 -33
  220. data/locale/gu/katello.po.time_stamp +0 -0
  221. data/locale/he_IL/LC_MESSAGES/katello.mo +0 -0
  222. data/locale/he_IL/katello.po +82 -31
  223. data/locale/he_IL/katello.po.time_stamp +0 -0
  224. data/locale/hi/LC_MESSAGES/katello.mo +0 -0
  225. data/locale/hi/katello.po +82 -31
  226. data/locale/hi/katello.po.time_stamp +0 -0
  227. data/locale/id/LC_MESSAGES/katello.mo +0 -0
  228. data/locale/id/katello.po +82 -31
  229. data/locale/id/katello.po.time_stamp +0 -0
  230. data/locale/it/LC_MESSAGES/katello.mo +0 -0
  231. data/locale/it/katello.po +85 -34
  232. data/locale/it/katello.po.time_stamp +0 -0
  233. data/locale/ja/LC_MESSAGES/katello.mo +0 -0
  234. data/locale/ja/katello.po +83 -32
  235. data/locale/ja/katello.po.time_stamp +0 -0
  236. data/locale/ka/LC_MESSAGES/katello.mo +0 -0
  237. data/locale/ka/katello.po +82 -31
  238. data/locale/ka/katello.po.time_stamp +0 -0
  239. data/locale/katello.pot +1232 -1140
  240. data/locale/kn/LC_MESSAGES/katello.mo +0 -0
  241. data/locale/kn/katello.po +82 -31
  242. data/locale/kn/katello.po.time_stamp +0 -0
  243. data/locale/ko/LC_MESSAGES/katello.mo +0 -0
  244. data/locale/ko/katello.po +82 -31
  245. data/locale/ko/katello.po.time_stamp +0 -0
  246. data/locale/ml_IN/LC_MESSAGES/katello.mo +0 -0
  247. data/locale/ml_IN/katello.po +82 -31
  248. data/locale/ml_IN/katello.po.time_stamp +0 -0
  249. data/locale/mr/LC_MESSAGES/katello.mo +0 -0
  250. data/locale/mr/katello.po +82 -31
  251. data/locale/mr/katello.po.time_stamp +0 -0
  252. data/locale/nl_NL/LC_MESSAGES/katello.mo +0 -0
  253. data/locale/nl_NL/katello.po +82 -31
  254. data/locale/nl_NL/katello.po.time_stamp +0 -0
  255. data/locale/or/LC_MESSAGES/katello.mo +0 -0
  256. data/locale/or/katello.po +82 -31
  257. data/locale/or/katello.po.time_stamp +0 -0
  258. data/locale/pa/LC_MESSAGES/katello.mo +0 -0
  259. data/locale/pa/katello.po +82 -31
  260. data/locale/pa/katello.po.time_stamp +0 -0
  261. data/locale/pl/LC_MESSAGES/katello.mo +0 -0
  262. data/locale/pl/katello.po +84 -33
  263. data/locale/pl/katello.po.time_stamp +0 -0
  264. data/locale/pl_PL/LC_MESSAGES/katello.mo +0 -0
  265. data/locale/pl_PL/katello.po +82 -31
  266. data/locale/pl_PL/katello.po.time_stamp +0 -0
  267. data/locale/pt/LC_MESSAGES/katello.mo +0 -0
  268. data/locale/pt/katello.po +82 -31
  269. data/locale/pt/katello.po.time_stamp +0 -0
  270. data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
  271. data/locale/pt_BR/katello.po +82 -31
  272. data/locale/pt_BR/katello.po.time_stamp +0 -0
  273. data/locale/ro/LC_MESSAGES/katello.mo +0 -0
  274. data/locale/ro/katello.po +82 -31
  275. data/locale/ro/katello.po.time_stamp +0 -0
  276. data/locale/ro_RO/LC_MESSAGES/katello.mo +0 -0
  277. data/locale/ro_RO/katello.po +82 -31
  278. data/locale/ro_RO/katello.po.time_stamp +0 -0
  279. data/locale/ru/LC_MESSAGES/katello.mo +0 -0
  280. data/locale/ru/katello.po +85 -34
  281. data/locale/ru/katello.po.time_stamp +0 -0
  282. data/locale/sl/LC_MESSAGES/katello.mo +0 -0
  283. data/locale/sl/katello.po +82 -31
  284. data/locale/sl/katello.po.time_stamp +0 -0
  285. data/locale/sv_SE/LC_MESSAGES/katello.mo +0 -0
  286. data/locale/sv_SE/katello.po +84 -33
  287. data/locale/sv_SE/katello.po.time_stamp +0 -0
  288. data/locale/ta/LC_MESSAGES/katello.mo +0 -0
  289. data/locale/ta/katello.po +82 -31
  290. data/locale/ta/katello.po.time_stamp +0 -0
  291. data/locale/ta_IN/LC_MESSAGES/katello.mo +0 -0
  292. data/locale/ta_IN/katello.po +82 -31
  293. data/locale/ta_IN/katello.po.time_stamp +0 -0
  294. data/locale/te/LC_MESSAGES/katello.mo +0 -0
  295. data/locale/te/katello.po +82 -31
  296. data/locale/te/katello.po.time_stamp +0 -0
  297. data/locale/tr/LC_MESSAGES/katello.mo +0 -0
  298. data/locale/tr/katello.po +82 -31
  299. data/locale/tr/katello.po.time_stamp +0 -0
  300. data/locale/vi/LC_MESSAGES/katello.mo +0 -0
  301. data/locale/vi/katello.po +82 -31
  302. data/locale/vi/katello.po.time_stamp +0 -0
  303. data/locale/vi_VN/LC_MESSAGES/katello.mo +0 -0
  304. data/locale/vi_VN/katello.po +82 -31
  305. data/locale/vi_VN/katello.po.time_stamp +0 -0
  306. data/locale/zh/LC_MESSAGES/katello.mo +0 -0
  307. data/locale/zh/katello.po +82 -31
  308. data/locale/zh/katello.po.time_stamp +0 -0
  309. data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
  310. data/locale/zh_CN/katello.po +83 -32
  311. data/locale/zh_CN/katello.po.time_stamp +0 -0
  312. data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
  313. data/locale/zh_TW/katello.po +85 -34
  314. data/locale/zh_TW/katello.po.time_stamp +0 -0
  315. data/webpack/ForemanColumnExtensions/index.js +12 -4
  316. data/webpack/components/ActivationKeysSearch/index.js +6 -7
  317. data/webpack/components/Bookmark/AddBookmarkModal.js +3 -3
  318. data/webpack/components/Bookmark/Bookmark.scss +3 -3
  319. data/webpack/components/Bookmark/index.js +7 -2
  320. data/webpack/components/EditableSwitch.js +1 -1
  321. data/webpack/components/EditableTextInput/EditableTextInput.js +1 -1
  322. data/webpack/components/EditableTextInput/editableTextInput.scss +1 -1
  323. data/webpack/components/Errata/index.js +1 -24
  324. data/webpack/components/Loading.js +10 -6
  325. data/webpack/components/Packages/index.js +2 -1
  326. data/webpack/components/SelectAllCheckbox/index.js +7 -3
  327. data/webpack/components/SelectableDropdown/SelectableDropdown.js +21 -3
  328. data/webpack/components/Table/EmptyStateMessage.js +12 -14
  329. data/webpack/components/Table/MainTable.js +8 -7
  330. data/webpack/components/Table/MainTable.scss +4 -4
  331. data/webpack/components/extensions/HostDetails/ActionsBar/index.js +4 -1
  332. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +1 -1
  333. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +9 -6
  334. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +2 -1
  335. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +4 -1
  336. data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +23 -6
  337. data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +1 -1
  338. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +5 -3
  339. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.scss +3 -3
  340. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +1 -1
  341. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +25 -10
  342. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +5 -2
  343. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +2 -2
  344. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +5 -4
  345. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +6 -3
  346. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +19 -12
  347. data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +1 -1
  348. data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +1 -4
  349. data/webpack/components/extensions/HostDetails/DetailsTabCards/ImageModeCard.js +1 -4
  350. data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +1 -4
  351. data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/HwPropertiesCard.test.js +63 -0
  352. data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/ImageModeCard.test.js +73 -0
  353. data/webpack/components/extensions/HostDetails/DetailsTabCards/__test__/InstalledProductsCard.test.js +45 -0
  354. data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebInstallModal.js +12 -2
  355. data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebInstallModal.scss +1 -1
  356. data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebsTab.js +10 -13
  357. data/webpack/components/extensions/HostDetails/Tabs/DebsTab/DebsTab.scss +1 -1
  358. data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +46 -21
  359. data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.scss +1 -1
  360. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +15 -7
  361. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +13 -3
  362. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.scss +1 -1
  363. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +34 -20
  364. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.scss +1 -1
  365. data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +8 -6
  366. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +5 -3
  367. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.scss +1 -1
  368. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +12 -13
  369. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +16 -6
  370. data/webpack/components/extensions/HostDetails/Tabs/__tests__/debsInstallModal.test.js +10 -5
  371. data/webpack/components/extensions/HostDetails/Tabs/__tests__/debsTab.test.js +48 -22
  372. data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +123 -47
  373. data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +14 -7
  374. data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +10 -5
  375. data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +41 -24
  376. data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +50 -25
  377. data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +50 -25
  378. data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +3 -0
  379. data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/04_Review.js +16 -2
  380. data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/04_ReviewFooter.js +6 -2
  381. data/webpack/components/extensions/Hosts/BulkActions/BulkErrataWizard/BulkErrataWizard.js +5 -1
  382. data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/04_Review.js +16 -2
  383. data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/04_ReviewFooter.js +6 -2
  384. data/webpack/components/extensions/Hosts/BulkActions/BulkPackagesWizard/BulkPackagesWizard.js +15 -2
  385. data/webpack/components/extensions/Hosts/BulkActions/HostReview.js +1 -1
  386. data/webpack/components/extensions/Hosts/BulkActions/__tests__/bulkChangeHostCVModal.test.js +2 -1
  387. data/webpack/components/extensions/Hosts/FontAwesomeImageModeIcon.js +1 -1
  388. data/webpack/components/extensions/Hosts/ImageModeHostAlert.js +14 -0
  389. data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +14 -17
  390. data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +1 -1
  391. data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +1 -1
  392. data/webpack/components/extensions/RegistrationCommands/fields/ActivationKeys.js +38 -49
  393. data/webpack/containers/Application/overrides.scss +7 -7
  394. data/webpack/ouia_id_check.js +15 -11
  395. data/webpack/redux/actions/RedHatRepositories/helpers.js +0 -2
  396. data/webpack/scenes/ActivationKeys/Details/__tests__/activationKeyDetails.test.js +12 -6
  397. data/webpack/scenes/ActivationKeys/Details/components/DeleteMenu.js +12 -2
  398. data/webpack/scenes/ActivationKeys/Details/components/EditModal.js +3 -3
  399. data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +3 -1
  400. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +3 -1
  401. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +12 -6
  402. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +1 -1
  403. data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +22 -7
  404. data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +2 -2
  405. data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +1 -1
  406. data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +6 -3
  407. data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +25 -15
  408. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +9 -6
  409. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +2 -2
  410. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +1 -1
  411. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +33 -7
  412. data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +10 -5
  413. data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +4 -2
  414. data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +10 -8
  415. data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +4 -2
  416. data/webpack/scenes/BootedContainerImages/BootedContainerImagesPage.js +5 -5
  417. data/webpack/scenes/Content/Details/__tests__/contentDetail.test.js +8 -4
  418. data/webpack/scenes/Content/__tests__/contentTable.test.js +4 -2
  419. data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +1 -1
  420. data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +1 -0
  421. data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +2 -1
  422. data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +86 -31
  423. data/webpack/scenes/ContentViews/Create/CreateContentViewForm.scss +10 -2
  424. data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +1 -0
  425. data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +10 -4
  426. data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +3 -1
  427. data/webpack/scenes/ContentViews/Delete/Steps/CVDeleteEnvironmentsSelection.js +6 -6
  428. data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignActivationKeysForm.js +7 -2
  429. data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignHostsForm.js +7 -2
  430. data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReview.js +3 -3
  431. data/webpack/scenes/ContentViews/Delete/Steps/CVEnvironmentSelectionForm.scss +1 -1
  432. data/webpack/scenes/ContentViews/Delete/__tests__/CvData.fixtures.json +2 -1
  433. data/webpack/scenes/ContentViews/Delete/__tests__/affectedHosts.fixtures.json +3 -2
  434. data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +10 -8
  435. data/webpack/scenes/ContentViews/Delete/__tests__/cvDetails.fixtures.json +2 -1
  436. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +16 -5
  437. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +19 -5
  438. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentEnvironments.js +1 -1
  439. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +11 -2
  440. data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/compositeCVDetails.fixtures.json +2 -1
  441. data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +69 -27
  442. data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/publishedContentViewDetails.fixtures.json +2 -1
  443. data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +22 -29
  444. data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +6 -2
  445. data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +20 -7
  446. data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +4 -2
  447. data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositorySelection.js +5 -2
  448. data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +3 -1
  449. data/webpack/scenes/ContentViews/Details/Filters/ArtifactsWithNoErrata.js +1 -1
  450. data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +4 -2
  451. data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +13 -1
  452. data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +23 -7
  453. data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +23 -5
  454. data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +15 -3
  455. data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +15 -3
  456. data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +13 -1
  457. data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +6 -4
  458. data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +11 -1
  459. data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +4 -2
  460. data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/matchContentModal.scss +1 -1
  461. data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +2 -2
  462. data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +4 -4
  463. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +18 -12
  464. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +7 -11
  465. data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +81 -70
  466. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewErrataByDateDetails.fixtures.json +1 -0
  467. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +4 -2
  468. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +52 -38
  469. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataDateFilterContent.test.js +9 -4
  470. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +18 -12
  471. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErratumFilterDetails.fixtures.json +1 -0
  472. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailModuleAffectedRepos.fixtures.json +1 -0
  473. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterDetailWithAffectedRepos.fixtures.json +1 -0
  474. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvFilterFixutre.fixture.json +2 -1
  475. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +77 -67
  476. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilterDetails.fixtures.json +1 -0
  477. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterDetail.fixtures.json +1 -0
  478. data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +2 -2
  479. data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +4 -2
  480. data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +1 -1
  481. data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +7 -5
  482. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +6 -3
  483. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
  484. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +3 -2
  485. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +3 -1
  486. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +2 -2
  487. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +3 -1
  488. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +3 -1
  489. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +4 -4
  490. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +11 -11
  491. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +15 -5
  492. data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionEnvironments.js +1 -1
  493. data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +13 -3
  494. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +3 -1
  495. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVEnvironmentSelectionForm.js +17 -13
  496. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignActivationKeysForm.js +12 -7
  497. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignHostsForm.js +64 -7
  498. data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +52 -21
  499. data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +30 -16
  500. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.scss +7 -7
  501. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +5 -3
  502. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +4 -2
  503. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +6 -3
  504. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +2 -1
  505. data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +6 -6
  506. data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +35 -4
  507. data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
  508. data/webpack/scenes/ContentViews/Details/__tests__/contentViewRollingDetail.test.js +197 -0
  509. data/webpack/scenes/ContentViews/Details/__tests__/contentViewRollingDetails.fixtures.json +82 -0
  510. data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +3 -7
  511. data/webpack/scenes/ContentViews/Publish/CVPublishForm.js +2 -2
  512. data/webpack/scenes/ContentViews/Publish/CVPublishReview.js +6 -5
  513. data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +3 -1
  514. data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +15 -7
  515. data/webpack/scenes/ContentViews/Publish/cvPublishForm.scss +4 -4
  516. data/webpack/scenes/ContentViews/Table/ContentViewVersionCell.js +6 -4
  517. data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +14 -3
  518. data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +3 -0
  519. data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +1 -0
  520. data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +89 -2
  521. data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +85 -14
  522. data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +2 -1
  523. data/webpack/scenes/ContentViews/components/ContentViewIcon.js +20 -6
  524. data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelect.js +4 -1
  525. data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelectOption.js +11 -2
  526. data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +27 -7
  527. data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +2 -2
  528. data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +6 -2
  529. data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +4 -1
  530. data/webpack/scenes/ContentViews/components/FiltersAppliedIcon.js +4 -2
  531. data/webpack/scenes/ContentViews/components/NeedsPublishIcon.js +7 -6
  532. data/webpack/scenes/ContentViews/components/NeedsPublishIcon.scss +2 -2
  533. data/webpack/scenes/ContentViews/components/contentViewIcon.scss +16 -3
  534. data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +6 -1
  535. data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +3 -3
  536. data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +2 -1
  537. data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceForm.js +5 -3
  538. data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceTemplate.js +3 -2
  539. data/webpack/scenes/Hosts/ChangeContentSource/components/FormField.js +1 -1
  540. data/webpack/scenes/Hosts/ChangeContentSource/components/HostsModal.js +1 -1
  541. data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepositoryContent.js +1 -1
  542. data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/__snapshots__/EnabledRepositoryContent.test.js.snap +1 -1
  543. data/webpack/scenes/RedHatRepositories/index.scss +1 -1
  544. data/webpack/scenes/SmartProxy/ExpandableCvDetails.js +27 -7
  545. data/webpack/scenes/SmartProxy/ExpandedSmartProxyRepositories.js +51 -2
  546. data/webpack/scenes/SmartProxy/SmartProxyExpandableTable.js +2 -2
  547. data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentTest.js +14 -9
  548. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationForm.scss +1 -1
  549. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CustomCdnTypeForm.js +2 -2
  550. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/NetworkSyncForm.js +6 -6
  551. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CdnTypeForm.test.js +2 -1
  552. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CustomCdnTypeForm.test.js +2 -1
  553. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/ExportSyncForm.test.js +2 -1
  554. data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/NetworkSyncForm.test.js +2 -1
  555. metadata +125 -53
  556. data/app/models/katello/yum_metadata_file.rb +0 -22
  557. data/app/services/katello/pulp3/yum_metadata_file.rb +0 -20
@@ -1,10 +1,10 @@
1
1
  import React from 'react';
2
- import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
2
+ import { renderWithRedux, patientlyWaitFor, fireEvent, act, waitFor } from 'react-testing-lib-wrapper';
3
3
  import { Route } from 'react-router-dom';
4
4
 
5
5
  import ContentViewFilterDetails from '../ContentViewFilterDetails';
6
6
  import { ADDED, cvFilterDetailsKey, NOT_ADDED } from '../../../ContentViewsConstants';
7
- import {
7
+ import nock, {
8
8
  nockInstance,
9
9
  assertNockRequest,
10
10
  mockAutocomplete,
@@ -46,6 +46,11 @@ const renderOptions = {
46
46
 
47
47
  const withCVRoute = component => <Route path="/content_views/:id([0-9]+)#/filters/:filterId([0-9]+)">{component}</Route>;
48
48
 
49
+ afterEach(() => {
50
+ nock.cleanAll(); // Removes all interceptors
51
+ nock.restore(); // Restores HTTP to normal behavior
52
+ });
53
+
49
54
  test('Can enable and disable add filter button', async (done) => {
50
55
  const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
51
56
  const { name: cvFilterName } = cvFilterDetails;
@@ -85,6 +90,7 @@ test('Can enable and disable add filter button', async (done) => {
85
90
  assertNockRequest(cvFilterScope);
86
91
  assertNockRequest(cvFiltersScope);
87
92
  assertNockRequest(packageGroupsScope, done);
93
+ act(done);
88
94
  });
89
95
 
90
96
  test('Can remove a filter rule', async (done) => {
@@ -127,10 +133,10 @@ test('Can remove a filter rule', async (done) => {
127
133
 
128
134
  await patientlyWaitFor(() => {
129
135
  expect(getByText(name)).toBeInTheDocument();
130
- expect(getAllByLabelText('Actions')[2]).toHaveAttribute('aria-expanded', 'false');
136
+ expect(getAllByLabelText('Kebab toggle')[2]).toHaveAttribute('aria-expanded', 'false');
131
137
  });
132
- fireEvent.click(getAllByLabelText('Actions')[2]);
133
- expect(getAllByLabelText('Actions')[2]).toHaveAttribute('aria-expanded', 'true');
138
+ fireEvent.click(getAllByLabelText('Kebab toggle')[2]);
139
+ expect(getAllByLabelText('Kebab toggle')[2]).toHaveAttribute('aria-expanded', 'true');
134
140
  await patientlyWaitFor(() => expect(getByText('Remove')).toBeInTheDocument());
135
141
  fireEvent.click(getByText('Remove'));
136
142
 
@@ -142,6 +148,7 @@ test('Can remove a filter rule', async (done) => {
142
148
  assertNockRequest(cvRequestCallbackScope);
143
149
 
144
150
  assertNockRequest(packageGroupsScope, done);
151
+ act(done);
145
152
  });
146
153
 
147
154
  test('Can add a filter rule', async (done) => {
@@ -186,10 +193,10 @@ test('Can add a filter rule', async (done) => {
186
193
 
187
194
  await patientlyWaitFor(() => {
188
195
  expect(getByText(name)).toBeInTheDocument();
189
- expect(getAllByLabelText('Actions')[3]).toHaveAttribute('aria-expanded', 'false');
196
+ expect(getAllByLabelText('Kebab toggle')[1]).toHaveAttribute('aria-expanded', 'false');
190
197
  });
191
- fireEvent.click(getAllByLabelText('Actions')[3]);
192
- expect(getAllByLabelText('Actions')[3]).toHaveAttribute('aria-expanded', 'true');
198
+ fireEvent.click(getAllByLabelText('Kebab toggle')[1]);
199
+ expect(getAllByLabelText('Kebab toggle')[1]).toHaveAttribute('aria-expanded', 'true');
193
200
  await patientlyWaitFor(() => expect(getByText('Add')).toBeInTheDocument());
194
201
  fireEvent.click(getByText('Add'));
195
202
 
@@ -201,6 +208,7 @@ test('Can add a filter rule', async (done) => {
201
208
  assertNockRequest(cvRequestCallbackScope);
202
209
 
203
210
  assertNockRequest(packageGroupsScope, done);
211
+ act(done);
204
212
  });
205
213
 
206
214
  test('Can bulk remove filter rules', async (done) => {
@@ -261,7 +269,7 @@ test('Can bulk remove filter rules', async (done) => {
261
269
  assertNockRequest(cvFiltersScope);
262
270
  assertNockRequest(cvFiltersRuleBulkDeleteScope);
263
271
  assertNockRequest(cvRequestCallbackScope);
264
-
272
+ await waitFor(() => expect(packageGroupsScope.isDone()).toBe(true));
265
273
  assertNockRequest(packageGroupsScope, done);
266
274
  });
267
275
 
@@ -320,6 +328,64 @@ test('Can bulk add filter rules', async (done) => {
320
328
  assertNockRequest(cvFiltersScope);
321
329
  assertNockRequest(cvFiltersRuleBulkAddScope);
322
330
  assertNockRequest(cvRequestCallbackScope);
331
+ await waitFor(() => expect(packageGroupsScope.isDone()).toBe(true));
332
+ assertNockRequest(packageGroupsScope, done);
333
+ });
334
+
335
+ test('Can filter by added/not added rules', async (done) => {
336
+ const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
337
+ const { rules } = cvFilterDetails;
338
+ const { name } = rules[0];
339
+
340
+ const cvFilterScope = nockInstance
341
+ .get(cvFilterDetailsPath)
342
+ .query(true)
343
+ .reply(200, cvFilterDetails);
344
+
345
+ const cvFiltersScope = nockInstance
346
+ .get(cvFiltersPath)
347
+ .query(true)
348
+ .reply(200, cvFilterFixtures);
349
+
350
+ const packageGroupsScope = nockInstance
351
+ .get(packageGroupsPath)
352
+ .query(true)
353
+ .times(3) // For first call (All), Added, and Not Added
354
+ .reply(200, allPackageGroups);
355
+
356
+ const {
357
+ getByText, queryByText, getByTestId, getByLabelText,
358
+ } = renderWithRedux(withCVRoute(<ContentViewFilterDetails
359
+ cvId={1}
360
+ details={details}
361
+ />), renderOptions);
362
+
363
+ // Nothing will show at first, page is loading
364
+ expect(queryByText(name)).toBeNull();
365
+
366
+ await patientlyWaitFor(() => {
367
+ expect(getByText(name)).toBeInTheDocument();
368
+ expect(getByTestId('allAddedNotAdded')).toBeInTheDocument();
369
+ });
370
+ fireEvent.click(getByTestId('allAddedNotAdded')?.childNodes[0]?.childNodes[0]);
371
+ await patientlyWaitFor(() => {
372
+ expect(getByLabelText(ADDED)).toBeInTheDocument();
373
+ });
374
+ fireEvent.click(getByLabelText(ADDED));
375
+ await patientlyWaitFor(() => {
376
+ expect(getByText(name)).toBeInTheDocument();
377
+ expect(getByTestId('allAddedNotAdded')).toBeInTheDocument();
378
+ });
379
+ fireEvent.click(getByTestId('allAddedNotAdded')?.childNodes[0]?.childNodes[0]);
380
+ await patientlyWaitFor(() => {
381
+ expect(getByLabelText(NOT_ADDED)).toBeInTheDocument();
382
+ });
383
+ fireEvent.click(getByLabelText(NOT_ADDED));
384
+
385
+ assertNockRequest(autocompleteScope);
386
+ assertNockRequest(cvFilterScope);
387
+ assertNockRequest(cvFiltersScope);
388
+ await waitFor(() => expect(packageGroupsScope.isDone()).toBe(true));
323
389
  assertNockRequest(packageGroupsScope, done);
324
390
  });
325
391
 
@@ -409,7 +475,9 @@ test('Can show affected repository tab on dropdown selection and add repos', asy
409
475
  fireEvent.click(getAllByLabelText('Select all rows')[1]);
410
476
  expect(getByLabelText('add_repositories')).toHaveAttribute('aria-disabled', 'false');
411
477
  fireEvent.click(getByLabelText('add_repositories'));
412
-
478
+ await patientlyWaitFor(() => {
479
+ expect(getByLabelText('add_repositories')).toHaveAttribute('aria-disabled', 'true');
480
+ });
413
481
  assertNockRequest(cvFilterScope);
414
482
  assertNockRequest(cvFiltersScope);
415
483
  assertNockRequest(cvAllReposScope);
@@ -419,6 +487,7 @@ test('Can show affected repository tab on dropdown selection and add repos', asy
419
487
  assertNockRequest(autocompleteScope);
420
488
  assertNockRequest(autocompleteScopeRepo);
421
489
  assertNockRequest(packageGroupsScope, done);
490
+ act(done);
422
491
  });
423
492
 
424
493
  test('Can show affected repository tab and remove affected repos', async (done) => {
@@ -510,64 +579,6 @@ test('Can show affected repository tab and remove affected repos', async (done)
510
579
  assertNockRequest(bulkRemoveReposScope);
511
580
  assertNockRequest(cvFilterScope);
512
581
  assertNockRequest(cvAllReposScope);
513
- assertNockRequest(packageGroupsScope, done);
514
- });
515
-
516
- test('Can filter by added/not added rules', async (done) => {
517
- const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl, autocompleteQuery);
518
- const { rules } = cvFilterDetails;
519
- const { name } = rules[0];
520
-
521
- const cvFilterScope = nockInstance
522
- .get(cvFilterDetailsPath)
523
- .query(true)
524
- .reply(200, cvFilterDetails);
525
-
526
- const cvFiltersScope = nockInstance
527
- .get(cvFiltersPath)
528
- .query(true)
529
- .reply(200, cvFilterFixtures);
530
-
531
- const packageGroupsScope = nockInstance
532
- .get(packageGroupsPath)
533
- .query(true)
534
- .times(3) // For first call (All), Added, and Not Added
535
- .reply(200, allPackageGroups);
536
-
537
- const {
538
- getByText, queryByText, getByTestId, getByLabelText,
539
- } = renderWithRedux(withCVRoute(<ContentViewFilterDetails
540
- cvId={1}
541
- details={details}
542
- />), renderOptions);
543
-
544
- // Nothing will show at first, page is loading
545
- expect(queryByText(name)).toBeNull();
546
-
547
- await patientlyWaitFor(() => {
548
- expect(getByText(name)).toBeInTheDocument();
549
- expect(getByTestId('allAddedNotAdded')).toBeInTheDocument();
550
- fireEvent.click(getByTestId('allAddedNotAdded')?.childNodes[0]?.childNodes[0]);
551
- });
552
-
553
- await patientlyWaitFor(() => {
554
- expect(getByLabelText(ADDED)).toBeInTheDocument();
555
- getByLabelText(ADDED).click();
556
- });
557
-
558
- await patientlyWaitFor(() => {
559
- expect(getByText(name)).toBeInTheDocument();
560
- expect(getByTestId('allAddedNotAdded')).toBeInTheDocument();
561
- fireEvent.click(getByTestId('allAddedNotAdded')?.childNodes[0]?.childNodes[0]);
562
- });
563
-
564
- await patientlyWaitFor(() => {
565
- expect(getByLabelText(NOT_ADDED)).toBeInTheDocument();
566
- getByLabelText(NOT_ADDED).click();
567
- });
568
-
569
- assertNockRequest(autocompleteScope);
570
- assertNockRequest(cvFilterScope);
571
- assertNockRequest(cvFiltersScope);
572
- assertNockRequest(packageGroupsScope, done);
582
+ assertNockRequest(packageGroupsScope);
583
+ done();
573
584
  });
@@ -7,6 +7,7 @@
7
7
  "updated_at": "2021-10-05 15:48:00 -0400",
8
8
  "content_view": {
9
9
  "composite": false,
10
+ "rolling": false,
10
11
  "component_ids": [],
11
12
  "default": false,
12
13
  "version_count": 4,
@@ -65,7 +65,8 @@ test('Can show filter details and package groups on page load', async (done) =>
65
65
  assertNockRequest(autocompleteScope);
66
66
  assertNockRequest(cvFilterScope);
67
67
  assertNockRequest(cvFiltersScope);
68
- assertNockRequest(packageGroupsScope, done);
68
+ assertNockRequest(packageGroupsScope);
69
+ done();
69
70
  act(done);
70
71
  });
71
72
 
@@ -145,6 +146,7 @@ test('Can search for package groups in package group filter', async (done) => {
145
146
  assertNockRequest(cvFiltersScope);
146
147
  assertNockRequest(packageGroupsScope);
147
148
  assertNockRequest(withSearchScope);
148
- assertNockRequest(packageGroupSearchScope, done);
149
+ assertNockRequest(packageGroupSearchScope);
150
+ done();
149
151
  act(done);
150
152
  });
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
2
+ import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
3
3
  import { Route } from 'react-router-dom';
4
4
 
5
5
  import api from '../../../../../services/api';
@@ -33,6 +33,38 @@ beforeEach(() => {
33
33
  [lastFilter] = results.slice(-1);
34
34
  });
35
35
 
36
+ test('Shows call-to-action button when there are no filters', async (done) => {
37
+ const repoTypesResponse = [{ name: 'deb' }, { name: 'docker' }, { name: 'file' }, { name: 'ostree' }, { name: 'yum' }];
38
+ const repoTypeScope = nockInstance
39
+ .get(api.getApiUrl('/repositories/repository_types'))
40
+ .query(true)
41
+ .reply(200, repoTypesResponse);
42
+
43
+ const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
44
+
45
+ const scope = nockInstance
46
+ .get(cvFilters)
47
+ .query(true)
48
+ .reply(200, emptyContentViewFiltersData);
49
+ const { queryByLabelText } =
50
+ renderWithRedux(withCVRoute(<ContentViewFilters cvId={1} details={details} />), renderOptions);
51
+
52
+ expect(queryByLabelText('create_filter_empty_state')).toBeNull();
53
+ await patientlyWaitFor(() => {
54
+ expect(queryByLabelText('create_filter_empty_state')).toBeInTheDocument();
55
+ });
56
+ await act(async () => {
57
+ fireEvent.click(queryByLabelText('create_filter_empty_state'));
58
+ });
59
+ await patientlyWaitFor(() => {
60
+ expect(queryByLabelText('create_filter')).toBeInTheDocument();
61
+ });
62
+ assertNockRequest(autocompleteScope);
63
+ assertNockRequest(repoTypeScope);
64
+ assertNockRequest(scope, done);
65
+ act(done);
66
+ });
67
+
36
68
  test('Can call API and show filters on page load', async (done) => {
37
69
  const { name, description } = firstFilter;
38
70
  const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
@@ -55,6 +87,7 @@ test('Can call API and show filters on page load', async (done) => {
55
87
 
56
88
  assertNockRequest(autocompleteScope);
57
89
  assertNockRequest(scope, done);
90
+ act(done);
58
91
  });
59
92
 
60
93
  test('Can search for filter', async (done) => {
@@ -116,6 +149,7 @@ test('Can search for filter', async (done) => {
116
149
  assertNockRequest(autocompleteScope);
117
150
  assertNockRequest(initialScope);
118
151
  assertNockRequest(withSearchScope, done);
152
+ act(done);
119
153
  });
120
154
 
121
155
  test('Can remove a filter', async (done) => {
@@ -143,17 +177,23 @@ test('Can remove a filter', async (done) => {
143
177
  );
144
178
 
145
179
  await patientlyWaitFor(() => {
146
- expect(getAllByLabelText('Actions')[0]).toHaveAttribute('aria-expanded', 'false');
180
+ expect(getAllByLabelText('Kebab toggle')[0]).toHaveAttribute('aria-expanded', 'false');
147
181
  });
148
- fireEvent.click(getAllByLabelText('Actions')[0]);
149
- expect(getAllByLabelText('Actions')[0]).toHaveAttribute('aria-expanded', 'true');
182
+
183
+ await act(async () => {
184
+ fireEvent.click(getAllByLabelText('Kebab toggle')[0]);
185
+ });
186
+ expect(getAllByLabelText('Kebab toggle')[0]).toHaveAttribute('aria-expanded', 'true');
150
187
  await patientlyWaitFor(() => expect(getByText('Remove')).toBeInTheDocument());
151
- fireEvent.click(getByText('Remove'));
188
+ await act(async () => {
189
+ fireEvent.click(getByText('Remove'));
190
+ });
152
191
 
153
192
  assertNockRequest(autocompleteScope);
154
193
  assertNockRequest(getContentViewScope);
155
194
  assertNockRequest(removeFilterScope);
156
195
  assertNockRequest(callbackGetContentViewScope, done);
196
+ act(done);
157
197
  });
158
198
 
159
199
  test('Can remove multiple filters', async (done) => {
@@ -184,43 +224,17 @@ test('Can remove multiple filters', async (done) => {
184
224
  fireEvent.click(getByLabelText('Select all rows'));
185
225
  expect(getAllByLabelText('bulk_actions')[0]).toHaveAttribute('aria-expanded', 'false');
186
226
  });
187
- fireEvent.click(getAllByLabelText('bulk_actions')[0]);
227
+ await act(async () => {
228
+ fireEvent.click(getAllByLabelText('bulk_actions')[0]);
229
+ });
188
230
  expect(getAllByLabelText('bulk_actions')[0]).toHaveAttribute('aria-expanded', 'true');
189
231
  await patientlyWaitFor(() => expect(getByText('Remove')).toBeInTheDocument());
190
- fireEvent.click(getByText('Remove'));
191
-
232
+ await act(async () => {
233
+ fireEvent.click(getByText('Remove'));
234
+ });
192
235
  assertNockRequest(autocompleteScope);
193
236
  assertNockRequest(getContentViewScope);
194
237
  assertNockRequest(removeFilterScope);
195
238
  assertNockRequest(callbackGetContentViewScope, done);
196
- });
197
-
198
- test('Shows call-to-action button when there are no filters', async (done) => {
199
- const repoTypesResponse = [{ name: 'deb' }, { name: 'docker' }, { name: 'file' }, { name: 'ostree' }, { name: 'yum' }];
200
- const repoTypeScope = nockInstance
201
- .get(api.getApiUrl('/repositories/repository_types'))
202
- .query(true)
203
- .reply(200, repoTypesResponse);
204
-
205
- const autocompleteScope = mockAutocomplete(nockInstance, autocompleteUrl);
206
-
207
- const scope = nockInstance
208
- .get(cvFilters)
209
- .query(true)
210
- .reply(200, emptyContentViewFiltersData);
211
-
212
- const { queryByLabelText } =
213
- renderWithRedux(withCVRoute(<ContentViewFilters cvId={1} details={details} />), renderOptions);
214
-
215
- expect(queryByLabelText('create_filter_empty_state')).toBeNull();
216
- await patientlyWaitFor(() => {
217
- expect(queryByLabelText('create_filter_empty_state')).toBeInTheDocument();
218
- });
219
- fireEvent.click(queryByLabelText('create_filter_empty_state'));
220
- await patientlyWaitFor(() => {
221
- expect(queryByLabelText('create_filter')).toBeInTheDocument();
222
- });
223
- assertNockRequest(autocompleteScope);
224
- assertNockRequest(repoTypeScope);
225
- assertNockRequest(scope, done);
239
+ act(done);
226
240
  });
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
2
+ import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
3
3
  import * as reactRedux from 'react-redux';
4
4
  import {
5
5
  nockInstance,
@@ -52,7 +52,9 @@ test('Can display errata-date filter rule and edit', async (done) => {
52
52
  expect(getByText('08/15/2020')).toBeInTheDocument();
53
53
  });
54
54
  // Can clear date with chip
55
- getByLabelText('08/15/1990').click();
55
+ await act(async () => {
56
+ getByLabelText('08/15/1990').click();
57
+ });
56
58
  await patientlyWaitFor(() => {
57
59
  expect(getByText('ANY')).toBeInTheDocument();
58
60
  expect(queryByText('08/15/1990')).not.toBeInTheDocument();
@@ -60,8 +62,11 @@ test('Can display errata-date filter rule and edit', async (done) => {
60
62
  // Enabled Edit rule button
61
63
  expect(getByLabelText('save_filter_rule')).toHaveAttribute('aria-disabled', 'false');
62
64
  });
63
- getByLabelText('save_filter_rule').click();
65
+ await act(async () => {
66
+ getByLabelText('save_filter_rule').click();
67
+ });
64
68
 
65
69
  useSelectorMock.mockClear();
66
- assertNockRequest(ruleEditScope, done);
70
+ assertNockRequest(ruleEditScope);
71
+ done();
67
72
  });
@@ -72,7 +72,8 @@ test('Can enable and disable add filter button', async (done) => {
72
72
  assertNockRequest(autocompleteScope);
73
73
  assertNockRequest(cvFilterScope);
74
74
  assertNockRequest(cvFiltersScope);
75
- assertNockRequest(errataScope, done);
75
+ assertNockRequest(errataScope);
76
+ done();
76
77
  act(done);
77
78
  });
78
79
 
@@ -118,10 +119,10 @@ test('Can add a filter rule', async (done) => {
118
119
 
119
120
  await patientlyWaitFor(() => {
120
121
  expect(getByText(errataId)).toBeInTheDocument();
121
- expect(getAllByLabelText('Actions')[3]).toHaveAttribute('aria-expanded', 'false');
122
+ expect(getAllByLabelText('Kebab toggle')[1]).toHaveAttribute('aria-expanded', 'false');
122
123
  });
123
- fireEvent.click(getAllByLabelText('Actions')[3]);
124
- expect(getAllByLabelText('Actions')[3]).toHaveAttribute('aria-expanded', 'true');
124
+ fireEvent.click(getAllByLabelText('Kebab toggle')[1]);
125
+ expect(getAllByLabelText('Kebab toggle')[1]).toHaveAttribute('aria-expanded', 'true');
125
126
  await patientlyWaitFor(() => expect(getByText('Add')).toBeInTheDocument());
126
127
  act(() => { fireEvent.click(getByText('Add')); });
127
128
 
@@ -131,7 +132,8 @@ test('Can add a filter rule', async (done) => {
131
132
  assertNockRequest(cvFiltersScope);
132
133
  assertNockRequest(cvFiltersRuleScope);
133
134
  assertNockRequest(cvRequestCallbackScope);
134
- assertNockRequest(errataScope, done);
135
+ assertNockRequest(errataScope);
136
+ done();
135
137
  act(done);
136
138
  });
137
139
 
@@ -176,10 +178,10 @@ test('Can remove a filter rule', async (done) => {
176
178
 
177
179
  await patientlyWaitFor(() => {
178
180
  expect(getByText(errataId)).toBeInTheDocument();
179
- expect(getAllByLabelText('Actions')[2]).toHaveAttribute('aria-expanded', 'false');
181
+ expect(getAllByLabelText('Kebab toggle')[2]).toHaveAttribute('aria-expanded', 'false');
180
182
  });
181
- fireEvent.click(getAllByLabelText('Actions')[2]);
182
- expect(getAllByLabelText('Actions')[2]).toHaveAttribute('aria-expanded', 'true');
183
+ fireEvent.click(getAllByLabelText('Kebab toggle')[2]);
184
+ expect(getAllByLabelText('Kebab toggle')[2]).toHaveAttribute('aria-expanded', 'true');
183
185
  await patientlyWaitFor(() => expect(getByText('Remove')).toBeInTheDocument());
184
186
  act(() => { fireEvent.click(getByText('Remove')); });
185
187
 
@@ -189,7 +191,8 @@ test('Can remove a filter rule', async (done) => {
189
191
  assertNockRequest(cvFiltersScope);
190
192
  assertNockRequest(cvFiltersRuleScope);
191
193
  assertNockRequest(cvRequestCallbackScope);
192
- assertNockRequest(errataScope, done);
194
+ assertNockRequest(errataScope);
195
+ done();
193
196
  act(done);
194
197
  });
195
198
 
@@ -253,7 +256,8 @@ test('Can bulk remove filter rules', async (done) => {
253
256
  assertNockRequest(cvFiltersScope);
254
257
  assertNockRequest(cvFiltersRuleBulkDeleteScope);
255
258
  assertNockRequest(cvRequestCallbackScope);
256
- assertNockRequest(errataScope, done);
259
+ assertNockRequest(errataScope);
260
+ done();
257
261
  act(done);
258
262
  });
259
263
 
@@ -314,7 +318,8 @@ test('Can bulk add filter rules', async (done) => {
314
318
  assertNockRequest(cvFiltersScope);
315
319
  assertNockRequest(cvFiltersRuleBulkAddScope);
316
320
  assertNockRequest(cvRequestCallbackScope);
317
- assertNockRequest(errataScope, done);
321
+ assertNockRequest(errataScope);
322
+ done();
318
323
  act(done);
319
324
  });
320
325
 
@@ -395,6 +400,7 @@ test('Can show filters and chips', async (done) => {
395
400
  assertNockRequest(errataScope); // 2nd call on status selection
396
401
  assertNockRequest(errataScope); // 3rd call on errata type selection
397
402
  assertNockRequest(errataScope); // 4th call on start date change
398
- assertNockRequest(errataScope, done); // Last call on end date change
403
+ assertNockRequest(errataScope);
404
+ done(); // Last call on end date change
399
405
  act(done);
400
406
  });
@@ -7,6 +7,7 @@
7
7
  "updated_at": "2020-12-08 09:26:11 -0500",
8
8
  "content_view": {
9
9
  "composite": false,
10
+ "rolling": false,
10
11
  "component_ids": [],
11
12
  "default": false,
12
13
  "version_count": 0,
@@ -7,6 +7,7 @@
7
7
  "updated_at": "2021-08-23 14:46:28 -0400",
8
8
  "content_view": {
9
9
  "composite": false,
10
+ "rolling": false,
10
11
  "component_ids": [],
11
12
  "default": false,
12
13
  "version_count": 4,
@@ -7,6 +7,7 @@
7
7
  "updated_at": "2021-08-23 14:46:28 -0400",
8
8
  "content_view": {
9
9
  "composite": false,
10
+ "rolling": false,
10
11
  "component_ids": [],
11
12
  "default": false,
12
13
  "version_count": 4,
@@ -19,6 +19,7 @@
19
19
  "updated_at": "2021-10-05 15:48:00 -0400",
20
20
  "content_view": {
21
21
  "composite": false,
22
+ "rolling": false,
22
23
  "component_ids": [],
23
24
  "default": false,
24
25
  "version_count": 4,
@@ -279,4 +280,4 @@
279
280
  ]
280
281
  }
281
282
  ]
282
- }
283
+ }