Commit 7b7e8a22 authored by Paul Slaughter's avatar Paul Slaughter

Add integration spec for IDE commit to new branch

- It is important that we update the route to the new
  branch.
- Also, we add a "destroy" event to the root component
  so that the spec can properly dispose of Singleton
  things. Otherwise, specs were bumping into eachother
  because Monaco models were being shared.
parent 96564b36
...@@ -74,6 +74,7 @@ export default { ...@@ -74,6 +74,7 @@ export default {
<input <input
:placeholder="placeholderBranchName" :placeholder="placeholderBranchName"
:value="newBranchName" :value="newBranchName"
data-testid="ide-new-branch-name"
type="text" type="text"
class="form-control monospace" class="form-control monospace"
@input="updateBranchName($event.target.value)" @input="updateBranchName($event.target.value)"
......
...@@ -63,6 +63,10 @@ export function initIde(el, options = {}) { ...@@ -63,6 +63,10 @@ export function initIde(el, options = {}) {
codesandboxBundlerUrl: el.dataset.codesandboxBundlerUrl, codesandboxBundlerUrl: el.dataset.codesandboxBundlerUrl,
}); });
}, },
beforeDestroy() {
// This helps tests do Singleton cleanups which we don't really have responsibility to know about here.
this.$emit('destroy');
},
methods: { methods: {
...mapActions(['setEmptyStateSvgs', 'setLinks', 'setInitialData']), ...mapActions(['setEmptyStateSvgs', 'setLinks', 'setInitialData']),
}, },
......
...@@ -138,6 +138,11 @@ export const createFile = async (path, content) => { ...@@ -138,6 +138,11 @@ export const createFile = async (path, content) => {
await findAndSetEditorValue(content); await findAndSetEditorValue(content);
}; };
export const updateFile = async (path, content) => {
await openFile(path);
await findAndSetEditorValue(content);
};
export const getFilesList = () => { export const getFilesList = () => {
return screen.getAllByTestId('file-row-name-container').map((e) => e.textContent.trim()); return screen.getAllByTestId('file-row-name-container').map((e) => e.textContent.trim());
}; };
...@@ -162,11 +167,33 @@ export const closeFile = async (path) => { ...@@ -162,11 +167,33 @@ export const closeFile = async (path) => {
button.click(); button.click();
}; };
export const commit = async () => { /**
* Fill out and submit the commit form in the Web IDE
*
* @param {Object} options - Used to fill out the commit form in the IDE
* @param {Boolean} options.newBranch - Flag for the "Create a new branch" radio.
* @param {Boolean} options.newMR - Flag for the "Start a new merge request" checkbox.
* @param {String} options.newBranchName - Value to put in the new branch name input field. The Web IDE supports leaving this field blank.
*/
export const commit = async ({ newBranch = false, newMR = false, newBranchName = '' } = {}) => {
switchLeftSidebarTab('Commit'); switchLeftSidebarTab('Commit');
screen.getByTestId('begin-commit-button').click(); screen.getByTestId('begin-commit-button').click();
await screen.findByLabelText(/Commit to .+ branch/).then((x) => x.click()); if (!newBranch) {
const option = await screen.findByLabelText(/Commit to .+ branch/);
option.click();
} else {
const option = await screen.findByLabelText('Create a new branch');
option.click();
const branchNameInput = await screen.findByTestId('ide-new-branch-name');
fireEvent.input(branchNameInput, { target: { value: newBranchName } });
const mrCheck = await screen.findByLabelText('Start a new merge request');
if (Boolean(mrCheck.checked) !== newMR) {
mrCheck.click();
}
}
screen.getByText('Commit').click(); screen.getByText('Commit').click();
}; };
...@@ -2,6 +2,7 @@ import { TEST_HOST } from 'helpers/test_constants'; ...@@ -2,6 +2,7 @@ import { TEST_HOST } from 'helpers/test_constants';
import extendStore from '~/ide/stores/extend'; import extendStore from '~/ide/stores/extend';
import { IDE_DATASET } from './mock_data'; import { IDE_DATASET } from './mock_data';
import { initIde } from '~/ide'; import { initIde } from '~/ide';
import Editor from '~/ide/lib/editor';
export default (container, { isRepoEmpty = false, path = '' } = {}) => { export default (container, { isRepoEmpty = false, path = '' } = {}) => {
global.jsdom.reconfigure({ global.jsdom.reconfigure({
...@@ -13,5 +14,16 @@ export default (container, { isRepoEmpty = false, path = '' } = {}) => { ...@@ -13,5 +14,16 @@ export default (container, { isRepoEmpty = false, path = '' } = {}) => {
const el = document.createElement('div'); const el = document.createElement('div');
Object.assign(el.dataset, IDE_DATASET); Object.assign(el.dataset, IDE_DATASET);
container.appendChild(el); container.appendChild(el);
return initIde(el, { extendStore }); const vm = initIde(el, { extendStore });
// We need to dispose of editor Singleton things or tests will bump into eachother
vm.$on('destroy', () => {
if (Editor.editorInstance) {
Editor.editorInstance.modelManager.dispose();
Editor.editorInstance.dispose();
Editor.editorInstance = null;
}
});
return vm;
}; };
...@@ -55,6 +55,25 @@ describe('WebIDE', () => { ...@@ -55,6 +55,25 @@ describe('WebIDE', () => {
}); });
}); });
it('user commits changes to new branch', async () => {
vm = startWebIDE(container);
expect(window.location.pathname).toBe('/-/ide/project/gitlab-test/lorem-ipsum/tree/master/-/');
await ideHelper.updateFile('README.md', 'Lorem dolar si amit\n');
await ideHelper.commit({ newBranch: true, newMR: false, newBranchName: 'test-hello-world' });
await waitForText('All changes are committed');
// Wait for IDE to load new commit
await waitForText('10000000', document.querySelector('.ide-status-bar'));
// It's important that the new branch is now in the route
expect(window.location.pathname).toBe(
'/-/ide/project/gitlab-test/lorem-ipsum/blob/test-hello-world/-/README.md',
);
});
it('user adds file that starts with +', async () => { it('user adds file that starts with +', async () => {
vm = startWebIDE(container); vm = startWebIDE(container);
......
...@@ -37,13 +37,23 @@ export default (server) => { ...@@ -37,13 +37,23 @@ export default (server) => {
); );
const branch = schema.branches.findBy({ name: branchName }); const branch = schema.branches.findBy({ name: branchName });
const prevCommit = branch
? branch.attrs.commit
: schema.branches.findBy({ name: 'master' }).attrs.commit;
const commit = { const commit = {
...createNewCommit({ id: commitIdGenerator.next(), message }, branch.attrs.commit), ...createNewCommit({ id: commitIdGenerator.next(), message }, prevCommit),
__actions: actions, __actions: actions,
}; };
if (branch) {
branch.update({ commit }); branch.update({ commit });
} else {
schema.branches.create({
name: branchName,
commit,
});
}
return commit; return commit;
}); });
......
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