aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-web')
-rw-r--r--server/sonar-web/src/main/js/apps/system/__tests__/utils-test.ts16
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/HealthCard.tsx13
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/HealthItem.tsx18
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/SysInfoItem.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/HealthItem-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/SysInfoItem-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthCard-test.tsx.snap11
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthItem-test.tsx.snap15
-rw-r--r--server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/SysInfoItem-test.tsx.snap21
-rw-r--r--server/sonar-web/src/main/js/apps/system/styles.css4
-rw-r--r--server/sonar-web/src/main/js/apps/system/utils.ts23
-rw-r--r--server/sonar-web/src/main/js/components/icons-components/CheckIcon.tsx41
-rw-r--r--server/sonar-web/src/main/js/components/icons-components/CloseIcon.tsx (renamed from server/sonar-web/src/main/js/components/icons-components/CloseIcon.js)13
-rw-r--r--server/sonar-web/src/main/js/components/icons-components/icons.js2
14 files changed, 151 insertions, 42 deletions
diff --git a/server/sonar-web/src/main/js/apps/system/__tests__/utils-test.ts b/server/sonar-web/src/main/js/apps/system/__tests__/utils-test.ts
index b1e915f0370..98cea1804e5 100644
--- a/server/sonar-web/src/main/js/apps/system/__tests__/utils-test.ts
+++ b/server/sonar-web/src/main/js/apps/system/__tests__/utils-test.ts
@@ -67,4 +67,20 @@ describe('getSystemLogsLevel', () => {
} as ClusterSysInfo)
).toBe('DEBUG');
});
+
+ it('should not fail if the log informations are not there yet', () => {
+ expect(
+ u.getSystemLogsLevel({
+ System: { 'High Availability': true },
+ 'Application Nodes': [{ Name: 'App 1' }, { Name: 'App 2' }]
+ } as ClusterSysInfo)
+ ).toBe('INFO');
+ expect(
+ u.getSystemLogsLevel({
+ System: { 'High Availability': true },
+ 'Application Nodes': [{ 'Compute Engine Logging': {} }, { Name: 'App 2' }]
+ } as ClusterSysInfo)
+ ).toBe('INFO');
+ expect(u.getSystemLogsLevel({ System: {} } as SysInfo)).toBe('INFO');
+ });
});
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/HealthCard.tsx b/server/sonar-web/src/main/js/apps/system/components/info-items/HealthCard.tsx
index ff49fc75a83..ec8372f5802 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/HealthCard.tsx
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/HealthCard.tsx
@@ -65,19 +65,20 @@ export default class HealthCard extends React.PureComponent<Props, State> {
<OpenCloseIcon className="little-spacer-right" open={open} />
{this.props.name}
</span>
+ {showLogLevelWarning && (
+ <span className="alert alert-danger spacer-left">
+ {translate('system.log_level.warning.short')}
+ </span>
+ )}
{health && (
<HealthItem
biggerHealth={this.props.biggerHealth}
- className="pull-right spacer-left"
+ className="pull-right"
health={health}
healthCauses={this.props.healthCauses}
+ name={this.props.name}
/>
)}
- {showLogLevelWarning && (
- <span className="pull-right alert alert-danger">
- {translate('system.log_level.warning.short')}
- </span>
- )}
</div>
{open && (
<div
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/HealthItem.tsx b/server/sonar-web/src/main/js/apps/system/components/info-items/HealthItem.tsx
index 2edc10805e0..933aa13b01a 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/HealthItem.tsx
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/HealthItem.tsx
@@ -21,24 +21,38 @@ import * as React from 'react';
import * as classNames from 'classnames';
import HealthCauseItem from './HealthCauseItem';
import StatusIndicator from '../../../../components/common/StatusIndicator';
+import Tooltip from '../../../../components/controls/Tooltip';
import { HealthType } from '../../../../api/system';
+import { translateWithParameters } from '../../../../helpers/l10n';
interface Props {
biggerHealth?: boolean;
+ name?: string;
className?: string;
health: HealthType;
healthCauses?: string[];
}
-export default function HealthItem({ biggerHealth, className, health, healthCauses }: Props) {
+export default function HealthItem({ biggerHealth, className, name, health, healthCauses }: Props) {
const hasHealthCauses = healthCauses && healthCauses.length > 0 && health !== HealthType.GREEN;
+ const statusIndicator = (
+ <StatusIndicator color={health.toLowerCase()} size={biggerHealth ? 'big' : undefined} />
+ );
return (
<div className={classNames('system-info-health-info', className)}>
{hasHealthCauses &&
healthCauses!.map((cause, idx) => (
<HealthCauseItem key={idx} className="spacer-right" health={health} healthCause={cause} />
))}
- <StatusIndicator color={health.toLowerCase()} size={biggerHealth ? 'big' : undefined} />
+ {name ? (
+ <Tooltip
+ overlay={translateWithParameters('system.current_health_of_x', name)}
+ placement="left">
+ <span>{statusIndicator}</span>
+ </Tooltip>
+ ) : (
+ statusIndicator
+ )}
</div>
);
}
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 12876d75940..bd1751ec61e 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,6 +19,8 @@
*/
import * as React from 'react';
import { map } from 'lodash';
+import CheckIcon from '../../../../components/icons-components/CheckIcon';
+import CloseIcon from '../../../../components/icons-components/CloseIcon';
import HealthItem from './HealthItem';
import { HealthType, SysValue, SysValueObject } from '../../../../api/system';
import { HEALTH_FIELD } from '../../utils';
@@ -29,7 +31,7 @@ interface Props {
}
export default function SysInfoItem({ name, value }: Props): JSX.Element {
- if (name === HEALTH_FIELD) {
+ if (name === HEALTH_FIELD || name === 'State') {
return <HealthItem className="no-margin" health={value as HealthType} />;
}
if (value instanceof Array) {
@@ -47,9 +49,9 @@ export default function SysInfoItem({ name, value }: Props): JSX.Element {
function BooleanItem({ value }: { value: boolean }) {
if (value) {
- return <i className="icon-check" />;
+ return <CheckIcon />;
} else {
- return <i className="icon-delete" />;
+ return <CloseIcon />;
}
}
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/HealthItem-test.tsx b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/HealthItem-test.tsx
index 7f21d999a4e..5476278f613 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/HealthItem-test.tsx
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/HealthItem-test.tsx
@@ -24,7 +24,9 @@ import { HealthType } from '../../../../../api/system';
it('should render correctly', () => {
expect(
- shallow(<HealthItem biggerHealth={true} health={HealthType.RED} healthCauses={['foo']} />)
+ shallow(
+ <HealthItem biggerHealth={true} name="Foo" health={HealthType.RED} healthCauses={['foo']} />
+ )
).toMatchSnapshot();
});
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 2761a2ddbf9..acbf8d43ab9 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
@@ -51,10 +51,10 @@ it('should render object correctly', () => {
it('should render `true`', () => {
const wrapper = mount(<SysInfoItem name="test" value={true} />);
- expect(wrapper.find('.icon-check')).toHaveLength(1);
+ expect(wrapper.find('CheckIcon')).toHaveLength(1);
});
it('should render `false`', () => {
const wrapper = mount(<SysInfoItem name="test" value={false} />);
- expect(wrapper.find('.icon-delete')).toHaveLength(1);
+ expect(wrapper.find('CloseIcon')).toHaveLength(1);
});
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthCard-test.tsx.snap b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthCard-test.tsx.snap
index 6c054721b70..77afaf39ea2 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthCard-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthCard-test.tsx.snap
@@ -2,7 +2,7 @@
exports[`should display the log level alert 1`] = `
<span
- className="pull-right alert alert-danger"
+ className="alert alert-danger spacer-left"
>
system.log_level.warning.short
</span>
@@ -27,13 +27,14 @@ exports[`should display the sysinfo detail 1`] = `
</span>
<HealthItem
biggerHealth={true}
- className="pull-right spacer-left"
+ className="pull-right"
health="RED"
healthCauses={
Array [
"foo",
]
}
+ name="Foobar"
/>
</div>
<div
@@ -63,13 +64,14 @@ exports[`should render correctly 1`] = `
</span>
<HealthItem
biggerHealth={false}
- className="pull-right spacer-left"
+ className="pull-right"
health="RED"
healthCauses={
Array [
"foo",
]
}
+ name="Foobar"
/>
</div>
</li>
@@ -94,13 +96,14 @@ exports[`should show a main section and multiple sub sections 1`] = `
</span>
<HealthItem
biggerHealth={false}
- className="pull-right spacer-left"
+ className="pull-right"
health="RED"
healthCauses={
Array [
"foo",
]
}
+ name="Foobar"
/>
</div>
<div
diff --git a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthItem-test.tsx.snap b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthItem-test.tsx.snap
index eafb250bdd1..81f4aa9ba6a 100644
--- a/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthItem-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/system/components/info-items/__tests__/__snapshots__/HealthItem-test.tsx.snap
@@ -29,10 +29,17 @@ exports[`should render correctly 1`] = `
health="RED"
healthCause="foo"
/>
- <StatusIndicator
- color="red"
- size="big"
- />
+ <Tooltip
+ overlay="system.current_health_of_x.Foo"
+ placement="left"
+ >
+ <span>
+ <StatusIndicator
+ color="red"
+ size="big"
+ />
+ </span>
+ </Tooltip>
</div>
`;
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 a1ff67c3506..b02b9854bdf 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
@@ -117,9 +117,24 @@ Array [
<BooleanItem
value={true}
>
- <i
- className="icon-check"
- />
+ <CheckIcon>
+ <svg
+ height={16}
+ viewBox="0 0 16 16"
+ width={16}
+ xmlns="http://www.w3.org/2000/svg"
+ >
+ <path
+ d="M14.92 4.804q0 0.357-0.25 0.607l-7.679 7.679q-0.25 0.25-0.607 0.25t-0.607-0.25l-4.446-4.446q-0.25-0.25-0.25-0.607t0.25-0.607l1.214-1.214q0.25-0.25 0.607-0.25t0.607 0.25l2.625 2.634 5.857-5.866q0.25-0.25 0.607-0.25t0.607 0.25l1.214 1.214q0.25 0.25 0.25 0.607z"
+ style={
+ Object {
+ "fill": "currentColor",
+ }
+ }
+ />
+ ;
+ </svg>
+ </CheckIcon>
</BooleanItem>
</SysInfoItem>
</td>
diff --git a/server/sonar-web/src/main/js/apps/system/styles.css b/server/sonar-web/src/main/js/apps/system/styles.css
index f34dc3fa394..e9b58438149 100644
--- a/server/sonar-web/src/main/js/apps/system/styles.css
+++ b/server/sonar-web/src/main/js/apps/system/styles.css
@@ -22,7 +22,9 @@
}
.system-info-health-card .boxed-group-header > .alert {
- margin-top: -6px;
+ display: inline-block;
+ margin-bottom: -3px;
+ margin-top: -3px;
}
.system-info-health-card .boxed-group-inner {
diff --git a/server/sonar-web/src/main/js/apps/system/utils.ts b/server/sonar-web/src/main/js/apps/system/utils.ts
index 5d98c9e74f8..5514ae4e705 100644
--- a/server/sonar-web/src/main/js/apps/system/utils.ts
+++ b/server/sonar-web/src/main/js/apps/system/utils.ts
@@ -42,9 +42,11 @@ export const LOGS_LEVELS = ['INFO', 'DEBUG', 'TRACE'];
export const HA_FIELD = 'High Availability';
export const HEALTH_FIELD = 'Health';
export const HEALTHCAUSES_FIELD = 'Health Causes';
+export const PLUGINS_FIELD = 'Plugins';
+export const SETTINGS_FIELD = 'Settings';
export function ignoreInfoFields(sysInfoObject: SysValueObject): SysValueObject {
- return omit(sysInfoObject, [HEALTH_FIELD, HEALTHCAUSES_FIELD, 'Name', 'Settings']);
+ return omit(sysInfoObject, [HEALTH_FIELD, HEALTHCAUSES_FIELD, 'Name', SETTINGS_FIELD]);
}
export function getHealth(sysInfoObject: SysValueObject): HealthType {
@@ -55,18 +57,21 @@ export function getHealthCauses(sysInfoObject: SysValueObject): string[] {
return sysInfoObject[HEALTHCAUSES_FIELD] as string[];
}
-export function getLogsLevel(sysInfoObject: SysValueObject): string {
- if (sysInfoObject['Web Logging']) {
+export function getLogsLevel(sysInfoObject?: SysValueObject): string {
+ if (!sysInfoObject) {
+ return LOGS_LEVELS[0];
+ }
+ if (sysInfoObject['Web Logging'] || sysInfoObject['Compute Engine Logging']) {
return sortBy(
[
- (sysInfoObject as NodeInfo)['Compute Engine Logging']['Logs Level'],
- (sysInfoObject as NodeInfo)['Web Logging']['Logs Level']
+ getLogsLevel((sysInfoObject as NodeInfo)['Web Logging']),
+ getLogsLevel((sysInfoObject as NodeInfo)['Compute Engine Logging'])
],
logLevel => LOGS_LEVELS.indexOf(logLevel)
)[1];
}
if (sysInfoObject['System']) {
- return (sysInfoObject as SysInfo)['System']['Logs Level'];
+ return getLogsLevel((sysInfoObject as SysInfo)['System']);
}
return (sysInfoObject['Logs Level'] || LOGS_LEVELS[0]) as string;
}
@@ -110,9 +115,9 @@ export function getClusterMainCardSection(sysInfoData: ClusterSysInfo): SysValue
...sysInfoData['System'],
...omit(sysInfoData, [
'Application Nodes',
- 'Plugins',
+ PLUGINS_FIELD,
'Search Nodes',
- 'Settings',
+ SETTINGS_FIELD,
'Statistics',
'System'
])
@@ -126,7 +131,7 @@ export function getStandaloneMainSections(sysInfoData: SysInfo): SysValueObject
sysInfoData,
(value, key) =>
value == null ||
- ['Plugins', 'Settings', 'Statistics', 'System'].includes(key) ||
+ [PLUGINS_FIELD, SETTINGS_FIELD, 'Statistics', 'System'].includes(key) ||
key.startsWith('Compute Engine') ||
key.startsWith('Search') ||
key.startsWith('Web')
diff --git a/server/sonar-web/src/main/js/components/icons-components/CheckIcon.tsx b/server/sonar-web/src/main/js/components/icons-components/CheckIcon.tsx
new file mode 100644
index 00000000000..487fac702cf
--- /dev/null
+++ b/server/sonar-web/src/main/js/components/icons-components/CheckIcon.tsx
@@ -0,0 +1,41 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2017 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 * as React from 'react';
+
+interface Props {
+ className?: string;
+ size?: number;
+}
+
+export default function CheckIcon({ className, size = 16 }: Props) {
+ return (
+ <svg
+ className={className}
+ xmlns="http://www.w3.org/2000/svg"
+ viewBox="0 0 16 16"
+ width={size}
+ height={size}>
+ <path
+ style={{ fill: 'currentColor' }}
+ d="M14.92 4.804q0 0.357-0.25 0.607l-7.679 7.679q-0.25 0.25-0.607 0.25t-0.607-0.25l-4.446-4.446q-0.25-0.25-0.25-0.607t0.25-0.607l1.214-1.214q0.25-0.25 0.607-0.25t0.607 0.25l2.625 2.634 5.857-5.866q0.25-0.25 0.607-0.25t0.607 0.25l1.214 1.214q0.25 0.25 0.25 0.607z"
+ />;
+ </svg>
+ );
+}
diff --git a/server/sonar-web/src/main/js/components/icons-components/CloseIcon.js b/server/sonar-web/src/main/js/components/icons-components/CloseIcon.tsx
index 7fb48b8b3f2..5ab53930909 100644
--- a/server/sonar-web/src/main/js/components/icons-components/CloseIcon.js
+++ b/server/sonar-web/src/main/js/components/icons-components/CloseIcon.tsx
@@ -17,15 +17,14 @@
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
-// @flow
-import React from 'react';
+import * as React from 'react';
-/*::
-type Props = { className?: string, size?: number };
-*/
+interface Props {
+ className?: string;
+ size?: number;
+}
-export default function CloseIcon({ className, size = 16 } /*: Props */) {
- /* eslint-disable max-len */
+export default function CloseIcon({ className, size = 16 }: Props) {
return (
<svg
xmlns="http://www.w3.org/2000/svg"
diff --git a/server/sonar-web/src/main/js/components/icons-components/icons.js b/server/sonar-web/src/main/js/components/icons-components/icons.js
index c50065921f4..407323488ae 100644
--- a/server/sonar-web/src/main/js/components/icons-components/icons.js
+++ b/server/sonar-web/src/main/js/components/icons-components/icons.js
@@ -23,6 +23,7 @@ import _BubblesIcon from './BubblesIcon';
import _BugIcon from './BugIcon';
import _ChangeIcon from './ChangeIcon';
import _ChartLegendIcon from './ChartLegendIcon';
+import _CheckIcon from './CheckIcon';
import _CloseIcon from './CloseIcon';
import _CodeSmellIcon from './CodeSmellIcon';
import _DeleteIcon from './DeleteIcon';
@@ -45,6 +46,7 @@ export const BubblesIcon = _BubblesIcon;
export const BugIcon = _BugIcon;
export const ChangeIcon = _ChangeIcon;
export const ChartLegendIcon = _ChartLegendIcon;
+export const CheckIcon = _CheckIcon;
export const CloseIcon = _CloseIcon;
export const CodeSmellIcon = _CodeSmellIcon;
export const DeleteIcon = _DeleteIcon;