import { GlButton } from '@gitlab/ui';
import { shallowMount, mount } from '@vue/test-utils';
import NoChanges from '~/diffs/components/no_changes.vue';
import store from '~/mr_notes/stores';
import diffsMockData from '../mock_data/merge_request_diffs';
jest.mock('~/mr_notes/stores', () => jest.requireActual('helpers/mocks/mr_notes/stores'));
const TEST_TARGET_BRANCH = 'foo';
const TEST_SOURCE_BRANCH = 'dev/update';
const latestVersionNumber = Math.max(...diffsMockData.map((version) => version.version_index));
describe('Diff no changes empty state', () => {
const createComponent = (mountFn = shallowMount) =>
mountFn(NoChanges, {
mocks: {
$store: store,
},
propsData: {
changesEmptyStateIllustration: '',
},
});
beforeEach(() => {
store.reset();
store.getters.getNoteableData = {
target_branch: TEST_TARGET_BRANCH,
source_branch: TEST_SOURCE_BRANCH,
};
store.getters['diffs/diffCompareDropdownSourceVersions'] = [];
store.getters['diffs/diffCompareDropdownTargetVersions'] = [];
});
const findMessage = (wrapper) => wrapper.find('[data-testid="no-changes-message"]');
it('prevents XSS', () => {
store.getters.getNoteableData = {
source_branch: '',
target_branch: '',
};
const wrapper = createComponent();
expect(wrapper.find('script').exists()).toBe(false);
});
describe('Renders', () => {
it('Show create commit button', () => {
const wrapper = createComponent();
expect(wrapper.findComponent(GlButton).exists()).toBe(true);
});
it.each`
expectedText | sourceIndex | targetIndex
${`No changes between ${TEST_SOURCE_BRANCH} and ${TEST_TARGET_BRANCH}`} | ${null} | ${null}
${`No changes between ${TEST_SOURCE_BRANCH} and version 1`} | ${diffsMockData[0].version_index} | ${1}
${`No changes between version 3 and version 2`} | ${3} | ${2}
${`No changes between version 3 and ${TEST_TARGET_BRANCH}`} | ${3} | ${-1}
`(
'renders text "$expectedText" (sourceIndex=$sourceIndex and targetIndex=$targetIndex)',
({ expectedText, targetIndex, sourceIndex }) => {
if (targetIndex !== null) {
store.getters['diffs/diffCompareDropdownTargetVersions'] = [
{
selected: true,
version_index: targetIndex,
versionName: `version ${targetIndex}`,
},
];
}
if (sourceIndex !== null) {
store.getters['diffs/diffCompareDropdownSourceVersions'] = [
{
isLatestVersion: sourceIndex === latestVersionNumber,
selected: true,
version_index: targetIndex,
versionName: `version ${sourceIndex}`,
},
];
}
const wrapper = createComponent(mount);
expect(findMessage(wrapper).text()).toBe(expectedText);
},
);
});
});