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.
- checksums.yaml +4 -4
- data/app/assets/javascripts/foreman_rh_cloud/locale/fr/foreman_rh_cloud.js +50 -50
- data/app/assets/javascripts/foreman_rh_cloud/locale/ja/foreman_rh_cloud.js +52 -52
- data/app/assets/javascripts/foreman_rh_cloud/locale/ko/foreman_rh_cloud.js +50 -50
- data/app/assets/javascripts/foreman_rh_cloud/locale/zh_CN/foreman_rh_cloud.js +50 -50
- data/app/controllers/api/v2/rh_cloud/inventory_controller.rb +2 -2
- data/app/controllers/insights_cloud/api/machine_telemetries_controller.rb +2 -0
- data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +1 -1
- data/lib/foreman_inventory_upload/async/queue_for_upload_job.rb +3 -3
- data/lib/foreman_inventory_upload/async/upload_report_job.rb +4 -4
- 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/locale/foreman_rh_cloud.pot +2 -2
- data/locale/fr/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/fr/foreman_rh_cloud.po +53 -53
- data/locale/ja/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/ja/foreman_rh_cloud.po +54 -53
- data/locale/ka/foreman_rh_cloud.po +1 -0
- data/locale/ko/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/ko/foreman_rh_cloud.po +53 -52
- data/locale/zh_CN/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- data/locale/zh_CN/foreman_rh_cloud.po +53 -52
- data/package.json +5 -5
- data/test/controllers/insights_cloud/api/machine_telemetries_controller_test.rb +19 -16
- data/test/controllers/inventory_upload/api/inventory_controller_test.rb +1 -1
- data/test/jobs/insights_full_sync_test.rb +28 -0
- data/test/jobs/insights_resolutions_sync_test.rb +22 -0
- data/test/jobs/inventory_full_sync_test.rb +6 -5
- data/test/jobs/inventory_hosts_sync_test.rb +6 -6
- data/test/jobs/upload_report_job_test.rb +1 -1
- data/test/test_plugin_helper.rb +14 -0
- data/test/unit/archived_report_generator_test.rb +4 -4
- data/test/unit/services/foreman_rh_cloud/branch_info_test.rb +7 -6
- data/test/unit/slice_generator_test.rb +4 -5
- data/test/unit/tags_generator_test.rb +2 -12
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItem/__tests__/__snapshots__/ListItem.test.js.snap +1 -7
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItemStatus/__tests__/__snapshots__/ListItemStatus.test.js.snap +1 -5
- data/webpack/ForemanInventoryUpload/Components/AccountList/accountList.scss +3 -3
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/inventoryFilter.scss +1 -1
- data/webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.scss +5 -5
- data/webpack/ForemanInventoryUpload/Components/PageHeader/PageTitle.js +5 -4
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/CloudPingModal/index.js +18 -3
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButton.js +0 -1
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButton.test.js.snap +0 -1
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/__tests__/__snapshots__/InventoryAutoUpload.test.js.snap +2 -10
- data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTable.js +5 -1
- data/webpack/InsightsCloudSync/Components/InsightsTable/InsightsTableConstants.js +1 -1
- data/webpack/InsightsCloudSync/Components/InsightsTable/Pagination.js +7 -7
- data/webpack/InsightsCloudSync/Components/InsightsTable/table.scss +1 -1
- data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationModal.js +5 -1
- data/webpack/InsightsCloudSync/Components/RemediationModal/RemediationTableConstants.js +8 -1
- data/webpack/InsightsCloudSync/Components/ToolbarDropdown.js +8 -2
- data/webpack/InsightsCloudSync/InsightsCloudSync.scss +1 -1
- data/webpack/InsightsHostDetailsTab/InsightsTotalRiskChart.js +11 -2
- data/webpack/InsightsHostDetailsTab/NewHostDetailsTab.js +5 -4
- data/webpack/common/DropdownToggle.js +2 -2
- data/webpack/common/Switcher/HelpLabel.js +1 -1
- data/webpack/common/Switcher/SwitcherPF4.scss +1 -1
- data/webpack/common/Switcher/__tests__/__snapshots__/HelpLabel.test.js.snap +2 -6
- data/webpack/common/table/EmptyState.js +25 -18
- metadata +3 -9
- data/app/assets/javascripts/foreman_rh_cloud/locale/en/foreman_rh_cloud.js +0 -589
- data/locale/en/LC_MESSAGES/foreman_rh_cloud.mo +0 -0
- 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>,
|
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>,
|
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 "
|
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": "
|
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": ">=
|
22
|
+
"@theforeman/vendor": ">= 15.0.1"
|
23
23
|
},
|
24
24
|
"devDependencies": {
|
25
25
|
"@babel/core": "^7.7.0",
|
26
|
-
"@theforeman/builder": ">=
|
27
|
-
"@theforeman/test": ">=
|
28
|
-
"@theforeman/eslint-plugin-foreman": ">=
|
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
|
-
|
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
|
-
|
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,
|
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
|
-
|
15
|
-
|
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:
|
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:
|
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:
|
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 =
|
12
|
-
cv =
|
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
|
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
|
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
|
21
|
+
assert_match(/Upload canceled/, progress_output.full_output)
|
22
22
|
assert_match(/exit 1/, progress_output.status)
|
23
23
|
end
|
24
24
|
|
data/test/test_plugin_helper.rb
CHANGED
@@ -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 =
|
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:
|
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
|
-
|
8
|
-
|
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:
|
17
|
-
lifecycle_environment:
|
18
|
-
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)
|