aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGrégoire Aubert <gregoire.aubert@sonarsource.com>2017-10-19 16:00:36 +0200
committerGrégoire Aubert <gregoire.aubert@sonarsource.com>2017-10-23 08:01:13 -0700
commit33a0c7138e444e5eba8272a48206c6bb05297793 (patch)
tree977e8c1e3bca3f4f2e4aead5b65bbbb16379d72d
parentf03c5e9858dd86ecd78e6278aa6f95d146ada270 (diff)
downloadsonarqube-33a0c7138e444e5eba8272a48206c6bb05297793.tar.gz
sonarqube-33a0c7138e444e5eba8272a48206c6bb05297793.zip
Update marketplace editions json format
-rw-r--r--server/sonar-web/src/main/js/api/marketplace.ts10
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/__tests__/EditionBoxes-test.tsx16
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/__tests__/__snapshots__/EditionBoxes-test.tsx.snap16
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/EditionBox.tsx45
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/EditionsStatusNotif.tsx14
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/LicenseEditionSet.tsx2
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/__tests__/EditionBox-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionForm-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionSet-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/__tests__/UninstallEditionForm-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/components/__tests__/__snapshots__/LicenseEditionForm-test.tsx.snap16
-rw-r--r--server/sonar-web/src/main/js/apps/marketplace/utils.ts14
12 files changed, 93 insertions, 72 deletions
diff --git a/server/sonar-web/src/main/js/api/marketplace.ts b/server/sonar-web/src/main/js/api/marketplace.ts
index 0574650e603..d067f7b3e22 100644
--- a/server/sonar-web/src/main/js/api/marketplace.ts
+++ b/server/sonar-web/src/main/js/api/marketplace.ts
@@ -23,10 +23,10 @@ import throwGlobalError from '../app/utils/throwGlobalError';
export interface Edition {
key: string;
name: string;
- desc: string;
- more_link: string;
- request_license_link: string;
- download_link: string;
+ textDescription: string;
+ homeUrl: string;
+ requestUrl: string;
+ downloadUrl: string;
}
export interface EditionsPerVersion {
@@ -47,7 +47,7 @@ export interface EditionStatus {
}
export function getEditionStatus(): Promise<EditionStatus> {
- return getJSON('/api/editions/status').catch(throwGlobalError);
+ return getJSON('/api/editions/status');
}
export function getEditionsList(url: string): Promise<EditionsPerVersion> {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/__tests__/EditionBoxes-test.tsx b/server/sonar-web/src/main/js/apps/marketplace/__tests__/EditionBoxes-test.tsx
index 0df72ac7f89..ca11079be15 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/__tests__/EditionBoxes-test.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/__tests__/EditionBoxes-test.tsx
@@ -32,18 +32,18 @@ const DEFAULT_EDITIONS = [
{
key: 'foo',
name: 'Foo',
- desc: 'Foo desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Foo desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
},
{
key: 'bar',
name: 'Bar',
- desc: 'Bar desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Bar desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
}
];
diff --git a/server/sonar-web/src/main/js/apps/marketplace/__tests__/__snapshots__/EditionBoxes-test.tsx.snap b/server/sonar-web/src/main/js/apps/marketplace/__tests__/__snapshots__/EditionBoxes-test.tsx.snap
index 59582a7e13d..f02b9834603 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/__tests__/__snapshots__/EditionBoxes-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/marketplace/__tests__/__snapshots__/EditionBoxes-test.tsx.snap
@@ -38,12 +38,12 @@ exports[`should display the edition boxes 2`] = `
<EditionBox
edition={
Object {
- "desc": "Foo desc",
- "download_link": "download_url",
+ "downloadUrl": "download_url",
+ "homeUrl": "more_url",
"key": "foo",
- "more_link": "more_url",
"name": "Foo",
- "request_license_link": "license_url",
+ "requestUrl": "license_url",
+ "textDescription": "Foo desc",
}
}
editionStatus={
@@ -59,12 +59,12 @@ exports[`should display the edition boxes 2`] = `
<EditionBox
edition={
Object {
- "desc": "Bar desc",
- "download_link": "download_url",
+ "downloadUrl": "download_url",
+ "homeUrl": "more_url",
"key": "bar",
- "more_link": "more_url",
"name": "Bar",
- "request_license_link": "license_url",
+ "requestUrl": "license_url",
+ "textDescription": "Bar desc",
}
}
editionStatus={
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/EditionBox.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/EditionBox.tsx
index 8ca571c0bfc..70920158b75 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/EditionBox.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/EditionBox.tsx
@@ -32,35 +32,44 @@ interface Props {
export default class EditionBox extends React.PureComponent<Props> {
handleInstall = () => this.props.onInstall(this.props.edition);
+ renderBadge(isInstalled?: boolean, installInProgress?: boolean) {
+ const { edition, editionStatus } = this.props;
+ const installReady = editionStatus && editionStatus.installationStatus === 'AUTOMATIC_READY';
+ const isInstalling =
+ installInProgress && editionStatus && editionStatus.nextEditionKey === edition.key;
+ if (isInstalling) {
+ return (
+ <span className="marketplace-edition-badge badge badge-normal-size">
+ {installReady ? translate('marketplace.pending') : translate('marketplace.installing')}
+ </span>
+ );
+ }
+ if (isInstalled) {
+ return (
+ <span className="marketplace-edition-badge badge badge-normal-size">
+ <CheckIcon size={14} className="little-spacer-right text-text-top" />
+ {translate('marketplace.installed')}
+ </span>
+ );
+ }
+ return null;
+ }
+
render() {
const { edition, editionStatus } = this.props;
+ const isInstalled = editionStatus && editionStatus.currentEditionKey === edition.key;
const installInProgress =
editionStatus &&
['AUTOMATIC_IN_PROGRESS', 'AUTOMATIC_READY'].includes(editionStatus.installationStatus);
- const installReady = editionStatus && editionStatus.installationStatus === 'AUTOMATIC_READY';
- const isInstalled = editionStatus && editionStatus.currentEditionKey === edition.key;
- const isInstalling =
- installInProgress && editionStatus && editionStatus.nextEditionKey === edition.key;
return (
<div className="boxed-group boxed-group-inner marketplace-edition">
- {isInstalled &&
- !isInstalling && (
- <span className="marketplace-edition-badge badge badge-normal-size">
- <CheckIcon size={14} className="little-spacer-right text-text-top" />
- {translate('marketplace.installed')}
- </span>
- )}
- {isInstalling && (
- <span className="marketplace-edition-badge badge badge-normal-size">
- {installReady ? translate('marketplace.pending') : translate('marketplace.installing')}
- </span>
- )}
+ {this.renderBadge(isInstalled, installInProgress)}
<div>
<h3 className="spacer-bottom">{edition.name}</h3>
- <p>{edition.desc}</p>
+ <p>{edition.textDescription}</p>
</div>
<div className="marketplace-edition-action spacer-top">
- <a href={edition.more_link} target="_blank">
+ <a href={edition.homeUrl} target="_blank">
{translate('marketplace.learn_more')}
</a>
{!isInstalled && (
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/EditionsStatusNotif.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/EditionsStatusNotif.tsx
index 672a0b7a28b..7679e29a591 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/EditionsStatusNotif.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/EditionsStatusNotif.tsx
@@ -21,7 +21,7 @@ import * as React from 'react';
import RestartForm from '../../../components/common/RestartForm';
import CloseIcon from '../../../components/icons-components/CloseIcon';
import { dismissErrorMessage, Edition, EditionStatus } from '../../../api/marketplace';
-import { translate } from '../../../helpers/l10n';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
interface Props {
editions?: Edition[];
@@ -67,7 +67,10 @@ export default class EditionsStatusNotif extends React.PureComponent<Props, Stat
<div className="alert alert-success">
<span>
{nextEdition ? (
- translate('marketplace.status_x.' + installationStatus, nextEdition.name)
+ translateWithParameters(
+ 'marketplace.status_x.' + installationStatus,
+ nextEdition.name
+ )
) : (
translate('marketplace.status', installationStatus)
)}
@@ -82,7 +85,10 @@ export default class EditionsStatusNotif extends React.PureComponent<Props, Stat
return (
<div className="alert alert-danger">
{nextEdition ? (
- translate('marketplace.status_x.' + installationStatus, nextEdition.name)
+ translateWithParameters(
+ 'marketplace.status_x.' + installationStatus,
+ nextEdition.name
+ )
) : (
translate('marketplace.status', installationStatus)
)}
@@ -91,7 +97,7 @@ export default class EditionsStatusNotif extends React.PureComponent<Props, Stat
<a
className="button spacer-right"
download={`sonarqube-${nextEdition.name}.zip`}
- href={nextEdition.download_link}
+ href={nextEdition.downloadUrl}
target="_blank">
{translate('marketplace.download_package')}
</a>
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/LicenseEditionSet.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/LicenseEditionSet.tsx
index 496c5fe988d..10def5d07bd 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/LicenseEditionSet.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/LicenseEditionSet.tsx
@@ -90,7 +90,7 @@ export default class LicenseEditionSet extends React.PureComponent<Props, State>
};
getLicenseFormUrl = (edition: Edition) => {
- let url = edition.request_license_link;
+ let url = edition.requestUrl;
if (this.state.formData) {
const query = stringify(omitNil(this.state.formData));
if (query) {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/EditionBox-test.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/EditionBox-test.tsx
index 0eb4f92f95d..ceaf61a7aa5 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/EditionBox-test.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/EditionBox-test.tsx
@@ -31,10 +31,10 @@ const DEFAULT_STATUS: EditionStatus = {
const DEFAULT_EDITION: Edition = {
key: 'foo',
name: 'Foo',
- desc: 'Foo desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Foo desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
};
it('should display the edition', () => {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionForm-test.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionForm-test.tsx
index 2beffa70f82..bb6e8d213ee 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionForm-test.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionForm-test.tsx
@@ -33,10 +33,10 @@ const applyLicense = require('../../../../api/marketplace').applyLicense as jest
const DEFAULT_EDITION = {
key: 'foo',
name: 'Foo',
- desc: 'Foo desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Foo desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
};
beforeEach(() => {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionSet-test.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionSet-test.tsx
index 4e682893968..0992ebb36bd 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionSet-test.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/LicenseEditionSet-test.tsx
@@ -41,10 +41,10 @@ const getLicensePreview = require('../../../../api/marketplace').getLicensePrevi
const DEFAULT_EDITION = {
key: 'foo',
name: 'Foo',
- desc: 'Foo desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Foo desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
};
beforeEach(() => {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/UninstallEditionForm-test.tsx b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/UninstallEditionForm-test.tsx
index 037c2d33cd2..3f52d0cce13 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/UninstallEditionForm-test.tsx
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/UninstallEditionForm-test.tsx
@@ -31,10 +31,10 @@ const uninstallEdition = require('../../../../api/marketplace').uninstallEdition
const DEFAULT_EDITION = {
key: 'foo',
name: 'Foo',
- desc: 'Foo desc',
- download_link: 'download_url',
- more_link: 'more_url',
- request_license_link: 'license_url'
+ textDescription: 'Foo desc',
+ downloadUrl: 'download_url',
+ homeUrl: 'more_url',
+ requestUrl: 'license_url'
};
beforeEach(() => {
diff --git a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/__snapshots__/LicenseEditionForm-test.tsx.snap b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/__snapshots__/LicenseEditionForm-test.tsx.snap
index e3951bfeaff..382c562bb02 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/__snapshots__/LicenseEditionForm-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/marketplace/components/__tests__/__snapshots__/LicenseEditionForm-test.tsx.snap
@@ -55,23 +55,23 @@ exports[`should display correctly 1`] = `
className="modal-body"
edition={
Object {
- "desc": "Foo desc",
- "download_link": "download_url",
+ "downloadUrl": "download_url",
+ "homeUrl": "more_url",
"key": "foo",
- "more_link": "more_url",
"name": "Foo",
- "request_license_link": "license_url",
+ "requestUrl": "license_url",
+ "textDescription": "Foo desc",
}
}
editions={
Array [
Object {
- "desc": "Foo desc",
- "download_link": "download_url",
+ "downloadUrl": "download_url",
+ "homeUrl": "more_url",
"key": "foo",
- "more_link": "more_url",
"name": "Foo",
- "request_license_link": "license_url",
+ "requestUrl": "license_url",
+ "textDescription": "Foo desc",
},
]
}
diff --git a/server/sonar-web/src/main/js/apps/marketplace/utils.ts b/server/sonar-web/src/main/js/apps/marketplace/utils.ts
index f4c8eea8d92..1f9216c1c2e 100644
--- a/server/sonar-web/src/main/js/apps/marketplace/utils.ts
+++ b/server/sonar-web/src/main/js/apps/marketplace/utils.ts
@@ -56,10 +56,16 @@ export function getEditionsForVersion(
editions: EditionsPerVersion,
version: string
): Edition[] | undefined {
- const matchResult = version.match(/\d+\.\d+/);
- if (matchResult) {
- if (editions[matchResult[0]]) {
- return editions[matchResult[0]];
+ const minorVersion = version.match(/\d+\.\d+.\d+/);
+ if (minorVersion) {
+ if (editions[minorVersion[0]]) {
+ return editions[minorVersion[0]];
+ }
+ }
+ const majorVersion = version.match(/\d+\.\d+/);
+ if (majorVersion) {
+ if (editions[majorVersion[0]]) {
+ return editions[majorVersion[0]];
}
}
return undefined;