Commit 53c3ef13 authored by Andrew Fontaine's avatar Andrew Fontaine

Merge branch 'afontaine/deployment-status-badge' into 'master'

Add deployment status badge

See merge request gitlab-org/gitlab!78089
parents 68c68249 3afe9b56
<script> <script>
import DeploymentStatusBadge from './deployment_status_badge.vue';
export default { export default {
components: {
DeploymentStatusBadge,
},
props: { props: {
deployment: { deployment: {
type: Object, type: Object,
required: true, required: true,
}, },
}, },
computed: {
status() {
return this.deployment?.status;
},
},
}; };
</script> </script>
<template> <template>
<div></div> <div>
<deployment-status-badge v-if="status" :status="status" />
</div>
</template> </template>
<script>
import { GlBadge } from '@gitlab/ui';
import { s__ } from '~/locale';
const STATUS_TEXT = {
created: s__('Deployment|Created'),
running: s__('Deployment|Running'),
success: s__('Deployment|Success'),
failed: s__('Deployment|Failed'),
canceled: s__('Deployment|Cancelled'),
skipped: s__('Deployment|Skipped'),
blocked: s__('Deployment|Waiting'),
};
const STATUS_VARIANT = {
success: 'success',
running: 'info',
failed: 'danger',
created: 'neutral',
canceled: 'neutral',
skipped: 'neutral',
blocked: 'neutral',
};
const STATUS_ICON = {
success: 'status_success',
running: 'status_running',
failed: 'status_failed',
created: 'status_created',
canceled: 'status_canceled',
skipped: 'status_skipped',
blocked: 'status_manual',
};
export default {
components: {
GlBadge,
},
props: {
status: {
type: String,
required: true,
},
},
computed: {
icon() {
return STATUS_ICON[this.status];
},
text() {
return STATUS_TEXT[this.status];
},
variant() {
return STATUS_VARIANT[this.status];
},
},
};
</script>
<template>
<gl-badge v-if="status" :icon="icon" :variant="variant">{{ text }}</gl-badge>
</template>
...@@ -11988,9 +11988,30 @@ msgstr[1] "" ...@@ -11988,9 +11988,30 @@ msgstr[1] ""
msgid "Deployment|API" msgid "Deployment|API"
msgstr "" msgstr ""
msgid "Deployment|Cancelled"
msgstr ""
msgid "Deployment|Created"
msgstr ""
msgid "Deployment|Failed"
msgstr ""
msgid "Deployment|Running"
msgstr ""
msgid "Deployment|Skipped"
msgstr ""
msgid "Deployment|Success"
msgstr ""
msgid "Deployment|This deployment was created using the API" msgid "Deployment|This deployment was created using the API"
msgstr "" msgstr ""
msgid "Deployment|Waiting"
msgstr ""
msgid "Deployment|blocked" msgid "Deployment|blocked"
msgstr "" msgstr ""
......
import { mountExtended } from 'helpers/vue_test_utils_helper';
import Deployment from '~/environments/components/deployment.vue';
import DeploymentStatusBadge from '~/environments/components/deployment_status_badge.vue';
import { resolvedEnvironment } from './graphql/mock_data';
describe('~/environments/components/deployment.vue', () => {
let wrapper;
const createWrapper = ({ propsData = {} } = {}) =>
mountExtended(Deployment, {
propsData: {
deployment: resolvedEnvironment.lastDeployment,
...propsData,
},
});
afterEach(() => {
wrapper?.destroy();
});
describe('status', () => {
it('should pass the deployable status to the badge', () => {
wrapper = createWrapper();
expect(wrapper.findComponent(DeploymentStatusBadge).props('status')).toBe(
resolvedEnvironment.lastDeployment.status,
);
});
});
});
import { GlBadge } from '@gitlab/ui';
import { mountExtended } from 'helpers/vue_test_utils_helper';
import { s__ } from '~/locale';
import DeploymentStatusBadge from '~/environments/components/deployment_status_badge.vue';
describe('~/environments/components/deployment_status_badge.vue', () => {
let wrapper;
const createWrapper = ({ propsData = {} } = {}) =>
mountExtended(DeploymentStatusBadge, {
propsData,
});
describe.each`
status | text | variant | icon
${'created'} | ${s__('Deployment|Created')} | ${'neutral'} | ${'status_created'}
${'running'} | ${s__('Deployment|Running')} | ${'info'} | ${'status_running'}
${'success'} | ${s__('Deployment|Success')} | ${'success'} | ${'status_success'}
${'failed'} | ${s__('Deployment|Failed')} | ${'danger'} | ${'status_failed'}
${'canceled'} | ${s__('Deployment|Cancelled')} | ${'neutral'} | ${'status_canceled'}
${'skipped'} | ${s__('Deployment|Skipped')} | ${'neutral'} | ${'status_skipped'}
${'blocked'} | ${s__('Deployment|Waiting')} | ${'neutral'} | ${'status_manual'}
`('$status', ({ status, text, variant, icon }) => {
let badge;
beforeEach(() => {
wrapper = createWrapper({ propsData: { status } });
badge = wrapper.findComponent(GlBadge);
});
it(`sets the text to ${text}`, () => {
expect(wrapper.text()).toBe(text);
});
it(`sets the variant to ${variant}`, () => {
expect(badge.props('variant')).toBe(variant);
});
it(`sets the icon to ${icon}`, () => {
expect(badge.props('icon')).toBe(icon);
});
});
});
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