aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Davis <jeremy.davis@sonarsource.com>2022-10-31 14:14:26 +0100
committersonartech <sonartech@sonarsource.com>2022-11-01 20:03:09 +0000
commite028637e1ab4ac6715eb56a6898c1c9758e5ec87 (patch)
tree911a56cfa3a1292414414320eb4caf22b4748665
parent493b522f0ac52122ace3fa12fa5d53e823b3cb20 (diff)
downloadsonarqube-e028637e1ab4ac6715eb56a6898c1c9758e5ec87.tar.gz
sonarqube-e028637e1ab4ac6715eb56a6898c1c9758e5ec87.zip
SONAR-17465 Handle missing port number for SonarLint Connection
-rw-r--r--server/sonar-web/src/main/js/app/components/SonarLintConnection.tsx27
-rw-r--r--server/sonar-web/src/main/js/app/components/__tests__/SonarLintConnection-test.tsx12
2 files changed, 21 insertions, 18 deletions
diff --git a/server/sonar-web/src/main/js/app/components/SonarLintConnection.tsx b/server/sonar-web/src/main/js/app/components/SonarLintConnection.tsx
index 591a14d4ee3..1a997e66bc7 100644
--- a/server/sonar-web/src/main/js/app/components/SonarLintConnection.tsx
+++ b/server/sonar-web/src/main/js/app/components/SonarLintConnection.tsx
@@ -19,7 +19,7 @@
*/
import * as React from 'react';
import { FormattedMessage } from 'react-intl';
-import { useNavigate, useSearchParams } from 'react-router-dom';
+import { useSearchParams } from 'react-router-dom';
import { generateToken, getTokens } from '../../api/user-tokens';
import Link from '../../components/common/Link';
import { Button } from '../../components/controls/buttons';
@@ -40,8 +40,8 @@ import './SonarLintConnection.css';
enum Status {
request,
tokenError,
- connectionError,
- success
+ tokenCreated,
+ tokenSent
}
interface Props {
@@ -64,7 +64,6 @@ async function computeExpirationDate() {
}
export function SonarLintConnection({ currentUser }: Props) {
- const navigate = useNavigate();
const [searchParams] = useSearchParams();
const [status, setStatus] = React.useState(Status.request);
const [newToken, setNewToken] = React.useState<NewUserToken | undefined>(undefined);
@@ -72,13 +71,6 @@ export function SonarLintConnection({ currentUser }: Props) {
const port = parseInt(searchParams.get('port') ?? '0', 10);
const ideName = searchParams.get('ideName') ?? translate('sonarlint-connection.unspecified-ide');
- // If the port is not in the expected range, redirect to home page
- React.useEffect(() => {
- if (!portIsValid(port)) {
- navigate('/');
- }
- }, [navigate, port]);
-
const { login } = currentUser;
const authorize = React.useCallback(async () => {
@@ -95,11 +87,16 @@ export function SonarLintConnection({ currentUser }: Props) {
setNewToken(token);
+ if (!portIsValid(port)) {
+ setStatus(Status.tokenCreated);
+ return;
+ }
+
try {
await sendUserToken(port, token);
- setStatus(Status.success);
+ setStatus(Status.tokenSent);
} catch (_) {
- setStatus(Status.connectionError);
+ setStatus(Status.tokenCreated);
}
}, [port, ideName, login]);
@@ -162,7 +159,7 @@ export function SonarLintConnection({ currentUser }: Props) {
</>
)}
- {status === Status.connectionError && newToken && (
+ {status === Status.tokenCreated && newToken && (
<>
<img
alt=""
@@ -200,7 +197,7 @@ export function SonarLintConnection({ currentUser }: Props) {
</>
)}
- {status === Status.success && newToken && (
+ {status === Status.tokenSent && newToken && (
<>
<h1 className="big-spacer-top big-spacer-bottom">
{translate('sonarlint-connection.success.title')}
diff --git a/server/sonar-web/src/main/js/app/components/__tests__/SonarLintConnection-test.tsx b/server/sonar-web/src/main/js/app/components/__tests__/SonarLintConnection-test.tsx
index 2137385bb1b..4c1daef425d 100644
--- a/server/sonar-web/src/main/js/app/components/__tests__/SonarLintConnection-test.tsx
+++ b/server/sonar-web/src/main/js/app/components/__tests__/SonarLintConnection-test.tsx
@@ -123,12 +123,18 @@ it('should require authentication if user is not logged in', () => {
expect(handleRequiredAuthentication).toHaveBeenCalled();
});
-it('should redirect if port is not provided', () => {
+it('should let the user copy the token if the port is not valid', async () => {
+ const user = userEvent.setup();
+
renderSonarLintConnection({ port: '' });
+ await user.click(
+ await screen.findByRole('button', { name: 'sonarlint-connection.request.action' })
+ );
+
expect(
- screen.queryByRole('heading', { name: 'sonarlint-connection.title' })
- ).not.toBeInTheDocument();
+ await screen.findByText('sonarlint-connection.connection-error.description')
+ ).toBeInTheDocument();
});
function renderSonarLintConnection(overrides: { currentUser?: CurrentUser; port?: string } = {}) {