aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web
diff options
context:
space:
mode:
authorWouter Admiraal <wouter.admiraal@sonarsource.com>2021-08-10 14:55:14 +0200
committersonartech <sonartech@sonarsource.com>2021-08-12 20:07:59 +0000
commit444b366de0628902a2530ff2833297341b953185 (patch)
tree6f1c676f67a78f6fe7f3a7cbf632f65a363a1e83 /server/sonar-web
parent25a855f89d998a717339376628201d4aac1b14a5 (diff)
downloadsonarqube-444b366de0628902a2530ff2833297341b953185.tar.gz
sonarqube-444b366de0628902a2530ff2833297341b953185.zip
SONAR-14023 Make system health status more explicit
Diffstat (limited to 'server/sonar-web')
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx47
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx50
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap22
-rw-r--r--server/sonar-web/src/main/js/components/common/StatusIndicator.css12
-rw-r--r--server/sonar-web/src/main/js/components/common/StatusIndicator.tsx31
-rw-r--r--server/sonar-web/src/main/js/components/common/__tests__/SatusIndicator-test.tsx34
-rw-r--r--server/sonar-web/src/main/js/components/common/__tests__/__snapshots__/SatusIndicator-test.tsx.snap34
7 files changed, 128 insertions, 102 deletions
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx b/server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx
index fb20e074f63..126d912c9b5 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx
@@ -19,8 +19,7 @@
*/
import { map } from 'lodash';
import * as React from 'react';
-import AlertErrorIcon from 'sonar-ui-common/components/icons/AlertErrorIcon';
-import AlertSuccessIcon from 'sonar-ui-common/components/icons/AlertSuccessIcon';
+import { translate } from 'sonar-ui-common/helpers/l10n';
import { HEALTH_FIELD, STATE_FIELD } from '../../utils';
import HealthItem from './HealthItem';
@@ -29,7 +28,7 @@ export interface Props {
value: T.SysInfoValue;
}
-export default function SysInfoItem({ name, value }: Props): JSX.Element {
+export default function SysInfoItem({ name, value }: Props) {
if (name === HEALTH_FIELD || name === STATE_FIELD) {
return <HealthItem className="no-margin" health={value as T.HealthType} />;
}
@@ -38,35 +37,23 @@ export default function SysInfoItem({ name, value }: Props): JSX.Element {
}
switch (typeof value) {
case 'boolean':
- return <BooleanItem value={value} />;
+ return <>{translate(value ? 'yes' : 'no')}</>;
case 'object':
- return <ObjectItem value={value} />;
+ return (
+ <table className="data">
+ <tbody>
+ {map(value, (v, n) => (
+ <tr key={n}>
+ <td className="thin nowrap">{n}</td>
+ <td>
+ <SysInfoItem name={n} value={v} />
+ </td>
+ </tr>
+ ))}
+ </tbody>
+ </table>
+ );
default:
return <code>{value}</code>;
}
}
-
-function BooleanItem({ value }: { value: boolean }) {
- if (value) {
- return <AlertSuccessIcon />;
- } else {
- return <AlertErrorIcon />;
- }
-}
-
-function ObjectItem({ value }: { value: T.SysInfoValueObject }) {
- return (
- <table className="data">
- <tbody>
- {map(value, (value, name) => (
- <tr key={name}>
- <td className="thin nowrap">{name}</td>
- <td>
- <SysInfoItem name={name} value={value} />
- </td>
- </tr>
- ))}
- </tbody>
- </table>
- );
-}
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx
index a640c7b0a57..ca0e85fdce1 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx
@@ -19,60 +19,24 @@
*/
import { shallow } from 'enzyme';
import * as React from 'react';
+import HealthItem from '../HealthItem';
import SysInfoItem, { Props } from '../SysInfoItem';
-it('should render string', () => {
- expect(
- shallowRender('/some/path/as/an/example')
- .find('code')
- .text()
- ).toBe('/some/path/as/an/example');
-});
-
-it('should render object', () => {
- expect(
- shallowRender({ bar: 'baz' })
- .find('ObjectItem')
- .prop('value')
- ).toEqual({ bar: 'baz' });
-});
-
-it('should render boolean', () => {
- expect(
- shallowRender(true)
- .find('BooleanItem')
- .prop('value')
- ).toBe(true);
+it('should render correctly', () => {
+ expect(shallowRender('/some/path/as/an/example')).toMatchSnapshot('string');
+ expect(shallowRender({ foo: 'Far', bar: { a: 1, b: 'b' }, baz: true })).toMatchSnapshot('object');
+ expect(shallowRender(true)).toMatchSnapshot('true');
+ expect(shallowRender(false)).toMatchSnapshot('false');
});
it('should render health item', () => {
expect(
shallowRender('GREEN', 'Health')
- .find('HealthItem')
+ .find(HealthItem)
.prop('health')
).toBe('GREEN');
});
-it('should render `true`', () => {
- const wrapper = shallowRender(true);
- expect(wrapper.find('BooleanItem').exists()).toBe(true);
- expect(wrapper.dive()).toMatchSnapshot();
-});
-
-it('should render `false`', () => {
- const wrapper = shallowRender(false);
- expect(wrapper.find('BooleanItem').exists()).toBe(true);
- expect(wrapper.dive()).toMatchSnapshot();
-});
-
-it('should render object correctly', () => {
- expect(
- shallowRender({ foo: 'Far', bar: { a: 1, b: 'b' }, baz: true })
- .find('ObjectItem')
- .dive()
- ).toMatchSnapshot();
-});
-
function shallowRender(value: Props['value'], name: Props['name'] = 'foo') {
return shallow(<SysInfoItem name={name} value={value} />);
}
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap
index 212e5d97aa1..7b2c54af4c1 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap
@@ -1,10 +1,12 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
-exports[`should render \`false\` 1`] = `<AlertErrorIcon />`;
-
-exports[`should render \`true\` 1`] = `<AlertSuccessIcon />`;
+exports[`should render correctly: false 1`] = `
+<Fragment>
+ no
+</Fragment>
+`;
-exports[`should render object correctly 1`] = `
+exports[`should render correctly: object 1`] = `
<table
className="data"
>
@@ -62,3 +64,15 @@ exports[`should render object correctly 1`] = `
</tbody>
</table>
`;
+
+exports[`should render correctly: string 1`] = `
+<code>
+ /some/path/as/an/example
+</code>
+`;
+
+exports[`should render correctly: true 1`] = `
+<Fragment>
+ yes
+</Fragment>
+`;
diff --git a/server/sonar-web/src/main/js/components/common/StatusIndicator.css b/server/sonar-web/src/main/js/components/common/StatusIndicator.css
index a855249da6d..dd54c4331ad 100644
--- a/server/sonar-web/src/main/js/components/common/StatusIndicator.css
+++ b/server/sonar-web/src/main/js/components/common/StatusIndicator.css
@@ -46,18 +46,6 @@
background-color: var(--red);
}
-.status-indicator.red::after {
- position: absolute;
- z-index: 3;
- display: block;
- width: 6px;
- height: 2px;
- top: 3px;
- left: 1px;
- background-color: #fff;
- content: '';
-}
-
.status-indicator.yellow {
background-color: var(--yellow);
}
diff --git a/server/sonar-web/src/main/js/components/common/StatusIndicator.tsx b/server/sonar-web/src/main/js/components/common/StatusIndicator.tsx
index 5037fef1f14..5e37429ade6 100644
--- a/server/sonar-web/src/main/js/components/common/StatusIndicator.tsx
+++ b/server/sonar-web/src/main/js/components/common/StatusIndicator.tsx
@@ -19,26 +19,31 @@
*/
import * as classNames from 'classnames';
import * as React from 'react';
+import { translate } from 'sonar-ui-common/helpers/l10n';
import './StatusIndicator.css';
-interface Props {
+export interface StatusIndicatorProps {
className?: string;
color?: string;
size?: string;
}
-export default function StatusIndicator({ className, color, size }: Props) {
+export default function StatusIndicator({ className, color, size }: StatusIndicatorProps) {
return (
- <i
- className={classNames(
- 'status-indicator',
- color,
- {
- 'small-status-indicator': size === 'small',
- 'big-status-indicator': size === 'big'
- },
- className
- )}
- />
+ <>
+ {color ? translate('system.current_health', color) : undefined}
+ <i
+ className={classNames(
+ 'spacer-left',
+ 'status-indicator',
+ color,
+ {
+ 'small-status-indicator': size === 'small',
+ 'big-status-indicator': size === 'big'
+ },
+ className
+ )}
+ />
+ </>
);
}
diff --git a/server/sonar-web/src/main/js/components/common/__tests__/SatusIndicator-test.tsx b/server/sonar-web/src/main/js/components/common/__tests__/SatusIndicator-test.tsx
new file mode 100644
index 00000000000..c8af02b4bcc
--- /dev/null
+++ b/server/sonar-web/src/main/js/components/common/__tests__/SatusIndicator-test.tsx
@@ -0,0 +1,34 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2021 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+import { shallow } from 'enzyme';
+import * as React from 'react';
+import StatusIndicator, { StatusIndicatorProps } from '../StatusIndicator';
+
+it('should render correctly', () => {
+ expect(shallowRender()).toMatchSnapshot('default');
+ expect(shallowRender({ color: 'green' })).toMatchSnapshot('green');
+ expect(shallowRender({ size: 'small' })).toMatchSnapshot('small');
+ expect(shallowRender({ size: 'big' })).toMatchSnapshot('big');
+});
+
+function shallowRender(props: Partial<StatusIndicatorProps> = {}) {
+ return shallow<StatusIndicatorProps>(<StatusIndicator className="my-class" {...props} />);
+}
diff --git a/server/sonar-web/src/main/js/components/common/__tests__/__snapshots__/SatusIndicator-test.tsx.snap b/server/sonar-web/src/main/js/components/common/__tests__/__snapshots__/SatusIndicator-test.tsx.snap
new file mode 100644
index 00000000000..e2fc7608203
--- /dev/null
+++ b/server/sonar-web/src/main/js/components/common/__tests__/__snapshots__/SatusIndicator-test.tsx.snap
@@ -0,0 +1,34 @@
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`should render correctly: big 1`] = `
+<Fragment>
+ <i
+ className="spacer-left status-indicator big-status-indicator my-class"
+ />
+</Fragment>
+`;
+
+exports[`should render correctly: default 1`] = `
+<Fragment>
+ <i
+ className="spacer-left status-indicator my-class"
+ />
+</Fragment>
+`;
+
+exports[`should render correctly: green 1`] = `
+<Fragment>
+ system.current_health.green
+ <i
+ className="spacer-left status-indicator green my-class"
+ />
+</Fragment>
+`;
+
+exports[`should render correctly: small 1`] = `
+<Fragment>
+ <i
+ className="spacer-left status-indicator small-status-indicator my-class"
+ />
+</Fragment>
+`;