2020-10-24 23:57:45 +05:30
|
|
|
import $ from 'jquery';
|
2022-07-16 23:28:13 +05:30
|
|
|
import { setHTMLFixture, resetHTMLFixture } from 'helpers/fixtures';
|
2022-01-26 12:08:38 +05:30
|
|
|
import IssuableForm from '~/issuable/issuable_form';
|
2022-06-21 17:19:12 +05:30
|
|
|
import setWindowLocation from 'helpers/set_window_location_helper';
|
2020-10-24 23:57:45 +05:30
|
|
|
|
|
|
|
describe('IssuableForm', () => {
|
|
|
|
let instance;
|
|
|
|
|
2022-06-21 17:19:12 +05:30
|
|
|
const createIssuable = (form) => {
|
|
|
|
instance = new IssuableForm(form);
|
|
|
|
};
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
beforeEach(() => {
|
2022-07-16 23:28:13 +05:30
|
|
|
setHTMLFixture(`
|
2022-06-21 17:19:12 +05:30
|
|
|
<form>
|
|
|
|
<input name="[title]" />
|
|
|
|
</form>
|
|
|
|
`);
|
|
|
|
createIssuable($('form'));
|
|
|
|
});
|
|
|
|
|
2022-07-16 23:28:13 +05:30
|
|
|
afterEach(() => {
|
|
|
|
resetHTMLFixture();
|
|
|
|
});
|
|
|
|
|
2022-06-21 17:19:12 +05:30
|
|
|
describe('initAutosave', () => {
|
|
|
|
it('creates autosave with the searchTerm included', () => {
|
|
|
|
setWindowLocation('https://gitlab.test/foo?bar=true');
|
|
|
|
const autosave = instance.initAutosave();
|
|
|
|
|
|
|
|
expect(autosave.key.includes('bar=true')).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("creates autosave fields without the searchTerm if it's an issue new form", () => {
|
2022-07-16 23:28:13 +05:30
|
|
|
setHTMLFixture(`
|
2022-06-21 17:19:12 +05:30
|
|
|
<form data-new-issue-path="/issues/new">
|
|
|
|
<input name="[title]" />
|
|
|
|
</form>
|
|
|
|
`);
|
|
|
|
createIssuable($('form'));
|
|
|
|
|
|
|
|
setWindowLocation('https://gitlab.test/issues/new?bar=true');
|
|
|
|
|
|
|
|
const autosave = instance.initAutosave();
|
|
|
|
|
|
|
|
expect(autosave.key.includes('bar=true')).toBe(false);
|
|
|
|
});
|
2020-10-24 23:57:45 +05:30
|
|
|
});
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
describe('resetAutosave', () => {
|
|
|
|
it('resets autosave on elements with the .js-reset-autosave class', () => {
|
|
|
|
setHTMLFixture(`
|
|
|
|
<form>
|
|
|
|
<input name="[title]" />
|
|
|
|
<textarea name="[description]"></textarea>
|
|
|
|
<a class="js-reset-autosave">Cancel</a>
|
|
|
|
</form>
|
|
|
|
`);
|
|
|
|
const $form = $('form');
|
|
|
|
const resetAutosave = jest.spyOn(IssuableForm.prototype, 'resetAutosave');
|
|
|
|
createIssuable($form);
|
|
|
|
|
|
|
|
$form.find('.js-reset-autosave').trigger('click');
|
|
|
|
|
|
|
|
expect(resetAutosave).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
describe('removeWip', () => {
|
|
|
|
it.each`
|
|
|
|
prefix
|
|
|
|
${'draFT: '}
|
|
|
|
${' [DRaft] '}
|
|
|
|
${'drAft:'}
|
|
|
|
${'[draFT]'}
|
|
|
|
${'(draft) '}
|
|
|
|
${' (DrafT)'}
|
2021-11-18 22:05:49 +05:30
|
|
|
${'draft: [draft] (draft)'}
|
2020-10-24 23:57:45 +05:30
|
|
|
`('removes "$prefix" from the beginning of the title', ({ prefix }) => {
|
|
|
|
instance.titleField.val(`${prefix}The Issuable's Title Value`);
|
|
|
|
|
|
|
|
instance.removeWip();
|
|
|
|
|
|
|
|
expect(instance.titleField.val()).toBe("The Issuable's Title Value");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('addWip', () => {
|
|
|
|
it("properly adds the work in progress prefix to the Issuable's title", () => {
|
|
|
|
instance.titleField.val("The Issuable's Title Value");
|
|
|
|
|
|
|
|
instance.addWip();
|
|
|
|
|
|
|
|
expect(instance.titleField.val()).toBe("Draft: The Issuable's Title Value");
|
|
|
|
});
|
|
|
|
});
|
2021-11-18 22:05:49 +05:30
|
|
|
|
|
|
|
describe('workInProgress', () => {
|
|
|
|
it.each`
|
|
|
|
title | expected
|
|
|
|
${'draFT: something is happening'} | ${true}
|
|
|
|
${'draft something is happening'} | ${false}
|
|
|
|
${'something is happening to drafts'} | ${false}
|
|
|
|
${'something is happening'} | ${false}
|
|
|
|
`('returns $expected with "$title"', ({ title, expected }) => {
|
|
|
|
instance.titleField.val(title);
|
|
|
|
|
|
|
|
expect(instance.workInProgress()).toBe(expected);
|
|
|
|
});
|
|
|
|
});
|
2020-10-24 23:57:45 +05:30
|
|
|
});
|