Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Business Process Maps #1931

Merged
merged 87 commits into from
Feb 14, 2020
Merged
Changes from 1 commit
Commits
Show all changes
87 commits
Select commit Hold shift + click to select a range
6e5b53e
Add ProcessMaps to Routes and menu
swaterkamp Sep 27, 2019
b5b7781
Add new BpmIcon
swaterkamp Sep 27, 2019
c051484
Add tests for BpmIcon
swaterkamp Sep 27, 2019
3262692
Add BPM to user commands
swaterkamp Jan 19, 2020
4c8e9d7
Add BPM to redux store
swaterkamp Jan 19, 2020
2069048
Add ProcessNode and Edge components
swaterkamp Jan 19, 2020
f6df8ab
Add BPM Dashboard
swaterkamp Jan 19, 2020
9bc73e0
Add BPM main page
swaterkamp Jan 19, 2020
e25226b
Add subcomponents used by BPM main component
swaterkamp Jan 19, 2020
01fe82a
Add main BPM component
swaterkamp Jan 19, 2020
d4049e8
Fix routes
swaterkamp Jan 19, 2020
46a6d32
Fix build
swaterkamp Jan 19, 2020
f5ea0fb
Move BusinessProcessMaps store components into own module
swaterkamp Jan 23, 2020
d6dfab4
Use Store for maps instead of local state
swaterkamp Jan 23, 2020
1554bd4
Fix edge proptype
swaterkamp Jan 24, 2020
74d71b8
Improve empty hostList handling in HostTable
swaterkamp Jan 28, 2020
4b82793
Fix ProcessPanel proptype
swaterkamp Jan 28, 2020
66c5701
Move loading maps and hosts to ProcessMapLoader, and create a tag for…
swaterkamp Jan 28, 2020
896600a
Improve ProcessNode styling with animation
swaterkamp Jan 29, 2020
5b5333c
Add new EntitiesSelector isLoadingAnyEntities
swaterkamp Jan 29, 2020
69cccbb
Add new useColorize hook for coloring processes
swaterkamp Jan 29, 2020
d7448a8
Let ProcessMapLoader handle pre-loading hosts and coloring processes
swaterkamp Jan 29, 2020
12df9f5
Allow to toggle conditional colorization of processes
swaterkamp Jan 29, 2020
86ec4e6
Add conditional colorization for more than one hop
swaterkamp Jan 31, 2020
2aa2a96
Improve ProcessNode animation
swaterkamp Feb 3, 2020
ec647c6
Add tag functionality to UI
swaterkamp Feb 3, 2020
f8cad8e
Remove GlobalStyles snapshot and test
swaterkamp Feb 3, 2020
3dd132b
Don't crash when clicking "Delete selected element" without a selecte…
swaterkamp Feb 3, 2020
3cb80a8
Remove unused prop from HostsList in ProcessPanel
swaterkamp Feb 4, 2020
ab99db9
Add new utils for use in ProcessMap
swaterkamp Feb 4, 2020
2849798
Allow to use ProcessMap with initially empty usersetting
swaterkamp Feb 4, 2020
a7c1de4
add test for processmap utils
sarahd93 Feb 5, 2020
c10e295
Differentiate between NA severity and non-existent due to no hosts in…
swaterkamp Feb 5, 2020
61f327c
Add data-testids to some components
swaterkamp Feb 6, 2020
b8230e7
Add pagination to ProcessPanel host list
swaterkamp Feb 6, 2020
66b0ffc
Fix layout of HostTable
swaterkamp Feb 6, 2020
b37ad86
Take special severity values for useColorize into account
swaterkamp Feb 6, 2020
6299933
Add tooltip for processes
swaterkamp Feb 7, 2020
b87263c
Fix colorization dealing with N/A severities explicitly
swaterkamp Feb 7, 2020
2266603
Fix 'no hosts associated' message in ProcessPanel
swaterkamp Feb 7, 2020
cd1253f
add tests for hosttable
sarahd93 Feb 7, 2020
f670aae
add tests for processpanel
sarahd93 Feb 7, 2020
9006a95
add tests for tools
sarahd93 Feb 7, 2020
4b2aa92
add tests for processmap
sarahd93 Feb 7, 2020
fe8ab2f
Use BPM without Dashboard
swaterkamp Feb 7, 2020
50c74ff
Add arrow heads to Egde for info about direction
swaterkamp Feb 7, 2020
f897619
Add permissions for BPM menu entry
swaterkamp Feb 10, 2020
0ca398b
Add ConfirmationDialog for deleting processes
swaterkamp Feb 10, 2020
e39e8cc
add more tests for processmap
sarahd93 Feb 10, 2020
ce7355b
Fix typo
swaterkamp Feb 10, 2020
34ed577
Allow other content than strings in ConfirmationDialog
swaterkamp Feb 10, 2020
911e2d0
Adjust ConfirmationDialog tests and usecases to new prop name
swaterkamp Feb 10, 2020
9d48cca
Add Dialog to ProcessmapLoader when tags don't exist while loading
swaterkamp Feb 10, 2020
d42f17f
add tests for usecolorize
sarahd93 Feb 11, 2020
aef62ec
use hostsfilter for tests
sarahd93 Feb 11, 2020
f0aeb0c
Adjust ConfirmationDialog tests and usecases to new prop name
swaterkamp Feb 10, 2020
7f20257
Add Dialog to ProcessmapLoader when tags don't exist while loading
swaterkamp Feb 11, 2020
b512a63
Update "Confirm delete process" message
swaterkamp Feb 11, 2020
703c24b
Add a MAX_HOSTS_PER_PROCESS
swaterkamp Feb 11, 2020
86ac837
Add Helper to Tools to help get started
swaterkamp Feb 11, 2020
795b629
Fix infinite loop for failedTags when there are no processes
swaterkamp Feb 11, 2020
58fa20d
Add onInteraction to ProcessMap und ProcessPanel to prevent session t…
swaterkamp Feb 11, 2020
be514ca
Update ProcessMap tests for usage of renewSession
swaterkamp Feb 11, 2020
4e1f7d0
Use UUIDs fro processes and edges
swaterkamp Feb 11, 2020
7eaf061
Adjust tests for uuids and string proptypes, remove id from process s…
swaterkamp Feb 12, 2020
d424434
Add new Icons
swaterkamp Feb 12, 2020
bd38693
Add tests for new Icons
swaterkamp Feb 12, 2020
ed0594b
Use new icons in BPM tools
swaterkamp Feb 12, 2020
f1fd0ed
Don't require onInteraction in ProcessPanel
swaterkamp Feb 12, 2020
9d3b1a3
Add new Icons for zoom tools
swaterkamp Feb 12, 2020
7f4601c
Add tests for new Icons
swaterkamp Feb 12, 2020
12c6849
Add Zoom
swaterkamp Feb 12, 2020
7c324f1
Adjust tests for additional Icons
swaterkamp Feb 12, 2020
6dddd2d
Fix build
swaterkamp Feb 12, 2020
8865f4b
Add link to manual
swaterkamp Feb 12, 2020
56915e4
add tests for processmapspage
sarahd93 Feb 13, 2020
9d9ae04
update tests for processmap
sarahd93 Feb 13, 2020
d488d31
Reorder ProcessMapLoader and add comments
swaterkamp Feb 13, 2020
67f0bf3
Remove Quick Help icon, update tests accordingly
swaterkamp Feb 13, 2020
0c143dc
add tests for createprocessdialog
sarahd93 Feb 13, 2020
f49d5f4
update tests for processmap
sarahd93 Feb 13, 2020
10d4e15
update tests for processpanel
sarahd93 Feb 13, 2020
47ee8ad
Adjust CMakeLists
swaterkamp Feb 13, 2020
74d5b71
Update Changelog
swaterkamp Feb 13, 2020
d126e5b
Translate BPM to German and adjust tests
swaterkamp Feb 14, 2020
2136b2f
Add some comments to ProcessPanel
swaterkamp Feb 14, 2020
81ba089
Fix isLoadingAnyEntities() selector
swaterkamp Feb 14, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 13 additions & 7 deletions gsa/src/web/components/processmap/__tests__/processmap.js
Original file line number Diff line number Diff line change
@@ -138,6 +138,9 @@ describe('ProcessMap tests', () => {
const edgeIcon = getByTestId('bpm-tool-icon-edge');
const deleteIcon = getByTestId('bpm-tool-icon-delete');
const colorIcon = getByTestId('bpm-tool-icon-color');
const zoomInIcon = getByTestId('bpm-tool-icon-zoomin');
const zoomResetIcon = getByTestId('bpm-tool-icon-zoomreset');
const zoomOutIcon = getByTestId('bpm-tool-icon-zoomout');
const helpIcon = getByTestId('bpm-tool-icon-help');

const buttons = element.querySelectorAll('button');
@@ -179,12 +182,15 @@ describe('ProcessMap tests', () => {
'title',
'Turn on conditional colorization',
);
expect(zoomInIcon).toHaveAttribute('title', 'Zoom in');
expect(zoomResetIcon).toHaveAttribute('title', 'Reset zoom');
expect(zoomOutIcon).toHaveAttribute('title', 'Zoom out');
expect(helpIcon).toHaveAttribute('title', 'Quick Help');

// process panel

expect(element).toHaveTextContent('No process selected');
expect(icons[5]).toHaveAttribute('title', 'Edit process');
expect(icons[8]).toHaveAttribute('title', 'Edit process');

expect(buttons[0]).toHaveAttribute('title', 'Add Selected Hosts');
expect(buttons[0]).toHaveTextContent('Add Selected Hosts');
@@ -253,7 +259,7 @@ describe('ProcessMap tests', () => {

// panel title
expect(element).toHaveTextContent('foo');
expect(icons[5]).toHaveAttribute('title', 'Edit process');
expect(icons[8]).toHaveAttribute('title', 'Edit process');

// add hosts
expect(buttons[0]).toHaveAttribute('title', 'Add Selected Hosts');
@@ -319,7 +325,7 @@ describe('ProcessMap tests', () => {

// panel title
expect(element).toHaveTextContent('foo');
expect(icons[5]).toHaveAttribute('title', 'Edit process');
expect(icons[8]).toHaveAttribute('title', 'Edit process');

// add hosts
expect(buttons[0]).toHaveAttribute('title', 'Add Selected Hosts');
@@ -337,14 +343,14 @@ describe('ProcessMap tests', () => {
expect(detailsLinks[0]).toHaveTextContent('123.456.78.910');
expect(progressBars[0]).toHaveAttribute('title', 'Medium');
expect(progressBars[0]).toHaveTextContent('5.0 (Medium)');
expect(icons[6]).toHaveAttribute('title', 'Remove host from process');
expect(icons[9]).toHaveAttribute('title', 'Remove host from process');

// Row 2
expect(detailsLinks[1]).toHaveAttribute('href', '/host/5678');
expect(detailsLinks[1]).toHaveTextContent('109.876.54.321');
expect(progressBars[1]).toHaveAttribute('title', 'N/A');
expect(progressBars[1]).toHaveTextContent('N/A');
expect(icons[7]).toHaveAttribute('title', 'Remove host from process');
expect(icons[10]).toHaveAttribute('title', 'Remove host from process');
});

test('should call click handler for colorization', () => {
@@ -608,8 +614,8 @@ describe('ProcessMap tests', () => {
const icons = getAllByTestId('svg-icon');

await act(async () => {
expect(icons[6]).toHaveAttribute('title', 'Remove host from process');
fireEvent.click(icons[6]);
expect(icons[9]).toHaveAttribute('title', 'Remove host from process');
fireEvent.click(icons[9]);
});

expect(handleForceUpdate).toHaveBeenCalled();
31 changes: 31 additions & 0 deletions gsa/src/web/components/processmap/__tests__/tools.js
Original file line number Diff line number Diff line change
@@ -48,6 +48,9 @@ describe('Tools tests', () => {
const edgeIcon = getByTestId('bpm-tool-icon-edge');
const deleteIcon = getByTestId('bpm-tool-icon-delete');
const colorIcon = getByTestId('bpm-tool-icon-color');
const zoomInIcon = getByTestId('bpm-tool-icon-zoomin');
const zoomResetIcon = getByTestId('bpm-tool-icon-zoomreset');
const zoomOutIcon = getByTestId('bpm-tool-icon-zoomout');
const helpIcon = getByTestId('bpm-tool-icon-help');

expect(newIcon).toHaveAttribute('title', 'Create new process');
@@ -63,6 +66,10 @@ describe('Tools tests', () => {
);
expect(colorIcon).not.toHaveStyleRule('background-color', '#66c430');

expect(zoomInIcon).toHaveAttribute('title', 'Zoom in');
expect(zoomResetIcon).toHaveAttribute('title', 'Reset zoom');
expect(zoomOutIcon).toHaveAttribute('title', 'Zoom out');

expect(helpIcon).toHaveAttribute('title', 'Quick Help');
});

@@ -87,6 +94,9 @@ describe('Tools tests', () => {
const edgeIcon = getByTestId('bpm-tool-icon-edge');
const deleteIcon = getByTestId('bpm-tool-icon-delete');
const colorIcon = getByTestId('bpm-tool-icon-color');
const zoomInIcon = getByTestId('bpm-tool-icon-zoomin');
const zoomResetIcon = getByTestId('bpm-tool-icon-zoomreset');
const zoomOutIcon = getByTestId('bpm-tool-icon-zoomout');
const helpIcon = getByTestId('bpm-tool-icon-help');

expect(newIcon).toHaveAttribute('title', 'Create new process');
@@ -102,6 +112,10 @@ describe('Tools tests', () => {
);
expect(colorIcon).toHaveStyleRule('background-color', '#66c430');

expect(zoomInIcon).not.toHaveStyleRule('background-color', '#66c430');
expect(zoomResetIcon).not.toHaveStyleRule('background-color', '#66c430');
expect(zoomOutIcon).not.toHaveStyleRule('background-color', '#66c430');

expect(helpIcon).toHaveAttribute('title', 'Quick Help');
});

@@ -110,6 +124,7 @@ describe('Tools tests', () => {
const handleDrawEdgeClick = jest.fn();
const handleDeleteClick = jest.fn();
const handleToggleConditionalColorization = jest.fn();
const handleZoomChangeClick = jest.fn();

const {getByTestId} = render(
<Tools
@@ -119,13 +134,17 @@ describe('Tools tests', () => {
onDeleteClick={handleDeleteClick}
onDrawEdgeClick={handleDrawEdgeClick}
onToggleConditionalColorization={handleToggleConditionalColorization}
onZoomChangeClick={handleZoomChangeClick}
/>,
);

const newIcon = getByTestId('bpm-tool-icon-new');
const edgeIcon = getByTestId('bpm-tool-icon-edge');
const deleteIcon = getByTestId('bpm-tool-icon-delete');
const colorIcon = getByTestId('bpm-tool-icon-color');
const zoomInIcon = getByTestId('bpm-tool-icon-zoomin');
const zoomResetIcon = getByTestId('bpm-tool-icon-zoomreset');
const zoomOutIcon = getByTestId('bpm-tool-icon-zoomout');

expect(newIcon).toHaveAttribute('title', 'Create new process');
fireEvent.click(newIcon);
@@ -145,5 +164,17 @@ describe('Tools tests', () => {
);
fireEvent.click(colorIcon);
expect(handleToggleConditionalColorization).toHaveBeenCalled();

expect(zoomInIcon).toHaveAttribute('title', 'Zoom in');
fireEvent.click(zoomInIcon);
expect(handleZoomChangeClick).toHaveBeenCalledWith('+');

expect(zoomResetIcon).toHaveAttribute('title', 'Reset zoom');
fireEvent.click(zoomResetIcon);
expect(handleZoomChangeClick).toHaveBeenCalledWith('0');

expect(zoomOutIcon).toHaveAttribute('title', 'Zoom out');
fireEvent.click(zoomOutIcon);
expect(handleZoomChangeClick).toHaveBeenCalledWith('-');
});
});