foreman_rh_cloud 1.0.5 → 2.0.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +8 -0
  3. data/app/controllers/foreman_inventory_upload/accounts_controller.rb +2 -6
  4. data/app/controllers/foreman_rh_cloud/react_controller.rb +8 -0
  5. data/app/models/setting/rh_cloud.rb +1 -0
  6. data/app/views/foreman_rh_cloud/react/inventory_upload.html.erb +1 -0
  7. data/app/views/{foreman_inventory_upload/layouts/react.html.erb → layouts/foreman_rh_cloud/application.html.erb} +2 -2
  8. data/config/routes.rb +4 -1
  9. data/lib/foreman_inventory_upload/async/async_helpers.rb +13 -0
  10. data/lib/foreman_inventory_upload/async/shell_process.rb +3 -1
  11. data/lib/foreman_inventory_upload/async/upload_report_job.rb +1 -5
  12. data/lib/foreman_inventory_upload/generators/fact_helpers.rb +56 -0
  13. data/lib/foreman_inventory_upload/generators/queries.rb +6 -0
  14. data/lib/foreman_inventory_upload/generators/slice.rb +14 -9
  15. data/lib/foreman_rh_cloud/engine.rb +17 -5
  16. data/lib/foreman_rh_cloud/version.rb +1 -1
  17. data/package.json +20 -100
  18. data/test/factories/inventory_upload_factories.rb +13 -13
  19. data/test/unit/archived_report_generator_test.rb +1 -0
  20. data/test/unit/fact_helpers_test.rb +29 -0
  21. data/test/unit/slice_generator_test.rb +206 -20
  22. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.fixtures.js +6 -2
  23. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.js +13 -10
  24. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.stories.js +5 -14
  25. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListActions.js +3 -2
  26. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListHelper.js +10 -0
  27. data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListSelectors.js +1 -1
  28. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/EmptyResults.js +15 -0
  29. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/__tests__/EmptyResults.test.js +13 -0
  30. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/__tests__/__snapshots__/EmptyResults.test.js.snap +18 -0
  31. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/emptyResults.scss +7 -0
  32. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyResults/index.js +1 -0
  33. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/EmptyState/__tests__/EmptyState.test.js +1 -1
  34. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ErrorState/__tests__/ErrorState.test.js +1 -1
  35. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItem/ListItem.js +1 -4
  36. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItem/__tests__/ListItem.test.js +1 -1
  37. data/webpack/ForemanInventoryUpload/Components/AccountList/Components/ListItemStatus/__tests__/ListItemStatus.test.js +1 -1
  38. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountList.test.js +2 -1
  39. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListActions.test.js +1 -1
  40. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListHelper.test.js +12 -0
  41. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListIntegration.test.js +2 -2
  42. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListReducer.test.js +1 -1
  43. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js +8 -9
  44. data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountList.test.js.snap +2 -3
  45. data/webpack/ForemanInventoryUpload/Components/AccountList/index.js +2 -0
  46. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherActions.js +4 -1
  47. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcher.test.js +1 -1
  48. data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcherActions.test.js +1 -1
  49. data/webpack/ForemanInventoryUpload/Components/Dashboard/Dashboard.fixtures.js +13 -9
  50. data/webpack/ForemanInventoryUpload/Components/Dashboard/Dashboard.stories.js +5 -15
  51. data/webpack/ForemanInventoryUpload/Components/Dashboard/DashboardActions.js +4 -3
  52. data/webpack/ForemanInventoryUpload/Components/Dashboard/DashboardSelectors.js +1 -1
  53. data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/Dashboard.test.js +1 -2
  54. data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardActions.test.js +17 -5
  55. data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardIntegration.test.js +2 -2
  56. data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardReducer.test.js +1 -1
  57. data/webpack/ForemanInventoryUpload/Components/Dashboard/__tests__/DashboardSelectors.test.js +4 -3
  58. data/webpack/ForemanInventoryUpload/Components/FileDownload/__tests__/FileDownload.test.js +1 -1
  59. data/webpack/ForemanInventoryUpload/Components/FullScreenModal/__tests__/FullScreenModal.test.js +1 -1
  60. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/Components/ClearButton/ClearButton.js +26 -0
  61. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/Components/ClearButton/index.js +1 -0
  62. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.fixtures.js +2 -0
  63. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilter.js +39 -0
  64. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterActions.js +16 -0
  65. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterConstants.js +3 -0
  66. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterReducer.js +36 -0
  67. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/InventoryFilterSelectors.js +7 -0
  68. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilter.test.js +14 -0
  69. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterActions.test.js +14 -0
  70. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterReducer.test.js +35 -0
  71. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/InventoryFilterSelectors.test.js +21 -0
  72. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilter.test.js.snap +25 -0
  73. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterActions.test.js.snap +17 -0
  74. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterReducer.test.js.snap +25 -0
  75. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/InventoryFilterSelectors.test.js.snap +9 -0
  76. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/integration.test.js.snap +31 -0
  77. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/integration.test.js +18 -0
  78. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/index.js +17 -0
  79. data/webpack/ForemanInventoryUpload/Components/InventoryFilter/inventoryFilter.scss +28 -0
  80. data/webpack/ForemanInventoryUpload/Components/NavContainer/NavContainer.fixtures.js +5 -2
  81. data/webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/NavContainer.test.js +1 -2
  82. data/webpack/ForemanInventoryUpload/Components/NavContainer/__tests__/__snapshots__/NavContainer.test.js.snap +1 -1
  83. data/webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.js +12 -3
  84. data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/PageHeader.test.js +1 -1
  85. data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/__snapshots__/PageHeader.test.js.snap +11 -2
  86. data/webpack/ForemanInventoryUpload/Components/PageHeader/pageHeader.scss +3 -0
  87. data/webpack/ForemanInventoryUpload/Components/ReportGenerate/__tests__/ReportGenerate.test.js +1 -1
  88. data/webpack/ForemanInventoryUpload/Components/ReportUpload/__tests__/ReportUpload.test.js +1 -1
  89. data/webpack/ForemanInventoryUpload/Components/ScheduledRun/__tests__/ScheduledRun.test.js +1 -1
  90. data/webpack/ForemanInventoryUpload/Components/StatusChart/__tests__/StatusChart.test.js +1 -1
  91. data/webpack/ForemanInventoryUpload/Components/TabBody/__tests__/TabBody.test.js +1 -1
  92. data/webpack/ForemanInventoryUpload/Components/TabContainer/__tests__/TabContainer.test.js +1 -1
  93. data/webpack/ForemanInventoryUpload/Components/TabFooter/__tests__/TabFooter.test.js +1 -1
  94. data/webpack/ForemanInventoryUpload/Components/TabHeader/__tests__/TabHeader.test.js +1 -1
  95. data/webpack/ForemanInventoryUpload/Components/Terminal/Terminal.js +1 -1
  96. data/webpack/ForemanInventoryUpload/Components/Terminal/__tests__/Terminal.test.js +1 -2
  97. data/webpack/ForemanInventoryUpload/ForemanInventoryConstants.js +3 -0
  98. data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +4 -0
  99. data/webpack/ForemanInventoryUpload/ForemanInventoryUpload.js +16 -8
  100. data/webpack/ForemanInventoryUpload/ForemanInventoryUploadReducers.js +4 -4
  101. data/webpack/ForemanInventoryUpload/__tests__/ForemanInventoryHelpers.test.js +9 -0
  102. data/webpack/ForemanInventoryUpload/{ForemanInventoryUpload.test.js → __tests__/ForemanInventoryUpload.test.js} +2 -2
  103. data/webpack/ForemanInventoryUpload/__tests__/__snapshots__/ForemanInventoryHelpers.test.js.snap +3 -0
  104. data/webpack/ForemanInventoryUpload/{__snapshots__ → __tests__/__snapshots__}/ForemanInventoryUpload.test.js.snap +0 -0
  105. data/webpack/ForemanRhCloudHelpers.js +6 -0
  106. data/webpack/ForemanRhCloudReducers.js +8 -0
  107. data/webpack/ForemanRhCloudSelectors.js +3 -0
  108. data/webpack/ForemanRhCloudTestHelpers.js +5 -0
  109. data/webpack/__mocks__/foremanReact/components/Layout/LayoutConstants.js +1 -0
  110. data/webpack/__tests__/ForemanRhCloudHelpers.test.js +11 -0
  111. data/webpack/__tests__/ForemanRhCloudSelectors.test.js +17 -0
  112. data/webpack/__tests__/ForemanRhCloudTestHelpers.test.js +10 -0
  113. data/webpack/__tests__/__snapshots__/ForemanRhCloudHelpers.test.js.snap +3 -0
  114. data/webpack/__tests__/__snapshots__/ForemanRhCloudSelectors.test.js.snap +15 -0
  115. data/webpack/__tests__/__snapshots__/ForemanRhCloudTestHelpers.test.js.snap +11 -0
  116. data/webpack/index.js +1 -1
  117. metadata +52 -14
  118. data/app/controllers/foreman_inventory_upload/react_controller.rb +0 -7
  119. data/webpack/ForemanInventoryUpload/ForemanInventoryUploadSelectors.js +0 -4
  120. data/webpack/stories/ForemanInventoryUploadReducers.js +0 -3
  121. data/webpack/stories/configureStore.js +0 -15
  122. data/webpack/stories/decorators/index.js +0 -1
  123. data/webpack/stories/decorators/withCardsDecorator.js +0 -14
  124. data/webpack/stories/index.js +0 -10
  125. data/webpack/stories/index.scss +0 -7
  126. data/webpack/test_setup.js +0 -6
@@ -1,4 +1,6 @@
1
1
  import API from 'foremanReact/API';
2
+ import { selectActiveTab } from './DashboardSelectors';
3
+ import { inventoryUrl } from '../../ForemanInventoryHelpers';
2
4
  import {
3
5
  INVENTORY_POLLING_START,
4
6
  INVENTORY_POLLING_STOP,
@@ -8,7 +10,6 @@ import {
8
10
  INVENTORY_REPORTS_DOWNLOAD,
9
11
  INVENTORY_TOGGLE_TERMINAL_FULL_SCREEN,
10
12
  } from './DashboardConstants';
11
- import { selectActiveTab } from './DashboardSelectors';
12
13
 
13
14
  export const startPolling = (accountID, pollingProcessID) => ({
14
15
  type: INVENTORY_POLLING_START,
@@ -34,7 +35,7 @@ export const fetchLogs = accountID => async (dispatch, getState) => {
34
35
  const processController = activeTab === 'uploading' ? 'uploads' : 'reports';
35
36
  const {
36
37
  data: { output, scheduled },
37
- } = await API.get(`${accountID}/${processController}/last`);
38
+ } = await API.get(inventoryUrl(`${accountID}/${processController}/last`));
38
39
  const outputArray = output.split('\n');
39
40
  dispatch({
40
41
  type: INVENTORY_POLLING,
@@ -66,7 +67,7 @@ export const setActiveTab = (accountID, tabName) => ({
66
67
  });
67
68
 
68
69
  export const downloadReports = accountID => {
69
- window.location.href = `/foreman_inventory_upload/${accountID}/uploads/file`;
70
+ window.location.href = inventoryUrl(`${accountID}/uploads/file`);
70
71
  return {
71
72
  type: INVENTORY_REPORTS_DOWNLOAD,
72
73
  payload: {
@@ -1,4 +1,4 @@
1
- import { selectForemanInventoryUpload } from '../../ForemanInventoryUploadSelectors';
1
+ import { selectForemanInventoryUpload } from '../../../ForemanRhCloudSelectors';
2
2
 
3
3
  export const selectDashboard = (state, accountID) =>
4
4
  selectForemanInventoryUpload(state).dashboard[accountID] || {};
@@ -1,6 +1,5 @@
1
1
  import React from 'react';
2
- import { shallow } from 'enzyme';
3
- import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
2
+ import { shallow, testComponentSnapshotsWithFixtures } from '@theforeman/test';
4
3
  import Dashboard from '../Dashboard';
5
4
  import { props } from '../Dashboard.fixtures';
6
5
 
@@ -1,4 +1,4 @@
1
- import { testActionSnapshotWithFixtures } from 'react-redux-test-utils';
1
+ import { testActionSnapshotWithFixtures } from '@theforeman/test';
2
2
  import API from 'foremanReact/API';
3
3
  import {
4
4
  startPolling,
@@ -14,14 +14,13 @@ import {
14
14
  activeTab,
15
15
  accountID,
16
16
  } from '../Dashboard.fixtures';
17
+ import { inventoryStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
17
18
 
18
19
  jest.mock('foremanReact/API');
19
20
  API.get.mockImplementation(() => serverMock);
20
21
 
21
22
  const runWithGetState = (state, action, params) => dispatch => {
22
- const getState = () => ({
23
- dashboard: state,
24
- });
23
+ const getState = () => inventoryStateWrapper({ dashboard: state });
25
24
  action(params)(dispatch, getState);
26
25
  };
27
26
 
@@ -36,4 +35,17 @@ const fixtures = {
36
35
  runWithGetState({ activeTab: 'reports' }, toggleFullScreen, accountID),
37
36
  };
38
37
 
39
- describe('Dashboard actions', () => testActionSnapshotWithFixtures(fixtures));
38
+ describe('Dashboard actions', () => {
39
+ const { location } = window;
40
+
41
+ beforeAll(() => {
42
+ delete window.location;
43
+ window.location = { href: jest.fn() };
44
+ });
45
+
46
+ afterAll(() => {
47
+ window.location = location;
48
+ });
49
+
50
+ return testActionSnapshotWithFixtures(fixtures);
51
+ });
@@ -1,8 +1,8 @@
1
1
  import React from 'react';
2
- import { IntegrationTestHelper } from 'react-redux-test-utils';
2
+ import { IntegrationTestHelper } from '@theforeman/test';
3
3
 
4
4
  import Dashboard from '../Dashboard';
5
- import reducers from '../../../ForemanInventoryUploadReducers';
5
+ import reducers from '../../../../ForemanRhCloudReducers';
6
6
  import { accountID } from '../Dashboard.fixtures';
7
7
 
8
8
  describe('Dashboard integration test', () => {
@@ -1,4 +1,4 @@
1
- import { testReducerSnapshotWithFixtures } from 'react-redux-test-utils';
1
+ import { testReducerSnapshotWithFixtures } from '@theforeman/test';
2
2
 
3
3
  import {
4
4
  INVENTORY_POLLING_START,
@@ -1,4 +1,4 @@
1
- import { testSelectorsSnapshotWithFixtures } from 'react-redux-test-utils';
1
+ import { testSelectorsSnapshotWithFixtures } from '@theforeman/test';
2
2
  import {
3
3
  selectDashboard,
4
4
  selectPollingProcessID,
@@ -13,8 +13,9 @@ import {
13
13
  activeTab,
14
14
  accountID,
15
15
  } from '../Dashboard.fixtures';
16
+ import { inventoryStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
16
17
 
17
- const state = {
18
+ const state = inventoryStateWrapper({
18
19
  dashboard: {
19
20
  [accountID]: {
20
21
  generating: {
@@ -29,7 +30,7 @@ const state = {
29
30
  pollingProcessID,
30
31
  },
31
32
  },
32
- };
33
+ });
33
34
 
34
35
  const fixtures = {
35
36
  'should return Dashboard': () => selectDashboard(state, accountID),
@@ -1,4 +1,4 @@
1
- import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
1
+ import { testComponentSnapshotsWithFixtures } from '@theforeman/test';
2
2
 
3
3
  import FileDownload from '../FileDownload';
4
4
 
@@ -1,4 +1,4 @@
1
- import { testComponentSnapshotsWithFixtures } from 'react-redux-test-utils';
1
+ import { testComponentSnapshotsWithFixtures } from '@theforeman/test';
2
2
 
3
3
  import FullScreenModal from '../FullScreenModal';
4
4
 
@@ -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;
@@ -0,0 +1,2 @@
1
+ export const filterTerm = 'test_filter_term';
2
+ export const org = { title: 'some_org', id: 1 };
@@ -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,3 @@
1
+ export const INVENTORY_FILTER_UPDATE = 'INVENTORY_FILTER_UPDATE';
2
+ export const INVENTORY_FILTER_CLEAR = 'INVENTORY_FILTER_CLEAR';
3
+ export const ANY_ORGANIZATION = 'Any Organization';
@@ -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;
@@ -0,0 +1,14 @@
1
+ import { testComponentSnapshotsWithFixtures } from '@theforeman/test';
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 '@theforeman/test';
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 '@theforeman/test';
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 '@theforeman/test';
2
+ import { filterTerm } from '../InventoryFilter.fixtures';
3
+ import { inventoryStateWrapper } from '../../../../ForemanRhCloudTestHelpers';
4
+ import {
5
+ selectInventoryFilter,
6
+ selectFilterTerm,
7
+ } from '../InventoryFilterSelectors';
8
+
9
+ const state = inventoryStateWrapper({
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
+ `;