foreman_rh_cloud 11.1.0 → 11.3.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 (47) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/foreman_rh_cloud/locale/fr/foreman_rh_cloud.js +400 -313
  3. data/app/assets/javascripts/foreman_rh_cloud/locale/ja/foreman_rh_cloud.js +400 -313
  4. data/app/assets/javascripts/foreman_rh_cloud/locale/ka/foreman_rh_cloud.js +393 -306
  5. data/app/assets/javascripts/foreman_rh_cloud/locale/ko/foreman_rh_cloud.js +589 -0
  6. data/app/assets/javascripts/foreman_rh_cloud/locale/zh_CN/foreman_rh_cloud.js +398 -311
  7. data/app/controllers/insights_cloud/api/machine_telemetries_controller.rb +11 -1
  8. data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +5 -3
  9. data/app/services/foreman_rh_cloud/hits_uploader.rb +3 -8
  10. data/app/services/foreman_rh_cloud/rules_ingester.rb +61 -0
  11. data/app/services/foreman_rh_cloud/template_renderer_helper.rb +1 -1
  12. data/config/routes.rb +10 -4
  13. data/db/seeds.d/189_add_host_inventory_param.rb +7 -0
  14. data/lib/foreman_inventory_upload/async/upload_report_job.rb +1 -1
  15. data/lib/foreman_inventory_upload/generators/queries.rb +1 -1
  16. data/lib/foreman_rh_cloud/engine.rb +1 -1
  17. data/lib/foreman_rh_cloud/version.rb +1 -1
  18. data/lib/insights_cloud/async/insights_full_sync.rb +14 -9
  19. data/lib/insights_cloud/async/insights_resolutions_sync.rb +5 -1
  20. data/lib/insights_cloud.rb +4 -0
  21. data/lib/tasks/insights.rake +10 -7
  22. data/lib/tasks/rh_cloud_inventory.rake +8 -3
  23. data/locale/Makefile +12 -2
  24. data/locale/foreman_rh_cloud.pot +217 -96
  25. data/locale/fr/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  26. data/locale/fr/foreman_rh_cloud.po +123 -36
  27. data/locale/ja/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  28. data/locale/ja/foreman_rh_cloud.po +124 -36
  29. data/locale/ka/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  30. data/locale/ka/foreman_rh_cloud.po +107 -19
  31. data/locale/ko/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  32. data/locale/ko/foreman_rh_cloud.po +592 -0
  33. data/locale/zh_CN/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  34. data/locale/zh_CN/foreman_rh_cloud.po +123 -35
  35. data/package.json +1 -1
  36. data/test/controllers/insights_cloud/api/machine_telemetries_controller_test.rb +13 -0
  37. data/test/jobs/insights_full_sync_test.rb +28 -0
  38. data/test/jobs/insights_resolutions_sync_test.rb +22 -0
  39. data/test/unit/services/foreman_rh_cloud/cloud_request_forwarder_test.rb +24 -0
  40. data/test/unit/services/foreman_rh_cloud/hits_uploader_test.rb +13 -2
  41. data/test/unit/services/foreman_rh_cloud/rules_ingester_test.rb +60 -0
  42. data/test/unit/slice_generator_test.rb +24 -2
  43. data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationModal.js +5 -1
  44. metadata +10 -6
  45. data/app/assets/javascripts/foreman_rh_cloud/locale/en/foreman_rh_cloud.js +0 -502
  46. data/locale/en/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  47. data/locale/en/foreman_rh_cloud.po +0 -496
@@ -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
- "Project-Id-Version: foreman_rh_cloud 1.0.0\n"
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"
@@ -25,8 +26,8 @@ msgstr ""
25
26
  "Language: zh_CN\n"
26
27
  "Plural-Forms: nplurals=1; plural=0;\n"
27
28
 
28
- msgid " Sync inventory status"
29
- msgstr " 同步清单状态"
29
+ msgid " Sync all inventory status"
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 "取消"
@@ -91,12 +92,12 @@ msgstr "完成"
91
92
  msgid "Configure"
92
93
  msgstr "配置"
93
94
 
94
- msgid "Configure Cloud Connector"
95
- msgstr "配置云连接器"
96
-
97
95
  msgid "Configure Cloud Connector on given hosts"
98
96
  msgstr "在给定主机上配置 Cloud Connector"
99
97
 
98
+ msgid "Configure cloud connector"
99
+ msgstr "配置云连接器"
100
+
100
101
  msgid "Connectivity test"
101
102
  msgstr "连接测试"
102
103
 
@@ -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 建议自动同步"
@@ -157,6 +158,9 @@ msgstr "排除软件包上传到红帽云"
157
158
  msgid "Exit Code: %s"
158
159
  msgstr "退出代码:%s"
159
160
 
161
+ msgid "Fetch Insights-related host details"
162
+ msgstr "获取与 Insights 相关的主机详情"
163
+
160
164
  msgid "Fetching data about your accounts"
161
165
  msgstr "获取有关您的帐户的数据"
162
166
 
@@ -170,10 +174,10 @@ msgid "For more info, please visit the"
170
174
  msgstr "如需更多信息,请访问"
171
175
 
172
176
  msgid "For more information about Insights and Cloud Connector, see:"
173
- msgstr ""
177
+ msgstr "有关 Insights 和云连接器的更多信息,请参阅"
174
178
 
175
179
  msgid "For more information about the Subscriptions service, see:"
176
- msgstr ""
180
+ msgstr "有关订阅服务的更多信息,请参阅:"
177
181
 
178
182
  msgid "Foreman plugin that process & upload data to Red Hat Cloud"
179
183
  msgstr "处理数据并将其上传到红帽云的 Foreman 插件"
@@ -181,14 +185,17 @@ msgstr "处理数据并将其上传到红帽云的 Foreman 插件"
181
185
  msgid "Full Screen"
182
186
  msgstr "全屏"
183
187
 
188
+ msgid "Generate and upload report"
189
+ msgstr "生成并上传报告"
190
+
184
191
  msgid "Generate the report, but do not upload"
185
- msgstr ""
192
+ msgstr "生成报告,但不上传"
186
193
 
187
194
  msgid "Generating"
188
195
  msgstr "生成中"
189
196
 
190
- msgid "Go to Satellite Insights page"
191
- msgstr "进入 Satellite Insights 页面"
197
+ msgid "Go to Foreman Insights page"
198
+ msgstr "进入 Foreman Insights 页面"
192
199
 
193
200
  msgid "Go to first page"
194
201
  msgstr "前往第一页"
@@ -203,7 +210,7 @@ msgid "Go to previous page"
203
210
  msgstr "前往上一页"
204
211
 
205
212
  msgid "Grab hosts that are missing in RH Cloud"
206
- msgstr ""
213
+ msgstr "获取 RH Cloud 中缺少的主机"
207
214
 
208
215
  msgid "Host Insights recommendations"
209
216
  msgstr "主机 Insights 建议"
@@ -229,9 +236,6 @@ msgstr "在 insights-client 报告中包含参数"
229
236
  msgid "Insights"
230
237
  msgstr "Insights"
231
238
 
232
- msgid "Insights synchronization process is used to provide Insights recommendations output for hosts managed here."
233
- msgstr "Insights 同步过程用于为此处管理的主机提供 Insights 建议输出。"
234
-
235
239
  msgid "Inventory"
236
240
  msgstr "清单"
237
241
 
@@ -253,6 +257,9 @@ msgstr "每页的项"
253
257
  msgid "Knowledgebase article"
254
258
  msgstr "知识库文章"
255
259
 
260
+ msgid "List of host UUIDs"
261
+ msgstr "主机 UUID 列表"
262
+
256
263
  msgid "Loading"
257
264
  msgstr "加载"
258
265
 
@@ -355,7 +362,7 @@ msgstr "选择的建议:%s。"
355
362
  msgid "Recommendations synced successfully"
356
363
  msgstr "成功同步建议"
357
364
 
358
- msgid "Reconfigure Cloud Connector"
365
+ msgid "Reconfigure cloud connector"
359
366
  msgstr "重新配置云连接器"
360
367
 
361
368
  msgid "Red Hat Cloud Inventory"
@@ -385,9 +392,6 @@ msgstr "报告"
385
392
  msgid "Resolution"
386
393
  msgstr "解决方案"
387
394
 
388
- msgid "Restart"
389
- msgstr "重新开始"
390
-
391
395
  msgid "Run RH Cloud playbook"
392
396
  msgstr "运行 RH Cloud playbook"
393
397
 
@@ -401,7 +405,7 @@ msgid "Satellite server has %{hits_count} recommendations by Red Hat"
401
405
  msgstr "Satellite 服务器有 %{hits_count} 个红帽提供的建议"
402
406
 
403
407
  msgid "Scoped search string for host removal"
404
- msgstr ""
408
+ msgstr "用于删除主机的有范围的搜索字符串"
405
409
 
406
410
  msgid "Select recommendations from all pages"
407
411
  msgstr "在所有页面中选择建议"
@@ -418,6 +422,9 @@ msgstr "应从 Foreman 导入包含参数标签?"
418
422
  msgid "Show Advanced Settings"
419
423
  msgstr "显示高级设置"
420
424
 
425
+ msgid "Show if system is configured to use local iop-advisor-engine."
426
+ msgstr "显示系统是否被配置为使用本地 iop-advisor-engine。"
427
+
421
428
  msgid "Start inventory synchronization"
422
429
  msgstr "启动清单同步"
423
430
 
@@ -439,15 +446,18 @@ msgstr "同步建议"
439
446
  msgid "Synchronize recommendations Automatically"
440
447
  msgstr "自动同步建议"
441
448
 
442
- 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 Satellite instance."
443
- msgstr ""
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."
450
+ msgstr "Foreman 清单上传插件会自动将 Foreman 主机清单数据上传到 Insights 的 Inventory 服务,订阅服务使用这些信息来提供订阅报告。如果使用订阅服务,则需要启用清单上传。"
444
451
 
445
- msgid "The Satellite inventory upload plugin automatically uploads Satellite 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."
446
- msgstr ""
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."
453
+ msgstr "Red Hat Hybrid Cloud Console 提供了一组云服务,包括 Red Hat Insights 和订阅,提供预测分析、修复问题以及针对此 Foreman 实例的统一订阅报告。"
447
454
 
448
455
  msgid "The report file %{filename} doesn't exist"
449
456
  msgstr "报告文件 %{filename} 不存在"
450
457
 
458
+ msgid "The scheduled process is disabled because this Foreman is configured with the use_local_advisor_engine option."
459
+ msgstr "调度的进程被禁用,因为此 Foreman 配置了 use_local_advisor_engine 选项。"
460
+
451
461
  msgid "The server returned the following error: %s"
452
462
  msgstr "服务器返回以下错误:%s"
453
463
 
@@ -455,16 +465,16 @@ msgid "The task failed with the following error:"
455
465
  msgstr "任务失败,错误为:"
456
466
 
457
467
  msgid "There are no recommendations for your hosts"
458
- msgstr ""
468
+ msgstr "没有适用于您的主机的建议"
459
469
 
460
470
  msgid "This action will also enable automatic reports upload"
461
471
  msgstr "此操作还会启用自动报告上传"
462
472
 
463
- msgid "To enable this reporting for all Satellite organizations, set {uploadButtonName} to on. The data will be reported automatically once per day."
464
- msgstr ""
473
+ msgid "To enable this reporting for all Foreman organizations, set {uploadButtonName} to on. The data will be reported automatically once per day."
474
+ msgstr "要为所有 Foreman 机构启用此报告,请将 {uploadButtonName} 设置为 on。数据将每天自动报告一次。"
465
475
 
466
476
  msgid "To manually upload the data for a specific organization, select an organization and click {restartButtonName}."
467
- msgstr ""
477
+ msgstr "要手动上传特定机构的数据,请选择机构并点 {restartButtonName}。"
468
478
 
469
479
  msgid "Total risk"
470
480
  msgstr "总风险"
@@ -472,6 +482,15 @@ msgstr "总风险"
472
482
  msgid "Total risks"
473
483
  msgstr "总风险"
474
484
 
485
+ msgid "Upload hits from iop-advisor-engine"
486
+ msgstr "从 iop-advisor-engine 上传 hits"
487
+
488
+ msgid "Upload hits information"
489
+ msgstr "上传 hits 信息"
490
+
491
+ msgid "Upload rules related to the hits"
492
+ msgstr "上传与 hits 相关的 rule"
493
+
475
494
  msgid "Uploading"
476
495
  msgstr "上载中"
477
496
 
@@ -487,18 +506,87 @@ msgstr "禁用 Red Hat Insights"
487
506
  msgid "Wait and %s"
488
507
  msgstr "等待和 %s"
489
508
 
509
+ msgid "Whether the resolution requires reboot"
510
+ msgstr "resolution 是否需要重启"
511
+
512
+ msgid "category name"
513
+ msgstr "类别名称"
514
+
515
+ msgid "generic"
516
+ msgstr "通用"
517
+
490
518
  msgid "hosts page"
491
519
  msgstr "主机页"
492
520
 
521
+ msgid "impact name"
522
+ msgstr "影响名称"
523
+
524
+ msgid "iop payload including resolutions, rules, hits"
525
+ msgstr "IOP 有效负载,包括 resolutions, rules, hits"
526
+
493
527
  msgid "items"
494
528
  msgstr "项"
495
529
 
530
+ msgid "likelihood number"
531
+ msgstr "可能性号"
532
+
533
+ msgid "more info"
534
+ msgstr "更多信息"
535
+
496
536
  msgid "page"
497
- msgstr "page"
537
+ msgstr ""
498
538
 
499
539
  msgid "per page"
500
540
  msgstr "每页"
501
541
 
542
+ msgid "publish date (YYYY-MM-DD)"
543
+ msgstr "发布日期 (YYYY-MM-DD)"
544
+
545
+ msgid "rating"
546
+ msgstr "评级"
547
+
548
+ msgid "reason"
549
+ msgstr "原因"
550
+
551
+ msgid "reboot required"
552
+ msgstr "需要重启"
553
+
554
+ msgid "resolution description"
555
+ msgstr "resolution 描述"
556
+
557
+ msgid "resolution risk"
558
+ msgstr "resolution 风险"
559
+
560
+ msgid "result url"
561
+ msgstr "结果 url"
562
+
563
+ msgid "rule description"
564
+ msgstr "rule 描述"
565
+
566
+ msgid "rule id"
567
+ msgstr "rule id"
568
+
569
+ msgid "rule title"
570
+ msgstr "rule 标题"
571
+
572
+ msgid "solution url"
573
+ msgstr "solution url"
574
+
575
+ msgid "summary"
576
+ msgstr "摘要"
577
+
578
+ msgid "total risk"
579
+ msgstr "总风险"
580
+
581
+ msgid "type"
582
+ msgstr "类型"
583
+
584
+ msgid "upload hits details json"
585
+ msgstr "上传 hits 详情 json"
586
+
587
+ msgid "upload resolutions related to the hits"
588
+ msgstr "上传与 hits 相关的 resolutions"
589
+
502
590
  msgid "view the job in progress"
503
591
  msgstr "查看正在进行中的任务"
504
592
 
data/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "foreman_rh_cloud",
3
- "version": "11.1.0",
3
+ "version": "11.3.0",
4
4
  "description": "Inventory Upload =============",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -1,4 +1,5 @@
1
1
  require 'test_plugin_helper'
2
+ require 'rest-client'
2
3
 
3
4
  module InsightsCloud::Api
4
5
  class MachineTelemetriesControllerTest < ActionController::TestCase
@@ -33,6 +34,18 @@ module InsightsCloud::Api
33
34
  assert_equal @body, @response.body
34
35
  end
35
36
 
37
+ test "should handle timeout from cloud" do
38
+ ::ForemanRhCloud::CloudRequestForwarder.any_instance.
39
+ stubs(:forward_request).
40
+ raises(RestClient::Exceptions::OpenTimeout.new("Timed out connecting to server"))
41
+
42
+ get :forward_request, params: { "path" => "platform/module-update-router/v1/channel" }
43
+ request_response = JSON.parse(@response.body)
44
+ # I can't get @response.status to take a nil value so I'm not asserting for that
45
+
46
+ assert_equal 'Timed out connecting to server', request_response['error']
47
+ end
48
+
36
49
  test "should respond with the same content type" do
37
50
  net_http_resp = Net::HTTPResponse.new(1.0, 200, "OK")
38
51
  net_http_resp.add_field 'Set-Cookie', 'Monster'
@@ -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
 
@@ -112,6 +112,30 @@ class CloudRequestForwarderTest < ActiveSupport::TestCase
112
112
  assert_equal params.merge(:branch_id => 74), @forwarder.prepare_forward_params(req, 74)
113
113
  end
114
114
 
115
+ test 'should NOT add branch id into forwarded params for compliance urls' do
116
+ user_agent = { :foo => :bar }
117
+ params = { :page => 5, :per_page => 42 }
118
+
119
+ uris = [
120
+ "/redhat_access/r/insights/platform/compliance/v2/systems/MyUUID/policies",
121
+ "/redhat_access/r/insights/platform/compliance/v2/policies/MyUUID",
122
+ "/redhat_access/r/insights/platform/compliance/v2/systems/MyUUID",
123
+ "/redhat_access/r/insights/platform/compliance/v2/policies",
124
+ "/redhat_access/r/insights/platform/compliance/v2/",
125
+ ]
126
+ uris.each do |uri|
127
+ req = ActionDispatch::Request.new(
128
+ 'REQUEST_URI' => uri,
129
+ 'REQUEST_METHOD' => 'GET',
130
+ 'HTTP_USER_AGENT' => user_agent,
131
+ 'rack.input' => ::Puma::NullIO.new,
132
+ 'action_dispatch.request.query_parameters' => params
133
+ )
134
+ req.stubs(:path).returns(uri)
135
+ refute @forwarder.prepare_forward_params(req, 74).key?(:branch_id), "Branch id should not be added for #{uri}"
136
+ end
137
+ end
138
+
115
139
  test 'should reuse BranchInfo identifiers for user_agent' do
116
140
  user_agent = { :foo => :bar }
117
141
  params = { :page => 5, :per_page => 42 }
@@ -72,8 +72,11 @@ class HitsUploaderTest < ActiveSupport::TestCase
72
72
  setup do
73
73
  @host = FactoryBot.create(:host)
74
74
  @uuid = SecureRandom.uuid
75
- uploader = ForemanRhCloud::HitsUploader.new(host: @host, payload: PAYLOAD, uuid: @uuid)
76
- uploader.upload!
75
+ rules_resolutions = [PAYLOAD[:rules], PAYLOAD[:resolutions]]
76
+ ForemanRhCloud::RulesIngester.any_instance.
77
+ expects(:fetch_rules_and_resolutions).returns(rules_resolutions)
78
+ @uploader = ForemanRhCloud::HitsUploader.new(host: @host, payload: PAYLOAD, uuid: @uuid)
79
+ @uploader.upload!
77
80
  @host.reload
78
81
  end
79
82
 
@@ -86,6 +89,14 @@ class HitsUploaderTest < ActiveSupport::TestCase
86
89
  assert_includes @host.insights_facet.hits.pluck(:rule_id), "R124"
87
90
  end
88
91
 
92
+ test 'assert reupload does not trigger rules download' do
93
+ # rules must already be in the database so dont retrigger
94
+ # rules download.
95
+ ForemanRhCloud::RulesIngester.any_instance.
96
+ expects(:ingest_rules_and_resolutions!).never
97
+ @uploader.upload!
98
+ end
99
+
89
100
  test "resolutions" do
90
101
  assert_equal 2, InsightsResolution.where(rule_id: ["R123", "R124"]).count
91
102
  end
@@ -0,0 +1,60 @@
1
+ require 'test_plugin_helper'
2
+
3
+ class RulesIngesterTest < ActiveSupport::TestCase
4
+ PAYLOAD = {
5
+ non_active: {
6
+ rule_id: "non_active",
7
+ active: false,
8
+ },
9
+ no_playbooks: {
10
+ rule_id: "no_playbooks",
11
+ active: true,
12
+ playbooks: {},
13
+ },
14
+ R123: {
15
+ active: true,
16
+ rule_id: "R123",
17
+ description: "R123 failed.",
18
+ category: "Stability",
19
+ reboot_required: false,
20
+ impact_name: "R123 Failure",
21
+ rec_impact: 1,
22
+ rec_likelihood: 1,
23
+ playbooks: {
24
+ resolution1: {
25
+ name: "Update package to 100.9 or above",
26
+ reboot_required: false,
27
+ },
28
+ resolution2: {
29
+ name: "Update other package to 101.9 or above",
30
+ reboot_required: true,
31
+ text: "- name: Update package-102",
32
+ },
33
+ },
34
+ },
35
+ }.freeze
36
+
37
+ setup do
38
+ ForemanRhCloud::RulesIngester.any_instance.expects(:fetch_rules_data).returns(PAYLOAD)
39
+ ForemanRhCloud::RulesIngester.new.ingest_rules_and_resolutions!
40
+ end
41
+
42
+ test 'non active are ignored' do
43
+ refute InsightsRule.where(rule_id: "non_active").exists?
44
+ end
45
+
46
+ test 'non playbooks are ignored' do
47
+ refute InsightsRule.where(rule_id: "no_playbooks").exists?
48
+ end
49
+
50
+ test 'R123 exists' do
51
+ rule = InsightsRule.find_by(rule_id: "R123")
52
+ refute_nil rule
53
+ assert_equal "R123 Failure", rule.impact_name
54
+ end
55
+
56
+ test 'Resolutions exists' do
57
+ assert_equal 2, InsightsResolution.where(rule_id: "R123").count
58
+ assert InsightsResolution.where(rule_id: "R123", resolution_type: "resolution1").exists?
59
+ end
60
+ end
@@ -453,9 +453,9 @@ class SliceGeneratorTest < ActiveSupport::TestCase
453
453
  assert_equal 1, generator.hosts_count
454
454
  end
455
455
 
456
- test 'excludes hosts with host_registration_insights set to false' do
456
+ test 'excludes hosts with host_registration_insights_inventory set to false' do
457
457
  @host.host_parameters << HostParameter.create(
458
- name: 'host_registration_insights',
458
+ name: 'host_registration_insights_inventory',
459
459
  value: "false",
460
460
  parameter_type: 'boolean'
461
461
  )
@@ -465,6 +465,28 @@ class SliceGeneratorTest < ActiveSupport::TestCase
465
465
  assert_equal 0, count
466
466
  end
467
467
 
468
+ test 'includes hosts with host_registration_insights set to true' do
469
+ @host.host_parameters.build(
470
+ name: 'host_registration_insights_inventory',
471
+ value: 'true',
472
+ parameter_type: 'boolean'
473
+ )
474
+ @host.save!
475
+
476
+ batch = Host.where(id: @host.id).in_batches.first
477
+ generator = create_generator(batch)
478
+
479
+ actual = JSON.parse(generator.render.join("\n"))
480
+
481
+ assert_equal '00000000-0000-0000-0000-000000000000', actual['report_slice_id']
482
+ assert_not_nil actual_host = actual['hosts'].first
483
+ assert_equal @host.fqdn, actual_host['fqdn']
484
+
485
+ param = @host.host_parameters.first
486
+ assert_equal 'host_registration_insights_inventory', param.name
487
+ assert_equal true, param.value
488
+ end
489
+
468
490
  test 'shows system_memory_bytes in bytes' do
469
491
  FactoryBot.create(:fact_value, fact_name: fact_names['memory::memtotal'], value: '1', host: @host)
470
492
 
@@ -74,7 +74,11 @@ const RemediationModal = ({
74
74
  <TableHeader />
75
75
  <TableBody />
76
76
  </Table>
77
- <TableEmptyState status={status} error={error} />
77
+ <TableEmptyState
78
+ status={status}
79
+ error={error}
80
+ rowsLength={rows.length}
81
+ />
78
82
  </Modal>
79
83
  </React.Fragment>
80
84
  );