2021-01-03 14:25:43 +05:30
|
|
|
import { GlFormGroup, GlFormInput } from '@gitlab/ui';
|
2021-03-11 19:13:27 +05:30
|
|
|
import { mount } from '@vue/test-utils';
|
2021-01-03 14:25:43 +05:30
|
|
|
import ParameterFormGroup from '~/feature_flags/components/strategies/parameter_form_group.vue';
|
|
|
|
|
|
|
|
describe('~/feature_flags/strategies/parameter_form_group.vue', () => {
|
|
|
|
let wrapper;
|
|
|
|
let formGroup;
|
|
|
|
let slot;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
wrapper = mount(ParameterFormGroup, {
|
|
|
|
propsData: { inputId: 'test-id', label: 'test' },
|
|
|
|
attrs: { description: 'test description' },
|
|
|
|
scopedSlots: {
|
|
|
|
default(props) {
|
|
|
|
return this.$createElement(GlFormInput, {
|
|
|
|
attrs: { id: props.inputId, 'data-testid': 'slot' },
|
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
formGroup = wrapper.find(GlFormGroup);
|
|
|
|
slot = wrapper.find('[data-testid="slot"]');
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
if (wrapper?.destroy) {
|
|
|
|
wrapper.destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
wrapper = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should display the default slot', () => {
|
|
|
|
expect(slot.exists()).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should bind the input id to the slot', () => {
|
|
|
|
expect(slot.attributes('id')).toBe('test-id');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should bind the label-for to the input id', () => {
|
|
|
|
expect(formGroup.find('[for="test-id"]').exists()).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should bind extra attributes to the form group', () => {
|
|
|
|
expect(formGroup.attributes('description')).toBe('test description');
|
|
|
|
});
|
|
|
|
});
|