Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-03-09 09:09:55 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-03-09 09:09:55 +0300
commit0221116862ee66024a03492b4fbbe4e069d84303 (patch)
treee0f46cc3c30534ab731af27c574183b1e222fd0e /spec/javascripts
parentce130e211808c9b02116f30af4a043f1a4d3a717 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/javascripts')
-rw-r--r--spec/javascripts/diffs/components/commit_item_spec.js168
1 files changed, 0 insertions, 168 deletions
diff --git a/spec/javascripts/diffs/components/commit_item_spec.js b/spec/javascripts/diffs/components/commit_item_spec.js
deleted file mode 100644
index 9fe31a5e727..00000000000
--- a/spec/javascripts/diffs/components/commit_item_spec.js
+++ /dev/null
@@ -1,168 +0,0 @@
-import Vue from 'vue';
-import { TEST_HOST } from 'spec/test_constants';
-import mountComponent from 'spec/helpers/vue_mount_component_helper';
-import { trimText } from 'spec/helpers/text_helper';
-import { getTimeago } from '~/lib/utils/datetime_utility';
-import CommitItem from '~/diffs/components/commit_item.vue';
-import getDiffWithCommit from '../mock_data/diff_with_commit';
-
-const TEST_AUTHOR_NAME = 'test';
-const TEST_AUTHOR_EMAIL = 'test+test@gitlab.com';
-const TEST_AUTHOR_GRAVATAR = `${TEST_HOST}/avatar/test?s=40`;
-const TEST_SIGNATURE_HTML = '<a>Legit commit</a>';
-const TEST_PIPELINE_STATUS_PATH = `${TEST_HOST}/pipeline/status`;
-
-const getTitleElement = vm => vm.$el.querySelector('.commit-row-message.item-title');
-const getDescElement = vm => vm.$el.querySelector('pre.commit-row-description');
-const getDescExpandElement = vm =>
- vm.$el.querySelector('.commit-content .text-expander.js-toggle-button');
-const getShaElement = vm => vm.$el.querySelector('.commit-sha-group');
-const getAvatarElement = vm => vm.$el.querySelector('.user-avatar-link');
-const getCommitterElement = vm => vm.$el.querySelector('.committer');
-const getCommitActionsElement = vm => vm.$el.querySelector('.commit-actions');
-
-describe('diffs/components/commit_item', () => {
- const Component = Vue.extend(CommitItem);
- const timeago = getTimeago();
- const { commit } = getDiffWithCommit();
-
- let vm;
-
- beforeEach(() => {
- vm = mountComponent(Component, {
- commit: getDiffWithCommit().commit,
- });
- });
-
- it('renders commit title', () => {
- const titleElement = getTitleElement(vm);
-
- expect(titleElement).toHaveAttr('href', commit.commit_url);
- expect(titleElement).toHaveText(commit.title_html);
- });
-
- // https://gitlab.com/gitlab-org/gitlab/issues/197139
- // eslint-disable-next-line jasmine/no-disabled-tests
- xit('renders commit description', () => {
- const descElement = getDescElement(vm);
- const descExpandElement = getDescExpandElement(vm);
-
- const expected = commit.description_html.replace(/&#x000A;/g, '');
-
- expect(trimText(descElement.innerHTML)).toEqual(trimText(expected));
- expect(descExpandElement).not.toBeNull();
- });
-
- it('renders commit sha', () => {
- const shaElement = getShaElement(vm);
- const labelElement = shaElement.querySelector('.label');
- const buttonElement = shaElement.querySelector('button');
-
- expect(labelElement.textContent).toEqual(commit.short_id);
- expect(buttonElement).toHaveData('clipboard-text', commit.id);
- });
-
- it('renders author avatar', () => {
- const avatarElement = getAvatarElement(vm);
- const imgElement = avatarElement.querySelector('img');
-
- expect(avatarElement).toHaveAttr('href', commit.author.web_url);
- expect(imgElement).toHaveClass('s40');
- expect(imgElement).toHaveAttr('alt', commit.author.name);
- expect(imgElement).toHaveAttr('src', commit.author.avatar_url);
- });
-
- it('renders committer text', () => {
- const committerElement = getCommitterElement(vm);
- const nameElement = committerElement.querySelector('a');
-
- const expectTimeText = timeago.format(commit.authored_date);
- const expectedText = `${commit.author.name} authored ${expectTimeText}`;
-
- expect(trimText(committerElement.textContent)).toEqual(expectedText);
- expect(nameElement).toHaveAttr('href', commit.author.web_url);
- expect(nameElement).toHaveText(commit.author.name);
- expect(nameElement).toHaveClass('js-user-link');
- expect(nameElement.dataset.userId).toEqual(commit.author.id.toString());
- });
-
- describe('without commit description', () => {
- beforeEach(done => {
- vm.commit.description_html = '';
-
- vm.$nextTick()
- .then(done)
- .catch(done.fail);
- });
-
- it('hides description', () => {
- const descElement = getDescElement(vm);
- const descExpandElement = getDescExpandElement(vm);
-
- expect(descElement).toBeNull();
- expect(descExpandElement).toBeNull();
- });
- });
-
- describe('with no matching user', () => {
- beforeEach(done => {
- vm.commit.author = null;
- vm.commit.author_email = TEST_AUTHOR_EMAIL;
- vm.commit.author_name = TEST_AUTHOR_NAME;
- vm.commit.author_gravatar_url = TEST_AUTHOR_GRAVATAR;
-
- vm.$nextTick()
- .then(done)
- .catch(done.fail);
- });
-
- it('renders author avatar', () => {
- const avatarElement = getAvatarElement(vm);
- const imgElement = avatarElement.querySelector('img');
-
- expect(avatarElement).toHaveAttr('href', `mailto:${TEST_AUTHOR_EMAIL}`);
- expect(imgElement).toHaveAttr('alt', TEST_AUTHOR_NAME);
- expect(imgElement).toHaveAttr('src', TEST_AUTHOR_GRAVATAR);
- });
-
- it('renders committer text', () => {
- const committerElement = getCommitterElement(vm);
- const nameElement = committerElement.querySelector('a');
-
- expect(nameElement).toHaveAttr('href', `mailto:${TEST_AUTHOR_EMAIL}`);
- expect(nameElement).toHaveText(TEST_AUTHOR_NAME);
- });
- });
-
- describe('with signature', () => {
- beforeEach(done => {
- vm.commit.signature_html = TEST_SIGNATURE_HTML;
-
- vm.$nextTick()
- .then(done)
- .catch(done.fail);
- });
-
- it('renders signature html', () => {
- const actionsElement = getCommitActionsElement(vm);
-
- expect(actionsElement).toContainHtml(TEST_SIGNATURE_HTML);
- });
- });
-
- describe('with pipeline status', () => {
- beforeEach(done => {
- vm.commit.pipeline_status_path = TEST_PIPELINE_STATUS_PATH;
-
- vm.$nextTick()
- .then(done)
- .catch(done.fail);
- });
-
- it('renders pipeline status', () => {
- const actionsElement = getCommitActionsElement(vm);
-
- expect(actionsElement).toContainElement('.ci-status-link');
- });
- });
-});