2021-01-03 14:25:43 +05:30
|
|
|
import waitForPromises from 'helpers/wait_for_promises';
|
2020-07-28 23:09:34 +05:30
|
|
|
import EditBlob from '~/blob_edit/edit_blob';
|
|
|
|
import EditorLite from '~/editor/editor_lite';
|
2021-03-08 18:12:59 +05:30
|
|
|
import { FileTemplateExtension } from '~/editor/extensions/editor_file_template_ext';
|
2021-03-11 19:13:27 +05:30
|
|
|
import { EditorMarkdownExtension } from '~/editor/extensions/editor_markdown_ext';
|
2020-07-28 23:09:34 +05:30
|
|
|
|
|
|
|
jest.mock('~/editor/editor_lite');
|
2021-03-08 18:12:59 +05:30
|
|
|
jest.mock('~/editor/extensions/editor_markdown_ext');
|
|
|
|
jest.mock('~/editor/extensions/editor_file_template_ext');
|
2020-07-28 23:09:34 +05:30
|
|
|
|
|
|
|
describe('Blob Editing', () => {
|
2021-01-03 14:25:43 +05:30
|
|
|
const useMock = jest.fn();
|
|
|
|
const mockInstance = {
|
|
|
|
use: useMock,
|
2021-02-22 17:27:13 +05:30
|
|
|
setValue: jest.fn(),
|
|
|
|
getValue: jest.fn().mockReturnValue('test value'),
|
2021-01-03 14:25:43 +05:30
|
|
|
focus: jest.fn(),
|
|
|
|
};
|
2020-07-28 23:09:34 +05:30
|
|
|
beforeEach(() => {
|
2021-02-22 17:27:13 +05:30
|
|
|
setFixtures(`
|
|
|
|
<form class="js-edit-blob-form">
|
|
|
|
<div id="file_path"></div>
|
|
|
|
<div id="editor"></div>
|
|
|
|
<textarea id="file-content"></textarea>
|
|
|
|
</form>
|
|
|
|
`);
|
2020-11-24 15:15:51 +05:30
|
|
|
jest.spyOn(EditorLite.prototype, 'createInstance').mockReturnValue(mockInstance);
|
2020-07-28 23:09:34 +05:30
|
|
|
});
|
2021-02-22 17:27:13 +05:30
|
|
|
afterEach(() => {
|
|
|
|
EditorMarkdownExtension.mockClear();
|
|
|
|
FileTemplateExtension.mockClear();
|
|
|
|
});
|
2020-07-28 23:09:34 +05:30
|
|
|
|
2021-03-08 18:12:59 +05:30
|
|
|
const editorInst = (isMarkdown) => {
|
2020-07-28 23:09:34 +05:30
|
|
|
return new EditBlob({
|
|
|
|
isMarkdown,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
const initEditor = async (isMarkdown = false) => {
|
|
|
|
editorInst(isMarkdown);
|
|
|
|
await waitForPromises();
|
|
|
|
};
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
it('loads FileTemplateExtension by default', async () => {
|
2020-07-28 23:09:34 +05:30
|
|
|
await initEditor();
|
2021-02-22 17:27:13 +05:30
|
|
|
expect(FileTemplateExtension).toHaveBeenCalledTimes(1);
|
2020-07-28 23:09:34 +05:30
|
|
|
});
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
describe('Markdown', () => {
|
|
|
|
it('does not load MarkdownExtension by default', async () => {
|
|
|
|
await initEditor();
|
2021-02-22 17:27:13 +05:30
|
|
|
expect(EditorMarkdownExtension).not.toHaveBeenCalled();
|
2020-11-24 15:15:51 +05:30
|
|
|
});
|
|
|
|
|
|
|
|
it('loads MarkdownExtension only for the markdown files', async () => {
|
|
|
|
await initEditor(true);
|
2021-01-03 14:25:43 +05:30
|
|
|
expect(useMock).toHaveBeenCalledTimes(2);
|
2021-02-22 17:27:13 +05:30
|
|
|
expect(FileTemplateExtension).toHaveBeenCalledTimes(1);
|
|
|
|
expect(EditorMarkdownExtension).toHaveBeenCalledTimes(1);
|
2020-11-24 15:15:51 +05:30
|
|
|
});
|
2020-07-28 23:09:34 +05:30
|
|
|
});
|
2021-02-22 17:27:13 +05:30
|
|
|
|
|
|
|
it('adds trailing newline to the blob content on submit', async () => {
|
|
|
|
const form = document.querySelector('.js-edit-blob-form');
|
|
|
|
const fileContentEl = document.getElementById('file-content');
|
|
|
|
|
|
|
|
await initEditor();
|
|
|
|
|
|
|
|
form.dispatchEvent(new Event('submit'));
|
|
|
|
|
|
|
|
expect(fileContentEl.value).toBe('test value\n');
|
|
|
|
});
|
2020-07-28 23:09:34 +05:30
|
|
|
});
|