diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-03-10 21:09:21 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-03-10 21:09:21 +0000 |
commit | 06bb4eba7828ce59fde366734828458c037059b4 (patch) | |
tree | 44b95a53123d91684cc1c67716ef87cc1c0964fb /spec | |
parent | 219eead23f9feb5da9ec378c451d773aea2dfe61 (diff) | |
download | gitlab-ce-06bb4eba7828ce59fde366734828458c037059b4.tar.gz |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec')
-rw-r--r-- | spec/controllers/dashboard/projects_controller_spec.rb | 51 | ||||
-rw-r--r-- | spec/frontend/confirm_modal_spec.js | 7 | ||||
-rw-r--r-- | spec/frontend/vue_shared/components/confirm_modal_spec.js | 80 |
3 files changed, 101 insertions, 37 deletions
diff --git a/spec/controllers/dashboard/projects_controller_spec.rb b/spec/controllers/dashboard/projects_controller_spec.rb index a13b56deb23..7ae31fc67aa 100644 --- a/spec/controllers/dashboard/projects_controller_spec.rb +++ b/spec/controllers/dashboard/projects_controller_spec.rb @@ -86,11 +86,58 @@ describe Dashboard::ProjectsController do end describe 'GET /starred.json' do + subject { get :starred, format: :json } + + let(:projects) { create_list(:project, 2, creator: user) } + before do - get :starred, format: :json + allow(Kaminari.config).to receive(:default_per_page).and_return(1) + + projects.each do |project| + project.add_developer(user) + create(:users_star_project, project_id: project.id, user_id: user.id) + end end - it { is_expected.to respond_with(:success) } + it 'returns success' do + subject + + expect(response).to have_gitlab_http_status(:ok) + end + + it 'paginates the records' do + subject + + expect(assigns(:projects).count).to eq(1) + end + end + end + + context 'atom requests' do + let(:user) { create(:user) } + + before do + sign_in(user) + end + + describe '#index' do + context 'project pagination' do + let(:projects) { create_list(:project, 2, creator: user) } + + before do + allow(Kaminari.config).to receive(:default_per_page).and_return(1) + + projects.each do |project| + project.add_developer(user) + end + end + + it 'does not paginate projects, even if page number is passed' do + get :index, format: :atom + + expect(assigns(:events).count).to eq(2) + end + end end end end diff --git a/spec/frontend/confirm_modal_spec.js b/spec/frontend/confirm_modal_spec.js index f133cef675f..89cfc3ef3a3 100644 --- a/spec/frontend/confirm_modal_spec.js +++ b/spec/frontend/confirm_modal_spec.js @@ -8,7 +8,6 @@ describe('ConfirmModal', () => { path: `${TEST_HOST}/1`, method: 'delete', modalAttributes: { - modalId: 'geo-entry-removal-modal', title: 'Remove tracking database entry', message: 'Tracking database entry will be removed. Are you sure?', okVariant: 'danger', @@ -19,7 +18,6 @@ describe('ConfirmModal', () => { path: `${TEST_HOST}/1`, method: 'post', modalAttributes: { - modalId: 'geo-entry-removal-modal', title: 'Update tracking database entry', message: 'Tracking database entry will be updated. Are you sure?', okVariant: 'success', @@ -53,6 +51,7 @@ describe('ConfirmModal', () => { const findModalOkButton = (modal, variant) => modal.querySelector(`.modal-footer .btn-${variant}`); const findModalCancelButton = modal => modal.querySelector('.modal-footer .btn-secondary'); + const modalIsHidden = () => findModal().getAttribute('aria-hidden') === 'true'; const serializeModal = (modal, buttonIndex) => { const { modalAttributes } = buttons[buttonIndex]; @@ -61,7 +60,6 @@ describe('ConfirmModal', () => { path: modal.querySelector('form').action, method: modal.querySelector('input[name="_method"]').value, modalAttributes: { - modalId: modal.id, title: modal.querySelector('.modal-title').innerHTML, message: modal.querySelector('.modal-body div').innerHTML, okVariant: [...findModalOkButton(modal, modalAttributes.okVariant).classList] @@ -92,6 +90,7 @@ describe('ConfirmModal', () => { describe('GlModal', () => { it('is rendered', () => { expect(findModal()).toExist(); + expect(modalIsHidden()).toBe(false); }); describe('Cancel Button', () => { @@ -102,7 +101,7 @@ describe('ConfirmModal', () => { }); it('closes the modal', () => { - expect(findModal()).not.toExist(); + expect(modalIsHidden()).toBe(true); }); }); }); diff --git a/spec/frontend/vue_shared/components/confirm_modal_spec.js b/spec/frontend/vue_shared/components/confirm_modal_spec.js index d3dea73e4a6..7bccd6f1a64 100644 --- a/spec/frontend/vue_shared/components/confirm_modal_spec.js +++ b/spec/frontend/vue_shared/components/confirm_modal_spec.js @@ -6,11 +6,10 @@ import ConfirmModal from '~/vue_shared/components/confirm_modal.vue'; jest.mock('~/lib/utils/csrf', () => ({ token: 'test-csrf-token' })); describe('vue_shared/components/confirm_modal', () => { - const testModalProps = { + const MOCK_MODAL_DATA = { path: `${TEST_HOST}/1`, method: 'delete', modalAttributes: { - modalId: 'test-confirm-modal', title: 'Are you sure?', message: 'This will remove item 1', okVariant: 'danger', @@ -18,8 +17,13 @@ describe('vue_shared/components/confirm_modal', () => { }, }; + const defaultProps = { + selector: '.test-button', + }; + const actionSpies = { openModal: jest.fn(), + closeModal: jest.fn(), }; let wrapper; @@ -27,7 +31,7 @@ describe('vue_shared/components/confirm_modal', () => { const createComponent = (props = {}) => { wrapper = shallowMount(ConfirmModal, { propsData: { - ...testModalProps, + ...defaultProps, ...props, }, methods: { @@ -48,28 +52,18 @@ describe('vue_shared/components/confirm_modal', () => { .wrappers.map(x => ({ name: x.attributes('name'), value: x.attributes('value') })); describe('template', () => { - describe('when showModal is false', () => { + describe('when modal data is set', () => { beforeEach(() => { createComponent(); + wrapper.vm.modalAttributes = MOCK_MODAL_DATA.modalAttributes; }); - it('does not render GlModal', () => { - expect(findModal().exists()).toBeFalsy(); - }); - }); - - describe('when showModal is true', () => { - beforeEach(() => { - createComponent({ showModal: true }); - }); - - it('renders GlModal', () => { + it('renders GlModal wtih data', () => { expect(findModal().exists()).toBeTruthy(); expect(findModal().attributes()).toEqual( expect.objectContaining({ - modalid: testModalProps.modalAttributes.modalId, - oktitle: testModalProps.modalAttributes.okTitle, - okvariant: testModalProps.modalAttributes.okVariant, + oktitle: MOCK_MODAL_DATA.modalAttributes.okTitle, + okvariant: MOCK_MODAL_DATA.modalAttributes.okVariant, }), ); }); @@ -77,25 +71,49 @@ describe('vue_shared/components/confirm_modal', () => { }); describe('methods', () => { - beforeEach(() => { - createComponent({ showModal: true }); - }); + describe('submitModal', () => { + beforeEach(() => { + createComponent(); + wrapper.vm.path = MOCK_MODAL_DATA.path; + wrapper.vm.method = MOCK_MODAL_DATA.method; + }); + + it('does not submit form', () => { + expect(findForm().element.submit).not.toHaveBeenCalled(); + }); + + describe('when modal submitted', () => { + beforeEach(() => { + findModal().vm.$emit('primary'); + }); - it('does not submit form', () => { - expect(findForm().element.submit).not.toHaveBeenCalled(); + it('submits form', () => { + expect(findFormData()).toEqual([ + { name: '_method', value: MOCK_MODAL_DATA.method }, + { name: 'authenticity_token', value: 'test-csrf-token' }, + ]); + expect(findForm().element.submit).toHaveBeenCalled(); + }); + }); }); - describe('when modal submitted', () => { + describe('closeModal', () => { beforeEach(() => { - findModal().vm.$emit('primary'); + createComponent(); }); - it('submits form', () => { - expect(findFormData()).toEqual([ - { name: '_method', value: testModalProps.method }, - { name: 'authenticity_token', value: 'test-csrf-token' }, - ]); - expect(findForm().element.submit).toHaveBeenCalled(); + it('does not close modal', () => { + expect(actionSpies.closeModal).not.toHaveBeenCalled(); + }); + + describe('when modal closed', () => { + beforeEach(() => { + findModal().vm.$emit('cancel'); + }); + + it('closes modal', () => { + expect(actionSpies.closeModal).toHaveBeenCalled(); + }); }); }); }); |