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.
- checksums.yaml +4 -4
- data/app/assets/javascripts/foreman_rh_cloud/locale/fr/foreman_rh_cloud.js +400 -313
- data/app/assets/javascripts/foreman_rh_cloud/locale/ja/foreman_rh_cloud.js +400 -313
- data/app/assets/javascripts/foreman_rh_cloud/locale/ka/foreman_rh_cloud.js +393 -306
- data/app/assets/javascripts/foreman_rh_cloud/locale/ko/foreman_rh_cloud.js +589 -0
- data/app/assets/javascripts/foreman_rh_cloud/locale/zh_CN/foreman_rh_cloud.js +398 -311
- data/app/controllers/insights_cloud/api/machine_telemetries_controller.rb +11 -1
- data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +5 -3
- data/app/services/foreman_rh_cloud/hits_uploader.rb +3 -8
- data/app/services/foreman_rh_cloud/rules_ingester.rb +61 -0
- data/app/services/foreman_rh_cloud/template_renderer_helper.rb +1 -1
- data/config/routes.rb +10 -4
- data/db/seeds.d/189_add_host_inventory_param.rb +7 -0
- data/lib/foreman_inventory_upload/async/upload_report_job.rb +1 -1
- data/lib/foreman_inventory_upload/generators/queries.rb +1 -1
- data/lib/foreman_rh_cloud/engine.rb +1 -1
- data/lib/foreman_rh_cloud/version.rb +1 -1
- data/lib/insights_cloud/async/insights_full_sync.rb +14 -9
- data/lib/insights_cloud/async/insights_resolutions_sync.rb +5 -1
- data/lib/insights_cloud.rb +4 -0
- data/lib/tasks/insights.rake +10 -7
- data/lib/tasks/rh_cloud_inventory.rake +8 -3
- data/locale/Makefile +12 -2
- data/locale/foreman_rh_cloud.pot +217 -96
- data/locale/fr/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/fr/foreman_rh_cloud.po +123 -36
- data/locale/ja/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/ja/foreman_rh_cloud.po +124 -36
- data/locale/ka/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/ka/foreman_rh_cloud.po +107 -19
- data/locale/ko/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/ko/foreman_rh_cloud.po +592 -0
- data/locale/zh_CN/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/zh_CN/foreman_rh_cloud.po +123 -35
- data/package.json +1 -1
- data/test/controllers/insights_cloud/api/machine_telemetries_controller_test.rb +13 -0
- data/test/jobs/insights_full_sync_test.rb +28 -0
- data/test/jobs/insights_resolutions_sync_test.rb +22 -0
- data/test/unit/services/foreman_rh_cloud/cloud_request_forwarder_test.rb +24 -0
- data/test/unit/services/foreman_rh_cloud/hits_uploader_test.rb +13 -2
- data/test/unit/services/foreman_rh_cloud/rules_ingester_test.rb +60 -0
- data/test/unit/slice_generator_test.rb +24 -2
- data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationModal.js +5 -1
- metadata +10 -6
- data/app/assets/javascripts/foreman_rh_cloud/locale/en/foreman_rh_cloud.js +0 -502
- data/locale/en/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- 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>,
|
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
|
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>,
|
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
|
191
|
-
msgstr "进入
|
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
|
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
|
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
|
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
|
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 "
|
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,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
|
-
|
76
|
-
|
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
|
456
|
+
test 'excludes hosts with host_registration_insights_inventory set to false' do
|
457
457
|
@host.host_parameters << HostParameter.create(
|
458
|
-
name: '
|
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
|
77
|
+
<TableEmptyState
|
78
|
+
status={status}
|
79
|
+
error={error}
|
80
|
+
rowsLength={rows.length}
|
81
|
+
/>
|
78
82
|
</Modal>
|
79
83
|
</React.Fragment>
|
80
84
|
);
|