foreman_rh_cloud 2.0.10 → 2.0.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (146) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +27 -2
  3. data/app/controllers/foreman_inventory_upload/accounts_controller.rb +2 -0
  4. data/app/controllers/foreman_inventory_upload/uploads_controller.rb +18 -0
  5. data/app/controllers/insights_cloud/hits_controller.rb +17 -0
  6. data/app/helpers/foreman_inventory_upload_host_helper.rb +2 -3
  7. data/app/models/concerns/rh_cloud_host.rb +15 -0
  8. data/app/models/insights_hit.rb +1 -1
  9. data/app/models/setting/rh_cloud.rb +2 -0
  10. data/app/overrides/hosts_list.rb +1 -1
  11. data/app/services/foreman_rh_cloud/cloud_auth.rb +28 -0
  12. data/app/views/foreman_rh_cloud/react/insights_cloud.html.erb +1 -6
  13. data/app/views/foreman_rh_cloud/react/inventory_upload.html.erb +1 -1
  14. data/app/views/hosts/_insights_tab.html.erb +9 -0
  15. data/app/views/layouts/foreman_rh_cloud/application.html.erb +0 -1
  16. data/config/routes.rb +3 -0
  17. data/db/migrate/20201007115752_add_hits_count_to_insights_facets_table.foreman_rh_cloud.rb +5 -0
  18. data/db/migrate/20201007121540_setup_hits_count_cache.foreman_rh_cloud.rb +10 -0
  19. data/lib/foreman_inventory_upload/async/generate_report_job.rb +1 -1
  20. data/lib/foreman_inventory_upload/async/shell_process.rb +15 -9
  21. data/lib/foreman_inventory_upload/async/upload_report_job.rb +21 -33
  22. data/lib/foreman_inventory_upload/generators/fact_helpers.rb +35 -0
  23. data/lib/foreman_inventory_upload/generators/json_stream.rb +7 -2
  24. data/lib/foreman_inventory_upload/generators/metadata.rb +3 -0
  25. data/lib/foreman_inventory_upload/generators/queries.rb +4 -4
  26. data/lib/foreman_inventory_upload/generators/slice.rb +27 -25
  27. data/lib/foreman_rh_cloud.rb +55 -0
  28. data/lib/foreman_rh_cloud/engine.rb +13 -2
  29. data/lib/foreman_rh_cloud/version.rb +1 -1
  30. data/lib/insights_cloud/async/insights_full_sync.rb +5 -24
  31. data/lib/inventory_sync/async/inventory_full_sync.rb +3 -22
  32. data/lib/tasks/insights.rake +15 -0
  33. data/lib/tasks/rh_cloud_inventory.rake +37 -0
  34. data/package.json +3 -1
  35. data/test/jobs/upload_report_job_test.rb +34 -0
  36. data/test/unit/fact_helpers_test.rb +22 -0
  37. data/test/unit/insights_facet_test.rb +7 -0
  38. data/test/unit/metadata_generator_test.rb +2 -0
  39. data/test/unit/rh_cloud_http_proxy_test.rb +65 -0
  40. data/test/unit/slice_generator_test.rb +164 -2
  41. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.fixtures.js +14 -1
  42. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListActions.js +22 -18
  43. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListReducer.js +16 -0
  44. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListSelectors.js +6 -0
  45. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListActions.test.js +7 -0
  46. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListReducer.test.js +12 -8
  47. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js +9 -0
  48. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListActions.test.js.snap +19 -0
  49. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListReducer.test.js.snap +11 -0
  50. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListSelectors.test.js.snap +6 -0
  51. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcher.fixtures.js +2 -0
  52. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherActions.js +10 -11
  53. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherConstants.js +0 -1
  54. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcherActions.test.js +12 -2
  55. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/__snapshots__/AutoUploadSwitcherActions.test.js.snap +17 -0
  56. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcher.fixtures.js +1 -0
  57. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcher.js +30 -0
  58. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcherActions.js +29 -0
  59. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcherConstants.js +1 -0
  60. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/ExcludePackagesSwitcher.test.js +13 -0
  61. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/ExcludePackagesSwitcherActions.test.js +21 -0
  62. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/ExcludePackagesSwitcher.test.js.snap +38 -0
  63. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/ExcludePackagesSwitcherActions.test.js.snap +31 -0
  64. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/integration.test.js.snap +41 -0
  65. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/integration.test.js +36 -0
  66. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/excludePackagesSwitcher.scss +3 -0
  67. data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/index.js +20 -0
  68. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.fixtures.js +2 -1
  69. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.js +1 -0
  70. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.scss +3 -0
  71. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherActions.js +10 -11
  72. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherConstants.js +0 -2
  73. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/HostObfuscationSwitcherActions.test.js +12 -2
  74. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/__snapshots__/HostObfuscationSwitcherActions.test.js.snap +18 -1
  75. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterReducer.js +13 -2
  76. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterReducer.test.js +10 -1
  77. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterReducer.test.js.snap +6 -0
  78. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/integration.test.js.snap +3 -0
  79. data/webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettings.js +4 -0
  80. data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettings.test.js.snap +2 -0
  81. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcher.fixtures.js +1 -0
  82. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcher.js +29 -0
  83. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcherActions.js +29 -0
  84. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcherConstants.js +1 -0
  85. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/IpsObfuscationSwitcher.test.js +13 -0
  86. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/IpsObfuscationSwitcherActions.test.js +21 -0
  87. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/__snapshots__/IpsObfuscationSwitcher.test.js.snap +38 -0
  88. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/__snapshots__/IpsObfuscationSwitcherActions.test.js.snap +31 -0
  89. data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/index.js +20 -0
  90. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButton.js +8 -2
  91. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonActions.js +9 -11
  92. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonConstants.js +1 -1
  93. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonReducer.js +2 -2
  94. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonActions.test.js +18 -0
  95. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonReducer.test.js +1 -8
  96. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonActions.test.js.snap +62 -0
  97. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonReducer.test.js.snap +0 -7
  98. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Modal.js +2 -2
  99. data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Toast.js +1 -1
  100. data/webpack/ForemanInventoryUpload/Components/StatusChart/StatusChart.js +1 -1
  101. data/webpack/ForemanInventoryUpload/Components/StatusChart/__tests__/__snapshots__/StatusChart.test.js.snap +1 -1
  102. data/webpack/ForemanInventoryUpload/Components/TabContainer/tabContainer.scss +1 -1
  103. data/webpack/ForemanInventoryUpload/Components/TabHeader/TabHeader.js +6 -1
  104. data/webpack/ForemanInventoryUpload/Components/Terminal/Terminal.js +2 -4
  105. data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +8 -0
  106. data/webpack/ForemanRhCloudPages.js +2 -0
  107. data/webpack/ForemanRhCloudReducers.js +2 -0
  108. data/webpack/ForemanRhCloudSelectors.js +5 -0
  109. data/webpack/ForemanRhCloudTestHelpers.js +6 -1
  110. data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsActions.js +17 -20
  111. data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsConstants.js +0 -6
  112. data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsReducer.js +0 -4
  113. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsActions.test.js +16 -0
  114. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsReducer.test.js +1 -24
  115. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsActions.test.js.snap +38 -4
  116. data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsReducer.test.js.snap +0 -14
  117. data/webpack/InsightsCloudSync/InsightsCloudSync.js +3 -5
  118. data/webpack/InsightsCloudSync/InsightsCloudSync.test.js +1 -3
  119. data/webpack/InsightsCloudSync/InsightsCloudSyncActions.js +10 -11
  120. data/webpack/InsightsCloudSync/InsightsCloudSyncConstants.js +0 -2
  121. data/webpack/InsightsCloudSync/__snapshots__/InsightsCloudSync.test.js.snap +1 -1
  122. data/webpack/InsightsHostDetailsTab/InsightsTab.js +66 -0
  123. data/webpack/InsightsHostDetailsTab/InsightsTab.scss +86 -0
  124. data/webpack/InsightsHostDetailsTab/InsightsTabActions.js +31 -0
  125. data/webpack/InsightsHostDetailsTab/InsightsTabConstants.js +2 -0
  126. data/webpack/InsightsHostDetailsTab/InsightsTabReducer.js +19 -0
  127. data/webpack/InsightsHostDetailsTab/InsightsTabSelectors.js +3 -0
  128. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.fixtures.js +25 -0
  129. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.test.js +13 -0
  130. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabActions.test.js +19 -0
  131. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabIntegration.test.js +17 -0
  132. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabReducer.test.js +26 -0
  133. data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabSelectors.test.js +13 -0
  134. data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTab.test.js.snap +34 -0
  135. data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabActions.test.js.snap +58 -0
  136. data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabReducer.test.js.snap +34 -0
  137. data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabSelectors.test.js.snap +20 -0
  138. data/webpack/InsightsHostDetailsTab/components/ListItem/ListItem.js +69 -0
  139. data/webpack/InsightsHostDetailsTab/components/ListItem/index.js +1 -0
  140. data/webpack/InsightsHostDetailsTab/index.js +20 -0
  141. data/webpack/__mocks__/foremanReact/components/Layout/LayoutConstants.js +1 -0
  142. data/webpack/__tests__/__snapshots__/ForemanRhCloudSelectors.test.js.snap +1 -0
  143. data/webpack/__tests__/__snapshots__/ForemanRhCloudTestHelpers.test.js.snap +3 -0
  144. metadata +67 -16
  145. data/lib/tasks/generator.rake +0 -29
  146. data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/hostObfuscationSwitcher.scss +0 -0
@@ -1,10 +1,11 @@
1
1
  {
2
2
  "name": "foreman_rh_cloud",
3
- "version": "0.0.1",
3
+ "version": "2.0.14",
4
4
  "description": "Inventory Upload =============",
5
5
  "main": "index.js",
6
6
  "scripts": {
7
7
  "lint": "tfm-lint --plugin -d /webpack",
8
+ "lint:spelling": "eslint ./",
8
9
  "test": "tfm-test --plugin",
9
10
  "test:watch": "tfm-test --plugin --watchAll",
10
11
  "test:current": "tfm-test --plugin --watch",
@@ -32,6 +33,7 @@
32
33
  "@theforeman/eslint-plugin-foreman": "^4.0.2",
33
34
  "babel-eslint": "^10.0.0",
34
35
  "eslint": "^6.7.2",
36
+ "eslint-plugin-spellcheck": "^0.0.17",
35
37
  "prettier": "^1.13.5",
36
38
  "raf": "^3.4.0",
37
39
  "stylelint": "^9.3.0",
@@ -0,0 +1,34 @@
1
+ require 'test_plugin_helper'
2
+
3
+ class UploadReportJobTest < ActiveJob::TestCase
4
+ include FolderIsolation
5
+
6
+ test 'returns aborted state when disconnected' do
7
+ organization = FactoryBot.create(:organization)
8
+ Organization.any_instance.stubs(:owner_details).returns(
9
+ 'upstreamConsumer' => {
10
+ 'idCert' => 'TEST_CERT',
11
+ }
12
+ )
13
+ FactoryBot.create(:setting, :name => 'content_disconnected', :value => true)
14
+
15
+ ForemanInventoryUpload::Async::UploadReportJob.perform_now('', organization.id)
16
+
17
+ label = ForemanInventoryUpload::Async::UploadReportJob.output_label(organization.id)
18
+ progress_output = ForemanInventoryUpload::Async::ProgressOutput.get(label)
19
+ assert_match(/Upload was stopped/, progress_output.full_output)
20
+ assert_match(/exit 1/, progress_output.status)
21
+ end
22
+
23
+ test 'returns aborted state when no certificate defined on organization' do
24
+ organization = FactoryBot.create(:organization)
25
+ Organization.any_instance.expects(:owner_details).returns(nil)
26
+
27
+ ForemanInventoryUpload::Async::UploadReportJob.perform_now('', organization.id)
28
+
29
+ label = ForemanInventoryUpload::Async::UploadReportJob.output_label(organization.id)
30
+ progress_output = ForemanInventoryUpload::Async::ProgressOutput.get(label)
31
+ assert_match(/Skipping organization/, progress_output.full_output)
32
+ assert_match(/exit 1/, progress_output.status)
33
+ end
34
+ end
@@ -26,4 +26,26 @@ class FactHelpersTest < ActiveSupport::TestCase
26
26
 
27
27
  assert actual
28
28
  end
29
+
30
+ test 'obfuscates ips with insights-client data' do
31
+ host = mock('host')
32
+ @instance.expects(:fact_value).with(host, 'insights_client::ips').returns(
33
+ '[{"obfuscated": "10.230.230.1", "original": "224.0.0.1"}, {"obfuscated": "10.230.230.2", "original": "224.0.0.251"}]'
34
+ )
35
+
36
+ actual = @instance.obfuscated_ips(host)
37
+
38
+ assert_equal '10.230.230.1', actual['224.0.0.1']
39
+ assert_equal '10.230.230.3', actual['224.0.0.2']
40
+ end
41
+
42
+ test 'obfuscates ips without insights-client data' do
43
+ host = mock('host')
44
+ @instance.expects(:fact_value).with(host, 'insights_client::ips').returns(nil)
45
+
46
+ actual = @instance.obfuscated_ips(host)
47
+
48
+ assert_equal '10.230.230.1', actual['224.0.0.1']
49
+ assert_equal '10.230.230.2', actual['224.0.0.2']
50
+ end
29
51
  end
@@ -3,6 +3,7 @@ require 'test_plugin_helper'
3
3
  class InsightsFacetTest < ActiveSupport::TestCase
4
4
  setup do
5
5
  @host = FactoryBot.create(:host, :with_insights_hits)
6
+ InsightsFacet.reset_counters(@host.insights.id, :hits_count)
6
7
  end
7
8
 
8
9
  test 'host with hits can be deleted' do
@@ -13,4 +14,10 @@ class InsightsFacetTest < ActiveSupport::TestCase
13
14
  actual_host = Host.find_by_id(host_id)
14
15
  assert_nil actual_host
15
16
  end
17
+
18
+ test 'search host by recommendations_count' do
19
+ FactoryBot.create(:host) # create another host with no recommendations
20
+
21
+ assert_equal 1, Host.search_for('insights_recommendations_count = 1').count
22
+ end
16
23
  end
@@ -13,6 +13,8 @@ class MetadataGeneratorTest < ActiveSupport::TestCase
13
13
 
14
14
  assert_not_nil actual['report_id']
15
15
  assert_equal 'Satellite', actual['source']
16
+ assert_not_nil (actual_metadata = actual['source_metadata'])
17
+ assert_equal ForemanRhCloud::VERSION, actual_metadata['foreman_rh_cloud_version']
16
18
  assert_equal({}, actual['report_slices'])
17
19
  end
18
20
 
@@ -0,0 +1,65 @@
1
+ require 'test_plugin_helper'
2
+
3
+ class RhCloudHttpProxyTest < ActiveSupport::TestCase
4
+ setup do
5
+ @global_content_proxy_mock = 'http://global:content@localhost:8888'
6
+ @global_foreman_proxy_mock = 'http://global:foreman@localhost:8888'
7
+ @katello_cdn_proxy_mock = {
8
+ host: 'localhost',
9
+ port: '8888',
10
+ user: 'katello',
11
+ password: 'cdn',
12
+ scheme: 'http',
13
+ }
14
+ @katello_cdn_proxy_string_mock = 'http://katello:cdn@localhost:8888'
15
+ end
16
+
17
+ test 'selects global content proxy' do
18
+ setup_global_content_proxy
19
+ 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
30
+ end
31
+
32
+ test 'selects global foreman proxy' do
33
+ setup_global_foreman_proxy
34
+
35
+ assert_equal @global_foreman_proxy_mock, ForemanRhCloud.proxy_setting
36
+ end
37
+
38
+ def setup_global_content_proxy
39
+ http_proxy = FactoryBot.create(:http_proxy, url: @global_content_proxy_mock)
40
+ HttpProxy.stubs(:default_global_content_proxy).returns(http_proxy)
41
+ end
42
+
43
+ def setup_global_foreman_proxy
44
+ FactoryBot.create(:setting, :name => 'http_proxy', :value => @global_foreman_proxy_mock)
45
+ end
46
+
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
+ test 'transform proxy scheme test' do
56
+ mock_http_proxy = 'http://user:password@localhost:8888'
57
+ mock_https_proxy = 'https://user:password@localhost:8888'
58
+
59
+ transformed_http_uri = URI.parse(ForemanRhCloud.transform_scheme(mock_http_proxy))
60
+ transformed_https_uri = URI.parse(ForemanRhCloud.transform_scheme(mock_https_proxy))
61
+
62
+ assert_equal 'proxy', transformed_http_uri.scheme
63
+ assert_equal 'proxys', transformed_https_uri.scheme
64
+ end
65
+ end
@@ -1,6 +1,6 @@
1
1
  require 'test_plugin_helper'
2
2
 
3
- class ReportGeneratorTest < ActiveSupport::TestCase
3
+ class SliceGeneratorTest < ActiveSupport::TestCase
4
4
  setup do
5
5
  User.current = User.find_by(login: 'secret_admin')
6
6
 
@@ -9,6 +9,7 @@ class ReportGeneratorTest < ActiveSupport::TestCase
9
9
 
10
10
  @host = FactoryBot.create(
11
11
  :host,
12
+ :redhat,
12
13
  :with_subscription,
13
14
  :with_content,
14
15
  content_view: cv.first,
@@ -43,6 +44,8 @@ class ReportGeneratorTest < ActiveSupport::TestCase
43
44
  'dmi::chassis::asset_tag',
44
45
  'insights_client::obfuscate_hostname_enabled',
45
46
  'insights_client::hostname',
47
+ 'insights_client::obfuscate_ip_enabled',
48
+ 'insights_client::ips',
46
49
  ]
47
50
  end
48
51
 
@@ -68,10 +71,62 @@ class ReportGeneratorTest < ActiveSupport::TestCase
68
71
  assert_equal @host.fqdn, actual_host['fqdn']
69
72
  assert_equal '1234', actual_host['account']
70
73
  assert_equal 1, generator.hosts_count
74
+ assert_not_nil(actual_system_profile = actual_host['system_profile'])
75
+ assert_nil actual_system_profile['number_of_cpus']
76
+ assert_nil actual_system_profile['number_of_sockets']
77
+ assert_nil actual_system_profile['cores_per_socket']
78
+ assert_nil actual_system_profile['system_memory_bytes']
79
+ assert_nil actual_system_profile['os_release']
80
+ assert_not_nil(actual_network_interfaces = actual_system_profile['network_interfaces'])
81
+ assert_not_nil(actual_nic = actual_network_interfaces.first)
82
+ refute actual_nic.key?('mtu')
83
+ refute actual_nic.key?('mac_address')
84
+ refute actual_nic.key?('name')
85
+ end
86
+
87
+ test 'hosts report fields should be present if fact exist' do
88
+ FactoryBot.create(:fact_value, fact_name: fact_names['cpu::cpu(s)'], value: '4', host: @host)
89
+ FactoryBot.create(:fact_value, fact_name: fact_names['cpu::cpu_socket(s)'], value: '2', host: @host)
90
+ FactoryBot.create(:fact_value, fact_name: fact_names['cpu::core(s)_per_socket'], value: '1', host: @host)
91
+
92
+ batch = Host.where(id: @host.id).in_batches.first
93
+ generator = create_generator(batch)
94
+
95
+ json_str = generator.render
96
+ actual = JSON.parse(json_str.join("\n"))
97
+
98
+ assert_equal 'slice_123', actual['report_slice_id']
99
+ assert_not_nil(actual_host = actual['hosts'].first)
100
+ assert_not_nil(actual_system_profile = actual_host['system_profile'])
101
+ assert_equal 4, actual_system_profile['number_of_cpus']
102
+ assert_equal 2, actual_system_profile['number_of_sockets']
103
+ assert_equal 1, actual_system_profile['cores_per_socket']
71
104
  end
72
105
 
73
106
  test 'generates ip_address and mac_address fields' do
74
- @host.interfaces << FactoryBot.build(:nic_managed)
107
+ nic = FactoryBot.build(:nic_managed)
108
+ nic.attrs['mtu'] = '1500'
109
+ @host.interfaces << nic
110
+ batch = Host.where(id: @host.id).in_batches.first
111
+ generator = create_generator(batch)
112
+
113
+ json_str = generator.render
114
+ actual = JSON.parse(json_str.join("\n"))
115
+
116
+ assert_equal 'slice_123', actual['report_slice_id']
117
+ assert_not_nil(actual_host = actual['hosts'].first)
118
+ assert_equal @host.interfaces.where.not(ip: nil).first.ip, actual_host['ip_addresses'].first
119
+ assert_equal @host.interfaces.where.not(mac: nil).first.mac, actual_host['mac_addresses'].first
120
+ assert_equal @host.fqdn, actual_host['fqdn']
121
+ assert_equal '1234', actual_host['account']
122
+ assert_equal 1, generator.hosts_count
123
+ end
124
+
125
+ test 'generates nic fields' do
126
+ ip6 = Array.new(4) { '%x' % rand(16**4) }.join(':') + '::' + '5'
127
+ nic = FactoryBot.build(:nic_managed, ip6: ip6)
128
+ nic.attrs['mtu'] = '1500'
129
+ @host.interfaces << nic
75
130
  batch = Host.where(id: @host.id).in_batches.first
76
131
  generator = create_generator(batch)
77
132
 
@@ -82,6 +137,66 @@ class ReportGeneratorTest < ActiveSupport::TestCase
82
137
  assert_not_nil(actual_host = actual['hosts'].first)
83
138
  assert_equal @host.interfaces.where.not(ip: nil).first.ip, actual_host['ip_addresses'].first
84
139
  assert_equal @host.interfaces.where.not(mac: nil).first.mac, actual_host['mac_addresses'].first
140
+ assert_not_nil(actual_system_profile = actual_host['system_profile'])
141
+ assert_not_nil(actual_network_interfaces = actual_system_profile['network_interfaces'])
142
+ assert_not_nil(actual_nic = actual_network_interfaces.first)
143
+ assert_equal nic.ip, actual_nic['ipv4_addresses'].first
144
+ assert_equal nic.ip6, actual_nic['ipv6_addresses'].first
145
+ assert_equal 1500, actual_nic['mtu']
146
+ assert_equal nic.mac, actual_nic['mac_address']
147
+ assert_equal nic.identifier, actual_nic['name']
148
+ assert_equal @host.fqdn, actual_host['fqdn']
149
+ assert_equal '1234', actual_host['account']
150
+ assert_equal 1, generator.hosts_count
151
+ end
152
+
153
+ test 'generates obfuscated ip_address fields without inisghts-client' do
154
+ FactoryBot.create(:setting, :name => 'obfuscate_inventory_ips', :value => true)
155
+
156
+ @host.interfaces << FactoryBot.build(:nic_managed)
157
+ batch = Host.where(id: @host.id).in_batches.first
158
+ generator = create_generator(batch)
159
+
160
+ json_str = generator.render
161
+ actual = JSON.parse(json_str.join("\n"))
162
+
163
+ assert_equal 'slice_123', actual['report_slice_id']
164
+ assert_not_nil(actual_host = actual['hosts'].first)
165
+ assert_equal '10.230.230.1', actual_host['ip_addresses'].first
166
+ assert_not_nil(actual_system_profile = actual_host['system_profile'])
167
+ assert_not_nil(actual_network_interfaces = actual_system_profile['network_interfaces'])
168
+ assert_not_nil(actual_nic = actual_network_interfaces.first)
169
+ assert_equal '10.230.230.1', actual_nic['ipv4_addresses'].first
170
+ assert_equal @host.fqdn, actual_host['fqdn']
171
+ assert_equal '1234', actual_host['account']
172
+ assert_equal 1, generator.hosts_count
173
+ end
174
+
175
+ test 'generates obfuscated ip_address fields with inisghts-client' do
176
+ nic = FactoryBot.build(:nic_managed)
177
+ @host.interfaces << nic
178
+
179
+ FactoryBot.create(:fact_value, fact_name: fact_names['insights_client::obfuscate_ip_enabled'], value: 'true', host: @host)
180
+ FactoryBot.create(
181
+ :fact_value,
182
+ fact_name: fact_names['insights_client::ips'],
183
+ value: "[{\"obfuscated\": \"10.230.230.100\", \"original\": \"#{nic.ip}\"}]",
184
+ host: @host
185
+ )
186
+
187
+ batch = Host.where(id: @host.id).in_batches.first
188
+ generator = create_generator(batch)
189
+
190
+ json_str = generator.render
191
+ actual = JSON.parse(json_str.join("\n"))
192
+
193
+ assert_equal 'slice_123', actual['report_slice_id']
194
+ assert_not_nil(actual_host = actual['hosts'].first)
195
+ assert_equal '10.230.230.100', actual_host['ip_addresses'].first
196
+ assert_not_nil(actual_system_profile = actual_host['system_profile'])
197
+ assert_not_nil(actual_network_interfaces = actual_system_profile['network_interfaces'])
198
+ assert_not_nil(actual_nic = actual_network_interfaces.first)
199
+ assert_equal '10.230.230.100', actual_nic['ipv4_addresses'].first
85
200
  assert_equal @host.fqdn, actual_host['fqdn']
86
201
  assert_equal '1234', actual_host['account']
87
202
  assert_equal 1, generator.hosts_count
@@ -146,6 +261,10 @@ class ReportGeneratorTest < ActiveSupport::TestCase
146
261
  end
147
262
 
148
263
  test 'generates a report with satellite facts' do
264
+ hostgroup = FactoryBot.create(:hostgroup)
265
+ @host.hostgroup = hostgroup
266
+ @host.save!
267
+
149
268
  Foreman.expects(:instance_id).twice.returns('satellite-id')
150
269
  batch = Host.where(id: @host.id).in_batches.first
151
270
  generator = create_generator(batch)
@@ -165,6 +284,7 @@ class ReportGeneratorTest < ActiveSupport::TestCase
165
284
  assert_tag(@host.content_view.name, actual_host, 'content_view')
166
285
  assert_tag(@host.location.name, actual_host, 'location')
167
286
  assert_tag(@host.organization.name, actual_host, 'organization')
287
+ assert_tag(@host.hostgroup.name, actual_host, 'hostgroup')
168
288
 
169
289
  assert_equal false, satellite_facts['is_hostname_obfuscated']
170
290
 
@@ -264,6 +384,22 @@ class ReportGeneratorTest < ActiveSupport::TestCase
264
384
  assert_equal 1, generator.hosts_count
265
385
  end
266
386
 
387
+ test 'include also hosts with non-redhat OS' do
388
+ os = @host.operatingsystem
389
+ os.name = 'Centos'
390
+ os.save!
391
+
392
+ # make a_host last
393
+ batch = ForemanInventoryUpload::Generators::Queries.for_org(@host.organization_id).first
394
+ generator = create_generator(batch)
395
+
396
+ json_str = generator.render
397
+ actual = JSON.parse(json_str.join("\n"))
398
+
399
+ assert_equal 'slice_123', actual['report_slice_id']
400
+ assert_equal 1, generator.hosts_count
401
+ end
402
+
267
403
  test 'shows system_memory_bytes in bytes' do
268
404
  FactoryBot.create(:fact_value, fact_name: fact_names['memory::memtotal'], value: '1', host: @host)
269
405
 
@@ -427,6 +563,32 @@ class ReportGeneratorTest < ActiveSupport::TestCase
427
563
  assert_equal 'alibaba', actual_profile['cloud_provider']
428
564
  end
429
565
 
566
+ test 'include packages installed in the report' do
567
+ FactoryBot.create(:setting, :name => 'exclude_installed_packages', :value => false)
568
+ installed_package = ::Katello::InstalledPackage.create(name: 'test-package', nvrea: 'test-package-1.0.x86_64', nvra: 'test-package-1.0.x86_64')
569
+
570
+ another_host = FactoryBot.create(
571
+ :host,
572
+ :with_subscription,
573
+ :with_content,
574
+ content_view: @host.content_view,
575
+ lifecycle_environment: @host.lifecycle_environment,
576
+ organization: @host.organization,
577
+ installed_packages: [installed_package]
578
+ )
579
+
580
+ batch = Host.where(id: another_host.id).in_batches.first
581
+ generator = create_generator(batch)
582
+
583
+ json_str = generator.render
584
+ actual = JSON.parse(json_str.join("\n"))
585
+
586
+ assert_equal 'slice_123', actual['report_slice_id']
587
+ assert_not_nil(actual_host = actual['hosts'].first)
588
+ assert_not_nil(actual_profile = actual_host['system_profile'])
589
+ assert_not_nil(actual_profile['installed_packages'])
590
+ end
591
+
430
592
  private
431
593
 
432
594
  def create_generator(batch, name = 'slice_123')
@@ -34,10 +34,14 @@ export const autoUploadEnabled = true;
34
34
 
35
35
  export const hostObfuscationEnabled = true;
36
36
 
37
+ export const ipsObfuscationEnabled = true;
38
+
37
39
  export const filterTerm = 'some_filter';
38
40
 
39
41
  export const cloudToken = 'some-cloud-token';
40
42
 
43
+ export const excludePackages = false;
44
+
41
45
  export const props = {
42
46
  accounts,
43
47
  fetchAccountsStatus: noop,
@@ -46,6 +50,15 @@ export const props = {
46
50
  pollingProcessID,
47
51
  };
48
52
 
53
+ export const pollingResponse = {
54
+ accounts,
55
+ autoUploadEnabled,
56
+ hostObfuscationEnabled,
57
+ ipsObfuscationEnabled,
58
+ cloudToken,
59
+ excludePackages,
60
+ };
61
+
49
62
  export const fetchAccountsStatusResponse = {
50
- data: { accounts, autoUploadEnabled, hostObfuscationEnabled, cloudToken },
63
+ data: pollingResponse,
51
64
  };
@@ -1,4 +1,5 @@
1
1
  import API from 'foremanReact/API';
2
+ import { addToast } from 'foremanReact/redux/actions/toasts';
2
3
  import { inventoryUrl } from '../../ForemanInventoryHelpers';
3
4
  import {
4
5
  INVENTORY_ACCOUNT_STATUS_POLLING,
@@ -10,17 +11,10 @@ import {
10
11
 
11
12
  export const fetchAccountsStatus = () => async dispatch => {
12
13
  try {
13
- const {
14
- data: { accounts, autoUploadEnabled, hostObfuscationEnabled, cloudToken },
15
- } = await API.get(inventoryUrl('accounts'));
14
+ const { data } = await API.get(inventoryUrl('accounts'));
16
15
  dispatch({
17
16
  type: INVENTORY_ACCOUNT_STATUS_POLLING,
18
- payload: {
19
- accounts,
20
- autoUploadEnabled,
21
- hostObfuscationEnabled,
22
- cloudToken,
23
- },
17
+ payload: data,
24
18
  });
25
19
  } catch (error) {
26
20
  dispatch({
@@ -46,7 +40,7 @@ export const stopAccountStatusPolling = pollingProcessID => dispatch => {
46
40
  });
47
41
  };
48
42
 
49
- export const restartProcess = (accountID, activeTab) => dispatch => {
43
+ export const restartProcess = (accountID, activeTab) => async dispatch => {
50
44
  let processController = null;
51
45
  let processStatusName = null;
52
46
 
@@ -58,12 +52,22 @@ export const restartProcess = (accountID, activeTab) => dispatch => {
58
52
  processStatusName = 'generate_report_status';
59
53
  }
60
54
 
61
- API.post(inventoryUrl(`${accountID}/${processController}`));
62
- dispatch({
63
- type: INVENTORY_PROCESS_RESTART,
64
- payload: {
65
- accountID,
66
- processStatusName,
67
- },
68
- });
55
+ try {
56
+ await API.post(inventoryUrl(`${accountID}/${processController}`));
57
+ dispatch({
58
+ type: INVENTORY_PROCESS_RESTART,
59
+ payload: {
60
+ accountID,
61
+ processStatusName,
62
+ },
63
+ });
64
+ } catch (error) {
65
+ dispatch(
66
+ addToast({
67
+ sticky: true,
68
+ type: 'error',
69
+ message: error.message,
70
+ })
71
+ );
72
+ }
69
73
  };