Commit e43b4c4e authored by Nathan Friend's avatar Nathan Friend

Merge branch '213239-fix-newly-added-deleted-files-in-ide' into 'master'

Fix Web IDE deleting newly added files

See merge request gitlab-org/gitlab!29783
parents ce588f38 e9034e2b
...@@ -216,7 +216,12 @@ export default { ...@@ -216,7 +216,12 @@ export default {
if (entry.type === 'blob') { if (entry.type === 'blob') {
if (tempFile) { if (tempFile) {
// Since we only support one list of file changes, it's safe to just remove from both
// changed and staged. Otherwise, we'd need to somehow evaluate the difference between
// changed and HEAD.
// https://gitlab.com/gitlab-org/create-stage/-/issues/12669
state.changedFiles = state.changedFiles.filter(f => f.path !== path); state.changedFiles = state.changedFiles.filter(f => f.path !== path);
state.stagedFiles = state.stagedFiles.filter(f => f.path !== path);
} else { } else {
state.changedFiles = state.changedFiles.concat(entry); state.changedFiles = state.changedFiles.concat(entry);
} }
......
---
title: Fix Web IDE handling of deleting newly added files
merge_request: 29783
author:
type: fixed
...@@ -30,4 +30,14 @@ describe 'IDE user commits changes', :js do ...@@ -30,4 +30,14 @@ describe 'IDE user commits changes', :js do
expect(project.repository.blob_at('master', 'foo/bar/.gitkeep')).to be_nil expect(project.repository.blob_at('master', 'foo/bar/.gitkeep')).to be_nil
expect(project.repository.blob_at('master', 'foo/bar/lorem_ipsum.md').data).to eql(content) expect(project.repository.blob_at('master', 'foo/bar/lorem_ipsum.md').data).to eql(content)
end end
it 'user adds then deletes new file' do
ide_create_new_file('foo/bar/lorem_ipsum.md')
expect(page).to have_selector(ide_commit_tab_selector)
ide_delete_file('foo/bar/lorem_ipsum.md')
expect(page).not_to have_selector(ide_commit_tab_selector)
end
end end
...@@ -273,7 +273,7 @@ describe('Multi-file store mutations', () => { ...@@ -273,7 +273,7 @@ describe('Multi-file store mutations', () => {
expect(localState.changedFiles).toEqual([]); expect(localState.changedFiles).toEqual([]);
}); });
it('removes tempFile from changedFiles when deleted', () => { it('removes tempFile from changedFiles and stagedFiles when deleted', () => {
localState.entries.filePath = { localState.entries.filePath = {
path: 'filePath', path: 'filePath',
deleted: false, deleted: false,
...@@ -282,10 +282,12 @@ describe('Multi-file store mutations', () => { ...@@ -282,10 +282,12 @@ describe('Multi-file store mutations', () => {
}; };
localState.changedFiles.push({ ...localState.entries.filePath }); localState.changedFiles.push({ ...localState.entries.filePath });
localState.stagedFiles.push({ ...localState.entries.filePath });
mutations.DELETE_ENTRY(localState, 'filePath'); mutations.DELETE_ENTRY(localState, 'filePath');
expect(localState.changedFiles).toEqual([]); expect(localState.changedFiles).toEqual([]);
expect(localState.stagedFiles).toEqual([]);
}); });
it('bursts unused seal', () => { it('bursts unused seal', () => {
......
...@@ -32,6 +32,10 @@ module WebIdeSpecHelpers ...@@ -32,6 +32,10 @@ module WebIdeSpecHelpers
page.find('.ide-tree-actions') page.find('.ide-tree-actions')
end end
def ide_tab_selector(mode)
".js-ide-#{mode}-mode"
end
def ide_file_row_open?(row) def ide_file_row_open?(row)
row.matches_css?('.is-open') row.matches_css?('.is-open')
end end
...@@ -106,16 +110,16 @@ module WebIdeSpecHelpers ...@@ -106,16 +110,16 @@ module WebIdeSpecHelpers
evaluate_script("monaco.editor.getModel('#{uri}').getValue()") evaluate_script("monaco.editor.getModel('#{uri}').getValue()")
end end
def ide_commit_tab_selector
ide_tab_selector('commit')
end
def ide_commit def ide_commit
ide_switch_mode('commit') find(ide_commit_tab_selector).click
commit_to_current_branch commit_to_current_branch
end end
def ide_switch_mode(mode)
find(".js-ide-#{mode}-mode").click
end
private private
def file_row_container(row) def file_row_container(row)
......
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