foreman_rh_cloud 1.0.4.1 → 1.0.9
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/controllers/foreman_inventory_upload/accounts_controller.rb +4 -6
- data/app/controllers/foreman_inventory_upload/uploads_controller.rb +33 -7
- data/app/controllers/foreman_rh_cloud/react_controller.rb +11 -0
- data/app/controllers/insights_cloud/tasks_controller.rb +8 -0
- data/app/helpers/foreman_inventory_upload_host_helper.rb +11 -0
- data/app/models/insights_facet.rb +3 -0
- data/app/models/insights_hit.rb +6 -0
- data/app/models/setting/rh_cloud.rb +15 -0
- 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 -0
- data/app/views/{foreman_inventory_upload/layouts/react.html.erb → layouts/foreman_rh_cloud/application.html.erb} +2 -2
- data/config/routes.rb +12 -1
- 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/lib/foreman_inventory_upload.rb +12 -0
- data/lib/foreman_inventory_upload/async/async_helpers.rb +13 -0
- data/lib/foreman_inventory_upload/async/generate_all_reports_job.rb +8 -0
- data/lib/foreman_inventory_upload/async/shell_process.rb +3 -1
- data/lib/foreman_inventory_upload/generators/archived_report.rb +6 -3
- data/lib/foreman_inventory_upload/generators/fact_helpers.rb +56 -0
- data/lib/foreman_inventory_upload/generators/json_stream.rb +10 -0
- data/lib/foreman_inventory_upload/generators/queries.rb +7 -0
- data/lib/foreman_inventory_upload/generators/slice.rb +47 -21
- data/lib/foreman_inventory_upload/notifications/manifest_import_success_notification_override.rb +19 -0
- data/lib/foreman_rh_cloud/engine.rb +33 -5
- 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 +96 -0
- data/test/controllers/accounts_controller_test.rb +8 -3
- data/test/controllers/uploads_controller_test.rb +13 -0
- data/test/jobs/insights_full_sync_test.rb +92 -0
- data/test/unit/archived_report_generator_test.rb +1 -0
- data/test/unit/fact_helpers_test.rb +29 -0
- data/test/unit/slice_generator_test.rb +274 -12
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.fixtures.js +14 -2
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.js +13 -10
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListActions.js +6 -3
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListHelper.js +10 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListReducer.js +16 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListSelectors.js +10 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/EmptyResults.js +15 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/__tests__/EmptyResults.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/__tests__/__snapshots__/EmptyResults.test.js.snap +18 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/emptyResults.scss +7 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItem/ListItem.js +1 -4
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountList.test.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListActions.test.js +8 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListHelper.test.js +12 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListIntegration.test.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListReducer.test.js +22 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js +20 -8
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountList.test.js.snap +2 -3
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListActions.test.js.snap +20 -2
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListReducer.test.js.snap +20 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListSelectors.test.js.snap +8 -2
- data/webpack/ForemanInventoryUpload/Components/AccountList/index.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcher.fixtures.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcher.js +32 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherActions.js +30 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherConstants.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcher.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcherActions.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/__snapshots__/AutoUploadSwitcher.test.js.snap +38 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/__snapshots__/AutoUploadSwitcherActions.test.js.snap +14 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/autoUploadSwitcher.scss +3 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/index.js +17 -0
- data/webpack/ForemanInventoryUpload/Components/Dashboard/DashboardActions.js +4 -3
- data/webpack/ForemanInventoryUpload/Components/Dashboard/DashboardSelectors.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardActions.test.js +2 -3
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardIntegration.test.js +2 -1
- data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardSelectors.test.js +3 -2
- 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/Components/ClearButton/ClearButton.js +26 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/Components/ClearButton/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.fixtures.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.js +39 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterActions.js +16 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterConstants.js +3 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterReducer.js +36 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterSelectors.js +7 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilter.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterActions.test.js +14 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterReducer.test.js +35 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterSelectors.test.js +21 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilter.test.js.snap +25 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterActions.test.js.snap +17 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterReducer.test.js.snap +25 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterSelectors.test.js.snap +9 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/integration.test.js.snap +31 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/integration.test.js +18 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/index.js +17 -0
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/inventoryFilter.scss +28 -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 +40 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/PageHeader.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/__snapshots__/PageHeader.test.js.snap +61 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/DocsButton.js +17 -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 +20 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/HistoryButton.js +18 -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 +21 -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/ToolbarButtons/ToolbarButtons.js +13 -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 +10 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/toolbarButtons.scss +7 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/index.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/pageHeader.scss +3 -0
- data/webpack/ForemanInventoryUpload/Components/ScheduledRun/ScheduledRun.fixtures.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/ScheduledRun/ScheduledRun.js +4 -2
- data/webpack/ForemanInventoryUpload/Components/ScheduledRun/__tests__/ScheduledRun.test.js +0 -1
- data/webpack/ForemanInventoryUpload/Components/ScheduledRun/__tests__/__snapshots__/ScheduledRun.test.js.snap +0 -2
- data/webpack/ForemanInventoryUpload/Components/ScheduledRun/index.js +12 -1
- data/webpack/ForemanInventoryUpload/Components/TabBody/__tests__/__snapshots__/TabBody.test.js.snap +1 -1
- data/webpack/ForemanInventoryUpload/ForemanInventoryConstants.js +7 -0
- data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +12 -0
- data/webpack/ForemanInventoryUpload/ForemanInventoryUpload.js +18 -9
- data/webpack/ForemanInventoryUpload/ForemanInventoryUploadReducers.js +4 -4
- data/webpack/ForemanInventoryUpload/SubscriptionsPageExtension/SubscriptionsPageExtensionActions.js +34 -0
- data/webpack/ForemanInventoryUpload/__tests__/ForemanInventoryHelpers.test.js +12 -0
- data/webpack/ForemanInventoryUpload/{ForemanInventoryUpload.test.js → __tests__/ForemanInventoryUpload.test.js} +1 -1
- data/webpack/ForemanInventoryUpload/__tests__/__snapshots__/ForemanInventoryHelpers.test.js.snap +5 -0
- data/webpack/ForemanInventoryUpload/{__snapshots__ → __tests__/__snapshots__}/ForemanInventoryUpload.test.js.snap +6 -5
- data/webpack/ForemanRhCloudHelpers.js +6 -0
- data/webpack/ForemanRhCloudReducers.js +10 -0
- data/webpack/ForemanRhCloudSelectors.js +5 -0
- data/webpack/ForemanRhCloudTestHelpers.js +6 -0
- data/webpack/InsightsCloudSync/InsightsCloudSync.js +55 -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 +3 -0
- data/webpack/InsightsCloudSync/__snapshots__/InsightsCloudSync.test.js.snap +62 -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 +17 -0
- data/webpack/__mocks__/foremanReact/components/Layout/LayoutConstants.js +1 -0
- data/webpack/__tests__/ForemanRhCloudHelpers.test.js +11 -0
- data/webpack/__tests__/ForemanRhCloudSelectors.test.js +19 -0
- data/webpack/__tests__/ForemanRhCloudTestHelpers.test.js +10 -0
- data/webpack/__tests__/__snapshots__/ForemanRhCloudHelpers.test.js.snap +3 -0
- data/webpack/__tests__/__snapshots__/ForemanRhCloudSelectors.test.js.snap +24 -0
- data/webpack/__tests__/__snapshots__/ForemanRhCloudTestHelpers.test.js.snap +14 -0
- data/webpack/index.js +8 -1
- data/webpack/subscriptions_extension_index.js +8 -0
- metadata +124 -7
- data/app/controllers/foreman_inventory_upload/react_controller.rb +0 -7
- data/webpack/ForemanInventoryUpload/ForemanInventoryUploadSelectors.js +0 -4
@@ -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);
|
data/webpack/ForemanInventoryUpload/Components/InventoryFilter/Components/ClearButton/ClearButton.js
ADDED
@@ -0,0 +1,26 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { Icon, OverlayTrigger, Tooltip, noop } from 'patternfly-react';
|
4
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
+
|
6
|
+
const ClearButton = ({ onClear }) => (
|
7
|
+
<OverlayTrigger
|
8
|
+
overlay={
|
9
|
+
<Tooltip id="inventory_filter_clear_overlay">{__('Clear')}</Tooltip>
|
10
|
+
}
|
11
|
+
placement="top"
|
12
|
+
trigger={['hover', 'focus']}
|
13
|
+
>
|
14
|
+
<Icon name="close" className="inventory-clear-button" onClick={onClear} />
|
15
|
+
</OverlayTrigger>
|
16
|
+
);
|
17
|
+
|
18
|
+
ClearButton.propTypes = {
|
19
|
+
onClear: PropTypes.func,
|
20
|
+
};
|
21
|
+
|
22
|
+
ClearButton.defaultProps = {
|
23
|
+
onClear: noop,
|
24
|
+
};
|
25
|
+
|
26
|
+
export default ClearButton;
|
data/webpack/ForemanInventoryUpload/Components/InventoryFilter/Components/ClearButton/index.js
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
export { default } from './ClearButton';
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { FormGroup, FormControl, noop } from 'patternfly-react';
|
4
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
+
import ClearButton from './Components/ClearButton';
|
6
|
+
import './inventoryFilter.scss';
|
7
|
+
|
8
|
+
const InventoryFilter = ({
|
9
|
+
handleFilterChange,
|
10
|
+
handleFilterClear,
|
11
|
+
filterTerm,
|
12
|
+
}) => (
|
13
|
+
<form id="inventory_filter_form">
|
14
|
+
<FormGroup controlId="inventory_filter_input">
|
15
|
+
<FormControl
|
16
|
+
value={filterTerm}
|
17
|
+
type="text"
|
18
|
+
placeholder={__('Filter..')}
|
19
|
+
bsSize="lg"
|
20
|
+
onChange={e => handleFilterChange(e.target.value)}
|
21
|
+
/>
|
22
|
+
<ClearButton onClear={handleFilterClear} />
|
23
|
+
</FormGroup>
|
24
|
+
</form>
|
25
|
+
);
|
26
|
+
|
27
|
+
InventoryFilter.propTypes = {
|
28
|
+
handleFilterChange: PropTypes.func,
|
29
|
+
handleFilterClear: PropTypes.func,
|
30
|
+
filterTerm: PropTypes.string,
|
31
|
+
};
|
32
|
+
|
33
|
+
InventoryFilter.defaultProps = {
|
34
|
+
handleFilterChange: noop,
|
35
|
+
handleFilterClear: noop,
|
36
|
+
filterTerm: '',
|
37
|
+
};
|
38
|
+
|
39
|
+
export default InventoryFilter;
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import {
|
2
|
+
INVENTORY_FILTER_UPDATE,
|
3
|
+
INVENTORY_FILTER_CLEAR,
|
4
|
+
} from './InventoryFilterConstants';
|
5
|
+
|
6
|
+
export const handleFilterChange = filterTerm => ({
|
7
|
+
type: INVENTORY_FILTER_UPDATE,
|
8
|
+
payload: {
|
9
|
+
filterTerm,
|
10
|
+
},
|
11
|
+
});
|
12
|
+
|
13
|
+
export const handleFilterClear = () => ({
|
14
|
+
type: INVENTORY_FILTER_CLEAR,
|
15
|
+
payload: {},
|
16
|
+
});
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import Immutable from 'seamless-immutable';
|
2
|
+
import { LAYOUT_CHANGE_ORG } from 'foremanReact/components/Layout/LayoutConstants';
|
3
|
+
import {
|
4
|
+
INVENTORY_FILTER_UPDATE,
|
5
|
+
INVENTORY_FILTER_CLEAR,
|
6
|
+
ANY_ORGANIZATION,
|
7
|
+
} from './InventoryFilterConstants';
|
8
|
+
|
9
|
+
const initialState = Immutable({
|
10
|
+
filterTerm: '',
|
11
|
+
});
|
12
|
+
|
13
|
+
export default (
|
14
|
+
state = initialState,
|
15
|
+
{ type, payload: { filterTerm, org } = {} }
|
16
|
+
) => {
|
17
|
+
switch (type) {
|
18
|
+
case INVENTORY_FILTER_UPDATE:
|
19
|
+
return state.merge({
|
20
|
+
filterTerm,
|
21
|
+
});
|
22
|
+
case INVENTORY_FILTER_CLEAR:
|
23
|
+
return state.merge({
|
24
|
+
filterTerm: '',
|
25
|
+
});
|
26
|
+
case LAYOUT_CHANGE_ORG: {
|
27
|
+
const { title } = org;
|
28
|
+
const term = title === ANY_ORGANIZATION ? '' : title;
|
29
|
+
return state.merge({
|
30
|
+
filterTerm: term,
|
31
|
+
});
|
32
|
+
}
|
33
|
+
default:
|
34
|
+
return state;
|
35
|
+
}
|
36
|
+
};
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import { selectForemanInventoryUpload } from '../../../ForemanRhCloudSelectors';
|
2
|
+
|
3
|
+
export const selectInventoryFilter = state =>
|
4
|
+
selectForemanInventoryUpload(state).inventoryFilter;
|
5
|
+
|
6
|
+
export const selectFilterTerm = state =>
|
7
|
+
selectInventoryFilter(state).filterTerm;
|
data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilter.test.js
ADDED
@@ -0,0 +1,14 @@
|
|
1
|
+
import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import { noop } from 'patternfly-react';
|
3
|
+
|
4
|
+
import InventoryFilter from '../InventoryFilter';
|
5
|
+
|
6
|
+
const fixtures = {
|
7
|
+
'render with props': { handleFilterChange: noop },
|
8
|
+
/** fixtures, props for the component */
|
9
|
+
};
|
10
|
+
|
11
|
+
describe('InventoryFilter', () => {
|
12
|
+
describe('rendering', () =>
|
13
|
+
testComponentSnapshotsWithFixtures(InventoryFilter, fixtures));
|
14
|
+
});
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { testActionSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import {
|
3
|
+
handleFilterChange,
|
4
|
+
handleFilterClear,
|
5
|
+
} from '../InventoryFilterActions';
|
6
|
+
import { filterTerm } from '../InventoryFilter.fixtures';
|
7
|
+
|
8
|
+
const fixtures = {
|
9
|
+
'should handleFilterChange': () => handleFilterChange(filterTerm),
|
10
|
+
'should handleFilterClear': () => handleFilterClear(),
|
11
|
+
};
|
12
|
+
|
13
|
+
describe('InventoryFilter actions', () =>
|
14
|
+
testActionSnapshotWithFixtures(fixtures));
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import { testReducerSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import { LAYOUT_CHANGE_ORG } from 'foremanReact/components/Layout/LayoutConstants';
|
3
|
+
import reducer from '../InventoryFilterReducer';
|
4
|
+
import { filterTerm, org } from '../InventoryFilter.fixtures';
|
5
|
+
import {
|
6
|
+
INVENTORY_FILTER_UPDATE,
|
7
|
+
INVENTORY_FILTER_CLEAR,
|
8
|
+
} from '../InventoryFilterConstants';
|
9
|
+
|
10
|
+
const fixtures = {
|
11
|
+
'should return the initial state': {},
|
12
|
+
'should handle INVENTORY_FILTER_UPDATE': {
|
13
|
+
action: {
|
14
|
+
type: INVENTORY_FILTER_UPDATE,
|
15
|
+
payload: {
|
16
|
+
filterTerm,
|
17
|
+
},
|
18
|
+
},
|
19
|
+
},
|
20
|
+
'should handle INVENTORY_FILTER_CLEAR': {
|
21
|
+
action: {
|
22
|
+
type: INVENTORY_FILTER_CLEAR,
|
23
|
+
payload: {},
|
24
|
+
},
|
25
|
+
},
|
26
|
+
'should handle LAYOUT_CHANGE_ORG': {
|
27
|
+
action: {
|
28
|
+
type: LAYOUT_CHANGE_ORG,
|
29
|
+
payload: { org },
|
30
|
+
},
|
31
|
+
},
|
32
|
+
};
|
33
|
+
|
34
|
+
describe('AccountList reducer', () =>
|
35
|
+
testReducerSnapshotWithFixtures(reducer, fixtures));
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import { testSelectorsSnapshotWithFixtures } from 'react-redux-test-utils';
|
2
|
+
import { filterTerm } from '../InventoryFilter.fixtures';
|
3
|
+
import { rhCloudStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
|
4
|
+
import {
|
5
|
+
selectInventoryFilter,
|
6
|
+
selectFilterTerm,
|
7
|
+
} from '../InventoryFilterSelectors';
|
8
|
+
|
9
|
+
const state = rhCloudStateWrapper({
|
10
|
+
inventoryFilter: {
|
11
|
+
filterTerm,
|
12
|
+
},
|
13
|
+
});
|
14
|
+
|
15
|
+
const fixtures = {
|
16
|
+
'should return InventoryFilter': () => selectInventoryFilter(state),
|
17
|
+
'should return filterTerm': () => selectFilterTerm(state),
|
18
|
+
};
|
19
|
+
|
20
|
+
describe('InventoryFilter selectors', () =>
|
21
|
+
testSelectorsSnapshotWithFixtures(fixtures));
|
@@ -0,0 +1,25 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`InventoryFilter rendering render with props 1`] = `
|
4
|
+
<form
|
5
|
+
id="inventory_filter_form"
|
6
|
+
>
|
7
|
+
<FormGroup
|
8
|
+
bsClass="form-group"
|
9
|
+
controlId="inventory_filter_input"
|
10
|
+
>
|
11
|
+
<FormControl
|
12
|
+
bsClass="form-control"
|
13
|
+
bsSize="lg"
|
14
|
+
componentClass="input"
|
15
|
+
onChange={[Function]}
|
16
|
+
placeholder="Filter.."
|
17
|
+
type="text"
|
18
|
+
value=""
|
19
|
+
/>
|
20
|
+
<ClearButton
|
21
|
+
onClear={[Function]}
|
22
|
+
/>
|
23
|
+
</FormGroup>
|
24
|
+
</form>
|
25
|
+
`;
|
@@ -0,0 +1,17 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`InventoryFilter actions should handleFilterChange 1`] = `
|
4
|
+
Object {
|
5
|
+
"payload": Object {
|
6
|
+
"filterTerm": "test_filter_term",
|
7
|
+
},
|
8
|
+
"type": "INVENTORY_FILTER_UPDATE",
|
9
|
+
}
|
10
|
+
`;
|
11
|
+
|
12
|
+
exports[`InventoryFilter actions should handleFilterClear 1`] = `
|
13
|
+
Object {
|
14
|
+
"payload": Object {},
|
15
|
+
"type": "INVENTORY_FILTER_CLEAR",
|
16
|
+
}
|
17
|
+
`;
|
@@ -0,0 +1,25 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`AccountList reducer should handle INVENTORY_FILTER_CLEAR 1`] = `
|
4
|
+
Object {
|
5
|
+
"filterTerm": "",
|
6
|
+
}
|
7
|
+
`;
|
8
|
+
|
9
|
+
exports[`AccountList reducer should handle INVENTORY_FILTER_UPDATE 1`] = `
|
10
|
+
Object {
|
11
|
+
"filterTerm": "test_filter_term",
|
12
|
+
}
|
13
|
+
`;
|
14
|
+
|
15
|
+
exports[`AccountList reducer should handle LAYOUT_CHANGE_ORG 1`] = `
|
16
|
+
Object {
|
17
|
+
"filterTerm": "some_org",
|
18
|
+
}
|
19
|
+
`;
|
20
|
+
|
21
|
+
exports[`AccountList reducer should return the initial state 1`] = `
|
22
|
+
Object {
|
23
|
+
"filterTerm": "",
|
24
|
+
}
|
25
|
+
`;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`InventoryFilter selectors should return InventoryFilter 1`] = `
|
4
|
+
Object {
|
5
|
+
"filterTerm": "test_filter_term",
|
6
|
+
}
|
7
|
+
`;
|
8
|
+
|
9
|
+
exports[`InventoryFilter selectors should return filterTerm 1`] = `"test_filter_term"`;
|
@@ -0,0 +1,31 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`InventoryFilter integration test should flow: filter have been updated 1`] = `
|
4
|
+
Object {
|
5
|
+
"action": Array [
|
6
|
+
Array [
|
7
|
+
Object {
|
8
|
+
"payload": Object {
|
9
|
+
"filterTerm": "some_new_filter",
|
10
|
+
},
|
11
|
+
"type": "INVENTORY_FILTER_UPDATE",
|
12
|
+
},
|
13
|
+
],
|
14
|
+
],
|
15
|
+
"state": Object {
|
16
|
+
"ForemanRhCloud": Object {
|
17
|
+
"inventoryUpload": Object {
|
18
|
+
"accountsList": Object {
|
19
|
+
"accounts": Object {},
|
20
|
+
"error": null,
|
21
|
+
"pollingProcessID": 0,
|
22
|
+
},
|
23
|
+
"dashboard": Object {},
|
24
|
+
"inventoryFilter": Object {
|
25
|
+
"filterTerm": "some_new_filter",
|
26
|
+
},
|
27
|
+
},
|
28
|
+
},
|
29
|
+
},
|
30
|
+
}
|
31
|
+
`;
|