foreman_rh_cloud 11.0.3 → 11.2.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 (90) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/app/assets/javascripts/foreman_rh_cloud/locale/en/foreman_rh_cloud.js +248 -161
  4. data/app/assets/javascripts/foreman_rh_cloud/locale/fr/foreman_rh_cloud.js +393 -306
  5. data/app/assets/javascripts/foreman_rh_cloud/locale/ja/foreman_rh_cloud.js +393 -306
  6. data/app/assets/javascripts/foreman_rh_cloud/locale/ka/foreman_rh_cloud.js +393 -306
  7. data/app/assets/javascripts/foreman_rh_cloud/locale/ko/foreman_rh_cloud.js +589 -0
  8. data/app/assets/javascripts/foreman_rh_cloud/locale/zh_CN/foreman_rh_cloud.js +393 -306
  9. data/app/controllers/api/v2/advisor_engine/advisor_engine_controller.rb +98 -0
  10. data/app/controllers/api/v2/rh_cloud/advisor_engine_config_controller.rb +16 -0
  11. data/app/controllers/insights_cloud/api/machine_telemetries_controller.rb +9 -1
  12. data/app/models/concerns/rh_cloud_host.rb +5 -0
  13. data/app/services/foreman_rh_cloud/cloud_connector.rb +1 -1
  14. data/app/services/foreman_rh_cloud/cloud_request.rb +1 -1
  15. data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +4 -2
  16. data/app/services/foreman_rh_cloud/hits_uploader.rb +50 -0
  17. data/app/services/foreman_rh_cloud/rules_ingester.rb +61 -0
  18. data/app/services/foreman_rh_cloud/template_renderer_helper.rb +1 -1
  19. data/app/views/api/v2/advisor_engine/host_details.json.rabl +9 -0
  20. data/app/views/api/v2/hosts/insights/base.rabl +5 -0
  21. data/app/views/api/v2/hosts/insights/insights.rabl +3 -0
  22. data/config/routes.rb +15 -4
  23. data/db/migrate/20241217190624_add_unique_index_to_rule_id_and_host_id_in_insights_hits.rb +5 -0
  24. data/db/migrate/20241220184900_change_sync_insights_recommendations_to_true.rb +5 -0
  25. data/db/seeds.d/189_add_host_inventory_param.rb +7 -0
  26. data/lib/foreman_inventory_upload/async/generate_all_reports_job.rb +21 -13
  27. data/lib/foreman_inventory_upload/async/upload_report_job.rb +2 -2
  28. data/lib/foreman_inventory_upload/generators/queries.rb +1 -1
  29. data/lib/foreman_inventory_upload/generators/slice.rb +1 -1
  30. data/lib/foreman_rh_cloud/engine.rb +24 -5
  31. data/lib/foreman_rh_cloud/version.rb +1 -1
  32. data/lib/foreman_rh_cloud.rb +21 -31
  33. data/lib/insights_cloud/async/insights_scheduled_sync.rb +10 -2
  34. data/lib/insights_cloud.rb +4 -0
  35. data/lib/inventory_sync/async/inventory_full_sync.rb +0 -10
  36. data/lib/inventory_sync/async/inventory_scheduled_sync.rb +15 -7
  37. data/lib/tasks/insights.rake +10 -7
  38. data/lib/tasks/rh_cloud_inventory.rake +8 -3
  39. data/locale/Makefile +12 -2
  40. data/locale/en/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  41. data/locale/en/foreman_rh_cloud.po +111 -22
  42. data/locale/foreman_rh_cloud.pot +217 -96
  43. data/locale/fr/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  44. data/locale/fr/foreman_rh_cloud.po +106 -19
  45. data/locale/ja/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  46. data/locale/ja/foreman_rh_cloud.po +106 -19
  47. data/locale/ka/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  48. data/locale/ka/foreman_rh_cloud.po +106 -19
  49. data/locale/ko/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  50. data/locale/ko/foreman_rh_cloud.po +591 -0
  51. data/locale/zh_CN/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
  52. data/locale/zh_CN/foreman_rh_cloud.po +106 -19
  53. data/package.json +1 -1
  54. data/test/controllers/insights_cloud/api/advisor_engine_controller_test.rb +48 -0
  55. data/test/controllers/insights_sync/settings_controller_test.rb +3 -0
  56. data/test/factories/insights_factories.rb +1 -1
  57. data/test/jobs/inventory_scheduled_sync_test.rb +10 -0
  58. data/test/unit/rh_cloud_http_proxy_test.rb +1 -26
  59. data/test/unit/services/foreman_rh_cloud/cloud_request_forwarder_test.rb +24 -0
  60. data/test/unit/services/foreman_rh_cloud/hits_uploader_test.rb +131 -0
  61. data/test/unit/services/foreman_rh_cloud/rules_ingester_test.rb +60 -0
  62. data/test/unit/slice_generator_test.rb +24 -2
  63. data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/__snapshots__/PageTitle.test.js.snap +1 -1
  64. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/CloudConnectorButton/CloudConnectorButton.js +2 -2
  65. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/CloudConnectorButton/__tests__/__snapshots__/CloudConnectorButton.test.js.snap +2 -2
  66. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/PageDescription.js +3 -1
  67. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/__snapshots__/PageDescription.test.js.snap +1 -1
  68. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButton.test.js.snap +1 -1
  69. data/webpack/ForemanInventoryUpload/Components/TabHeader/TabHeader.js +1 -1
  70. data/webpack/ForemanInventoryUpload/ForemanInventoryConstants.js +1 -1
  71. data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +1 -1
  72. data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettings.js +26 -22
  73. data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsActions.js +2 -1
  74. data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTable.js +10 -1
  75. data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTableConstants.js +8 -1
  76. data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTableHelpers.js +3 -1
  77. data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationModal.js +5 -1
  78. data/webpack/InsightsCloudSync/Components/ToolbarDropdown.js +5 -0
  79. data/webpack/InsightsCloudSync/InsightsCloudSync.js +1 -2
  80. data/webpack/InsightsCloudSync/__snapshots__/InsightsCloudSync.test.js.snap +1 -1
  81. data/webpack/InsightsHostDetailsTab/NewHostDetailsTab.js +3 -1
  82. data/webpack/__mocks__/foremanReact/common/hooks/API/APIHooks.js +3 -0
  83. data/webpack/common/Hooks/ConfigHooks.js +19 -0
  84. metadata +23 -8
  85. data/webpack/InsightsCloudSync/Components/InsightsHeader/InsightsHeader.scss +0 -8
  86. data/webpack/InsightsCloudSync/Components/InsightsHeader/index.js +0 -16
  87. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettings.test.js +0 -18
  88. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettings.test.js.snap +0 -15
  89. data/webpack/InsightsCloudSync/Components/__tests__/InsightsHeader.test.js +0 -10
  90. data/webpack/InsightsCloudSync/Components/__tests__/__snapshots__/InsightsHeader.test.js.snap +0 -13
@@ -12,7 +12,7 @@
12
12
  #
13
13
  msgid ""
14
14
  msgstr ""
15
- "Project-Id-Version: foreman_rh_cloud 1.0.0\n"
15
+ "Project-Id-Version: foreman_rh_cloud 11.1.0\n"
16
16
  "Report-Msgid-Bugs-To: \n"
17
17
  "PO-Revision-Date: 2023-01-20 13:26+0000\n"
18
18
  "Last-Translator: Ewoud Kohl van Wijngaarden <ewoud+transifex@kohlvanwijngaarde"
@@ -25,8 +25,8 @@ msgstr ""
25
25
  "Language: zh_CN\n"
26
26
  "Plural-Forms: nplurals=1; plural=0;\n"
27
27
 
28
- msgid " Sync inventory status"
29
- msgstr " 同步清单状态"
28
+ msgid " Sync all inventory status"
29
+ msgstr ""
30
30
 
31
31
  msgid "%s organizations"
32
32
  msgstr "%s 机构"
@@ -91,12 +91,12 @@ msgstr "完成"
91
91
  msgid "Configure"
92
92
  msgstr "配置"
93
93
 
94
- msgid "Configure Cloud Connector"
95
- msgstr "配置云连接器"
96
-
97
94
  msgid "Configure Cloud Connector on given hosts"
98
95
  msgstr "在给定主机上配置 Cloud Connector"
99
96
 
97
+ msgid "Configure cloud connector"
98
+ msgstr ""
99
+
100
100
  msgid "Connectivity test"
101
101
  msgstr "连接测试"
102
102
 
@@ -157,6 +157,9 @@ msgstr "排除软件包上传到红帽云"
157
157
  msgid "Exit Code: %s"
158
158
  msgstr "退出代码:%s"
159
159
 
160
+ msgid "Fetch Insights-related host details"
161
+ msgstr ""
162
+
160
163
  msgid "Fetching data about your accounts"
161
164
  msgstr "获取有关您的帐户的数据"
162
165
 
@@ -181,14 +184,17 @@ msgstr "处理数据并将其上传到红帽云的 Foreman 插件"
181
184
  msgid "Full Screen"
182
185
  msgstr "全屏"
183
186
 
187
+ msgid "Generate and upload report"
188
+ msgstr ""
189
+
184
190
  msgid "Generate the report, but do not upload"
185
191
  msgstr ""
186
192
 
187
193
  msgid "Generating"
188
194
  msgstr "生成中"
189
195
 
190
- msgid "Go to Satellite Insights page"
191
- msgstr "进入 Satellite Insights 页面"
196
+ msgid "Go to Foreman Insights page"
197
+ msgstr ""
192
198
 
193
199
  msgid "Go to first page"
194
200
  msgstr "前往第一页"
@@ -229,9 +235,6 @@ msgstr "在 insights-client 报告中包含参数"
229
235
  msgid "Insights"
230
236
  msgstr "Insights"
231
237
 
232
- msgid "Insights synchronization process is used to provide Insights recommendations output for hosts managed here."
233
- msgstr "Insights 同步过程用于为此处管理的主机提供 Insights 建议输出。"
234
-
235
238
  msgid "Inventory"
236
239
  msgstr "清单"
237
240
 
@@ -253,6 +256,9 @@ msgstr "每页的项"
253
256
  msgid "Knowledgebase article"
254
257
  msgstr "知识库文章"
255
258
 
259
+ msgid "List of host UUIDs"
260
+ msgstr ""
261
+
256
262
  msgid "Loading"
257
263
  msgstr "加载"
258
264
 
@@ -355,8 +361,8 @@ msgstr "选择的建议:%s。"
355
361
  msgid "Recommendations synced successfully"
356
362
  msgstr "成功同步建议"
357
363
 
358
- msgid "Reconfigure Cloud Connector"
359
- msgstr "重新配置云连接器"
364
+ msgid "Reconfigure cloud connector"
365
+ msgstr ""
360
366
 
361
367
  msgid "Red Hat Cloud Inventory"
362
368
  msgstr "红帽云清单"
@@ -385,9 +391,6 @@ msgstr "报告"
385
391
  msgid "Resolution"
386
392
  msgstr "解决方案"
387
393
 
388
- msgid "Restart"
389
- msgstr "重新开始"
390
-
391
394
  msgid "Run RH Cloud playbook"
392
395
  msgstr "运行 RH Cloud playbook"
393
396
 
@@ -418,6 +421,9 @@ msgstr "应从 Foreman 导入包含参数标签?"
418
421
  msgid "Show Advanced Settings"
419
422
  msgstr "显示高级设置"
420
423
 
424
+ msgid "Show if system is configured to use local iop-advisor-engine."
425
+ msgstr ""
426
+
421
427
  msgid "Start inventory synchronization"
422
428
  msgstr "启动清单同步"
423
429
 
@@ -439,15 +445,18 @@ msgstr "同步建议"
439
445
  msgid "Synchronize recommendations Automatically"
440
446
  msgstr "自动同步建议"
441
447
 
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."
448
+ 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."
443
449
  msgstr ""
444
450
 
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."
451
+ 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."
446
452
  msgstr ""
447
453
 
448
454
  msgid "The report file %{filename} doesn't exist"
449
455
  msgstr "报告文件 %{filename} 不存在"
450
456
 
457
+ msgid "The scheduled process is disabled because this Foreman is configured with the use_local_advisor_engine option."
458
+ msgstr ""
459
+
451
460
  msgid "The server returned the following error: %s"
452
461
  msgstr "服务器返回以下错误:%s"
453
462
 
@@ -460,7 +469,7 @@ msgstr ""
460
469
  msgid "This action will also enable automatic reports upload"
461
470
  msgstr "此操作还会启用自动报告上传"
462
471
 
463
- msgid "To enable this reporting for all Satellite organizations, set {uploadButtonName} to on. The data will be reported automatically once per day."
472
+ msgid "To enable this reporting for all Foreman organizations, set {uploadButtonName} to on. The data will be reported automatically once per day."
464
473
  msgstr ""
465
474
 
466
475
  msgid "To manually upload the data for a specific organization, select an organization and click {restartButtonName}."
@@ -472,6 +481,15 @@ msgstr "总风险"
472
481
  msgid "Total risks"
473
482
  msgstr "总风险"
474
483
 
484
+ msgid "Upload hits from iop-advisor-engine"
485
+ msgstr ""
486
+
487
+ msgid "Upload hits information"
488
+ msgstr ""
489
+
490
+ msgid "Upload rules related to the hits"
491
+ msgstr ""
492
+
475
493
  msgid "Uploading"
476
494
  msgstr "上载中"
477
495
 
@@ -487,18 +505,87 @@ msgstr "禁用 Red Hat Insights"
487
505
  msgid "Wait and %s"
488
506
  msgstr "等待和 %s"
489
507
 
508
+ msgid "Whether the resolution requires reboot"
509
+ msgstr ""
510
+
511
+ msgid "category name"
512
+ msgstr ""
513
+
514
+ msgid "generic"
515
+ msgstr ""
516
+
490
517
  msgid "hosts page"
491
518
  msgstr "主机页"
492
519
 
520
+ msgid "impact name"
521
+ msgstr ""
522
+
523
+ msgid "iop payload including resolutions, rules, hits"
524
+ msgstr ""
525
+
493
526
  msgid "items"
494
527
  msgstr "项"
495
528
 
529
+ msgid "likelihood number"
530
+ msgstr ""
531
+
532
+ msgid "more info"
533
+ msgstr ""
534
+
496
535
  msgid "page"
497
536
  msgstr "page"
498
537
 
499
538
  msgid "per page"
500
539
  msgstr "每页"
501
540
 
541
+ msgid "publish date (YYYY-MM-DD)"
542
+ msgstr ""
543
+
544
+ msgid "rating"
545
+ msgstr ""
546
+
547
+ msgid "reason"
548
+ msgstr ""
549
+
550
+ msgid "reboot required"
551
+ msgstr ""
552
+
553
+ msgid "resolution description"
554
+ msgstr ""
555
+
556
+ msgid "resolution risk"
557
+ msgstr ""
558
+
559
+ msgid "result url"
560
+ msgstr ""
561
+
562
+ msgid "rule description"
563
+ msgstr ""
564
+
565
+ msgid "rule id"
566
+ msgstr ""
567
+
568
+ msgid "rule title"
569
+ msgstr ""
570
+
571
+ msgid "solution url"
572
+ msgstr ""
573
+
574
+ msgid "summary"
575
+ msgstr ""
576
+
577
+ msgid "total risk"
578
+ msgstr ""
579
+
580
+ msgid "type"
581
+ msgstr ""
582
+
583
+ msgid "upload hits details json"
584
+ msgstr ""
585
+
586
+ msgid "upload resolutions related to the hits"
587
+ msgstr ""
588
+
502
589
  msgid "view the job in progress"
503
590
  msgstr "查看正在进行中的任务"
504
591
 
data/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "foreman_rh_cloud",
3
- "version": "11.0.3",
3
+ "version": "11.2.0",
4
4
  "description": "Inventory Upload =============",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -0,0 +1,48 @@
1
+ require 'test_plugin_helper'
2
+
3
+ module InsightsCloud
4
+ module Api
5
+ class AdvisorEngineControllerTest < ActionController::TestCase
6
+ tests ::Api::V2::AdvisorEngine::AdvisorEngineController
7
+
8
+ setup do
9
+ @test_org = FactoryBot.create(:organization)
10
+ @host1 = FactoryBot.create(:host, :with_insights_hits, organization: @test_org, hostname: 'insightshost1')
11
+ @host2 = FactoryBot.create(:host, :with_insights_hits, organization: @test_org, hostname: 'insightshost2')
12
+ @host3 = FactoryBot.create(:host, organization: @test_org)
13
+ end
14
+
15
+ test 'shows hosts with uuids' do
16
+ uuids = [@host1.insights.uuid, @host2.insights.uuid]
17
+ get :host_details, params: { organization_id: @test_org.id, host_uuids: uuids }
18
+ assert_response :success
19
+ assert_template 'api/v2/advisor_engine/host_details'
20
+ assert_equal @test_org.hosts.joins(:insights).where(:insights => { :uuid => uuids }).count, assigns(:hosts).count
21
+ refute_equal @test_org.hosts.count, assigns(:hosts).count
22
+ end
23
+
24
+ test 'shows error when no hosts found' do
25
+ get :host_details, params: { organization_id: @test_org.id, host_uuids: ['nonexistentuuid'] }
26
+ assert_response :not_found
27
+ assert_equal 'No hosts found for the given UUIDs', JSON.parse(response.body)['error']
28
+ end
29
+
30
+ test 'test upload hits with payload' do
31
+ uuid = SecureRandom.uuid
32
+ payload = { "data": "dummy data" }
33
+ ForemanRhCloud::HitsUploader.any_instance.expects(:upload!).returns
34
+ patch :upload_hits, params: { host_name: @host1.name, host_uuid: uuid, payload: payload }
35
+ assert_response :ok
36
+ assert_equal 'success', JSON.parse(response.body)['action_status']
37
+ end
38
+
39
+ test 'test upload hits with bad host' do
40
+ uuid = SecureRandom.uuid
41
+ payload = { "data": "dummy data" }
42
+ patch :upload_hits, params: { host_name: "NO SUCH HOST", host_uuid: uuid, payload: payload }
43
+ assert_response :not_found
44
+ assert_equal 'No host found for the given host name', JSON.parse(response.body)['error']
45
+ end
46
+ end
47
+ end
48
+ end
@@ -2,6 +2,9 @@ require 'test_plugin_helper'
2
2
 
3
3
  class SettingsControllerTest < ActionController::TestCase
4
4
  tests InsightsCloud::SettingsController
5
+ def setup
6
+ ForemanRhCloud.stubs(:with_local_advisor_engine?).returns(false)
7
+ end
5
8
 
6
9
  test 'should return allow_auto_insights_sync setting' do
7
10
  Setting[:allow_auto_insights_sync] = false
@@ -1,6 +1,6 @@
1
1
  FactoryBot.define do
2
2
  factory :insights_facet do
3
- # sequence(:uuid) { |n| "uuid-#{n}" }
3
+ sequence(:uuid) { |n| "uuid-#{n}" }
4
4
 
5
5
  trait :with_hits do
6
6
  hits do
@@ -14,6 +14,16 @@ class InventoryScheduledSyncTest < ActiveSupport::TestCase
14
14
  ForemanTasks.sync_task(InventorySync::Async::InventoryScheduledSync)
15
15
  end
16
16
 
17
+ test 'Skips execution if with_local_advisor_engine? is true' do
18
+ ForemanRhCloud.stubs(:with_local_advisor_engine?).returns(true)
19
+
20
+ InventorySync::Async::InventoryScheduledSync.any_instance.expects(:plan_org_sync).never
21
+
22
+ task = ForemanTasks.sync_task(InventorySync::Async::InventoryScheduledSync)
23
+ status = task.output[:status].to_s
24
+ assert_match(/Foreman is configured with the use_local_advisor_engine option/, status)
25
+ end
26
+
17
27
  test 'Skips execution if auto upload is disabled' do
18
28
  Setting[:allow_auto_inventory_upload] = false
19
29
 
@@ -4,29 +4,12 @@ class RhCloudHttpProxyTest < ActiveSupport::TestCase
4
4
  setup do
5
5
  @global_content_proxy_mock = 'http://global:content@localhost:80'
6
6
  @global_foreman_proxy_mock = 'http://global:foreman@localhost:80'
7
- @katello_cdn_proxy_mock = {
8
- host: 'localhost',
9
- port: '80',
10
- user: 'katello',
11
- password: 'cdn',
12
- scheme: 'http',
13
- }
14
- @katello_cdn_proxy_string_mock = 'http://katello:cdn@localhost:80'
15
7
  end
16
8
 
17
9
  test 'selects global content proxy' do
18
10
  setup_global_content_proxy
19
11
  setup_global_foreman_proxy
20
- setup_cdn_proxy do
21
- assert_equal @global_content_proxy_mock, ForemanRhCloud.proxy_setting
22
- end
23
- end
24
-
25
- test 'selects cdn proxy' do
26
- setup_global_foreman_proxy
27
- setup_cdn_proxy do
28
- assert_equal @katello_cdn_proxy_string_mock, ForemanRhCloud.proxy_setting
29
- end
12
+ assert_equal @global_content_proxy_mock, ForemanRhCloud.proxy_setting
30
13
  end
31
14
 
32
15
  test 'selects global foreman proxy' do
@@ -44,14 +27,6 @@ class RhCloudHttpProxyTest < ActiveSupport::TestCase
44
27
  Setting[:http_proxy] = @global_foreman_proxy_mock
45
28
  end
46
29
 
47
- def setup_cdn_proxy
48
- old_cdn_setting = SETTINGS[:katello][:cdn_proxy]
49
- SETTINGS[:katello][:cdn_proxy] = @katello_cdn_proxy_mock
50
- yield
51
- ensure
52
- SETTINGS[:katello][:cdn_proxy] = old_cdn_setting
53
- end
54
-
55
30
  test 'transform proxy scheme test' do
56
31
  mock_http_proxy = 'http://user:password@localhost:8888'
57
32
  mock_https_proxy = 'https://user:password@localhost:8888'
@@ -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 }
@@ -0,0 +1,131 @@
1
+ require 'test_plugin_helper'
2
+
3
+ class HitsUploaderTest < ActiveSupport::TestCase
4
+ PAYLOAD = {
5
+ resolutions: [
6
+ {
7
+ rule_id: "R123",
8
+ description: "Apply security patch to fix vulnerability CVE-2025-0001.",
9
+ needs_reboot: true,
10
+ resolution_risk: "Medium",
11
+ resolution_type: "fix",
12
+ },
13
+ {
14
+ rule_id: "R124",
15
+ description: "Update configuration file to improve system stability.",
16
+ needs_reboot: false,
17
+ resolution_risk: "Low",
18
+ resolution_type: "fix",
19
+ },
20
+ ],
21
+ rules: [
22
+ {
23
+ rule_id: "R123",
24
+ description: "Security patch for CVE-2025-0001.",
25
+ category_name: "Security",
26
+ impact_name: "High",
27
+ summary: "Fixes critical vulnerability.",
28
+ generic: "Security updates are mandatory.",
29
+ reason: "Vulnerability exposed in external audit.",
30
+ total_risk: 5,
31
+ reboot_required: true,
32
+ more_info: "https://example.com/security-update",
33
+ rating: 4.8,
34
+ },
35
+ {
36
+ rule_id: "R124",
37
+ description: "Configuration update to improve performance.",
38
+ category_name: "Availability",
39
+ impact_name: "Medium",
40
+ summary: "Improves application stability and reduces crashes.",
41
+ generic: "Periodic updates recommended.",
42
+ reason: "Frequent crashes observed in logs.",
43
+ total_risk: 3,
44
+ reboot_required: false,
45
+ more_info: "https://example.com/config-update",
46
+ rating: 4.0,
47
+ },
48
+ ],
49
+ hits: [
50
+ {
51
+ rule_id: "R123",
52
+ title: "Critical Vulnerability Patch",
53
+ solution_url: "https://example.com/solution",
54
+ total_risk: 5,
55
+ likelihood: 4,
56
+ publish_date: "2025-01-01",
57
+ results_url: "https://example.com/results",
58
+ },
59
+ {
60
+ rule_id: "R124",
61
+ title: "Configuration Update",
62
+ solution_url: "https://example.com/config-solution",
63
+ total_risk: 3,
64
+ likelihood: 3,
65
+ publish_date: "2025-01-02",
66
+ results_url: "https://example.com/config-results",
67
+ },
68
+ ],
69
+ details: "{\"summary\": \"Detected issues and resolutions applied successfully.\"}",
70
+ }.freeze
71
+
72
+ setup do
73
+ @host = FactoryBot.create(:host)
74
+ @uuid = SecureRandom.uuid
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!
80
+ @host.reload
81
+ end
82
+
83
+ test 'facets' do
84
+ assert_equal @uuid, @host.insights_facet.uuid
85
+ end
86
+
87
+ test 'hits' do
88
+ assert_equal PAYLOAD[:hits].count, @host.insights_facet.hits_count
89
+ assert_includes @host.insights_facet.hits.pluck(:rule_id), "R124"
90
+ end
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
+
100
+ test "resolutions" do
101
+ assert_equal 2, InsightsResolution.where(rule_id: ["R123", "R124"]).count
102
+ end
103
+
104
+ test "details" do
105
+ fact_name = FactName.where(name: "insights::hit_details").first
106
+ fact_value = @host.fact_values.where(fact_name: fact_name).first
107
+ refute_nil fact_value
108
+ assert_equal PAYLOAD[:details], fact_value.value
109
+ end
110
+
111
+ test "empty payload" do
112
+ payload = {
113
+ resolutions: [],
114
+ rules: [],
115
+ hits: [],
116
+ details: "",
117
+ }
118
+
119
+ @host = FactoryBot.create(:host)
120
+ @uuid = SecureRandom.uuid
121
+ uploader = ForemanRhCloud::HitsUploader.new(host: @host, payload: payload, uuid: @uuid)
122
+ uploader.upload!
123
+ @host.reload
124
+ assert_equal @uuid, @host.insights_facet.uuid
125
+ assert_empty @host.insights_facet.hits
126
+ assert_equal 0, @host.insights_facet.hits_count
127
+ fact_name = FactName.where(name: "insights::hit_details").first
128
+ fact_value = @host.fact_values.where(fact_name: fact_name).first
129
+ assert_nil fact_value
130
+ end
131
+ 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
 
@@ -24,7 +24,7 @@ exports[`PageTitle rendering render without Props 1`] = `
24
24
  dropdownItems={
25
25
  Array [
26
26
  <DropdownItem
27
- href="/foreman_tasks/tasks?search=action++%3D++ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateReportJob+or+action++%3D++ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateAllReportsJob&page=1"
27
+ href="/foreman_tasks/tasks?search=label+%3D+ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateReportJob+or+label+%3D+ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateAllReportsJob&page=1"
28
28
  rel="noopener noreferrer"
29
29
  target="_blank"
30
30
  >
@@ -37,14 +37,14 @@ export const CloudConnectorButton = ({ status, onClick, jobLink }) => {
37
37
  if (status === CONNECTOR_STATUS.RESOLVED) {
38
38
  return (
39
39
  <Button variant="secondary" onClick={onClick}>
40
- {__('Reconfigure Cloud Connector')}
40
+ {__('Reconfigure cloud connector')}
41
41
  </Button>
42
42
  );
43
43
  }
44
44
 
45
45
  return (
46
46
  <Button variant="secondary" onClick={onClick}>
47
- {__('Configure Cloud Connector')}
47
+ {__('Configure cloud connector')}
48
48
  </Button>
49
49
  );
50
50
  };