Commit 7d2bdf23 authored by Himanshu Kapoor's avatar Himanshu Kapoor Committed by Natalia Tepluhina

Remove staging from the commit workflow

Bypass staging in Web IDE by ommitting staging from Vue templates.
parent c943774f
...@@ -24,25 +24,19 @@ export default { ...@@ -24,25 +24,19 @@ export default {
discardModalTitle() { discardModalTitle() {
return sprintf(__('Discard changes to %{path}?'), { path: this.activeFile.path }); return sprintf(__('Discard changes to %{path}?'), { path: this.activeFile.path });
}, },
actionButtonText() {
return this.activeFile.staged ? __('Unstage') : __('Stage');
},
isStaged() { isStaged() {
return !this.activeFile.changed && this.activeFile.staged; return !this.activeFile.changed && this.activeFile.staged;
}, },
}, },
methods: { methods: {
...mapActions(['stageChange', 'unstageChange', 'discardFileChanges']), ...mapActions(['stageChange', 'unstageChange', 'discardFileChanges']),
actionButtonClicked() {
if (this.activeFile.staged) {
this.unstageChange(this.activeFile.path);
} else {
this.stageChange(this.activeFile.path);
}
},
showDiscardModal() { showDiscardModal() {
this.$refs.discardModal.show(); this.$refs.discardModal.show();
}, },
discardChanges(path) {
this.unstageChange(path);
this.discardFileChanges(path);
},
}, },
}; };
</script> </script>
...@@ -65,19 +59,7 @@ export default { ...@@ -65,19 +59,7 @@ export default {
class="btn btn-remove btn-inverted append-right-8" class="btn btn-remove btn-inverted append-right-8"
@click="showDiscardModal" @click="showDiscardModal"
> >
{{ __('Discard') }} {{ __('Discard changes') }}
</button>
<button
ref="actionButton"
:class="{
'btn-success': !isStaged,
'btn-warning': isStaged,
}"
type="button"
class="btn btn-inverted"
@click="actionButtonClicked"
>
{{ actionButtonText }}
</button> </button>
</div> </div>
<gl-modal <gl-modal
...@@ -87,7 +69,7 @@ export default { ...@@ -87,7 +69,7 @@ export default {
:ok-title="__('Discard changes')" :ok-title="__('Discard changes')"
:modal-id="discardModalId" :modal-id="discardModalId"
:title="discardModalTitle" :title="discardModalTitle"
@ok="discardFileChanges(activeFile.path)" @ok="discardChanges(activeFile.path)"
> >
{{ __("You will lose all changes you've made to this file. This action cannot be undone.") }} {{ __("You will lose all changes you've made to this file. This action cannot be undone.") }}
</gl-modal> </gl-modal>
......
<script> <script>
import { mapState, mapActions, mapGetters } from 'vuex'; import { mapState, mapActions, mapGetters } from 'vuex';
import { sprintf, __ } from '~/locale'; import { n__, __ } from '~/locale';
import LoadingButton from '~/vue_shared/components/loading_button.vue'; import LoadingButton from '~/vue_shared/components/loading_button.vue';
import CommitMessageField from './message_field.vue'; import CommitMessageField from './message_field.vue';
import Actions from './actions.vue'; import Actions from './actions.vue';
...@@ -26,15 +26,7 @@ export default { ...@@ -26,15 +26,7 @@ export default {
...mapGetters(['hasChanges']), ...mapGetters(['hasChanges']),
...mapGetters('commit', ['discardDraftButtonDisabled', 'preBuiltCommitMessage']), ...mapGetters('commit', ['discardDraftButtonDisabled', 'preBuiltCommitMessage']),
overviewText() { overviewText() {
return sprintf( return n__('%d changed file', '%d changed files', this.stagedFiles.length);
__(
'<strong>%{stagedFilesLength} staged</strong> and <strong>%{changedFilesLength} unstaged</strong> changes',
),
{
stagedFilesLength: this.stagedFiles.length,
changedFilesLength: this.changedFiles.length,
},
);
}, },
commitButtonText() { commitButtonText() {
return this.stagedFiles.length ? __('Commit') : __('Stage & Commit'); return this.stagedFiles.length ? __('Commit') : __('Stage & Commit');
...@@ -125,7 +117,7 @@ export default { ...@@ -125,7 +117,7 @@ export default {
> >
{{ __('Commit…') }} {{ __('Commit…') }}
</button> </button>
<p class="text-center" v-html="overviewText"></p> <p class="text-center bold">{{ overviewText }}</p>
</div> </div>
<form v-if="!isCompact" ref="formEl" @submit.prevent.stop="commitChanges"> <form v-if="!isCompact" ref="formEl" @submit.prevent.stop="commitChanges">
<transition name="fade"> <success-message v-show="lastCommitMsg" /> </transition> <transition name="fade"> <success-message v-show="lastCommitMsg" /> </transition>
......
...@@ -17,10 +17,6 @@ export default { ...@@ -17,10 +17,6 @@ export default {
tooltip, tooltip,
}, },
props: { props: {
title: {
type: String,
required: true,
},
fileList: { fileList: {
type: Array, type: Array,
required: true, required: true,
...@@ -29,18 +25,6 @@ export default { ...@@ -29,18 +25,6 @@ export default {
type: String, type: String,
required: true, required: true,
}, },
action: {
type: String,
required: true,
},
actionBtnText: {
type: String,
required: true,
},
actionBtnIcon: {
type: String,
required: true,
},
stagedList: { stagedList: {
type: Boolean, type: Boolean,
required: false, required: false,
...@@ -63,9 +47,9 @@ export default { ...@@ -63,9 +47,9 @@ export default {
}, },
computed: { computed: {
titleText() { titleText() {
return sprintf(__('%{title} changes'), { if (!this.title) return __('Changes');
title: this.title,
}); return sprintf(__('%{title} changes'), { title: this.title });
}, },
filesLength() { filesLength() {
return this.fileList.length; return this.fileList.length;
...@@ -73,17 +57,16 @@ export default { ...@@ -73,17 +57,16 @@ export default {
}, },
methods: { methods: {
...mapActions(['stageAllChanges', 'unstageAllChanges', 'discardAllChanges']), ...mapActions(['stageAllChanges', 'unstageAllChanges', 'discardAllChanges']),
actionBtnClicked() {
this[this.action]();
$(this.$refs.actionBtn).tooltip('hide');
},
openDiscardModal() { openDiscardModal() {
$('#discard-all-changes').modal('show'); $('#discard-all-changes').modal('show');
}, },
unstageAndDiscardAllChanges() {
this.unstageAllChanges();
this.discardAllChanges();
},
}, },
discardModalText: __( discardModalText: __(
"You will lose all the unstaged changes you've made in this project. This action cannot be undone.", "You will lose all uncommitted changes you've made in this project. This action cannot be undone.",
), ),
}; };
</script> </script>
...@@ -95,24 +78,6 @@ export default { ...@@ -95,24 +78,6 @@ export default {
<icon v-once :name="iconName" :size="18" class="append-right-8" /> <icon v-once :name="iconName" :size="18" class="append-right-8" />
<strong> {{ titleText }} </strong> <strong> {{ titleText }} </strong>
<div class="d-flex ml-auto"> <div class="d-flex ml-auto">
<button
ref="actionBtn"
v-tooltip
:title="actionBtnText"
:aria-label="actionBtnText"
:disabled="!filesLength"
:class="{
'disabled-content': !filesLength,
}"
type="button"
class="d-flex ide-staged-action-btn p-0 border-0 align-items-center"
data-placement="bottom"
data-container="body"
data-boundary="viewport"
@click="actionBtnClicked"
>
<icon :name="actionBtnIcon" :size="16" class="ml-auto mr-auto" />
</button>
<button <button
v-if="!stagedList" v-if="!stagedList"
v-tooltip v-tooltip
...@@ -151,9 +116,9 @@ export default { ...@@ -151,9 +116,9 @@ export default {
v-if="!stagedList" v-if="!stagedList"
id="discard-all-changes" id="discard-all-changes"
:footer-primary-button-text="__('Discard all changes')" :footer-primary-button-text="__('Discard all changes')"
:header-title-text="__('Discard all unstaged changes?')" :header-title-text="__('Discard all changes?')"
footer-primary-button-variant="danger" footer-primary-button-variant="danger"
@submit="discardAllChanges" @submit="unstageAndDiscardAllChanges"
> >
{{ $options.discardModalText }} {{ $options.discardModalText }}
</gl-modal> </gl-modal>
......
...@@ -57,13 +57,7 @@ export default { ...@@ -57,13 +57,7 @@ export default {
}, },
}, },
methods: { methods: {
...mapActions([ ...mapActions(['discardFileChanges', 'updateViewer', 'openPendingTab']),
'discardFileChanges',
'updateViewer',
'openPendingTab',
'unstageChange',
'stageChange',
]),
openFileInEditor() { openFileInEditor() {
if (this.file.type === 'tree') return null; if (this.file.type === 'tree') return null;
...@@ -76,13 +70,6 @@ export default { ...@@ -76,13 +70,6 @@ export default {
} }
}); });
}, },
fileAction() {
if (this.file.staged) {
this.unstageChange(this.file.path);
} else {
this.stageChange(this.file.path);
}
},
}, },
}; };
</script> </script>
...@@ -97,7 +84,6 @@ export default { ...@@ -97,7 +84,6 @@ export default {
}" }"
class="multi-file-commit-list-path w-100 border-0 ml-0 mr-0" class="multi-file-commit-list-path w-100 border-0 ml-0 mr-0"
role="button" role="button"
@dblclick="fileAction"
@click="openFileInEditor" @click="openFileInEditor"
> >
<span class="multi-file-commit-list-file-path d-flex align-items-center"> <span class="multi-file-commit-list-file-path d-flex align-items-center">
......
<script> <script>
import { mapGetters } from 'vuex'; import { mapGetters } from 'vuex';
import { n__, __, sprintf } from '~/locale'; import { n__ } from '~/locale';
import tooltip from '~/vue_shared/directives/tooltip'; import tooltip from '~/vue_shared/directives/tooltip';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import ChangedFileIcon from '~/vue_shared/components/changed_file_icon.vue'; import ChangedFileIcon from '~/vue_shared/components/changed_file_icon.vue';
...@@ -49,16 +49,7 @@ export default { ...@@ -49,16 +49,7 @@ export default {
folderChangesTooltip() { folderChangesTooltip() {
if (this.changesCount === 0) return undefined; if (this.changesCount === 0) return undefined;
if (this.folderUnstagedCount > 0 && this.folderStagedCount === 0) { return n__('%d changed file', '%d changed files', this.changesCount);
return n__('%d unstaged change', '%d unstaged changes', this.folderUnstagedCount);
} else if (this.folderUnstagedCount === 0 && this.folderStagedCount > 0) {
return n__('%d staged change', '%d staged changes', this.folderStagedCount);
}
return sprintf(__('%{staged} staged and %{unstaged} unstaged changes'), {
unstaged: this.folderUnstagedCount,
staged: this.folderStagedCount,
});
}, },
showTreeChangesCount() { showTreeChangesCount() {
return this.isTree && this.changesCount > 0 && !this.file.opened; return this.isTree && this.changesCount > 0 && !this.file.opened;
......
...@@ -86,28 +86,12 @@ export default { ...@@ -86,28 +86,12 @@ export default {
</deprecated-modal> </deprecated-modal>
<template v-if="showStageUnstageArea"> <template v-if="showStageUnstageArea">
<commit-files-list <commit-files-list
:title="__('Unstaged')"
:key-prefix="$options.stageKeys.unstaged"
:file-list="changedFiles"
:action-btn-text="__('Stage all changes')"
:active-file-key="activeFileKey"
:empty-state-text="__('There are no unstaged changes')"
action="stageAllChanges"
action-btn-icon="stage-all"
class="is-first"
icon-name="unstaged"
/>
<commit-files-list
:title="__('Staged')"
:key-prefix="$options.stageKeys.staged" :key-prefix="$options.stageKeys.staged"
:file-list="stagedFiles" :file-list="stagedFiles"
:action-btn-text="__('Unstage all changes')"
:staged-list="true"
:active-file-key="activeFileKey" :active-file-key="activeFileKey"
:empty-state-text="__('There are no staged changes')" :empty-state-text="__('There are no changes')"
action="unstageAllChanges" class="is-first"
action-btn-icon="unstage-all" icon-name="unstaged"
icon-name="staged"
/> />
</template> </template>
<empty-state v-if="unusedSeal" /> <empty-state v-if="unusedSeal" />
......
<script> <script>
import { GlTooltipDirective } from '@gitlab/ui'; import { GlTooltipDirective } from '@gitlab/ui';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import { __, sprintf } from '~/locale'; import { __ } from '~/locale';
import { getCommitIconMap } from '~/ide/utils'; import { getCommitIconMap } from '~/ide/utils';
export default { export default {
...@@ -51,17 +51,7 @@ export default { ...@@ -51,17 +51,7 @@ export default {
tooltipTitle() { tooltipTitle() {
if (!this.showTooltip || !this.file.changed) return undefined; if (!this.showTooltip || !this.file.changed) return undefined;
const type = this.file.tempFile ? 'addition' : 'modification'; return this.file.tempFile ? __('Added') : __('Modified');
if (this.file.staged) {
return sprintf(__('Staged %{type}'), {
type,
});
}
return sprintf(__('Unstaged %{type}'), {
type,
});
}, },
showIcon() { showIcon() {
return ( return (
......
---
title: Remove staging from commit workflow in the Web IDE
merge_request: 26151
author:
type: removed
...@@ -43,30 +43,33 @@ you can find a more complete list of supported languages in the ...@@ -43,30 +43,33 @@ you can find a more complete list of supported languages in the
NOTE: **Note:** NOTE: **Note:**
Single file editing is based on the [Ace Editor](https://ace.c9.io). Single file editing is based on the [Ace Editor](https://ace.c9.io).
## Stage and commit changes ## Commit changes
After making your changes, click the **Commit** button in the bottom left to > - [Introduced](https://gitlab.com/gitlab-org/gitlab/issues/4539) in [GitLab Ultimate](https://about.gitlab.com/pricing/) 10.4 and [brought to GitLab Core](https://gitlab.com/gitlab-org/gitlab-foss/issues/44157) in 10.7.
review the list of changed files. If you're using GitLab 12.6 or older versions, > - From [GitLab 12.7 onwards](https://gitlab.com/gitlab-org/gitlab/issues/33441),
click on each file to review the changes and tick the item to stage a file. files were automatically staged.
> - From [GitLab 12.9 onwards](https://gitlab.com/gitlab-org/gitlab/-/issues/196609), support for staging files was removed
to prevent loss of unstaged data. All your current changes necessarily have to be
committed or discarded.
From [GitLab 12.7 onward](https://gitlab.com/gitlab-org/gitlab/issues/33441), After making your changes, click the **Commit** button on the bottom-left to
all your files will be automatically staged. You still have the option to unstage review the list of changed files.
changes in case you want to submit them in multiple smaller commits. To unstage
a change, simply click the **Unstage** button when a staged file is open, or click
the undo icon next to **Staged changes** to unstage all changes.
Once you have finalized your changes, you can add a commit message, commit the Once you have finalized your changes, you can add a commit message, commit the
staged changes and directly create a merge request. In case you don't have write changes and directly create a merge request. In case you don't have write
access to the selected branch, you will see a warning, but still be able to create access to the selected branch, you will see a warning, but still be able to create
a new branch and start a merge request. a new branch and start a merge request.
![Commit changes](img/commit_changes_v12_3.png) To discard a change in a particular file, click the **Discard changes** button on that
file in the changes tab. To discard all the changes, click the trash icon on the
top-right corner of the changes sidebar.
![Commit changes](img/commit_changes_v12_9.png)
## Reviewing changes ## Reviewing changes
Before you commit your changes, you can compare them with the previous commit Before you commit your changes, you can compare them with the previous commit
by switching to the review mode or selecting the file from the staged files by switching to the review mode or selecting the file from the list of changes.
list.
An additional review mode is available when you open a merge request, which An additional review mode is available when you open a merge request, which
shows you a preview of the merge request diff if you commit your changes. shows you a preview of the merge request diff if you commit your changes.
......
...@@ -68,6 +68,11 @@ msgstr "" ...@@ -68,6 +68,11 @@ msgstr ""
msgid "\"%{path}\" did not exist on \"%{ref}\"" msgid "\"%{path}\" did not exist on \"%{ref}\""
msgstr "" msgstr ""
msgid "%d changed file"
msgid_plural "%d changed files"
msgstr[0] ""
msgstr[1] ""
msgid "%d code quality issue" msgid "%d code quality issue"
msgid_plural "%d code quality issues" msgid_plural "%d code quality issues"
msgstr[0] "" msgstr[0] ""
...@@ -186,21 +191,11 @@ msgid_plural "%d shards selected" ...@@ -186,21 +191,11 @@ msgid_plural "%d shards selected"
msgstr[0] "" msgstr[0] ""
msgstr[1] "" msgstr[1] ""
msgid "%d staged change"
msgid_plural "%d staged changes"
msgstr[0] ""
msgstr[1] ""
msgid "%d tag" msgid "%d tag"
msgid_plural "%d tags" msgid_plural "%d tags"
msgstr[0] "" msgstr[0] ""
msgstr[1] "" msgstr[1] ""
msgid "%d unstaged change"
msgid_plural "%d unstaged changes"
msgstr[0] ""
msgstr[1] ""
msgid "%d vulnerability dismissed" msgid "%d vulnerability dismissed"
msgid_plural "%d vulnerabilities dismissed" msgid_plural "%d vulnerabilities dismissed"
msgstr[0] "" msgstr[0] ""
...@@ -431,9 +426,6 @@ msgstr "" ...@@ -431,9 +426,6 @@ msgstr ""
msgid "%{spanStart}in%{spanEnd} %{errorFn}" msgid "%{spanStart}in%{spanEnd} %{errorFn}"
msgstr "" msgstr ""
msgid "%{staged} staged and %{unstaged} unstaged changes"
msgstr ""
msgid "%{start} to %{end}" msgid "%{start} to %{end}"
msgstr "" msgstr ""
...@@ -777,9 +769,6 @@ msgstr "" ...@@ -777,9 +769,6 @@ msgstr ""
msgid "<strong>%{group_name}</strong> group members" msgid "<strong>%{group_name}</strong> group members"
msgstr "" msgstr ""
msgid "<strong>%{stagedFilesLength} staged</strong> and <strong>%{changedFilesLength} unstaged</strong> changes"
msgstr ""
msgid "<strong>Deletes</strong> source branch" msgid "<strong>Deletes</strong> source branch"
msgstr "" msgstr ""
...@@ -6884,13 +6873,10 @@ msgstr "" ...@@ -6884,13 +6873,10 @@ msgstr ""
msgid "Disabled mirrors can only be enabled by instance owners. It is recommended that you delete them." msgid "Disabled mirrors can only be enabled by instance owners. It is recommended that you delete them."
msgstr "" msgstr ""
msgid "Discard"
msgstr ""
msgid "Discard all changes" msgid "Discard all changes"
msgstr "" msgstr ""
msgid "Discard all unstaged changes?" msgid "Discard all changes?"
msgstr "" msgstr ""
msgid "Discard changes" msgid "Discard changes"
...@@ -12738,6 +12724,9 @@ msgstr "" ...@@ -12738,6 +12724,9 @@ msgstr ""
msgid "Modal|Close" msgid "Modal|Close"
msgstr "" msgstr ""
msgid "Modified"
msgstr ""
msgid "Modified in this version" msgid "Modified in this version"
msgstr "" msgstr ""
...@@ -18656,21 +18645,12 @@ msgstr "" ...@@ -18656,21 +18645,12 @@ msgstr ""
msgid "Stage & Commit" msgid "Stage & Commit"
msgstr "" msgstr ""
msgid "Stage all changes"
msgstr ""
msgid "Stage data updated" msgid "Stage data updated"
msgstr "" msgstr ""
msgid "Stage removed" msgid "Stage removed"
msgstr "" msgstr ""
msgid "Staged"
msgstr ""
msgid "Staged %{type}"
msgstr ""
msgid "Star a label to make it a priority label. Order the prioritized labels to change their relative priority, by dragging." msgid "Star a label to make it a priority label. Order the prioritized labels to change their relative priority, by dragging."
msgstr "" msgstr ""
...@@ -19827,6 +19807,9 @@ msgstr "" ...@@ -19827,6 +19807,9 @@ msgstr ""
msgid "There are no archived projects yet" msgid "There are no archived projects yet"
msgstr "" msgstr ""
msgid "There are no changes"
msgstr ""
msgid "There are no charts configured for this page" msgid "There are no charts configured for this page"
msgstr "" msgstr ""
...@@ -19863,12 +19846,6 @@ msgstr "" ...@@ -19863,12 +19846,6 @@ msgstr ""
msgid "There are no projects shared with this group yet" msgid "There are no projects shared with this group yet"
msgstr "" msgstr ""
msgid "There are no staged changes"
msgstr ""
msgid "There are no unstaged changes"
msgstr ""
msgid "There is a limit of %{ci_project_subscriptions_limit} subscriptions from or to a project." msgid "There is a limit of %{ci_project_subscriptions_limit} subscriptions from or to a project."
msgstr "" msgstr ""
...@@ -21280,18 +21257,6 @@ msgstr "" ...@@ -21280,18 +21257,6 @@ msgstr ""
msgid "Unschedule job" msgid "Unschedule job"
msgstr "" msgstr ""
msgid "Unstage"
msgstr ""
msgid "Unstage all changes"
msgstr ""
msgid "Unstaged"
msgstr ""
msgid "Unstaged %{type}"
msgstr ""
msgid "Unstar" msgid "Unstar"
msgstr "" msgstr ""
...@@ -22955,7 +22920,7 @@ msgstr "" ...@@ -22955,7 +22920,7 @@ msgstr ""
msgid "You will lose all changes you've made to this file. This action cannot be undone." msgid "You will lose all changes you've made to this file. This action cannot be undone."
msgstr "" msgstr ""
msgid "You will lose all the unstaged changes you've made in this project. This action cannot be undone." msgid "You will lose all uncommitted changes you've made in this project. This action cannot be undone."
msgstr "" msgstr ""
msgid "You will need to update your local repositories to point to the new location." msgid "You will need to update your local repositories to point to the new location."
......
...@@ -14,7 +14,6 @@ describe('IDE commit editor header', () => { ...@@ -14,7 +14,6 @@ describe('IDE commit editor header', () => {
const findDiscardModal = () => wrapper.find({ ref: 'discardModal' }); const findDiscardModal = () => wrapper.find({ ref: 'discardModal' });
const findDiscardButton = () => wrapper.find({ ref: 'discardButton' }); const findDiscardButton = () => wrapper.find({ ref: 'discardButton' });
const findActionButton = () => wrapper.find({ ref: 'actionButton' });
beforeEach(() => { beforeEach(() => {
f = file('file'); f = file('file');
...@@ -28,9 +27,7 @@ describe('IDE commit editor header', () => { ...@@ -28,9 +27,7 @@ describe('IDE commit editor header', () => {
}, },
}); });
jest.spyOn(wrapper.vm, 'stageChange').mockImplementation(); jest.spyOn(wrapper.vm, 'discardChanges').mockImplementation();
jest.spyOn(wrapper.vm, 'unstageChange').mockImplementation();
jest.spyOn(wrapper.vm, 'discardFileChanges').mockImplementation();
}); });
afterEach(() => { afterEach(() => {
...@@ -38,8 +35,8 @@ describe('IDE commit editor header', () => { ...@@ -38,8 +35,8 @@ describe('IDE commit editor header', () => {
wrapper = null; wrapper = null;
}); });
it('renders button to discard & stage', () => { it('renders button to discard', () => {
expect(wrapper.vm.$el.querySelectorAll('.btn').length).toBe(2); expect(wrapper.vm.$el.querySelectorAll('.btn')).toHaveLength(1);
}); });
describe('discard button', () => { describe('discard button', () => {
...@@ -60,23 +57,7 @@ describe('IDE commit editor header', () => { ...@@ -60,23 +57,7 @@ describe('IDE commit editor header', () => {
it('calls discardFileChanges if dialog result is confirmed', () => { it('calls discardFileChanges if dialog result is confirmed', () => {
modal.vm.$emit('ok'); modal.vm.$emit('ok');
expect(wrapper.vm.discardFileChanges).toHaveBeenCalledWith(f.path); expect(wrapper.vm.discardChanges).toHaveBeenCalledWith(f.path);
});
});
describe('stage/unstage button', () => {
it('unstages the file if it was already staged', () => {
f.staged = true;
findActionButton().trigger('click');
expect(wrapper.vm.unstageChange).toHaveBeenCalledWith(f.path);
});
it('stages the file if it was not staged', () => {
findActionButton().trigger('click');
expect(wrapper.vm.stageChange).toHaveBeenCalledWith(f.path);
}); });
}); });
}); });
...@@ -54,10 +54,10 @@ describe('Changed file icon', () => { ...@@ -54,10 +54,10 @@ describe('Changed file icon', () => {
}); });
describe.each` describe.each`
file | iconName | tooltipText | desc file | iconName | tooltipText | desc
${changedFile()} | ${'file-modified'} | ${'Unstaged modification'} | ${'with file changed'} ${changedFile()} | ${'file-modified'} | ${'Modified'} | ${'with file changed'}
${stagedFile()} | ${'file-modified-solid'} | ${'Staged modification'} | ${'with file staged'} ${stagedFile()} | ${'file-modified-solid'} | ${'Modified'} | ${'with file staged'}
${newFile()} | ${'file-addition'} | ${'Unstaged addition'} | ${'with file new'} ${newFile()} | ${'file-addition'} | ${'Added'} | ${'with file new'}
`('$desc', ({ file, iconName, tooltipText }) => { `('$desc', ({ file, iconName, tooltipText }) => {
beforeEach(() => { beforeEach(() => {
factory({ file }); factory({ file });
......
...@@ -52,7 +52,7 @@ describe('IDE commit form', () => { ...@@ -52,7 +52,7 @@ describe('IDE commit form', () => {
vm.$store.state.stagedFiles.push('test'); vm.$store.state.stagedFiles.push('test');
vm.$nextTick(() => { vm.$nextTick(() => {
expect(vm.$el.querySelector('p').textContent).toContain('1 staged and 1 unstaged changes'); expect(vm.$el.querySelector('p').textContent).toContain('1 changed file');
done(); done();
}); });
}); });
......
...@@ -41,30 +41,20 @@ describe('IDE extra file row component', () => { ...@@ -41,30 +41,20 @@ describe('IDE extra file row component', () => {
describe('folderChangesTooltip', () => { describe('folderChangesTooltip', () => {
it('returns undefined when changes count is 0', () => { it('returns undefined when changes count is 0', () => {
expect(vm.folderChangesTooltip).toBe(undefined); changesCount = 0;
});
it('returns unstaged changes text', () => {
changesCount = 1;
unstagedFilesCount = 1;
expect(vm.folderChangesTooltip).toBe('1 unstaged change');
});
it('returns staged changes text', () => { expect(vm.folderChangesTooltip).toBe(undefined);
changesCount = 1;
stagedFilesCount = 1;
expect(vm.folderChangesTooltip).toBe('1 staged change');
}); });
it('returns staged and unstaged changes text', () => { [{ input: 1, output: '1 changed file' }, { input: 2, output: '2 changed files' }].forEach(
changesCount = 1; ({ input, output }) => {
stagedFilesCount = 1; it('returns changed files count if changes count is not 0', () => {
unstagedFilesCount = 1; changesCount = input;
expect(vm.folderChangesTooltip).toBe('1 staged and 1 unstaged changes'); expect(vm.folderChangesTooltip).toBe(output);
}); });
},
);
}); });
describe('show tree changes count', () => { describe('show tree changes count', () => {
......
...@@ -30,19 +30,13 @@ describe('RepoCommitSection', () => { ...@@ -30,19 +30,13 @@ describe('RepoCommitSection', () => {
const files = [file('file1'), file('file2')].map(f => const files = [file('file1'), file('file2')].map(f =>
Object.assign(f, { Object.assign(f, {
type: 'blob', type: 'blob',
content: 'orginal content',
}), }),
); );
vm.$store.state.rightPanelCollapsed = false; vm.$store.state.rightPanelCollapsed = false;
vm.$store.state.currentBranch = 'master'; vm.$store.state.currentBranch = 'master';
vm.$store.state.changedFiles = [...files]; vm.$store.state.changedFiles = [];
vm.$store.state.changedFiles.forEach(f =>
Object.assign(f, {
changed: true,
content: 'changedFile testing',
}),
);
vm.$store.state.stagedFiles = [{ ...files[0] }, { ...files[1] }]; vm.$store.state.stagedFiles = [{ ...files[0] }, { ...files[1] }];
vm.$store.state.stagedFiles.forEach(f => vm.$store.state.stagedFiles.forEach(f =>
Object.assign(f, { Object.assign(f, {
...@@ -51,7 +45,7 @@ describe('RepoCommitSection', () => { ...@@ -51,7 +45,7 @@ describe('RepoCommitSection', () => {
}), }),
); );
vm.$store.state.changedFiles.forEach(f => { files.forEach(f => {
vm.$store.state.entries[f.path] = f; vm.$store.state.entries[f.path] = f;
}); });
...@@ -96,7 +90,7 @@ describe('RepoCommitSection', () => { ...@@ -96,7 +90,7 @@ describe('RepoCommitSection', () => {
const changedFileElements = [...vm.$el.querySelectorAll('.multi-file-commit-list > li')]; const changedFileElements = [...vm.$el.querySelectorAll('.multi-file-commit-list > li')];
const allFiles = vm.$store.state.changedFiles.concat(vm.$store.state.stagedFiles); const allFiles = vm.$store.state.changedFiles.concat(vm.$store.state.stagedFiles);
expect(changedFileElements.length).toEqual(4); expect(changedFileElements).toHaveLength(2);
changedFileElements.forEach((changedFile, i) => { changedFileElements.forEach((changedFile, i) => {
expect(changedFile.textContent.trim()).toContain(allFiles[i].path); expect(changedFile.textContent.trim()).toContain(allFiles[i].path);
......
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