foreman_rh_cloud 1.0.7 → 1.0.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +33 -0
- data/app/controllers/foreman_inventory_upload/accounts_controller.rb +2 -0
- data/app/controllers/foreman_inventory_upload/tasks_controller.rb +25 -0
- data/app/controllers/foreman_inventory_upload/uploads_controller.rb +22 -3
- data/app/controllers/foreman_rh_cloud/react_controller.rb +3 -0
- data/app/controllers/insights_cloud/hits_controller.rb +17 -0
- data/app/controllers/insights_cloud/settings_controller.rb +24 -0
- data/app/controllers/insights_cloud/tasks_controller.rb +7 -0
- data/app/helpers/foreman_inventory_upload_host_helper.rb +20 -0
- data/app/models/concerns/rh_cloud_host.rb +12 -0
- data/app/models/insights_facet.rb +7 -0
- data/app/models/insights_hit.rb +6 -0
- data/app/models/inventory_sync/inventory_status.rb +30 -0
- data/app/models/setting/rh_cloud.rb +3 -1
- data/app/overrides/hosts_list.rb +13 -0
- data/app/views/foreman_rh_cloud/react/insights_cloud.html.erb +6 -0
- data/app/views/foreman_rh_cloud/react/inventory_upload.html.erb +1 -1
- data/app/views/hosts/_insights_tab.html.erb +15 -0
- data/config/routes.rb +11 -0
- data/db/migrate/20191215104806_create_insights_hits.foreman_inventory_upload.rb +14 -0
- data/db/migrate/20191216062008_create_insights_facets.foreman_inventory_upload.rb +7 -0
- data/db/migrate/20200727111529_add_uuid_column_to_insights_facets.foreman_rh_cloud.rb +5 -0
- data/lib/foreman_inventory_upload.rb +4 -0
- data/lib/foreman_inventory_upload/async/generate_report_job.rb +1 -1
- data/lib/foreman_inventory_upload/async/shell_process.rb +15 -9
- data/lib/foreman_inventory_upload/async/upload_report_job.rb +21 -9
- data/lib/foreman_inventory_upload/generators/fact_helpers.rb +1 -1
- data/lib/foreman_inventory_upload/generators/json_stream.rb +10 -0
- data/lib/foreman_inventory_upload/generators/metadata.rb +3 -0
- data/lib/foreman_inventory_upload/generators/queries.rb +2 -4
- data/lib/foreman_inventory_upload/generators/slice.rb +40 -13
- data/lib/foreman_inventory_upload/notifications/manifest_import_success_notification_override.rb +19 -0
- data/lib/foreman_rh_cloud.rb +67 -0
- data/lib/foreman_rh_cloud/engine.rb +36 -9
- data/lib/foreman_rh_cloud/version.rb +1 -1
- data/lib/insights_cloud.rb +15 -0
- data/lib/insights_cloud/async/insights_full_sync.rb +105 -0
- data/lib/insights_cloud/async/insights_scheduled_sync.rb +23 -0
- data/lib/inventory_sync/async/host_result.rb +50 -0
- data/lib/inventory_sync/async/inventory_full_sync.rb +101 -0
- data/lib/tasks/insights.rake +15 -0
- data/lib/tasks/rh_cloud_inventory.rake +37 -0
- data/package.json +3 -1
- data/test/controllers/insights_sync/settings_controller_test.rb +30 -0
- data/test/factories/insights_factories.rb +31 -0
- data/test/jobs/insights_full_sync_test.rb +94 -0
- data/test/jobs/inventory_full_sync_test.rb +91 -0
- data/test/jobs/upload_report_job_test.rb +34 -0
- data/test/unit/insights_facet_test.rb +16 -0
- data/test/unit/metadata_generator_test.rb +2 -0
- data/test/unit/rh_cloud_http_proxy_test.rb +65 -0
- data/test/unit/slice_generator_test.rb +73 -10
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.fixtures.js +8 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListActions.js +3 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListReducer.js +11 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListSelectors.js +9 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListActions.test.js +8 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListReducer.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js +7 -2
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListActions.test.js.snap +21 -2
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListReducer.test.js.snap +11 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListSelectors.test.js.snap +3 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcher.js +6 -6
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/__snapshots__/AutoUploadSwitcher.test.js.snap +9 -9
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/autoUploadSwitcher.scss +1 -1
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardActions.test.js +2 -2
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardSelectors.test.js +2 -2
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/FullScreenModal.js +5 -1
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/__tests__/__snapshots__/FullScreenModal.test.js.snap +1 -0
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/fullScreenModal.scss +15 -13
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.fixtures.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.js +29 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherActions.js +30 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherConstants.js +3 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/HostObfuscationSwitcher.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/HostObfuscationSwitcherActions.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/__snapshots__/HostObfuscationSwitcher.test.js.snap +38 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/__snapshots__/HostObfuscationSwitcherActions.test.js.snap +14 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/hostObfuscationSwitcher.scss +0 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/index.js +20 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterSelectors.test.js +2 -2
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/integration.test.js.snap +9 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettings.js +15 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/InventorySettings.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettings.test.js.snap +13 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/inventorySettings.scss +15 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.js +14 -4
- data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/__snapshots__/PageHeader.test.js.snap +24 -5
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/DocsButton.js +18 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/__tests__/DocsButton.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/__tests__/__snapshots__/DocsButton.test.js.snap +21 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/HistoryButton.js +19 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/__tests__/HistoryButton.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/__tests__/__snapshots__/HistoryButton.test.js.snap +22 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/PageDescription.js +24 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/PageDescription.test.js +11 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/__snapshots__/PageDescription.test.js.snap +17 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButton.js +52 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonActions.js +59 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonConstants.js +3 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonReducer.js +36 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonSelectors.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButton.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonActions.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonFixtures.js +9 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonReducer.test.js +33 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonSelectors.test.js +36 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButton.test.js.snap +26 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonActions.test.js.snap +36 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonReducer.test.js.snap +25 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonSelectors.test.js.snap +18 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Modal.js +63 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Toast.js +41 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/modal.scss +20 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/index.js +22 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/ToolbarButtons.js +15 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/ToolbarButtons.test.js +12 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/__snapshots__/ToolbarButtons.test.js.snap +11 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/toolbarButtons.scss +12 -0
- data/webpack/ForemanInventoryUpload/Components/StatusChart/StatusChart.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/StatusChart/__tests__/__snapshots__/StatusChart.test.js.snap +1 -1
- data/webpack/ForemanInventoryUpload/Components/TabContainer/tabContainer.scss +1 -1
- data/webpack/ForemanInventoryUpload/ForemanInventoryConstants.js +7 -1
- data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +8 -0
- data/webpack/ForemanInventoryUpload/ForemanInventoryUploadReducers.js +2 -0
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/SubscriptionsPageExtensionActions.js +34 -0
- data/webpack/ForemanInventoryUpload/__tests__/ForemanInventoryHelpers.test.js +2 -1
- data/webpack/ForemanInventoryUpload/__tests__/__snapshots__/ForemanInventoryHelpers.test.js.snap +2 -0
- data/webpack/ForemanRhCloudPages.js +9 -0
- data/webpack/ForemanRhCloudReducers.js +4 -0
- data/webpack/ForemanRhCloudSelectors.js +7 -0
- data/webpack/ForemanRhCloudTestHelpers.js +17 -2
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettings.js +33 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsActions.js +60 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsConstants.js +10 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsReducer.js +28 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsSelectors.js +6 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettings.test.js +18 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsActions.test.js +46 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsReducer.test.js +56 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsSelectors.test.js +21 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettings.test.js.snap +15 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsActions.test.js.snap +31 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsReducer.test.js.snap +33 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsSelectors.test.js.snap +9 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/index.js +21 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/insightsSettings.scss +16 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/InsightsSyncSwitcher.fixtures.js +1 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/InsightsSyncSwitcher.js +45 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/__tests__/InsightsSyncSwitcher.test.js +17 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/__tests__/__snapshots__/InsightsSyncSwitcher.test.js.snap +38 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/index.js +1 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/insightsSyncSwitcher.scss +3 -0
- data/webpack/InsightsCloudSync/InsightsCloudSync.js +59 -0
- data/webpack/InsightsCloudSync/InsightsCloudSync.test.js +16 -0
- data/webpack/InsightsCloudSync/InsightsCloudSyncActions.js +23 -0
- data/webpack/InsightsCloudSync/InsightsCloudSyncConstants.js +6 -0
- data/webpack/InsightsCloudSync/InsightsCloudSyncHelpers.js +3 -0
- data/webpack/InsightsCloudSync/InsightsCloudSyncReducers.js +8 -0
- data/webpack/InsightsCloudSync/__snapshots__/InsightsCloudSync.test.js.snap +67 -0
- data/webpack/InsightsCloudSync/__tests__/InsightsCloudSyncHelpers.test.js +11 -0
- data/webpack/InsightsCloudSync/__tests__/__snapshots__/InsightsCloudSyncHelpers.test.js.snap +3 -0
- data/webpack/InsightsCloudSync/index.js +18 -0
- data/webpack/InsightsHostDetailsTab/InsightsTab.js +64 -0
- data/webpack/InsightsHostDetailsTab/InsightsTab.scss +86 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabActions.js +30 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabConstants.js +3 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabReducer.js +26 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabSelectors.js +3 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.fixtures.js +25 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.test.js +13 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabActions.test.js +13 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabIntegration.test.js +17 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabReducer.test.js +35 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabSelectors.test.js +13 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTab.test.js.snap +30 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabActions.test.js.snap +20 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabReducer.test.js.snap +41 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabSelectors.test.js.snap +20 -0
- data/webpack/InsightsHostDetailsTab/components/ListItem/ListItem.js +69 -0
- data/webpack/InsightsHostDetailsTab/components/ListItem/index.js +1 -0
- data/webpack/InsightsHostDetailsTab/index.js +20 -0
- data/webpack/__mocks__/foremanReact/constants.js +5 -0
- data/webpack/__mocks__/foremanReact/redux/actions/toasts.js +8 -0
- data/webpack/__tests__/ForemanRhCloudSelectors.test.js +7 -2
- data/webpack/__tests__/ForemanRhCloudTestHelpers.test.js +12 -2
- data/webpack/__tests__/__snapshots__/ForemanRhCloudSelectors.test.js.snap +12 -2
- data/webpack/__tests__/__snapshots__/ForemanRhCloudTestHelpers.test.js.snap +29 -1
- data/webpack/index.js +2 -5
- data/webpack/stories/decorators/withCardsDecorator.js +1 -1
- data/webpack/subscriptions_extension_index.js +8 -0
- metadata +144 -3
- data/lib/tasks/generator.rake +0 -29
data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js
CHANGED
@@ -4,19 +4,22 @@ import {
|
|
4
4
|
selectAccounts,
|
5
5
|
selectPollingProcessID,
|
6
6
|
selectAutoUploadEnabled,
|
7
|
+
selectHostObfuscationEnabled,
|
7
8
|
} from '../AccountListSelectors';
|
8
9
|
import {
|
9
10
|
pollingProcessID,
|
10
11
|
accounts,
|
11
12
|
autoUploadEnabled,
|
13
|
+
hostObfuscationEnabled,
|
12
14
|
} from '../AccountList.fixtures';
|
13
|
-
import {
|
15
|
+
import { rhCloudStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
|
14
16
|
|
15
|
-
const state =
|
17
|
+
const state = rhCloudStateWrapper({
|
16
18
|
accountsList: {
|
17
19
|
accounts,
|
18
20
|
pollingProcessID,
|
19
21
|
autoUploadEnabled,
|
22
|
+
hostObfuscationEnabled,
|
20
23
|
},
|
21
24
|
});
|
22
25
|
|
@@ -27,6 +30,8 @@ const fixtures = {
|
|
27
30
|
selectPollingProcessID(state),
|
28
31
|
'should return AccountList autoUploadEnabled': () =>
|
29
32
|
selectAutoUploadEnabled(state),
|
33
|
+
'should return AccountList hostObfuscationEnabled': () =>
|
34
|
+
selectHostObfuscationEnabled(state),
|
30
35
|
};
|
31
36
|
|
32
37
|
describe('AccountList selectors', () =>
|
@@ -5,9 +5,28 @@ Array [
|
|
5
5
|
Array [
|
6
6
|
Object {
|
7
7
|
"payload": Object {
|
8
|
-
"
|
8
|
+
"accounts": Object {
|
9
|
+
"Account1": Object {
|
10
|
+
"generate_report_status": "running",
|
11
|
+
"label": "test_org1",
|
12
|
+
"upload_report_status": "running",
|
13
|
+
},
|
14
|
+
"Account2": Object {
|
15
|
+
"generate_report_status": "failure",
|
16
|
+
"label": "test_org2",
|
17
|
+
"upload_report_status": "unknown",
|
18
|
+
},
|
19
|
+
"Account3": Object {
|
20
|
+
"generate_report_status": "running",
|
21
|
+
"label": "test_org3",
|
22
|
+
"upload_report_status": "success",
|
23
|
+
},
|
24
|
+
},
|
25
|
+
"autoUploadEnabled": true,
|
26
|
+
"cloudToken": "some-cloud-token",
|
27
|
+
"hostObfuscationEnabled": true,
|
9
28
|
},
|
10
|
-
"type": "
|
29
|
+
"type": "INVENTORY_ACCOUNT_STATUS_POLLING",
|
11
30
|
},
|
12
31
|
],
|
13
32
|
]
|
@@ -9,6 +9,15 @@ Object {
|
|
9
9
|
}
|
10
10
|
`;
|
11
11
|
|
12
|
+
exports[`AccountList reducer should handle HOST_OBFUSCATION_TOGGLE 1`] = `
|
13
|
+
Object {
|
14
|
+
"accounts": Object {},
|
15
|
+
"error": null,
|
16
|
+
"hostObfuscationEnabled": true,
|
17
|
+
"pollingProcessID": 0,
|
18
|
+
}
|
19
|
+
`;
|
20
|
+
|
12
21
|
exports[`AccountList reducer should handle INVENTORY_ACCOUNT_STATUS_POLLING 1`] = `
|
13
22
|
Object {
|
14
23
|
"accounts": Object {
|
@@ -29,7 +38,9 @@ Object {
|
|
29
38
|
},
|
30
39
|
},
|
31
40
|
"autoUploadEnabled": true,
|
41
|
+
"cloudToken": "some-cloud-token",
|
32
42
|
"error": null,
|
43
|
+
"hostObfuscationEnabled": true,
|
33
44
|
"pollingProcessID": 0,
|
34
45
|
}
|
35
46
|
`;
|
@@ -22,6 +22,8 @@ Object {
|
|
22
22
|
|
23
23
|
exports[`AccountList selectors should return AccountList autoUploadEnabled 1`] = `true`;
|
24
24
|
|
25
|
+
exports[`AccountList selectors should return AccountList hostObfuscationEnabled 1`] = `true`;
|
26
|
+
|
25
27
|
exports[`AccountList selectors should return AccountList pollingProcessID 1`] = `0`;
|
26
28
|
|
27
29
|
exports[`AccountList selectors should return AccountsList 1`] = `
|
@@ -44,6 +46,7 @@ Object {
|
|
44
46
|
},
|
45
47
|
},
|
46
48
|
"autoUploadEnabled": true,
|
49
|
+
"hostObfuscationEnabled": true,
|
47
50
|
"pollingProcessID": 0,
|
48
51
|
}
|
49
52
|
`;
|
@@ -6,17 +6,17 @@ import './autoUploadSwitcher.scss';
|
|
6
6
|
|
7
7
|
const AutoUploadSwitcher = ({ autoUploadEnabled, handleToggle }) => (
|
8
8
|
<div className="auto_upload_switcher">
|
9
|
-
<
|
10
|
-
size="mini"
|
11
|
-
value={autoUploadEnabled}
|
12
|
-
onChange={() => handleToggle(autoUploadEnabled)}
|
13
|
-
/>
|
9
|
+
<span>Auto upload</span>
|
14
10
|
<FieldLevelHelp
|
15
11
|
content={__(
|
16
12
|
'Enable automatic upload of your host inventory to the Red Hat cloud'
|
17
13
|
)}
|
18
14
|
/>
|
19
|
-
<
|
15
|
+
<Switch
|
16
|
+
size="mini"
|
17
|
+
value={autoUploadEnabled}
|
18
|
+
onChange={() => handleToggle(autoUploadEnabled)}
|
19
|
+
/>
|
20
20
|
</div>
|
21
21
|
);
|
22
22
|
|
@@ -4,6 +4,15 @@ exports[`AutoUploadSwitcher rendering render with props 1`] = `
|
|
4
4
|
<div
|
5
5
|
className="auto_upload_switcher"
|
6
6
|
>
|
7
|
+
<span>
|
8
|
+
Auto upload
|
9
|
+
</span>
|
10
|
+
<FieldLevelHelp
|
11
|
+
buttonClass=""
|
12
|
+
content="Enable automatic upload of your host inventory to the Red Hat cloud"
|
13
|
+
placement="top"
|
14
|
+
rootClose={true}
|
15
|
+
/>
|
7
16
|
<Switch
|
8
17
|
animate={true}
|
9
18
|
baseClass="bootstrap-switch"
|
@@ -25,14 +34,5 @@ exports[`AutoUploadSwitcher rendering render with props 1`] = `
|
|
25
34
|
value={true}
|
26
35
|
wrapperClass="wrapper"
|
27
36
|
/>
|
28
|
-
<FieldLevelHelp
|
29
|
-
buttonClass=""
|
30
|
-
content="Enable automatic upload of your host inventory to the Red Hat cloud"
|
31
|
-
placement="top"
|
32
|
-
rootClose={true}
|
33
|
-
/>
|
34
|
-
<span>
|
35
|
-
Allow Auto Upload
|
36
|
-
</span>
|
37
37
|
</div>
|
38
38
|
`;
|
@@ -14,13 +14,13 @@ import {
|
|
14
14
|
activeTab,
|
15
15
|
accountID,
|
16
16
|
} from '../Dashboard.fixtures';
|
17
|
-
import {
|
17
|
+
import { rhCloudStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
|
18
18
|
|
19
19
|
jest.mock('foremanReact/API');
|
20
20
|
API.get.mockImplementation(() => serverMock);
|
21
21
|
|
22
22
|
const runWithGetState = (state, action, params) => dispatch => {
|
23
|
-
const getState = () =>
|
23
|
+
const getState = () => rhCloudStateWrapper({ dashboard: state });
|
24
24
|
action(params)(dispatch, getState);
|
25
25
|
};
|
26
26
|
|
data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardSelectors.test.js
CHANGED
@@ -13,9 +13,9 @@ import {
|
|
13
13
|
activeTab,
|
14
14
|
accountID,
|
15
15
|
} from '../Dashboard.fixtures';
|
16
|
-
import {
|
16
|
+
import { rhCloudStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
|
17
17
|
|
18
|
-
const state =
|
18
|
+
const state = rhCloudStateWrapper({
|
19
19
|
dashboard: {
|
20
20
|
[accountID]: {
|
21
21
|
generating: {
|
@@ -10,7 +10,11 @@ const FullScreenModal = ({
|
|
10
10
|
toggleFullScreen,
|
11
11
|
terminalProps,
|
12
12
|
}) => (
|
13
|
-
<Modal
|
13
|
+
<Modal
|
14
|
+
id="full-screen-terminal"
|
15
|
+
show={showFullScreen}
|
16
|
+
onHide={toggleFullScreen}
|
17
|
+
>
|
14
18
|
<Modal.Header>
|
15
19
|
<button
|
16
20
|
className="close"
|
@@ -1,18 +1,20 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
1
|
+
#full-screen-terminal {
|
2
|
+
.modal-dialog {
|
3
|
+
width: 95%;
|
4
|
+
height: 95%;
|
5
|
+
margin: 30px 0 0 30px;
|
5
6
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
7
|
+
.modal-body {
|
8
|
+
padding: 0;
|
9
|
+
display: flex;
|
10
|
+
height: -webkit-fill-available;
|
11
|
+
height: -moz-available;
|
12
|
+
height: fill-available;
|
12
13
|
|
13
|
-
|
14
|
-
|
15
|
-
|
14
|
+
.terminal {
|
15
|
+
margin: 0 -20px;
|
16
|
+
height: 100%;
|
17
|
+
}
|
16
18
|
}
|
17
19
|
}
|
18
20
|
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export const handleToggleResponse = { data: { autoUploadEnabled: true } };
|
data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.js
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { Switch, FieldLevelHelp } from 'patternfly-react';
|
4
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
+
|
6
|
+
const HostObfuscationSwitcher = ({ hostObfuscationEnabled, handleToggle }) => (
|
7
|
+
<div className="host_obfuscation_switcher">
|
8
|
+
<span>Obfuscate host names</span>
|
9
|
+
<FieldLevelHelp
|
10
|
+
content={__('Obfuscate host names sent to the Red Hat cloud')}
|
11
|
+
/>
|
12
|
+
<Switch
|
13
|
+
size="mini"
|
14
|
+
value={hostObfuscationEnabled}
|
15
|
+
onChange={() => handleToggle(hostObfuscationEnabled)}
|
16
|
+
/>
|
17
|
+
</div>
|
18
|
+
);
|
19
|
+
|
20
|
+
HostObfuscationSwitcher.propTypes = {
|
21
|
+
hostObfuscationEnabled: PropTypes.bool,
|
22
|
+
handleToggle: PropTypes.func.isRequired,
|
23
|
+
};
|
24
|
+
|
25
|
+
HostObfuscationSwitcher.defaultProps = {
|
26
|
+
hostObfuscationEnabled: false,
|
27
|
+
};
|
28
|
+
|
29
|
+
export default HostObfuscationSwitcher;
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import API from 'foremanReact/API';
|
2
|
+
import { inventoryUrl } from '../../ForemanInventoryHelpers';
|
3
|
+
import {
|
4
|
+
HOST_OBFUSCATION_TOGGLE,
|
5
|
+
HOST_OBFUSCATION_TOGGLE_ERROR,
|
6
|
+
} from './HostObfuscationSwitcherConstants';
|
7
|
+
|
8
|
+
export const handleToggle = currentHostObfuscationEnabled => async dispatch => {
|
9
|
+
const toggledHostObfuscationEnabled = !currentHostObfuscationEnabled;
|
10
|
+
try {
|
11
|
+
const {
|
12
|
+
data: { hostObfuscationEnabled },
|
13
|
+
} = await API.post(inventoryUrl('host_obfuscation'), {
|
14
|
+
value: toggledHostObfuscationEnabled,
|
15
|
+
});
|
16
|
+
dispatch({
|
17
|
+
type: HOST_OBFUSCATION_TOGGLE,
|
18
|
+
payload: {
|
19
|
+
hostObfuscationEnabled,
|
20
|
+
},
|
21
|
+
});
|
22
|
+
} catch (error) {
|
23
|
+
dispatch({
|
24
|
+
type: HOST_OBFUSCATION_TOGGLE_ERROR,
|
25
|
+
payload: {
|
26
|
+
error: error.message,
|
27
|
+
},
|
28
|
+
});
|
29
|
+
}
|
30
|
+
};
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import { noop } from 'patternfly-react';
|
3
|
+
|
4
|
+
import HostObfuscationSwitcher from '../HostObfuscationSwitcher';
|
5
|
+
|
6
|
+
const fixtures = {
|
7
|
+
'render with props': { hostObfuscationEnabled: true, handleToggle: noop },
|
8
|
+
/** fixtures, props for the component */
|
9
|
+
};
|
10
|
+
|
11
|
+
describe('HostObfuscationSwitcher', () => {
|
12
|
+
describe('rendering', () =>
|
13
|
+
testComponentSnapshotsWithFixtures(HostObfuscationSwitcher, fixtures));
|
14
|
+
});
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { testActionSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import API from 'foremanReact/API';
|
3
|
+
import { handleToggle } from '../HostObfuscationSwitcherActions';
|
4
|
+
import { handleToggleResponse } from '../HostObfuscationSwitcher.fixtures';
|
5
|
+
|
6
|
+
jest.mock('foremanReact/API');
|
7
|
+
API.post.mockImplementation(async () => handleToggleResponse);
|
8
|
+
|
9
|
+
const fixtures = {
|
10
|
+
'should handleToggle': () => handleToggle(),
|
11
|
+
};
|
12
|
+
|
13
|
+
describe('HostObfuscationSwitcher actions', () =>
|
14
|
+
testActionSnapshotWithFixtures(fixtures));
|
@@ -0,0 +1,38 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`HostObfuscationSwitcher rendering render with props 1`] = `
|
4
|
+
<div
|
5
|
+
className="host_obfuscation_switcher"
|
6
|
+
>
|
7
|
+
<span>
|
8
|
+
Obfuscate host names
|
9
|
+
</span>
|
10
|
+
<FieldLevelHelp
|
11
|
+
buttonClass=""
|
12
|
+
content="Obfuscate host names sent to the Red Hat cloud"
|
13
|
+
placement="top"
|
14
|
+
rootClose={true}
|
15
|
+
/>
|
16
|
+
<Switch
|
17
|
+
animate={true}
|
18
|
+
baseClass="bootstrap-switch"
|
19
|
+
bsSize={null}
|
20
|
+
defaultValue={true}
|
21
|
+
disabled={false}
|
22
|
+
handleWidth="auto"
|
23
|
+
inverse={false}
|
24
|
+
labelText=" "
|
25
|
+
labelWidth="auto"
|
26
|
+
offColor="default"
|
27
|
+
offText="OFF"
|
28
|
+
onChange={[Function]}
|
29
|
+
onColor="primary"
|
30
|
+
onText="ON"
|
31
|
+
readonly={false}
|
32
|
+
size="mini"
|
33
|
+
tristate={false}
|
34
|
+
value={true}
|
35
|
+
wrapperClass="wrapper"
|
36
|
+
/>
|
37
|
+
</div>
|
38
|
+
`;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`HostObfuscationSwitcher actions should handleToggle 1`] = `
|
4
|
+
Array [
|
5
|
+
Array [
|
6
|
+
Object {
|
7
|
+
"payload": Object {
|
8
|
+
"hostObfuscationEnabled": undefined,
|
9
|
+
},
|
10
|
+
"type": "HOST_OBFUSCATION_TOGGLE",
|
11
|
+
},
|
12
|
+
],
|
13
|
+
]
|
14
|
+
`;
|
data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/hostObfuscationSwitcher.scss
ADDED
File without changes
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { bindActionCreators } from 'redux';
|
2
|
+
import { connect } from 'react-redux';
|
3
|
+
|
4
|
+
import * as actions from './HostObfuscationSwitcherActions';
|
5
|
+
import HostObfuscationSwitcher from './HostObfuscationSwitcher';
|
6
|
+
import { selectHostObfuscationEnabled } from '../AccountList/AccountListSelectors';
|
7
|
+
|
8
|
+
// map state to props
|
9
|
+
const mapStateToProps = state => ({
|
10
|
+
hostObfuscationEnabled: selectHostObfuscationEnabled(state),
|
11
|
+
});
|
12
|
+
|
13
|
+
// map action dispatchers to props
|
14
|
+
const mapDispatchToProps = dispatch => bindActionCreators(actions, dispatch);
|
15
|
+
|
16
|
+
// export connected component
|
17
|
+
export default connect(
|
18
|
+
mapStateToProps,
|
19
|
+
mapDispatchToProps
|
20
|
+
)(HostObfuscationSwitcher);
|
@@ -1,12 +1,12 @@
|
|
1
1
|
import { testSelectorsSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
2
|
import { filterTerm } from '../InventoryFilter.fixtures';
|
3
|
-
import {
|
3
|
+
import { rhCloudStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
|
4
4
|
import {
|
5
5
|
selectInventoryFilter,
|
6
6
|
selectFilterTerm,
|
7
7
|
} from '../InventoryFilterSelectors';
|
8
8
|
|
9
|
-
const state =
|
9
|
+
const state = rhCloudStateWrapper({
|
10
10
|
inventoryFilter: {
|
11
11
|
filterTerm,
|
12
12
|
},
|