foreman_rh_cloud 12.0.0 → 12.1.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/controllers/concerns/inventory_upload/report_actions.rb +1 -1
- data/app/controllers/foreman_inventory_upload/accounts_controller.rb +2 -0
- data/app/controllers/foreman_inventory_upload/uploads_settings_controller.rb +2 -0
- data/app/services/foreman_rh_cloud/cloud_request.rb +4 -0
- data/app/services/foreman_rh_cloud/cloud_request_forwarder.rb +17 -1
- data/app/services/foreman_rh_cloud/rules_ingester.rb +12 -1
- data/config/routes.rb +4 -0
- data/lib/foreman_inventory_upload/generators/queries.rb +2 -0
- data/lib/foreman_inventory_upload/generators/slice.rb +83 -42
- data/lib/foreman_inventory_upload.rb +5 -0
- data/lib/foreman_rh_cloud/engine.rb +15 -3
- data/lib/foreman_rh_cloud/version.rb +1 -1
- data/lib/foreman_rh_cloud.rb +2 -0
- data/package.json +1 -1
- data/test/unit/slice_generator_test.rb +212 -4
- data/webpack/ForemanInventoryUpload/Components/Dashboard/Dashboard.js +5 -1
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/__snapshots__/Dashboard.test.js.snap +2 -1
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/AdvancedSetting/AdvancedSettingsConstants.js +27 -8
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/AdvancedSetting/index.js +11 -3
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettings.js +71 -10
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettingsSelectors.js +13 -1
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/MinimalInventoryDropdown.js +107 -0
- data/webpack/ForemanInventoryUpload/Components/NavContainer/NavContainer.fixtures.js +9 -2
- data/webpack/ForemanInventoryUpload/Components/NavContainer/NavContainer.js +8 -0
- data/webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/NavContainer.test.js +53 -9
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/PageDescription.js +72 -58
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/PageDescription.test.js +61 -6
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/ToolbarButtons.js +18 -6
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/ToolbarButtons.test.js +54 -6
- data/webpack/ForemanInventoryUpload/Components/ReportGenerate/ReportGenerate.fixtures.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/ReportGenerate/ReportGenerate.js +8 -0
- data/webpack/ForemanInventoryUpload/Components/ReportGenerate/__tests__/__snapshots__/ReportGenerate.test.js.snap +4 -2
- data/webpack/ForemanInventoryUpload/Components/ReportUpload/ReportUpload.js +1 -8
- data/webpack/ForemanInventoryUpload/Components/ReportUpload/__tests__/__snapshots__/ReportUpload.test.js.snap +4 -2
- data/webpack/ForemanInventoryUpload/Components/TabHeader/TabHeader.js +47 -28
- data/webpack/ForemanInventoryUpload/Components/TabHeader/__tests__/TabHeader.test.js +46 -8
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/InventoryAutoUpload.js +2 -7
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/__tests__/__snapshots__/InventoryAutoUpload.test.js.snap +1 -6
- data/webpack/common/Switcher/SwitcherPF4.js +11 -1
- metadata +4 -11
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/InventorySettings.test.js +0 -13
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettings.test.js.snap +0 -31
- data/webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/__snapshots__/NavContainer.test.js.snap +0 -89
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/__snapshots__/PageDescription.test.js.snap +0 -62
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/__snapshots__/ToolbarButtons.test.js.snap +0 -10
- data/webpack/ForemanInventoryUpload/Components/TabHeader/__tests__/__snapshots__/TabHeader.test.js.snap +0 -43
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/components/AdvancedSettings/AdvancedSettings.js +0 -72
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/components/AdvancedSettings/index.js +0 -23
@@ -1,13 +1,25 @@
|
|
1
1
|
import React from 'react';
|
2
|
+
import { useSelector } from 'react-redux';
|
2
3
|
import SyncButton from '../SyncButton';
|
3
4
|
import CloudConnectorButton from '../CloudConnectorButton';
|
4
5
|
import './toolbarButtons.scss';
|
6
|
+
import { selectSubscriptionConnectionEnabled } from '../../../InventorySettings/InventorySettingsSelectors';
|
5
7
|
|
6
|
-
const ToolbarButtons = () =>
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
)
|
8
|
+
const ToolbarButtons = () => {
|
9
|
+
const subscriptionConnectionEnabled = useSelector(
|
10
|
+
selectSubscriptionConnectionEnabled
|
11
|
+
);
|
12
|
+
|
13
|
+
if (!subscriptionConnectionEnabled) {
|
14
|
+
return null;
|
15
|
+
}
|
16
|
+
|
17
|
+
return (
|
18
|
+
<div className="inventory_toolbar_buttons">
|
19
|
+
<CloudConnectorButton />
|
20
|
+
<SyncButton />
|
21
|
+
</div>
|
22
|
+
);
|
23
|
+
};
|
12
24
|
|
13
25
|
export default ToolbarButtons;
|
@@ -1,12 +1,60 @@
|
|
1
|
-
import
|
2
|
-
|
1
|
+
import React from 'react';
|
2
|
+
import { Provider } from 'react-redux';
|
3
|
+
import configureMockStore from 'redux-mock-store';
|
4
|
+
import thunk from 'redux-thunk';
|
5
|
+
import { screen, render } from '@testing-library/react';
|
3
6
|
import ToolbarButtons from '../ToolbarButtons';
|
4
7
|
|
5
|
-
const
|
6
|
-
|
8
|
+
const middlewares = [thunk];
|
9
|
+
const mockStore = configureMockStore(middlewares);
|
10
|
+
|
11
|
+
const renderOptions = {
|
12
|
+
API: {
|
13
|
+
INVENTORY_SETTINGS: {
|
14
|
+
response: { subscriptionConnectionEnabled: true },
|
15
|
+
},
|
16
|
+
},
|
17
|
+
ForemanRhCloud: {
|
18
|
+
inventoryUpload: {
|
19
|
+
accountsList: {
|
20
|
+
CloudConnectorStatus: {},
|
21
|
+
},
|
22
|
+
},
|
23
|
+
},
|
7
24
|
};
|
8
25
|
|
9
26
|
describe('ToolbarButtons', () => {
|
10
|
-
|
11
|
-
|
27
|
+
test('when subscription connection is enabled', () => {
|
28
|
+
const store = mockStore(renderOptions);
|
29
|
+
|
30
|
+
render(
|
31
|
+
<Provider store={store}>
|
32
|
+
<ToolbarButtons />
|
33
|
+
</Provider>
|
34
|
+
);
|
35
|
+
expect(screen.queryAllByText('Configure cloud connector')).toHaveLength(1);
|
36
|
+
expect(screen.queryAllByText('Sync all inventory status')).toHaveLength(1);
|
37
|
+
});
|
38
|
+
|
39
|
+
test('when subscription connection is not enabled', () => {
|
40
|
+
const localSetting = {
|
41
|
+
API: {
|
42
|
+
INVENTORY_SETTINGS: {
|
43
|
+
response: { subscriptionConnectionEnabled: false },
|
44
|
+
},
|
45
|
+
},
|
46
|
+
};
|
47
|
+
const store = mockStore({
|
48
|
+
...renderOptions,
|
49
|
+
...localSetting,
|
50
|
+
});
|
51
|
+
|
52
|
+
render(
|
53
|
+
<Provider store={store}>
|
54
|
+
<ToolbarButtons />
|
55
|
+
</Provider>
|
56
|
+
);
|
57
|
+
expect(screen.queryAllByText('Configure cloud connector')).toHaveLength(0);
|
58
|
+
expect(screen.queryAllByText('Sync all inventory status')).toHaveLength(0);
|
59
|
+
});
|
12
60
|
});
|
@@ -4,6 +4,7 @@ export const exitCode = 'exit 0';
|
|
4
4
|
export const logs = ['No running process'];
|
5
5
|
export const completed = 0;
|
6
6
|
export const restartProcess = noop;
|
7
|
+
export const downloadReports = noop;
|
7
8
|
export const error = null;
|
8
9
|
export const scheduled = '2019-08-21T16:14:16.520+03:00';
|
9
10
|
export const props = {
|
@@ -11,6 +12,7 @@ export const props = {
|
|
11
12
|
logs,
|
12
13
|
completed,
|
13
14
|
restartProcess,
|
15
|
+
downloadReports,
|
14
16
|
error,
|
15
17
|
scheduled,
|
16
18
|
};
|
@@ -12,6 +12,8 @@ const ReportGenerate = ({
|
|
12
12
|
completed,
|
13
13
|
error,
|
14
14
|
restartProcess,
|
15
|
+
downloadReports,
|
16
|
+
downloadButtonDisabled,
|
15
17
|
toggleFullScreen,
|
16
18
|
scheduled,
|
17
19
|
}) => (
|
@@ -19,6 +21,8 @@ const ReportGenerate = ({
|
|
19
21
|
<TabHeader
|
20
22
|
exitCode={exitCode}
|
21
23
|
onRestart={restartProcess}
|
24
|
+
onDownload={downloadReports}
|
25
|
+
downloadButtonDisabled={downloadButtonDisabled}
|
22
26
|
toggleFullScreen={toggleFullScreen}
|
23
27
|
/>
|
24
28
|
<TabBody
|
@@ -40,6 +44,8 @@ ReportGenerate.propTypes = {
|
|
40
44
|
completed: PropTypes.number,
|
41
45
|
error: PropTypes.string,
|
42
46
|
restartProcess: PropTypes.func,
|
47
|
+
downloadReports: PropTypes.func,
|
48
|
+
downloadButtonDisabled: PropTypes.func,
|
43
49
|
toggleFullScreen: PropTypes.func,
|
44
50
|
scheduled: PropTypes.string,
|
45
51
|
};
|
@@ -50,6 +56,8 @@ ReportGenerate.defaultProps = {
|
|
50
56
|
completed: 0,
|
51
57
|
error: null,
|
52
58
|
restartProcess: noop,
|
59
|
+
downloadReports: noop,
|
60
|
+
downloadButtonDisabled: noop,
|
53
61
|
toggleFullScreen: noop,
|
54
62
|
scheduled: null,
|
55
63
|
};
|
@@ -5,8 +5,9 @@ exports[`ReportGenerate rendering render with Props 1`] = `
|
|
5
5
|
className="report-generate"
|
6
6
|
>
|
7
7
|
<TabHeader
|
8
|
+
downloadButtonDisabled={[Function]}
|
8
9
|
exitCode="exit 0"
|
9
|
-
onDownload={
|
10
|
+
onDownload={[Function]}
|
10
11
|
onRestart={[Function]}
|
11
12
|
toggleFullScreen={[Function]}
|
12
13
|
/>
|
@@ -29,8 +30,9 @@ exports[`ReportGenerate rendering render without Props 1`] = `
|
|
29
30
|
className="report-generate"
|
30
31
|
>
|
31
32
|
<TabHeader
|
33
|
+
downloadButtonDisabled={[Function]}
|
32
34
|
exitCode=""
|
33
|
-
onDownload={
|
35
|
+
onDownload={[Function]}
|
34
36
|
onRestart={[Function]}
|
35
37
|
toggleFullScreen={[Function]}
|
36
38
|
/>
|
@@ -10,16 +10,11 @@ const ReportUpload = ({
|
|
10
10
|
exitCode,
|
11
11
|
logs,
|
12
12
|
completed,
|
13
|
-
downloadReports,
|
14
13
|
error,
|
15
14
|
toggleFullScreen,
|
16
15
|
}) => (
|
17
16
|
<TabContainer className="report-upload">
|
18
|
-
<TabHeader
|
19
|
-
exitCode={exitCode}
|
20
|
-
onDownload={downloadReports}
|
21
|
-
toggleFullScreen={toggleFullScreen}
|
22
|
-
/>
|
17
|
+
<TabHeader exitCode={exitCode} toggleFullScreen={toggleFullScreen} />
|
23
18
|
<TabBody
|
24
19
|
exitCode={exitCode}
|
25
20
|
logs={logs}
|
@@ -36,7 +31,6 @@ ReportUpload.propTypes = {
|
|
36
31
|
PropTypes.string,
|
37
32
|
]),
|
38
33
|
completed: PropTypes.number,
|
39
|
-
downloadReports: PropTypes.func,
|
40
34
|
error: PropTypes.string,
|
41
35
|
toggleFullScreen: PropTypes.func,
|
42
36
|
};
|
@@ -45,7 +39,6 @@ ReportUpload.defaultProps = {
|
|
45
39
|
exitCode: '',
|
46
40
|
logs: null,
|
47
41
|
completed: 0,
|
48
|
-
downloadReports: noop,
|
49
42
|
error: null,
|
50
43
|
toggleFullScreen: noop,
|
51
44
|
};
|
@@ -5,8 +5,9 @@ exports[`ReportUpload rendering render with Props 1`] = `
|
|
5
5
|
className="report-upload"
|
6
6
|
>
|
7
7
|
<TabHeader
|
8
|
+
downloadButtonDisabled={[Function]}
|
8
9
|
exitCode="exit 0"
|
9
|
-
onDownload={
|
10
|
+
onDownload={null}
|
10
11
|
onRestart={null}
|
11
12
|
toggleFullScreen={[Function]}
|
12
13
|
/>
|
@@ -29,8 +30,9 @@ exports[`ReportUpload rendering render without Props 1`] = `
|
|
29
30
|
className="report-upload"
|
30
31
|
>
|
31
32
|
<TabHeader
|
33
|
+
downloadButtonDisabled={[Function]}
|
32
34
|
exitCode=""
|
33
|
-
onDownload={
|
35
|
+
onDownload={null}
|
34
36
|
onRestart={null}
|
35
37
|
toggleFullScreen={[Function]}
|
36
38
|
/>
|
@@ -1,45 +1,63 @@
|
|
1
1
|
import React from 'react';
|
2
|
+
import { useSelector } from 'react-redux';
|
2
3
|
import PropTypes from 'prop-types';
|
3
4
|
import { Grid, Button, Icon } from 'patternfly-react';
|
4
5
|
import { noop } from 'foremanReact/common/helpers';
|
5
6
|
import { sprintf, translate as __ } from 'foremanReact/common/I18n';
|
7
|
+
import { selectSubscriptionConnectionEnabled } from '../InventorySettings/InventorySettingsSelectors';
|
6
8
|
import { isExitCodeLoading } from '../../ForemanInventoryHelpers';
|
7
9
|
import './tabHeader.scss';
|
8
10
|
|
9
|
-
const TabHeader = ({
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
11
|
+
const TabHeader = ({
|
12
|
+
exitCode,
|
13
|
+
onRestart,
|
14
|
+
onDownload,
|
15
|
+
downloadButtonDisabled,
|
16
|
+
toggleFullScreen,
|
17
|
+
}) => {
|
18
|
+
const subscriptionConnectionEnabled = useSelector(
|
19
|
+
selectSubscriptionConnectionEnabled
|
20
|
+
);
|
21
|
+
const buttonGenerateLabel = subscriptionConnectionEnabled
|
22
|
+
? __('Generate and upload report')
|
23
|
+
: __('Generate report');
|
24
|
+
|
25
|
+
return (
|
26
|
+
<Grid.Row className="tab-header">
|
27
|
+
<Grid.Col sm={6}>
|
28
|
+
<p>{sprintf(__('Exit Code: %s'), exitCode)}</p>
|
29
|
+
</Grid.Col>
|
30
|
+
<Grid.Col sm={6}>
|
31
|
+
<div className="tab-action-buttons">
|
32
|
+
{onRestart ? (
|
33
|
+
<Button
|
34
|
+
bsStyle="primary"
|
35
|
+
onClick={onRestart}
|
36
|
+
disabled={isExitCodeLoading(exitCode)}
|
37
|
+
>
|
38
|
+
{buttonGenerateLabel}
|
39
|
+
</Button>
|
40
|
+
) : null}
|
41
|
+
{onDownload ? (
|
42
|
+
<Button onClick={onDownload} disabled={downloadButtonDisabled()}>
|
43
|
+
{__('Download Report')} <Icon name="download" />
|
44
|
+
</Button>
|
45
|
+
) : null}
|
46
|
+
<Button onClick={toggleFullScreen}>
|
47
|
+
{__('Full Screen')}
|
48
|
+
<Icon name="arrows-alt" />
|
28
49
|
</Button>
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
</div>
|
35
|
-
</Grid.Col>
|
36
|
-
</Grid.Row>
|
37
|
-
);
|
50
|
+
</div>
|
51
|
+
</Grid.Col>
|
52
|
+
</Grid.Row>
|
53
|
+
);
|
54
|
+
};
|
38
55
|
|
39
56
|
TabHeader.propTypes = {
|
40
57
|
onRestart: PropTypes.func,
|
41
58
|
onDownload: PropTypes.func,
|
42
59
|
exitCode: PropTypes.string,
|
60
|
+
downloadButtonDisabled: PropTypes.func,
|
43
61
|
toggleFullScreen: PropTypes.func,
|
44
62
|
};
|
45
63
|
|
@@ -47,6 +65,7 @@ TabHeader.defaultProps = {
|
|
47
65
|
onRestart: null,
|
48
66
|
exitCode: '',
|
49
67
|
onDownload: null,
|
68
|
+
downloadButtonDisabled: noop,
|
50
69
|
toggleFullScreen: noop,
|
51
70
|
};
|
52
71
|
|
@@ -1,13 +1,51 @@
|
|
1
|
-
import
|
2
|
-
|
1
|
+
import React from 'react';
|
2
|
+
import { Provider } from 'react-redux';
|
3
|
+
import configureMockStore from 'redux-mock-store';
|
4
|
+
import thunk from 'redux-thunk';
|
5
|
+
import { screen, render } from '@testing-library/react';
|
6
|
+
import { noop } from 'foremanReact/common/helpers';
|
3
7
|
import TabHeader from '../TabHeader';
|
4
8
|
|
5
|
-
const
|
6
|
-
|
7
|
-
/** fixtures, props for the component */
|
8
|
-
};
|
9
|
+
const middlewares = [thunk];
|
10
|
+
const mockStore = configureMockStore(middlewares);
|
9
11
|
|
10
12
|
describe('TabHeader', () => {
|
11
|
-
|
12
|
-
|
13
|
+
test('when subscription connection is enabled', () => {
|
14
|
+
const renderOptions = {
|
15
|
+
API: {
|
16
|
+
INVENTORY_SETTINGS: {
|
17
|
+
response: { subscriptionConnectionEnabled: true },
|
18
|
+
},
|
19
|
+
},
|
20
|
+
};
|
21
|
+
const store = mockStore(renderOptions);
|
22
|
+
|
23
|
+
render(
|
24
|
+
<Provider store={store}>
|
25
|
+
<TabHeader exitCode="exit 0" onRestart={noop} toggleFullScreen={noop} />
|
26
|
+
</Provider>
|
27
|
+
);
|
28
|
+
expect(screen.queryAllByText('Generate and upload report')).toHaveLength(1);
|
29
|
+
expect(screen.queryAllByText('Full Screen')).toHaveLength(1);
|
30
|
+
});
|
31
|
+
|
32
|
+
test('when subscription connection is not enabled', () => {
|
33
|
+
const renderOptions = {
|
34
|
+
API: {
|
35
|
+
INVENTORY_SETTINGS: {
|
36
|
+
response: { subscriptionConnectionEnabled: false },
|
37
|
+
},
|
38
|
+
},
|
39
|
+
};
|
40
|
+
const store = mockStore(renderOptions);
|
41
|
+
|
42
|
+
render(
|
43
|
+
<Provider store={store}>
|
44
|
+
<TabHeader exitCode="exit 0" onRestart={noop} toggleFullScreen={noop} />
|
45
|
+
</Provider>
|
46
|
+
);
|
47
|
+
|
48
|
+
expect(screen.queryAllByText('Generate report')).toHaveLength(1);
|
49
|
+
expect(screen.queryAllByText('Full Screen')).toHaveLength(1);
|
50
|
+
});
|
13
51
|
});
|
@@ -6,8 +6,8 @@ import { FormGroup, Grid } from 'patternfly-react';
|
|
6
6
|
import { translate as __ } from 'foremanReact/common/I18n';
|
7
7
|
import { foremanUrl } from '../../../ForemanRhCloudHelpers';
|
8
8
|
import Switcher from '../../../common/Switcher';
|
9
|
-
import AdvancedSettings from './components/AdvancedSettings';
|
10
9
|
import { settingsDict } from '../../Components/InventorySettings/AdvancedSetting/AdvancedSettingsConstants';
|
10
|
+
import InventorySettings from '../../Components/InventorySettings/InventorySettings';
|
11
11
|
|
12
12
|
const InventoryAutoUploadSwitcher = ({
|
13
13
|
autoUploadEnabled,
|
@@ -44,12 +44,7 @@ const InventoryAutoUploadSwitcher = ({
|
|
44
44
|
headerContent={
|
45
45
|
<strong>{__('Advanced Inventory Settings')}</strong>
|
46
46
|
}
|
47
|
-
bodyContent={
|
48
|
-
<AdvancedSettings
|
49
|
-
autoUploadEnabled={autoUploadEnabled}
|
50
|
-
handleToggle={handleToggle}
|
51
|
-
/>
|
52
|
-
}
|
47
|
+
bodyContent={<InventorySettings />}
|
53
48
|
position="right"
|
54
49
|
>
|
55
50
|
<Button
|
@@ -32,12 +32,7 @@ exports[`InventoryAutoUpload rendering render with props 1`] = `
|
|
32
32
|
sm={5}
|
33
33
|
>
|
34
34
|
<Popover
|
35
|
-
bodyContent={
|
36
|
-
<Memo(Connect(AdvancedSettings))
|
37
|
-
autoUploadEnabled={true}
|
38
|
-
handleToggle={[Function]}
|
39
|
-
/>
|
40
|
-
}
|
35
|
+
bodyContent={<InventorySettings />}
|
41
36
|
headerContent={
|
42
37
|
<strong>
|
43
38
|
Advanced Inventory Settings
|
@@ -4,11 +4,19 @@ import { Switch } from '@patternfly/react-core';
|
|
4
4
|
import { HelpLabel } from './HelpLabel';
|
5
5
|
import './SwitcherPF4.scss';
|
6
6
|
|
7
|
-
const SwitcherPF4 = ({
|
7
|
+
const SwitcherPF4 = ({
|
8
|
+
id,
|
9
|
+
label,
|
10
|
+
tooltip,
|
11
|
+
isChecked,
|
12
|
+
onChange,
|
13
|
+
isDisabled,
|
14
|
+
}) => (
|
8
15
|
<Switch
|
9
16
|
className="foreman-rh-cloud-switcher"
|
10
17
|
id={`rh-cloud-switcher-${id}`}
|
11
18
|
isChecked={isChecked}
|
19
|
+
isDisabled={isDisabled}
|
12
20
|
onChange={onChange}
|
13
21
|
label={
|
14
22
|
<div>
|
@@ -24,6 +32,7 @@ SwitcherPF4.propTypes = {
|
|
24
32
|
label: PropTypes.string,
|
25
33
|
tooltip: PropTypes.string,
|
26
34
|
isChecked: PropTypes.bool,
|
35
|
+
isDisabled: PropTypes.bool,
|
27
36
|
onChange: PropTypes.func.isRequired,
|
28
37
|
};
|
29
38
|
|
@@ -31,6 +40,7 @@ SwitcherPF4.defaultProps = {
|
|
31
40
|
label: null,
|
32
41
|
tooltip: null,
|
33
42
|
isChecked: true,
|
43
|
+
isDisabled: false,
|
34
44
|
};
|
35
45
|
|
36
46
|
export default SwitcherPF4;
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: foreman_rh_cloud
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 12.
|
4
|
+
version: 12.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Foreman Red Hat Cloud team
|
8
8
|
bindir: bin
|
9
9
|
cert_chain: []
|
10
|
-
date:
|
10
|
+
date: 1980-01-02 00:00:00.000000000 Z
|
11
11
|
dependencies:
|
12
12
|
- !ruby/object:Gem::Dependency
|
13
13
|
name: foreman_ansible
|
@@ -392,16 +392,14 @@ files:
|
|
392
392
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettingsActions.js
|
393
393
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettingsConstants.js
|
394
394
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettingsSelectors.js
|
395
|
-
- webpack/ForemanInventoryUpload/Components/InventorySettings/
|
395
|
+
- webpack/ForemanInventoryUpload/Components/InventorySettings/MinimalInventoryDropdown.js
|
396
396
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/InventorySettingsActions.test.js
|
397
|
-
- webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettings.test.js.snap
|
398
397
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettingsActions.test.js.snap
|
399
398
|
- webpack/ForemanInventoryUpload/Components/InventorySettings/index.js
|
400
399
|
- webpack/ForemanInventoryUpload/Components/NavContainer/NavContainer.fixtures.js
|
401
400
|
- webpack/ForemanInventoryUpload/Components/NavContainer/NavContainer.js
|
402
401
|
- webpack/ForemanInventoryUpload/Components/NavContainer/NavContainerHelper.js
|
403
402
|
- webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/NavContainer.test.js
|
404
|
-
- webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/__snapshots__/NavContainer.test.js.snap
|
405
403
|
- webpack/ForemanInventoryUpload/Components/NavContainer/index.js
|
406
404
|
- webpack/ForemanInventoryUpload/Components/NavContainer/navContainer.scss
|
407
405
|
- webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.js
|
@@ -423,7 +421,6 @@ files:
|
|
423
421
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/CloudPingModal/index.js
|
424
422
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/PageDescription.js
|
425
423
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/PageDescription.test.js
|
426
|
-
- webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/__tests__/__snapshots__/PageDescription.test.js.snap
|
427
424
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/PageDescription/index.js
|
428
425
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/SettingsWarning/SettingsWarning.js
|
429
426
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/SettingsWarning/SettingsWarning.test.js
|
@@ -444,7 +441,6 @@ files:
|
|
444
441
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/index.js
|
445
442
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/ToolbarButtons.js
|
446
443
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/ToolbarButtons.test.js
|
447
|
-
- webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/__snapshots__/ToolbarButtons.test.js.snap
|
448
444
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/index.js
|
449
445
|
- webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/toolbarButtons.scss
|
450
446
|
- webpack/ForemanInventoryUpload/Components/PageHeader/index.js
|
@@ -501,7 +497,6 @@ files:
|
|
501
497
|
- webpack/ForemanInventoryUpload/Components/TabHeader/TabHeader.js
|
502
498
|
- webpack/ForemanInventoryUpload/Components/TabHeader/TabHeaderHelper.js
|
503
499
|
- webpack/ForemanInventoryUpload/Components/TabHeader/__tests__/TabHeader.test.js
|
504
|
-
- webpack/ForemanInventoryUpload/Components/TabHeader/__tests__/__snapshots__/TabHeader.test.js.snap
|
505
500
|
- webpack/ForemanInventoryUpload/Components/TabHeader/index.js
|
506
501
|
- webpack/ForemanInventoryUpload/Components/TabHeader/tabHeader.scss
|
507
502
|
- webpack/ForemanInventoryUpload/Components/Terminal/Terminal.fixtures.js
|
@@ -518,8 +513,6 @@ files:
|
|
518
513
|
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/InventoryAutoUpload.js
|
519
514
|
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/__tests__/InventoryAutoUpload.test.js
|
520
515
|
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/__tests__/__snapshots__/InventoryAutoUpload.test.js.snap
|
521
|
-
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/components/AdvancedSettings/AdvancedSettings.js
|
522
|
-
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/components/AdvancedSettings/index.js
|
523
516
|
- webpack/ForemanInventoryUpload/SubscriptionsPageExtension/InventoryAutoUpload/index.js
|
524
517
|
- webpack/ForemanInventoryUpload/__tests__/ForemanInventoryHelpers.test.js
|
525
518
|
- webpack/ForemanInventoryUpload/__tests__/ForemanInventoryUpload.test.js
|
@@ -665,7 +658,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
665
658
|
- !ruby/object:Gem::Version
|
666
659
|
version: '0'
|
667
660
|
requirements: []
|
668
|
-
rubygems_version: 3.6.
|
661
|
+
rubygems_version: 3.6.7
|
669
662
|
specification_version: 4
|
670
663
|
summary: Summary of ForemanRhCloud.
|
671
664
|
test_files:
|
data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/InventorySettings.test.js
DELETED
@@ -1,13 +0,0 @@
|
|
1
|
-
import { testComponentSnapshotsWithFixtures } from '@theforeman/test';
|
2
|
-
|
3
|
-
import InventorySettings from '../InventorySettings';
|
4
|
-
|
5
|
-
const fixtures = {
|
6
|
-
'render without Props': {},
|
7
|
-
/** fixtures, props for the component */
|
8
|
-
};
|
9
|
-
|
10
|
-
describe('InventorySettings', () => {
|
11
|
-
describe('rendering', () =>
|
12
|
-
testComponentSnapshotsWithFixtures(InventorySettings, fixtures));
|
13
|
-
});
|
@@ -1,31 +0,0 @@
|
|
1
|
-
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
-
|
3
|
-
exports[`InventorySettings rendering render without Props 1`] = `
|
4
|
-
<div
|
5
|
-
className="inventory-settings"
|
6
|
-
>
|
7
|
-
<h3>
|
8
|
-
Settings
|
9
|
-
</h3>
|
10
|
-
<AdvancedSetting
|
11
|
-
key="autoUploadEnabled"
|
12
|
-
setting="autoUploadEnabled"
|
13
|
-
/>
|
14
|
-
<AdvancedSetting
|
15
|
-
key="hostObfuscationEnabled"
|
16
|
-
setting="hostObfuscationEnabled"
|
17
|
-
/>
|
18
|
-
<AdvancedSetting
|
19
|
-
key="ipsObfuscationEnabled"
|
20
|
-
setting="ipsObfuscationEnabled"
|
21
|
-
/>
|
22
|
-
<AdvancedSetting
|
23
|
-
key="excludePackagesEnabled"
|
24
|
-
setting="excludePackagesEnabled"
|
25
|
-
/>
|
26
|
-
<AdvancedSetting
|
27
|
-
key="allowAutoInsightsMismatchDelete"
|
28
|
-
setting="allowAutoInsightsMismatchDelete"
|
29
|
-
/>
|
30
|
-
</div>
|
31
|
-
`;
|
@@ -1,89 +0,0 @@
|
|
1
|
-
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
-
|
3
|
-
exports[`NavContainer rendering render with Props 1`] = `
|
4
|
-
<ForwardRef
|
5
|
-
defaultActiveKey={0}
|
6
|
-
id="basic-tabs-pf"
|
7
|
-
>
|
8
|
-
<div
|
9
|
-
className="dashboard"
|
10
|
-
>
|
11
|
-
<Nav
|
12
|
-
bsClass="nav nav-tabs nav-tabs-pf"
|
13
|
-
justified={false}
|
14
|
-
pullLeft={false}
|
15
|
-
pullRight={false}
|
16
|
-
stacked={false}
|
17
|
-
>
|
18
|
-
<NavItem
|
19
|
-
active={false}
|
20
|
-
className="nav_item"
|
21
|
-
disabled={false}
|
22
|
-
eventKey={0}
|
23
|
-
key="0"
|
24
|
-
onClick={[Function]}
|
25
|
-
>
|
26
|
-
<Icon
|
27
|
-
name="some-icon"
|
28
|
-
size="2x"
|
29
|
-
type="fa"
|
30
|
-
/>
|
31
|
-
<p>
|
32
|
-
some-name
|
33
|
-
</p>
|
34
|
-
</NavItem>
|
35
|
-
</Nav>
|
36
|
-
<TabContent
|
37
|
-
animation={true}
|
38
|
-
bsClass="tab"
|
39
|
-
componentClass="div"
|
40
|
-
mountOnEnter={false}
|
41
|
-
unmountOnExit={false}
|
42
|
-
>
|
43
|
-
<TabPane
|
44
|
-
bsClass="tab-pane"
|
45
|
-
eventKey={0}
|
46
|
-
key="0"
|
47
|
-
>
|
48
|
-
<component />
|
49
|
-
</TabPane>
|
50
|
-
</TabContent>
|
51
|
-
<FullScreenModal
|
52
|
-
showFullScreen={false}
|
53
|
-
terminalProps={Object {}}
|
54
|
-
toggleFullScreen={[Function]}
|
55
|
-
/>
|
56
|
-
</div>
|
57
|
-
</ForwardRef>
|
58
|
-
`;
|
59
|
-
|
60
|
-
exports[`NavContainer rendering render without Props 1`] = `
|
61
|
-
<ForwardRef
|
62
|
-
defaultActiveKey={0}
|
63
|
-
id="basic-tabs-pf"
|
64
|
-
>
|
65
|
-
<div
|
66
|
-
className="dashboard"
|
67
|
-
>
|
68
|
-
<Nav
|
69
|
-
bsClass="nav nav-tabs nav-tabs-pf"
|
70
|
-
justified={false}
|
71
|
-
pullLeft={false}
|
72
|
-
pullRight={false}
|
73
|
-
stacked={false}
|
74
|
-
/>
|
75
|
-
<TabContent
|
76
|
-
animation={true}
|
77
|
-
bsClass="tab"
|
78
|
-
componentClass="div"
|
79
|
-
mountOnEnter={false}
|
80
|
-
unmountOnExit={false}
|
81
|
-
/>
|
82
|
-
<FullScreenModal
|
83
|
-
showFullScreen={false}
|
84
|
-
terminalProps={Object {}}
|
85
|
-
toggleFullScreen={[Function]}
|
86
|
-
/>
|
87
|
-
</div>
|
88
|
-
</ForwardRef>
|
89
|
-
`;
|