foreman_rh_cloud 11.2.0 → 12.0.0

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.
Files changed (67) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/foreman_rh_cloud/locale/fr/foreman_rh_cloud.js +50 -50
  3. data/app/assets/javascripts/foreman_rh_cloud/locale/ja/foreman_rh_cloud.js +52 -52
  4. data/app/assets/javascripts/foreman_rh_cloud/locale/ko/foreman_rh_cloud.js +50 -50
  5. data/app/assets/javascripts/foreman_rh_cloud/locale/zh_CN/foreman_rh_cloud.js +50 -50
  6. data/app/controllers/api/v2/rh_cloud/inventory_controller.rb +2 -2
  7. data/app/controllers/insights_cloud/api/machine_telemetries_controller.rb +2 -0
  8. data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +1 -1
  9. data/lib/foreman_inventory_upload/async/queue_for_upload_job.rb +3 -3
  10. data/lib/foreman_inventory_upload/async/upload_report_job.rb +4 -4
  11. data/lib/foreman_rh_cloud/engine.rb +1 -1
  12. data/lib/foreman_rh_cloud/version.rb +1 -1
  13. data/lib/insights_cloud/async/insights_full_sync.rb +14 -9
  14. data/lib/insights_cloud/async/insights_resolutions_sync.rb +5 -1
  15. data/locale/foreman_rh_cloud.pot +2 -2
  16. data/locale/fr/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  17. data/locale/fr/foreman_rh_cloud.po +53 -53
  18. data/locale/ja/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  19. data/locale/ja/foreman_rh_cloud.po +54 -53
  20. data/locale/ka/foreman_rh_cloud.po +1 -0
  21. data/locale/ko/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  22. data/locale/ko/foreman_rh_cloud.po +53 -52
  23. data/locale/zh_CN/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  24. data/locale/zh_CN/foreman_rh_cloud.po +53 -52
  25. data/package.json +5 -5
  26. data/test/controllers/insights_cloud/api/machine_telemetries_controller_test.rb +19 -16
  27. data/test/controllers/inventory_upload/api/inventory_controller_test.rb +1 -1
  28. data/test/jobs/insights_full_sync_test.rb +28 -0
  29. data/test/jobs/insights_resolutions_sync_test.rb +22 -0
  30. data/test/jobs/inventory_full_sync_test.rb +6 -5
  31. data/test/jobs/inventory_hosts_sync_test.rb +6 -6
  32. data/test/jobs/upload_report_job_test.rb +1 -1
  33. data/test/test_plugin_helper.rb +14 -0
  34. data/test/unit/archived_report_generator_test.rb +4 -4
  35. data/test/unit/services/foreman_rh_cloud/branch_info_test.rb +7 -6
  36. data/test/unit/slice_generator_test.rb +4 -5
  37. data/test/unit/tags_generator_test.rb +2 -12
  38. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItem/__tests__/__snapshots__/ListItem.test.js.snap +1 -7
  39. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItemStatus/__tests__/__snapshots__/ListItemStatus.test.js.snap +1 -5
  40. data/webpack/ForemanInventoryUpload/Components/AccountList/accountList.scss +3 -3
  41. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.js +1 -1
  42. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/inventoryFilter.scss +1 -1
  43. data/webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.scss +5 -5
  44. data/webpack/ForemanInventoryUpload/Components/PageHeader/PageTitle.js +5 -4
  45. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/CloudPingModal/index.js +18 -3
  46. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButton.js +0 -1
  47. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButton.test.js.snap +0 -1
  48. data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/__tests__/__snapshots__/InventoryAutoUpload.test.js.snap +2 -10
  49. data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTable.js +5 -1
  50. data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTableConstants.js +1 -1
  51. data/webpack/InsightsCloudSync/Components/InsightsTable/Pagination.js +7 -7
  52. data/webpack/InsightsCloudSync/Components/InsightsTable/table.scss +1 -1
  53. data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationModal.js +5 -1
  54. data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationTableConstants.js +8 -1
  55. data/webpack/InsightsCloudSync/Components/ToolbarDropdown.js +8 -2
  56. data/webpack/InsightsCloudSync/InsightsCloudSync.scss +1 -1
  57. data/webpack/InsightsHostDetailsTab/InsightsTotalRiskChart.js +11 -2
  58. data/webpack/InsightsHostDetailsTab/NewHostDetailsTab.js +5 -4
  59. data/webpack/common/DropdownToggle.js +2 -2
  60. data/webpack/common/Switcher/HelpLabel.js +1 -1
  61. data/webpack/common/Switcher/SwitcherPF4.scss +1 -1
  62. data/webpack/common/Switcher/__tests__/__snapshots__/HelpLabel.test.js.snap +2 -6
  63. data/webpack/common/table/EmptyState.js +25 -18
  64. metadata +3 -9
  65. data/app/assets/javascripts/foreman_rh_cloud/locale/en/foreman_rh_cloud.js +0 -589
  66. data/locale/en/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  67. data/locale/en/foreman_rh_cloud.po +0 -585
@@ -4,19 +4,20 @@
4
4
  # FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
5
5
  #
6
6
  # Translators:
7
+ # Bryan Kearney <bryan.kearney@gmail.com>, 2023
7
8
  # tim123, 2023
8
9
  # 0868a4d1af5275b3f70b0a6dac4c99a4, 2023
9
- # Bryan Kearney <bryan.kearney@gmail.com>, 2023
10
10
  # Amit Upadhye <aupadhye@redhat.com>, 2023
11
- # Ewoud Kohl van Wijngaarden <ewoud+transifex@kohlvanwijngaarden.nl>, 2023
11
+ # Ewoud Kohl van Wijngaarden <ewoud+transifex@kohlvanwijngaarden.nl>, 2025
12
12
  #
13
+ #, fuzzy
13
14
  msgid ""
14
15
  msgstr ""
15
16
  "Project-Id-Version: foreman_rh_cloud 11.1.0\n"
16
17
  "Report-Msgid-Bugs-To: \n"
17
18
  "PO-Revision-Date: 2023-01-20 13:26+0000\n"
18
19
  "Last-Translator: Ewoud Kohl van Wijngaarden <ewoud+transifex@kohlvanwijngaarde"
19
- "n.nl>, 2023\n"
20
+ "n.nl>, 2025\n"
20
21
  "Language-Team: Chinese (China) (https://app.transifex.com/foreman/teams/114/zh"
21
22
  "_CN/)\n"
22
23
  "MIME-Version: 1.0\n"
@@ -26,7 +27,7 @@ msgstr ""
26
27
  "Plural-Forms: nplurals=1; plural=0;\n"
27
28
 
28
29
  msgid " Sync all inventory status"
29
- msgstr ""
30
+ msgstr " 同步所有清单状态"
30
31
 
31
32
  msgid "%s organizations"
32
33
  msgstr "%s 机构"
@@ -53,7 +54,7 @@ msgid "Automatic inventory upload"
53
54
  msgstr "自动清单上传"
54
55
 
55
56
  msgid "Automatic mismatch deletion"
56
- msgstr ""
57
+ msgstr "自动清单删除"
57
58
 
58
59
  msgid "Cancel"
59
60
  msgstr "取消"
@@ -95,7 +96,7 @@ msgid "Configure Cloud Connector on given hosts"
95
96
  msgstr "在给定主机上配置 Cloud Connector"
96
97
 
97
98
  msgid "Configure cloud connector"
98
- msgstr ""
99
+ msgstr "配置云连接器"
99
100
 
100
101
  msgid "Connectivity test"
101
102
  msgstr "连接测试"
@@ -119,10 +120,10 @@ msgid "Download Report"
119
120
  msgstr "下载报告"
120
121
 
121
122
  msgid "Download latest report"
122
- msgstr "下载最新報告"
123
+ msgstr "下载最新的报告"
123
124
 
124
125
  msgid "Enable automatic deletion of mismatched host records from the Red Hat cloud"
125
- msgstr ""
126
+ msgstr "启用自动删除来自红帽云的主机记录"
126
127
 
127
128
  msgid "Enable automatic synchronization of Insights recommendations from the Red Hat cloud"
128
129
  msgstr "启用来自红帽云的 Insights 建议自动同步"
@@ -158,7 +159,7 @@ msgid "Exit Code: %s"
158
159
  msgstr "退出代码:%s"
159
160
 
160
161
  msgid "Fetch Insights-related host details"
161
- msgstr ""
162
+ msgstr "获取与 Insights 相关的主机详情"
162
163
 
163
164
  msgid "Fetching data about your accounts"
164
165
  msgstr "获取有关您的帐户的数据"
@@ -173,10 +174,10 @@ msgid "For more info, please visit the"
173
174
  msgstr "如需更多信息,请访问"
174
175
 
175
176
  msgid "For more information about Insights and Cloud Connector, see:"
176
- msgstr ""
177
+ msgstr "有关 Insights 和云连接器的更多信息,请参阅"
177
178
 
178
179
  msgid "For more information about the Subscriptions service, see:"
179
- msgstr ""
180
+ msgstr "有关订阅服务的更多信息,请参阅:"
180
181
 
181
182
  msgid "Foreman plugin that process & upload data to Red Hat Cloud"
182
183
  msgstr "处理数据并将其上传到红帽云的 Foreman 插件"
@@ -185,16 +186,16 @@ msgid "Full Screen"
185
186
  msgstr "全屏"
186
187
 
187
188
  msgid "Generate and upload report"
188
- msgstr ""
189
+ msgstr "生成并上传报告"
189
190
 
190
191
  msgid "Generate the report, but do not upload"
191
- msgstr ""
192
+ msgstr "生成报告,但不上传"
192
193
 
193
194
  msgid "Generating"
194
195
  msgstr "生成中"
195
196
 
196
197
  msgid "Go to Foreman Insights page"
197
- msgstr ""
198
+ msgstr "进入 Foreman Insights 页面"
198
199
 
199
200
  msgid "Go to first page"
200
201
  msgstr "前往第一页"
@@ -209,7 +210,7 @@ msgid "Go to previous page"
209
210
  msgstr "前往上一页"
210
211
 
211
212
  msgid "Grab hosts that are missing in RH Cloud"
212
- msgstr ""
213
+ msgstr "获取 RH Cloud 中缺少的主机"
213
214
 
214
215
  msgid "Host Insights recommendations"
215
216
  msgstr "主机 Insights 建议"
@@ -257,7 +258,7 @@ msgid "Knowledgebase article"
257
258
  msgstr "知识库文章"
258
259
 
259
260
  msgid "List of host UUIDs"
260
- msgstr ""
261
+ msgstr "主机 UUID 列表"
261
262
 
262
263
  msgid "Loading"
263
264
  msgstr "加载"
@@ -362,7 +363,7 @@ msgid "Recommendations synced successfully"
362
363
  msgstr "成功同步建议"
363
364
 
364
365
  msgid "Reconfigure cloud connector"
365
- msgstr ""
366
+ msgstr "重新配置云连接器"
366
367
 
367
368
  msgid "Red Hat Cloud Inventory"
368
369
  msgstr "红帽云清单"
@@ -404,7 +405,7 @@ msgid "Satellite server has %{hits_count} recommendations by Red Hat"
404
405
  msgstr "Satellite 服务器有 %{hits_count} 个红帽提供的建议"
405
406
 
406
407
  msgid "Scoped search string for host removal"
407
- msgstr ""
408
+ msgstr "用于删除主机的有范围的搜索字符串"
408
409
 
409
410
  msgid "Select recommendations from all pages"
410
411
  msgstr "在所有页面中选择建议"
@@ -422,7 +423,7 @@ msgid "Show Advanced Settings"
422
423
  msgstr "显示高级设置"
423
424
 
424
425
  msgid "Show if system is configured to use local iop-advisor-engine."
425
- msgstr ""
426
+ msgstr "显示系统是否被配置为使用本地 iop-advisor-engine。"
426
427
 
427
428
  msgid "Start inventory synchronization"
428
429
  msgstr "启动清单同步"
@@ -446,16 +447,16 @@ msgid "Synchronize recommendations Automatically"
446
447
  msgstr "自动同步建议"
447
448
 
448
449
  msgid "The Foreman inventory upload plugin automatically uploads Foreman host inventory data to the Inventory service of Insights, where it can also be used by the Subscriptions service for subscription reporting. If you use the Subscriptions service, enabling inventory uploads is required."
449
- msgstr ""
450
+ msgstr "Foreman 清单上传插件会自动将 Foreman 主机清单数据上传到 Insights 的 Inventory 服务,订阅服务使用这些信息来提供订阅报告。如果使用订阅服务,则需要启用清单上传。"
450
451
 
451
452
  msgid "The Red Hat Hybrid Cloud Console provides a set of cloud services, including Red Hat Insights and Subscriptions, that provide predictive analysis, remediation of issues, and unified subscription reporting for this Foreman instance."
452
- msgstr ""
453
+ msgstr "Red Hat Hybrid Cloud Console 提供了一组云服务,包括 Red Hat Insights 和订阅,提供预测分析、修复问题以及针对此 Foreman 实例的统一订阅报告。"
453
454
 
454
455
  msgid "The report file %{filename} doesn't exist"
455
456
  msgstr "报告文件 %{filename} 不存在"
456
457
 
457
458
  msgid "The scheduled process is disabled because this Foreman is configured with the use_local_advisor_engine option."
458
- msgstr ""
459
+ msgstr "调度的进程被禁用,因为此 Foreman 配置了 use_local_advisor_engine 选项。"
459
460
 
460
461
  msgid "The server returned the following error: %s"
461
462
  msgstr "服务器返回以下错误:%s"
@@ -464,16 +465,16 @@ msgid "The task failed with the following error:"
464
465
  msgstr "任务失败,错误为:"
465
466
 
466
467
  msgid "There are no recommendations for your hosts"
467
- msgstr ""
468
+ msgstr "没有适用于您的主机的建议"
468
469
 
469
470
  msgid "This action will also enable automatic reports upload"
470
471
  msgstr "此操作还会启用自动报告上传"
471
472
 
472
473
  msgid "To enable this reporting for all Foreman organizations, set {uploadButtonName} to on. The data will be reported automatically once per day."
473
- msgstr ""
474
+ msgstr "要为所有 Foreman 机构启用此报告,请将 {uploadButtonName} 设置为 on。数据将每天自动报告一次。"
474
475
 
475
476
  msgid "To manually upload the data for a specific organization, select an organization and click {restartButtonName}."
476
- msgstr ""
477
+ msgstr "要手动上传特定机构的数据,请选择机构并点 {restartButtonName}。"
477
478
 
478
479
  msgid "Total risk"
479
480
  msgstr "总风险"
@@ -482,13 +483,13 @@ msgid "Total risks"
482
483
  msgstr "总风险"
483
484
 
484
485
  msgid "Upload hits from iop-advisor-engine"
485
- msgstr ""
486
+ msgstr "从 iop-advisor-engine 上传 hits"
486
487
 
487
488
  msgid "Upload hits information"
488
- msgstr ""
489
+ msgstr "上传 hits 信息"
489
490
 
490
491
  msgid "Upload rules related to the hits"
491
- msgstr ""
492
+ msgstr "上传与 hits 相关的 rule"
492
493
 
493
494
  msgid "Uploading"
494
495
  msgstr "上载中"
@@ -506,85 +507,85 @@ msgid "Wait and %s"
506
507
  msgstr "等待和 %s"
507
508
 
508
509
  msgid "Whether the resolution requires reboot"
509
- msgstr ""
510
+ msgstr "resolution 是否需要重启"
510
511
 
511
512
  msgid "category name"
512
- msgstr ""
513
+ msgstr "类别名称"
513
514
 
514
515
  msgid "generic"
515
- msgstr ""
516
+ msgstr "通用"
516
517
 
517
518
  msgid "hosts page"
518
519
  msgstr "主机页"
519
520
 
520
521
  msgid "impact name"
521
- msgstr ""
522
+ msgstr "影响名称"
522
523
 
523
524
  msgid "iop payload including resolutions, rules, hits"
524
- msgstr ""
525
+ msgstr "IOP 有效负载,包括 resolutions, rules, hits"
525
526
 
526
527
  msgid "items"
527
528
  msgstr "项"
528
529
 
529
530
  msgid "likelihood number"
530
- msgstr ""
531
+ msgstr "可能性号"
531
532
 
532
533
  msgid "more info"
533
- msgstr ""
534
+ msgstr "更多信息"
534
535
 
535
536
  msgid "page"
536
- msgstr "page"
537
+ msgstr ""
537
538
 
538
539
  msgid "per page"
539
540
  msgstr "每页"
540
541
 
541
542
  msgid "publish date (YYYY-MM-DD)"
542
- msgstr ""
543
+ msgstr "发布日期 (YYYY-MM-DD)"
543
544
 
544
545
  msgid "rating"
545
- msgstr ""
546
+ msgstr "评级"
546
547
 
547
548
  msgid "reason"
548
- msgstr ""
549
+ msgstr "原因"
549
550
 
550
551
  msgid "reboot required"
551
- msgstr ""
552
+ msgstr "需要重启"
552
553
 
553
554
  msgid "resolution description"
554
- msgstr ""
555
+ msgstr "resolution 描述"
555
556
 
556
557
  msgid "resolution risk"
557
- msgstr ""
558
+ msgstr "resolution 风险"
558
559
 
559
560
  msgid "result url"
560
- msgstr ""
561
+ msgstr "结果 url"
561
562
 
562
563
  msgid "rule description"
563
- msgstr ""
564
+ msgstr "rule 描述"
564
565
 
565
566
  msgid "rule id"
566
- msgstr ""
567
+ msgstr "rule id"
567
568
 
568
569
  msgid "rule title"
569
- msgstr ""
570
+ msgstr "rule 标题"
570
571
 
571
572
  msgid "solution url"
572
- msgstr ""
573
+ msgstr "solution url"
573
574
 
574
575
  msgid "summary"
575
- msgstr ""
576
+ msgstr "摘要"
576
577
 
577
578
  msgid "total risk"
578
- msgstr ""
579
+ msgstr "总风险"
579
580
 
580
581
  msgid "type"
581
- msgstr ""
582
+ msgstr "类型"
582
583
 
583
584
  msgid "upload hits details json"
584
- msgstr ""
585
+ msgstr "上传 hits 详情 json"
585
586
 
586
587
  msgid "upload resolutions related to the hits"
587
- msgstr ""
588
+ msgstr "上传与 hits 相关的 resolutions"
588
589
 
589
590
  msgid "view the job in progress"
590
591
  msgstr "查看正在进行中的任务"
data/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "foreman_rh_cloud",
3
- "version": "11.2.0",
3
+ "version": "12.0.0",
4
4
  "description": "Inventory Upload =============",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -19,13 +19,13 @@
19
19
  "url": "http://projects.theforeman.org/projects/foreman_rh_cloud/issues"
20
20
  },
21
21
  "peerDependencies": {
22
- "@theforeman/vendor": ">= 10.1.1"
22
+ "@theforeman/vendor": ">= 15.0.1"
23
23
  },
24
24
  "devDependencies": {
25
25
  "@babel/core": "^7.7.0",
26
- "@theforeman/builder": ">= 10.1.1",
27
- "@theforeman/test": ">= 10.1.1",
28
- "@theforeman/eslint-plugin-foreman": ">= 10.1.1",
26
+ "@theforeman/builder": ">= 15.0.1",
27
+ "@theforeman/test": ">= 15.0.1",
28
+ "@theforeman/eslint-plugin-foreman": ">= 15.0.1",
29
29
  "babel-eslint": "~10.0.0",
30
30
  "eslint": "~6.7.2",
31
31
  "eslint-plugin-spellcheck": "~0.0.17",
@@ -1,7 +1,10 @@
1
1
  require 'test_plugin_helper'
2
+ require 'rest-client'
2
3
 
3
4
  module InsightsCloud::Api
4
5
  class MachineTelemetriesControllerTest < ActionController::TestCase
6
+ include KatelloCVEHelper
7
+
5
8
  setup do
6
9
  FactoryBot.create(:common_parameter, name: InsightsCloud.enable_client_param, key_type: 'boolean', value: true)
7
10
  end
@@ -33,6 +36,18 @@ module InsightsCloud::Api
33
36
  assert_equal @body, @response.body
34
37
  end
35
38
 
39
+ test "should handle timeout from cloud" do
40
+ ::ForemanRhCloud::CloudRequestForwarder.any_instance.
41
+ stubs(:forward_request).
42
+ raises(RestClient::Exceptions::OpenTimeout.new("Timed out connecting to server"))
43
+
44
+ get :forward_request, params: { "path" => "platform/module-update-router/v1/channel" }
45
+ request_response = JSON.parse(@response.body)
46
+ # I can't get @response.status to take a nil value so I'm not asserting for that
47
+
48
+ assert_equal 'Timed out connecting to server', request_response['error']
49
+ end
50
+
36
51
  test "should respond with the same content type" do
37
52
  net_http_resp = Net::HTTPResponse.new(1.0, 200, "OK")
38
53
  net_http_resp.add_field 'Set-Cookie', 'Monster'
@@ -109,9 +124,8 @@ module InsightsCloud::Api
109
124
  setup do
110
125
  UpstreamOnlySettingsTestHelper.set_if_available('allow_multiple_content_views')
111
126
  User.current = User.find_by(login: 'secret_admin')
112
-
113
- @env = FactoryBot.create(:katello_k_t_environment)
114
- @env2 = FactoryBot.create(:katello_k_t_environment, organization: @env.organization)
127
+ env = FactoryBot.create(:katello_k_t_environment)
128
+ env2 = FactoryBot.create(:katello_k_t_environment, organization: env.organization)
115
129
 
116
130
  @host = FactoryBot.create(
117
131
  :host,
@@ -119,19 +133,8 @@ module InsightsCloud::Api
119
133
  :with_content,
120
134
  :with_hostgroup,
121
135
  :with_parameter,
122
- content_view_environments: [
123
- FactoryBot.create(
124
- :katello_content_view_environment,
125
- content_view: FactoryBot.create(:katello_content_view, organization: @env.organization),
126
- lifecycle_environment: @env
127
- ),
128
- FactoryBot.create(
129
- :katello_content_view_environment,
130
- content_view: FactoryBot.create(:katello_content_view, organization: @env.organization),
131
- lifecycle_environment: @env2
132
- ),
133
- ],
134
- organization: @env.organization
136
+ content_view_environments: [make_cve(lifecycle_environment: env), make_cve(lifecycle_environment: env2)],
137
+ organization: env.organization
135
138
  )
136
139
 
137
140
  @host.subscription_facet.pools << FactoryBot.create(:katello_pool, account_number: '5678', cp_id: 1)
@@ -14,7 +14,7 @@ module InventoryUpload::Api
14
14
  .expects(:start_report_generation)
15
15
  .with(@test_org.id.to_s, @disconnected)
16
16
 
17
- post :generate_report, params: { organization_id: @test_org.id, disconnected: @disconnected }
17
+ post :generate_report, params: { organization_id: @test_org.id, no_upload: @disconnected }
18
18
 
19
19
  assert_response :success
20
20
  end
@@ -65,6 +65,8 @@ class InsightsFullSyncTest < ActiveSupport::TestCase
65
65
  end
66
66
 
67
67
  test 'Hits data is replaced with data from cloud' do
68
+ Organization.any_instance.stubs(:manifest_expired?).returns(false)
69
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
68
70
  InsightsCloud::Async::InsightsFullSync.any_instance.expects(:query_insights_hits).returns(@hits)
69
71
 
70
72
  InsightsCloud::Async::InsightsFullSync.any_instance.expects(:plan_hosts_sync)
@@ -79,7 +81,31 @@ class InsightsFullSyncTest < ActiveSupport::TestCase
79
81
  assert_equal 1, @host2.insights.hits.count
80
82
  end
81
83
 
84
+ test 'Manifest is expired do not run task steps' do
85
+ Organization.any_instance.stubs(:manifest_expired?).returns(true)
86
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
87
+
88
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:query_insights_hits).never
89
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:plan_hosts_sync).never
90
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:plan_self).never
91
+
92
+ ForemanTasks.sync_task(InsightsCloud::Async::InsightsFullSync, [@host1.organization])
93
+ end
94
+
95
+ test 'Manifest is deleted do not run task steps' do
96
+ Organization.any_instance.stubs(:manifest_expired?).returns(false)
97
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(false)
98
+
99
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:query_insights_hits).never
100
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:plan_hosts_sync).never
101
+ InsightsCloud::Async::InsightsFullSync.any_instance.expects(:plan_self).never
102
+
103
+ ForemanTasks.sync_task(InsightsCloud::Async::InsightsFullSync, [@host1.organization])
104
+ end
105
+
82
106
  test 'Hits counters are reset correctly' do
107
+ Organization.any_instance.stubs(:manifest_expired?).returns(false)
108
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
83
109
  InsightsCloud::Async::InsightsFullSync.any_instance.expects(:query_insights_hits).returns(@hits).twice
84
110
 
85
111
  InsightsCloud::Async::InsightsFullSync.any_instance.stubs(:plan_hosts_sync)
@@ -97,6 +123,8 @@ class InsightsFullSyncTest < ActiveSupport::TestCase
97
123
  end
98
124
 
99
125
  test 'Hits ignoring non-existent hosts' do
126
+ Organization.any_instance.stubs(:manifest_expired?).returns(false)
127
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
100
128
  hits_json = <<-HITS_JSON
101
129
  [
102
130
  {
@@ -73,6 +73,7 @@ class InsightsResolutionsSyncTest < ActiveSupport::TestCase
73
73
  end
74
74
 
75
75
  test 'Resolutions data is replaced with data from cloud' do
76
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
76
77
  InsightsCloud::Async::InsightsResolutionsSync.any_instance.stubs(:query_insights_resolutions).returns(@resolutions)
77
78
 
78
79
  ForemanTasks.sync_task(InsightsCloud::Async::InsightsResolutionsSync)
@@ -82,7 +83,28 @@ class InsightsResolutionsSyncTest < ActiveSupport::TestCase
82
83
  assert_equal 2, @rule.resolutions.count
83
84
  end
84
85
 
86
+ test 'Manifest is deleted do not run task steps' do
87
+ Organization.any_instance.stubs(:manifest_expired?).returns(false)
88
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(false)
89
+ InsightsCloud::Async::InsightsResolutionsSync.any_instance.expects(:query_insights_resolutions).never
90
+
91
+ ForemanTasks.sync_task(InsightsCloud::Async::InsightsResolutionsSync)
92
+
93
+ assert_equal 0, InsightsResolution.all.count
94
+ end
95
+
96
+ test 'Manifest is expired do not run task steps' do
97
+ Organization.any_instance.stubs(:manifest_expired?).returns(true)
98
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
99
+ InsightsCloud::Async::InsightsResolutionsSync.any_instance.expects(:query_insights_resolutions).never
100
+
101
+ ForemanTasks.sync_task(InsightsCloud::Async::InsightsResolutionsSync)
102
+
103
+ assert_equal 0, InsightsResolution.all.count
104
+ end
105
+
85
106
  test 'Skips pinging the cloud if no rule ids were found' do
107
+ Katello::UpstreamConnectionChecker.any_instance.stubs(:can_connect?).returns(true)
86
108
  InsightsCloud::Async::InsightsResolutionsSync.any_instance.expects(:query_insights_resolutions).never
87
109
  InsightsRule.all.delete_all
88
110
 
@@ -4,6 +4,7 @@ require 'foreman_tasks/test_helpers'
4
4
  class InventoryFullSyncTest < ActiveSupport::TestCase
5
5
  include ForemanTasks::TestHelpers::WithInThreadExecutor
6
6
  include MockCerts
7
+ include KatelloCVEHelper
7
8
 
8
9
  setup do
9
10
  User.current = User.find_by(login: 'secret_admin')
@@ -11,15 +12,15 @@ class InventoryFullSyncTest < ActiveSupport::TestCase
11
12
  InventorySync::Async::InventoryFullSync.any_instance.stubs(:plan_self_host_sync)
12
13
  Organization.any_instance.stubs(:manifest_expired?).returns(false)
13
14
 
14
- env = FactoryBot.create(:katello_k_t_environment)
15
- cv = env.content_views << FactoryBot.create(:katello_content_view, organization: env.organization)
15
+ cve = make_cve
16
+ env = cve.lifecycle_environment
16
17
 
17
18
  # this host would pass our plugin queries, so it could be uploaded to the cloud.
18
19
  @host1 = FactoryBot.create(
19
20
  :host,
20
21
  :with_subscription,
21
22
  :with_content,
22
- content_view: cv.first,
23
+ content_view: cve.content_view,
23
24
  lifecycle_environment: env,
24
25
  organization: env.organization
25
26
  )
@@ -33,7 +34,7 @@ class InventoryFullSyncTest < ActiveSupport::TestCase
33
34
  :host,
34
35
  :with_subscription,
35
36
  :with_content,
36
- content_view: cv.first,
37
+ content_view: cve.content_view,
37
38
  lifecycle_environment: env,
38
39
  organization: env.organization
39
40
  )
@@ -46,7 +47,7 @@ class InventoryFullSyncTest < ActiveSupport::TestCase
46
47
  :host,
47
48
  :with_subscription,
48
49
  :with_content,
49
- content_view: cv.first,
50
+ content_view: cve.content_view,
50
51
  lifecycle_environment: env,
51
52
  organization: env.organization
52
53
  )
@@ -4,19 +4,19 @@ require 'foreman_tasks/test_helpers'
4
4
  class InventoryHostsSyncTest < ActiveSupport::TestCase
5
5
  include ForemanTasks::TestHelpers::WithInThreadExecutor
6
6
  include MockCerts
7
+ include KatelloCVEHelper
7
8
 
8
9
  setup do
9
10
  User.current = User.find_by(login: 'secret_admin')
10
-
11
- env = FactoryBot.create(:katello_k_t_environment)
12
- cv = env.content_views << FactoryBot.create(:katello_content_view, organization: env.organization)
13
-
11
+ cve = make_cve
12
+ env = cve.lifecycle_environment
13
+ cv = cve.content_view
14
14
  # this host would pass our plugin queries, so it could be uploaded to the cloud.
15
15
  @host1 = FactoryBot.create(
16
16
  :host,
17
17
  :with_subscription,
18
18
  :with_content,
19
- content_view: cv.first,
19
+ content_view: cv,
20
20
  lifecycle_environment: env,
21
21
  organization: env.organization
22
22
  )
@@ -30,7 +30,7 @@ class InventoryHostsSyncTest < ActiveSupport::TestCase
30
30
  :host,
31
31
  :with_subscription,
32
32
  :with_content,
33
- content_view: cv.first,
33
+ content_view: cv,
34
34
  lifecycle_environment: env,
35
35
  organization: env.organization
36
36
  )
@@ -18,7 +18,7 @@ class UploadReportJobTest < ActiveSupport::TestCase
18
18
 
19
19
  label = ForemanInventoryUpload::Async::UploadReportJob.output_label(organization.id)
20
20
  progress_output = ForemanInventoryUpload::Async::ProgressOutput.get(label)
21
- assert_match(/Upload was stopped/, progress_output.full_output)
21
+ assert_match(/Upload canceled/, progress_output.full_output)
22
22
  assert_match(/exit 1/, progress_output.status)
23
23
  end
24
24
 
@@ -118,6 +118,20 @@ module CandlepinIsolation
118
118
  end
119
119
  end
120
120
 
121
+ module KatelloCVEHelper
122
+ def make_cve(lifecycle_environment: nil, content_view: nil)
123
+ env = lifecycle_environment || FactoryBot.create(:katello_k_t_environment)
124
+ content_view ||= FactoryBot.create(:katello_content_view, organization: env.organization)
125
+ cvv = ::Katello::ContentViewVersion.create!(:major => 2, :content_view => content_view)
126
+ FactoryBot.create(
127
+ :katello_content_view_environment,
128
+ content_view_version: cvv,
129
+ content_view: content_view,
130
+ lifecycle_environment: env
131
+ )
132
+ end
133
+ end
134
+
121
135
  module UpstreamOnlySettingsTestHelper
122
136
  def self.set_if_available(setting_name, value: true)
123
137
  Setting[setting_name] = value
@@ -2,18 +2,18 @@ require 'test_plugin_helper'
2
2
 
3
3
  class ArchivedReportGeneratorTest < ActiveSupport::TestCase
4
4
  include MockForemanHostname
5
+ include KatelloCVEHelper
5
6
 
6
7
  setup do
7
8
  User.current = User.find_by(login: 'secret_admin')
8
-
9
- env = FactoryBot.create(:katello_k_t_environment)
10
- cv = env.content_views << FactoryBot.create(:katello_content_view, organization: env.organization)
9
+ cve = make_cve
10
+ env = cve.lifecycle_environment
11
11
 
12
12
  @host = FactoryBot.create(
13
13
  :host,
14
14
  :with_subscription,
15
15
  :with_content,
16
- content_view: cv.first,
16
+ content_view: cve.content_view,
17
17
  lifecycle_environment: env,
18
18
  organization: env.organization
19
19
  )
@@ -1,21 +1,22 @@
1
1
  require 'test_plugin_helper'
2
2
 
3
3
  class BranchInfoTest < ActiveSupport::TestCase
4
+ include KatelloCVEHelper
5
+
4
6
  setup do
5
7
  User.current = User.find_by(login: 'secret_admin')
6
8
 
7
- @env = FactoryBot.create(:katello_k_t_environment)
8
- cv = @env.content_views << FactoryBot.create(:katello_content_view, organization: @env.organization)
9
-
9
+ cve = make_cve
10
+ env = cve.lifecycle_environment
10
11
  @host = FactoryBot.create(
11
12
  :host,
12
13
  :with_subscription,
13
14
  :with_content,
14
15
  :with_hostgroup,
15
16
  :with_parameter,
16
- content_view: cv.first,
17
- lifecycle_environment: @env,
18
- organization: @env.organization
17
+ content_view: cve.content_view,
18
+ lifecycle_environment: env,
19
+ organization: env.organization
19
20
  )
20
21
 
21
22
  @host.subscription_facet.pools << FactoryBot.create(:katello_pool, account_number: '5678', cp_id: 1)