Commit f98d2f4f authored by Phil Hughes's avatar Phil Hughes

Merge branch '201730-refactoring-package-installation-instructions-part-1' into 'master'

Refactor package install instructions to use state and getters

See merge request gitlab-org/gitlab!24860
parents 4376e173 53f12503
...@@ -47,56 +47,16 @@ export default { ...@@ -47,56 +47,16 @@ export default {
}, },
mixins: [timeagoMixin, Tracking.mixin()], mixins: [timeagoMixin, Tracking.mixin()],
trackingActions: { ...TrackingActions }, trackingActions: { ...TrackingActions },
props: {
canDelete: {
type: Boolean,
default: false,
required: true,
},
destroyPath: {
type: String,
default: '',
required: true,
},
emptySvgPath: {
type: String,
required: true,
},
npmPath: {
type: String,
required: true,
},
npmHelpPath: {
type: String,
required: true,
},
mavenPath: {
type: String,
required: true,
},
mavenHelpPath: {
type: String,
required: true,
},
conanPath: {
type: String,
required: true,
},
conanHelpPath: {
type: String,
required: true,
},
nugetPath: {
type: String,
required: true,
},
nugetHelpPath: {
type: String,
required: true,
},
},
computed: { computed: {
...mapState(['packageEntity', 'packageFiles']), ...mapState([
'packageEntity',
'packageFiles',
'canDelete',
'destroyPath',
'svgPath',
'npmPath',
'npmHelpPath',
]),
isNpmPackage() { isNpmPackage() {
return this.packageEntity.package_type === PackageType.NPM; return this.packageEntity.package_type === PackageType.NPM;
}, },
...@@ -210,8 +170,7 @@ export default { ...@@ -210,8 +170,7 @@ export default {
v-if="!isValidPackage" v-if="!isValidPackage"
:title="s__('PackageRegistry|Unable to load package')" :title="s__('PackageRegistry|Unable to load package')"
:description="s__('PackageRegistry|There was a problem fetching the details for this package.')" :description="s__('PackageRegistry|There was a problem fetching the details for this package.')"
:svg-path="emptySvgPath" :svg-path="svgPath"
class="js-package-empty-state"
/> />
<div v-else class="packages-app"> <div v-else class="packages-app">
...@@ -249,26 +208,9 @@ export default { ...@@ -249,26 +208,9 @@ export default {
:help-url="npmHelpPath" :help-url="npmHelpPath"
/> />
<maven-installation <maven-installation v-else-if="isMavenPackage" />
v-else-if="isMavenPackage" <conan-installation v-else-if="isConanPackage" />
:maven-metadata="packageEntity.maven_metadatum" <nuget-installation v-else-if="isNugetPackage" />
:registry-url="mavenPath"
:help-url="mavenHelpPath"
/>
<conan-installation
v-else-if="isConanPackage"
:package-entity="packageEntity"
:registry-url="conanPath"
:help-url="conanHelpPath"
/>
<nuget-installation
v-else-if="isNugetPackage"
:package-entity="packageEntity"
:registry-url="nugetPath"
:help-url="nugetHelpPath"
/>
</div> </div>
</div> </div>
......
<script> <script>
import { GlTab, GlTabs } from '@gitlab/ui'; import { GlLink, GlSprintf, GlTab, GlTabs } from '@gitlab/ui';
import { s__, sprintf } from '~/locale'; import { s__ } from '~/locale';
import CodeInstruction from './code_instruction.vue'; import CodeInstruction from './code_instruction.vue';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import { TrackingActions, TrackingLabels } from '../constants'; import { TrackingActions, TrackingLabels } from '../constants';
import { generateConanRecipe, trackInstallationTabChange } from '../utils'; import { trackInstallationTabChange } from '../utils';
import { mapGetters, mapState } from 'vuex';
export default { export default {
name: 'ConanInstallation', name: 'ConanInstallation',
components: { components: {
CodeInstruction, CodeInstruction,
GlLink,
GlSprintf,
GlTab, GlTab,
GlTabs, GlTabs,
}, },
...@@ -19,48 +22,14 @@ export default { ...@@ -19,48 +22,14 @@ export default {
}), }),
trackInstallationTabChange, trackInstallationTabChange,
], ],
props: {
heading: {
type: String,
default: s__('PackageRegistry|Package installation'),
required: false,
},
packageEntity: {
type: Object,
required: true,
},
registryUrl: {
type: String,
required: true,
},
helpUrl: {
type: String,
required: true,
},
},
computed: { computed: {
conanCommand() { ...mapState(['conanHelpPath']),
const recipe = generateConanRecipe(this.packageEntity); ...mapGetters(['conanInstallationCommand', 'conanSetupCommand']),
// eslint-disable-next-line @gitlab/i18n/no-non-i18n-strings
return `conan install ${recipe} --remote=gitlab`;
},
setupCommand() {
// eslint-disable-next-line @gitlab/i18n/no-non-i18n-strings
return `conan remote add gitlab ${this.registryUrl}`;
}, },
helpText() { i18n: {
return sprintf( helpText: s__(
s__( 'PackageRegistry|For more information on the Conan registry, %{linkStart}see the documentation%{linkEnd}.',
`PackageRegistry|For more information on the Conan registry, %{linkStart}see the documentation%{linkEnd}.`,
), ),
{
linkStart: `<a href="${this.helpUrl}" target="_blank" rel="noopener noreferer">`,
linkEnd: '</a>',
},
false,
);
},
}, },
trackingActions: { ...TrackingActions }, trackingActions: { ...TrackingActions },
}; };
...@@ -73,7 +42,7 @@ export default { ...@@ -73,7 +42,7 @@ export default {
<div class="prepend-left-default append-right-default"> <div class="prepend-left-default append-right-default">
<p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|Conan Command') }}</p> <p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|Conan Command') }}</p>
<code-instruction <code-instruction
:instruction="conanCommand" :instruction="conanInstallationCommand"
:copy-text="s__('PackageRegistry|Copy Conan Command')" :copy-text="s__('PackageRegistry|Copy Conan Command')"
class="js-conan-command" class="js-conan-command"
:tracking-action="$options.trackingActions.COPY_CONAN_COMMAND" :tracking-action="$options.trackingActions.COPY_CONAN_COMMAND"
...@@ -86,12 +55,16 @@ export default { ...@@ -86,12 +55,16 @@ export default {
{{ s__('PackageRegistry|Add Conan Remote') }} {{ s__('PackageRegistry|Add Conan Remote') }}
</p> </p>
<code-instruction <code-instruction
:instruction="setupCommand" :instruction="conanSetupCommand"
:copy-text="s__('PackageRegistry|Copy Conan Setup Command')" :copy-text="s__('PackageRegistry|Copy Conan Setup Command')"
class="js-conan-setup" class="js-conan-setup"
:tracking-action="$options.trackingActions.COPY_CONAN_SETUP_COMMAND" :tracking-action="$options.trackingActions.COPY_CONAN_SETUP_COMMAND"
/> />
<p v-html="helpText"></p> <gl-sprintf :message="$options.i18n.helpText">
<template #link="{ content }">
<gl-link :href="conanHelpPath" target="_blank">{{ content }}</gl-link>
</template>
</gl-sprintf>
</div> </div>
</gl-tab> </gl-tab>
</gl-tabs> </gl-tabs>
......
<script> <script>
import { GlTab, GlTabs } from '@gitlab/ui'; import { GlLink, GlSprintf, GlTab, GlTabs } from '@gitlab/ui';
import { s__, sprintf } from '~/locale'; import { s__ } from '~/locale';
import CodeInstruction from './code_instruction.vue'; import CodeInstruction from './code_instruction.vue';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import { TrackingActions, TrackingLabels } from '../constants'; import { TrackingActions, TrackingLabels } from '../constants';
import { trackInstallationTabChange } from '../utils'; import { trackInstallationTabChange } from '../utils';
import { mapGetters, mapState } from 'vuex';
export default { export default {
name: 'MavenInstallation', name: 'MavenInstallation',
components: { components: {
CodeInstruction, CodeInstruction,
GlLink,
GlSprintf,
GlTab, GlTab,
GlTabs, GlTabs,
}, },
...@@ -19,104 +22,19 @@ export default { ...@@ -19,104 +22,19 @@ export default {
}), }),
trackInstallationTabChange, trackInstallationTabChange,
], ],
props: {
heading: {
type: String,
default: s__('PackageRegistry|Package installation'),
required: false,
},
mavenMetadata: {
type: Object,
required: true,
},
registryUrl: {
type: String,
required: true,
},
helpUrl: {
type: String,
required: true,
},
},
computed: { computed: {
mavenData() { ...mapState(['mavenHelpPath']),
const { ...mapGetters(['mavenInstallationXml', 'mavenInstallationCommand', 'mavenSetupXml']),
app_group: appGroup = '',
app_name: appName = '',
app_version: appVersion = '',
} = this.mavenMetadata;
return {
appGroup,
appName,
appVersion,
};
},
mavenXml() {
return `<dependency>
<groupId>${this.mavenData.appGroup}</groupId>
<artifactId>${this.mavenData.appName}</artifactId>
<version>${this.mavenData.appVersion}</version>
</dependency>`;
},
mavenCommand() {
const { appGroup: group, appName: name, appVersion: version } = this.mavenData;
return `mvn dependency:get -Dartifact=${group}:${name}:${version}`;
},
mavenSetupXml() {
return `<repositories>
<repository>
<id>gitlab-maven</id>
<url>${this.registryUrl}</url>
</repository>
</repositories>
<distributionManagement>
<repository>
<id>gitlab-maven</id>
<url>${this.registryUrl}</url>
</repository>
<snapshotRepository>
<id>gitlab-maven</id>
<url>${this.registryUrl}</url>
</snapshotRepository>
</distributionManagement>`;
},
helpText() {
return sprintf(
s__(
`PackageRegistry|For more information on the Maven registry, %{linkStart}see the documentation%{linkEnd}.`,
),
{
linkStart: `<a href="${this.helpUrl}" target="_blank" rel="noopener noreferer">`,
linkEnd: '</a>',
},
false,
);
},
}, },
i18n: { i18n: {
xmlText: sprintf( xmlText: s__(
s__(
`PackageRegistry|Copy and paste this inside your %{codeStart}pom.xml%{codeEnd} %{codeStart}dependencies%{codeEnd} block.`, `PackageRegistry|Copy and paste this inside your %{codeStart}pom.xml%{codeEnd} %{codeStart}dependencies%{codeEnd} block.`,
), ),
{ setupText: s__(
codeStart: `<code>`,
codeEnd: '</code>',
},
false,
),
setupText: sprintf(
s__(
`PackageRegistry|If you haven't already done so, you will need to add the below to your %{codeStart}pom.xml%{codeEnd} file.`, `PackageRegistry|If you haven't already done so, you will need to add the below to your %{codeStart}pom.xml%{codeEnd} file.`,
), ),
{ helpText: s__(
codeStart: `<code>`, 'PackageRegistry|For more information on the Maven registry, %{linkStart}see the documentation%{linkEnd}.',
codeEnd: '</code>',
},
false,
), ),
}, },
trackingActions: { ...TrackingActions }, trackingActions: { ...TrackingActions },
...@@ -129,9 +47,15 @@ export default { ...@@ -129,9 +47,15 @@ export default {
<gl-tab :title="s__('PackageRegistry|Installation')" title-item-class="js-installation-tab"> <gl-tab :title="s__('PackageRegistry|Installation')" title-item-class="js-installation-tab">
<div class="prepend-left-default append-right-default"> <div class="prepend-left-default append-right-default">
<p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|Maven XML') }}</p> <p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|Maven XML') }}</p>
<p v-html="$options.i18n.xmlText"></p> <p>
<gl-sprintf :message="$options.i18n.xmlText">
<template #code="{ content }">
<code>{{ content }}</code>
</template>
</gl-sprintf>
</p>
<code-instruction <code-instruction
:instruction="mavenXml" :instruction="mavenInstallationXml"
:copy-text="s__('PackageRegistry|Copy Maven XML')" :copy-text="s__('PackageRegistry|Copy Maven XML')"
class="js-maven-xml" class="js-maven-xml"
multiline multiline
...@@ -142,7 +66,7 @@ export default { ...@@ -142,7 +66,7 @@ export default {
{{ s__('PackageRegistry|Maven Command') }} {{ s__('PackageRegistry|Maven Command') }}
</p> </p>
<code-instruction <code-instruction
:instruction="mavenCommand" :instruction="mavenInstallationCommand"
:copy-text="s__('PackageRegistry|Copy Maven command')" :copy-text="s__('PackageRegistry|Copy Maven command')"
class="js-maven-command" class="js-maven-command"
:tracking-action="$options.trackingActions.COPY_MAVEN_COMMAND" :tracking-action="$options.trackingActions.COPY_MAVEN_COMMAND"
...@@ -151,7 +75,13 @@ export default { ...@@ -151,7 +75,13 @@ export default {
</gl-tab> </gl-tab>
<gl-tab :title="s__('PackageRegistry|Registry Setup')" title-item-class="js-setup-tab"> <gl-tab :title="s__('PackageRegistry|Registry Setup')" title-item-class="js-setup-tab">
<div class="prepend-left-default append-right-default"> <div class="prepend-left-default append-right-default">
<p v-html="$options.i18n.setupText"></p> <p>
<gl-sprintf :message="$options.i18n.setupText">
<template #code="{ content }">
<code>{{ content }}</code>
</template>
</gl-sprintf>
</p>
<code-instruction <code-instruction
:instruction="mavenSetupXml" :instruction="mavenSetupXml"
:copy-text="s__('PackageRegistry|Copy Maven registry XML')" :copy-text="s__('PackageRegistry|Copy Maven registry XML')"
...@@ -159,7 +89,11 @@ export default { ...@@ -159,7 +89,11 @@ export default {
multiline multiline
:tracking-action="$options.trackingActions.COPY_MAVEN_SETUP" :tracking-action="$options.trackingActions.COPY_MAVEN_SETUP"
/> />
<p v-html="helpText"></p> <gl-sprintf :message="$options.i18n.helpText">
<template #link="{ content }">
<gl-link :href="mavenHelpPath" target="_blank">{{ content }}</gl-link>
</template>
</gl-sprintf>
</div> </div>
</gl-tab> </gl-tab>
</gl-tabs> </gl-tabs>
......
<script> <script>
import { GlTab, GlTabs } from '@gitlab/ui'; import { GlLink, GlSprintf, GlTab, GlTabs } from '@gitlab/ui';
import { s__, sprintf } from '~/locale'; import { s__ } from '~/locale';
import CodeInstruction from './code_instruction.vue'; import CodeInstruction from './code_instruction.vue';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import { TrackingActions, TrackingLabels } from '../constants'; import { TrackingActions, TrackingLabels } from '../constants';
import { trackInstallationTabChange } from '../utils'; import { trackInstallationTabChange } from '../utils';
import { mapGetters, mapState } from 'vuex';
export default { export default {
name: 'NugetInstallation', name: 'NugetInstallation',
components: { components: {
CodeInstruction, CodeInstruction,
GlLink,
GlSprintf,
GlTab, GlTab,
GlTabs, GlTabs,
}, },
...@@ -19,39 +22,14 @@ export default { ...@@ -19,39 +22,14 @@ export default {
}), }),
trackInstallationTabChange, trackInstallationTabChange,
], ],
props: {
packageEntity: {
type: Object,
required: true,
},
registryUrl: {
type: String,
required: true,
},
helpUrl: {
type: String,
required: true,
},
},
computed: { computed: {
nugetCommand() { ...mapState(['nugetHelpPath']),
return `nuget install ${this.packageEntity.name} -Source "GitLab"`; ...mapGetters(['nugetInstallationCommand', 'nugetSetupCommand']),
}, },
setupCommand() { i18n: {
return `nuget source Add -Name "GitLab" -Source "${this.registryUrl}" -UserName <your_username> -Password <your_token>`; helpText: s__(
}, 'PackageRegistry|For more information on the NuGet registry, %{linkStart}see the documentation%{linkEnd}.',
helpText() {
return sprintf(
s__(
`PackageRegistry|For more information on the NuGet registry, %{linkStart}see the documentation%{linkEnd}.`,
), ),
{
linkStart: `<a href="${this.helpUrl}" target="_blank" rel="noopener noreferer">`,
linkEnd: '</a>',
},
false,
);
},
}, },
trackingActions: { ...TrackingActions }, trackingActions: { ...TrackingActions },
}; };
...@@ -64,7 +42,7 @@ export default { ...@@ -64,7 +42,7 @@ export default {
<div class="prepend-left-default append-right-default"> <div class="prepend-left-default append-right-default">
<p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|NuGet Command') }}</p> <p class="prepend-top-8 font-weight-bold">{{ s__('PackageRegistry|NuGet Command') }}</p>
<code-instruction <code-instruction
:instruction="nugetCommand" :instruction="nugetInstallationCommand"
:copy-text="s__('PackageRegistry|Copy NuGet Command')" :copy-text="s__('PackageRegistry|Copy NuGet Command')"
class="js-nuget-command" class="js-nuget-command"
:tracking-action="$options.trackingActions.COPY_NUGET_INSTALL_COMMAND" :tracking-action="$options.trackingActions.COPY_NUGET_INSTALL_COMMAND"
...@@ -77,12 +55,16 @@ export default { ...@@ -77,12 +55,16 @@ export default {
{{ s__('PackageRegistry|Add NuGet Source') }} {{ s__('PackageRegistry|Add NuGet Source') }}
</p> </p>
<code-instruction <code-instruction
:instruction="setupCommand" :instruction="nugetSetupCommand"
:copy-text="s__('PackageRegistry|Copy NuGet Setup Command')" :copy-text="s__('PackageRegistry|Copy NuGet Setup Command')"
class="js-nuget-setup" class="js-nuget-setup"
:tracking-action="$options.trackingActions.COPY_NUGET_SETUP_COMMAND" :tracking-action="$options.trackingActions.COPY_NUGET_SETUP_COMMAND"
/> />
<p v-html="helpText"></p> <gl-sprintf :message="$options.i18n.helpText">
<template #link="{ content }">
<gl-link :href="nugetHelpPath" target="_blank">{{ content }}</gl-link>
</template>
</gl-sprintf>
</div> </div>
</gl-tab> </gl-tab>
</gl-tabs> </gl-tabs>
......
...@@ -6,52 +6,29 @@ import createStore from './store'; ...@@ -6,52 +6,29 @@ import createStore from './store';
Vue.use(Translate); Vue.use(Translate);
export default () => { export default () => {
const { dataset } = document.querySelector('#js-vue-packages-detail'); const el = document.querySelector('#js-vue-packages-detail');
const packageEntity = JSON.parse(dataset.package); const {
const packageFiles = JSON.parse(dataset.packageFiles); package: packageJson,
const canDelete = dataset.canDelete === 'true'; packageFiles: packageFilesJson,
canDelete: canDeleteStr,
...rest
} = el.dataset;
const packageEntity = JSON.parse(packageJson);
const packageFiles = JSON.parse(packageFilesJson);
const canDelete = canDeleteStr === 'true';
const store = createStore({ packageEntity, packageFiles }); const store = createStore({ packageEntity, packageFiles, canDelete, ...rest });
store.dispatch('fetchPipelineInfo'); store.dispatch('fetchPipelineInfo');
// eslint-disable-next-line no-new // eslint-disable-next-line no-new
new Vue({ new Vue({
el: '#js-vue-packages-detail', el,
components: { components: {
PackagesApp, PackagesApp,
}, },
store, store,
data() {
return {
canDelete,
destroyPath: dataset.destroyPath,
emptySvgPath: dataset.svgPath,
npmPath: dataset.npmPath,
npmHelpPath: dataset.npmHelpPath,
mavenPath: dataset.mavenPath,
mavenHelpPath: dataset.mavenHelpPath,
conanPath: dataset.conanPath,
conanHelpPath: dataset.conanHelpPath,
nugetPath: dataset.nugetPath,
nugetHelpPath: dataset.nugetHelpPath,
};
},
render(createElement) { render(createElement) {
return createElement('packages-app', { return createElement('packages-app');
props: {
canDelete: this.canDelete,
destroyPath: this.destroyPath,
emptySvgPath: this.emptySvgPath,
npmPath: this.npmPath,
npmHelpPath: this.npmHelpPath,
mavenPath: this.mavenPath,
mavenHelpPath: this.mavenHelpPath,
conanPath: this.conanPath,
conanHelpPath: this.conanHelpPath,
nugetPath: this.nugetPath,
nugetHelpPath: this.nugetHelpPath,
},
});
}, },
}); });
}; };
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import { generateConanRecipe } from '../utils';
export const packageHasPipeline = ({ packageEntity }) => { export const packageHasPipeline = ({ packageEntity }) => {
if (packageEntity?.build_info?.pipeline_id) { if (packageEntity?.build_info?.pipeline_id) {
...@@ -23,3 +24,63 @@ export const packageTypeDisplay = ({ packageEntity }) => { ...@@ -23,3 +24,63 @@ export const packageTypeDisplay = ({ packageEntity }) => {
return null; return null;
} }
}; };
export const conanInstallationCommand = ({ packageEntity }) => {
const recipe = generateConanRecipe(packageEntity);
// eslint-disable-next-line @gitlab/i18n/no-non-i18n-strings
return `conan install ${recipe} --remote=gitlab`;
};
export const conanSetupCommand = ({ conanPath }) =>
// eslint-disable-next-line @gitlab/i18n/no-non-i18n-strings
`conan remote add gitlab ${conanPath}`;
export const mavenInstallationXml = ({ packageEntity = {} }) => {
const {
app_group: appGroup = '',
app_name: appName = '',
app_version: appVersion = '',
} = packageEntity.maven_metadatum;
return `<dependency>
<groupId>${appGroup}</groupId>
<artifactId>${appName}</artifactId>
<version>${appVersion}</version>
</dependency>`;
};
export const mavenInstallationCommand = ({ packageEntity = {} }) => {
const {
app_group: group = '',
app_name: name = '',
app_version: version = '',
} = packageEntity.maven_metadatum;
return `mvn dependency:get -Dartifact=${group}:${name}:${version}`;
};
export const mavenSetupXml = ({ mavenPath }) => `<repositories>
<repository>
<id>gitlab-maven</id>
<url>${mavenPath}</url>
</repository>
</repositories>
<distributionManagement>
<repository>
<id>gitlab-maven</id>
<url>${mavenPath}</url>
</repository>
<snapshotRepository>
<id>gitlab-maven</id>
<url>${mavenPath}</url>
</snapshotRepository>
</distributionManagement>`;
export const nugetInstallationCommand = ({ packageEntity }) =>
`nuget install ${packageEntity.name} -Source "GitLab"`;
export const nugetSetupCommand = ({ nugetPath }) =>
`nuget source Add -Name "GitLab" -Source "${nugetPath}" -UserName <your_username> -Password <your_token>`;
import Vuex from 'vuex'; import Vuex from 'vuex';
import { mount, createLocalVue } from '@vue/test-utils'; import { mount, createLocalVue } from '@vue/test-utils';
import { GlModal } from '@gitlab/ui'; import { GlEmptyState, GlModal } from '@gitlab/ui';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import PackagesApp from 'ee/packages/details/components/app.vue'; import PackagesApp from 'ee/packages/details/components/app.vue';
import PackageTitle from 'ee/packages/details/components/package_title.vue'; import PackageTitle from 'ee/packages/details/components/package_title.vue';
...@@ -19,6 +19,7 @@ import { ...@@ -19,6 +19,7 @@ import {
npmFiles, npmFiles,
nugetPackage, nugetPackage,
} from '../../mock_data'; } from '../../mock_data';
import stubChildren from 'helpers/stub_children';
const localVue = createLocalVue(); const localVue = createLocalVue();
localVue.use(Vuex); localVue.use(Vuex);
...@@ -27,25 +28,7 @@ describe('PackagesApp', () => { ...@@ -27,25 +28,7 @@ describe('PackagesApp', () => {
let wrapper; let wrapper;
let store; let store;
const defaultProps = {
canDelete: true,
destroyPath: 'destroy-package-path',
emptySvgPath: 'empty-illustration',
npmPath: 'foo',
npmHelpPath: 'foo',
mavenPath: 'foo',
mavenHelpPath: 'foo',
conanPath: 'foo',
conanHelpPath: 'foo',
nugetPath: 'foo',
nugetHelpPath: 'foo',
};
function createComponent(packageEntity = mavenPackage, packageFiles = mavenFiles) { function createComponent(packageEntity = mavenPackage, packageFiles = mavenFiles) {
const propsData = {
...defaultProps,
};
store = new Vuex.Store({ store = new Vuex.Store({
state: { state: {
isLoading: false, isLoading: false,
...@@ -53,22 +36,29 @@ describe('PackagesApp', () => { ...@@ -53,22 +36,29 @@ describe('PackagesApp', () => {
packageFiles, packageFiles,
pipelineInfo: {}, pipelineInfo: {},
pipelineError: null, pipelineError: null,
}, canDelete: true,
getters: { destroyPath: 'destroy-package-path',
packageHasPipeline: () => packageEntity.build_info && packageEntity.build_info.pipeline_id, emptySvgPath: 'empty-illustration',
packageTypeDisplay: () => {}, npmPath: 'foo',
npmHelpPath: 'foo',
}, },
}); });
wrapper = mount(PackagesApp, { wrapper = mount(PackagesApp, {
localVue, localVue,
propsData,
store, store,
stubs: {
...stubChildren(PackagesApp),
GlButton: false,
GlLink: false,
GlModal: false,
GlTable: false,
},
}); });
} }
const packageTitle = () => wrapper.find(PackageTitle); const packageTitle = () => wrapper.find(PackageTitle);
const emptyState = () => wrapper.find('.js-package-empty-state'); const emptyState = () => wrapper.find(GlEmptyState);
const allPackageInformation = () => wrapper.findAll(PackageInformation); const allPackageInformation = () => wrapper.findAll(PackageInformation);
const packageInformation = index => allPackageInformation().at(index); const packageInformation = index => allPackageInformation().at(index);
const npmInstallation = () => wrapper.find(NpmInstallation); const npmInstallation = () => wrapper.find(NpmInstallation);
......
import { mount } from '@vue/test-utils'; import Vuex from 'vuex';
import { mount, createLocalVue } from '@vue/test-utils';
import ConanInstallation from 'ee/packages/details/components/conan_installation.vue'; import ConanInstallation from 'ee/packages/details/components/conan_installation.vue';
import { generateConanRecipe } from 'ee/packages/details/utils'; import { conanPackage as packageEntity } from '../../mock_data';
import { conanPackage } from '../../mock_data'; import { registryUrl as conanPath } from '../mock_data';
import { registryUrl } from '../mock_data';
import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants'; import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('ConanInstallation', () => { describe('ConanInstallation', () => {
let wrapper; let wrapper;
const defaultProps = { const conanInstallationCommandStr = 'foo/command';
packageEntity: conanPackage, const conanSetupCommandStr = 'foo/setup';
registryUrl,
helpUrl: 'foo', const store = new Vuex.Store({
}; state: {
packageEntity,
const recipe = generateConanRecipe(conanPackage); conanPath,
const conanInstallationCommandStr = `conan install ${recipe} --remote=gitlab`; },
const conanSetupCommandStr = `conan remote add gitlab ${registryUrl}`; getters: {
conanInstallationCommand: () => conanInstallationCommandStr,
conanSetupCommand: () => conanSetupCommandStr,
},
});
const installationTab = () => wrapper.find('.js-installation-tab > a'); const installationTab = () => wrapper.find('.js-installation-tab > a');
const setupTab = () => wrapper.find('.js-setup-tab > a'); const setupTab = () => wrapper.find('.js-setup-tab > a');
const conanInstallationCommand = () => wrapper.find('.js-conan-command > input'); const conanInstallationCommand = () => wrapper.find('.js-conan-command > input');
const conanSetupCommand = () => wrapper.find('.js-conan-setup > input'); const conanSetupCommand = () => wrapper.find('.js-conan-setup > input');
function createComponent(props = {}) { function createComponent() {
const propsData = {
...defaultProps,
...props,
};
wrapper = mount(ConanInstallation, { wrapper = mount(ConanInstallation, {
propsData, localVue,
store,
}); });
} }
......
import { mount } from '@vue/test-utils'; import Vuex from 'vuex';
import { mount, createLocalVue } from '@vue/test-utils';
import MavenInstallation from 'ee/packages/details/components/maven_installation.vue'; import MavenInstallation from 'ee/packages/details/components/maven_installation.vue';
import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants'; import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants';
import { import { registryUrl as mavenPath } from '../mock_data';
generateMavenCommand, import { mavenPackage as packageEntity } from '../../mock_data';
generateXmlCodeBlock,
generateMavenSetupXml,
mavenMetadata,
registryUrl,
} from '../mock_data';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('MavenInstallation', () => { describe('MavenInstallation', () => {
let wrapper; let wrapper;
const defaultProps = { const xmlCodeBlock = 'foo/xml';
mavenMetadata, const mavenCommandStr = 'foo/command';
registryUrl, const mavenSetupXml = 'foo/setup';
helpUrl: 'foo',
};
const mavenCommandStr = generateMavenCommand(mavenMetadata); const store = new Vuex.Store({
const xmlCodeBlock = generateXmlCodeBlock(mavenMetadata); state: {
const mavenSetupXml = generateMavenSetupXml(); packageEntity,
mavenPath,
},
getters: {
mavenInstallationXml: () => xmlCodeBlock,
mavenInstallationCommand: () => mavenCommandStr,
mavenSetupXml: () => mavenSetupXml,
},
});
const installationTab = () => wrapper.find('.js-installation-tab > a'); const installationTab = () => wrapper.find('.js-installation-tab > a');
const setupTab = () => wrapper.find('.js-setup-tab > a'); const setupTab = () => wrapper.find('.js-setup-tab > a');
...@@ -29,14 +34,10 @@ describe('MavenInstallation', () => { ...@@ -29,14 +34,10 @@ describe('MavenInstallation', () => {
const mavenCommand = () => wrapper.find('.js-maven-command > input'); const mavenCommand = () => wrapper.find('.js-maven-command > input');
const xmlSetup = () => wrapper.find('.js-maven-setup-xml > pre'); const xmlSetup = () => wrapper.find('.js-maven-setup-xml > pre');
function createComponent(props = {}) { function createComponent() {
const propsData = {
...defaultProps,
...props,
};
wrapper = mount(MavenInstallation, { wrapper = mount(MavenInstallation, {
propsData, localVue,
store,
}); });
} }
...@@ -48,26 +49,6 @@ describe('MavenInstallation', () => { ...@@ -48,26 +49,6 @@ describe('MavenInstallation', () => {
if (wrapper) wrapper.destroy(); if (wrapper) wrapper.destroy();
}); });
describe('with empty maven metadata', () => {
beforeEach(() => {
createComponent({
mavenMetadata: {},
});
});
it('renders empty strings in the xml block', () => {
const emptyXmlBlock = generateXmlCodeBlock({});
expect(xmlCode().text()).toBe(emptyXmlBlock);
});
it('renders empty strings in the command block', () => {
const emptyMavenCommand = generateMavenCommand({});
expect(mavenCommand().element.value).toBe(emptyMavenCommand);
});
});
describe('installation commands', () => { describe('installation commands', () => {
it('renders the correct xml block', () => { it('renders the correct xml block', () => {
expect(xmlCode().text()).toBe(xmlCodeBlock); expect(xmlCode().text()).toBe(xmlCodeBlock);
......
import { mount } from '@vue/test-utils'; import Vuex from 'vuex';
import { mount, createLocalVue } from '@vue/test-utils';
import NugetInstallation from 'ee/packages/details/components/nuget_installation.vue'; import NugetInstallation from 'ee/packages/details/components/nuget_installation.vue';
import { nugetPackage } from '../../mock_data'; import { nugetPackage as packageEntity } from '../../mock_data';
import { registryUrl } from '../mock_data'; import { registryUrl as nugetPath } from '../mock_data';
import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants'; import { TrackingActions, TrackingLabels } from 'ee/packages/details/constants';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('NugetInstallation', () => { describe('NugetInstallation', () => {
let wrapper; let wrapper;
const defaultProps = { const nugetInstallationCommandStr = 'foo/command';
packageEntity: nugetPackage, const nugetSetupCommandStr = 'foo/setup';
registryUrl,
helpUrl: 'foo', const store = new Vuex.Store({
}; state: {
packageEntity,
const nugetInstallationCommandStr = `nuget install ${nugetPackage.name} -Source "GitLab"`; nugetPath,
const nugetSetupCommandStr = `nuget source Add -Name "GitLab" -Source "${registryUrl}" -UserName <your_username> -Password <your_token>`; },
getters: {
nugetInstallationCommand: () => nugetInstallationCommandStr,
nugetSetupCommand: () => nugetSetupCommandStr,
},
});
const installationTab = () => wrapper.find('.js-installation-tab > a'); const installationTab = () => wrapper.find('.js-installation-tab > a');
const setupTab = () => wrapper.find('.js-setup-tab > a'); const setupTab = () => wrapper.find('.js-setup-tab > a');
const nugetInstallationCommand = () => wrapper.find('.js-nuget-command > input'); const nugetInstallationCommand = () => wrapper.find('.js-nuget-command > input');
const nugetSetupCommand = () => wrapper.find('.js-nuget-setup > input'); const nugetSetupCommand = () => wrapper.find('.js-nuget-setup > input');
function createComponent(props = {}) { function createComponent() {
const propsData = {
...defaultProps,
...props,
};
wrapper = mount(NugetInstallation, { wrapper = mount(NugetInstallation, {
propsData, localVue,
store,
}); });
} }
......
import { packageHasPipeline, packageTypeDisplay } from 'ee/packages/details/store/getters'; import {
conanInstallationCommand,
conanSetupCommand,
packageHasPipeline,
packageTypeDisplay,
mavenInstallationXml,
mavenInstallationCommand,
mavenSetupXml,
nugetInstallationCommand,
nugetSetupCommand,
} from 'ee/packages/details/store/getters';
import { import {
conanPackage, conanPackage,
npmPackage, npmPackage,
...@@ -6,6 +16,13 @@ import { ...@@ -6,6 +16,13 @@ import {
mockPipelineInfo, mockPipelineInfo,
mavenPackage as packageWithoutBuildInfo, mavenPackage as packageWithoutBuildInfo,
} from '../../mock_data'; } from '../../mock_data';
import {
generateMavenCommand,
generateXmlCodeBlock,
generateMavenSetupXml,
registryUrl,
} from '../mock_data';
import { generateConanRecipe } from 'ee/packages/details/utils';
describe('Getters PackageDetails Store', () => { describe('Getters PackageDetails Store', () => {
let state; let state;
...@@ -16,12 +33,29 @@ describe('Getters PackageDetails Store', () => { ...@@ -16,12 +33,29 @@ describe('Getters PackageDetails Store', () => {
packageEntity: packageWithoutBuildInfo, packageEntity: packageWithoutBuildInfo,
pipelineInfo: mockPipelineInfo, pipelineInfo: mockPipelineInfo,
pipelineError: mockPipelineError, pipelineError: mockPipelineError,
conanPath: registryUrl,
mavenPath: registryUrl,
nugetPath: registryUrl,
}; };
const setupState = (testState = defaultState) => { const setupState = (testState = {}) => {
state = testState; state = {
...defaultState,
...testState,
};
}; };
const recipe = generateConanRecipe(conanPackage);
const conanInstallationCommandStr = `conan install ${recipe} --remote=gitlab`;
const conanSetupCommandStr = `conan remote add gitlab ${registryUrl}`;
const mavenCommandStr = generateMavenCommand(packageWithoutBuildInfo.maven_metadatum);
const mavenInstallationXmlBlock = generateXmlCodeBlock(packageWithoutBuildInfo.maven_metadatum);
const mavenSetupXmlBlock = generateMavenSetupXml();
const nugetInstallationCommandStr = `nuget install ${nugetPackage.name} -Source "GitLab"`;
const nugetSetupCommandStr = `nuget source Add -Name "GitLab" -Source "${registryUrl}" -UserName <your_username> -Password <your_token>`;
describe('packageHasPipeline', () => { describe('packageHasPipeline', () => {
it('should return true when build_info and pipeline_id exist', () => { it('should return true when build_info and pipeline_id exist', () => {
setupState({ setupState({
...@@ -53,4 +87,52 @@ describe('Getters PackageDetails Store', () => { ...@@ -53,4 +87,52 @@ describe('Getters PackageDetails Store', () => {
}); });
}); });
}); });
describe('conan string getters', () => {
it('gets the correct conanInstallationCommand', () => {
setupState({ packageEntity: conanPackage });
expect(conanInstallationCommand(state)).toEqual(conanInstallationCommandStr);
});
it('gets the correct conanSetupCommand', () => {
setupState({ packageEntity: conanPackage });
expect(conanSetupCommand(state)).toEqual(conanSetupCommandStr);
});
});
describe('maven string getters', () => {
it('gets the correct mavenInstallationXml', () => {
setupState();
expect(mavenInstallationXml(state)).toEqual(mavenInstallationXmlBlock);
});
it('gets the correct mavenInstallationCommand', () => {
setupState();
expect(mavenInstallationCommand(state)).toEqual(mavenCommandStr);
});
it('gets the correct mavenSetupXml', () => {
setupState();
expect(mavenSetupXml(state)).toEqual(mavenSetupXmlBlock);
});
});
describe('nuget string getters', () => {
it('gets the correct nugetInstallationCommand', () => {
setupState({ packageEntity: nugetPackage });
expect(nugetInstallationCommand(state)).toEqual(nugetInstallationCommandStr);
});
it('gets the correct nugetSetupCommand', () => {
setupState({ packageEntity: nugetPackage });
expect(nugetSetupCommand(state)).toEqual(nugetSetupCommandStr);
});
});
}); });
...@@ -13363,9 +13363,6 @@ msgstr "" ...@@ -13363,9 +13363,6 @@ msgstr ""
msgid "PackageRegistry|NuGet Command" msgid "PackageRegistry|NuGet Command"
msgstr "" msgstr ""
msgid "PackageRegistry|Package installation"
msgstr ""
msgid "PackageRegistry|Registry Setup" msgid "PackageRegistry|Registry Setup"
msgstr "" msgstr ""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment