Commit 5fe5117a authored by Lukas 'Eipi' Eipert's avatar Lukas 'Eipi' Eipert Committed by Vitaly Slobodin

Remove capybara specs relying on jQuery.ajax

We had some capybara specs that checked whether expanding a diff calls
the Backend more than once. These specs have been broken since we are
using axios. Unfortunately as they are testing a negative, they never
failed.

We are removing those specs in favor of new JS unit tests which actually
test that the API is called exactly once.
parent 411b8819
...@@ -73,7 +73,7 @@ export default class SingleFileDiff { ...@@ -73,7 +73,7 @@ export default class SingleFileDiff {
this.collapsedContent.hide(); this.collapsedContent.hide();
this.loadingContent.show(); this.loadingContent.show();
axios return axios
.get(this.diffForPath) .get(this.diffForPath)
.then(({ data }) => { .then(({ data }) => {
this.loadingContent.hide(); this.loadingContent.hide();
......
...@@ -17,7 +17,6 @@ RSpec.describe 'Expand and collapse diffs', :js do ...@@ -17,7 +17,6 @@ RSpec.describe 'Expand and collapse diffs', :js do
# Ensure that undiffable.md is in .gitattributes # Ensure that undiffable.md is in .gitattributes
project.repository.copy_gitattributes(branch) project.repository.copy_gitattributes(branch)
visit project_commit_path(project, project.commit(branch)) visit project_commit_path(project, project.commit(branch))
execute_script('window.ajaxUris = []; $(document).ajaxSend(function(event, xhr, settings) { ajaxUris.push(settings.url) });')
end end
def file_container(filename) def file_container(filename)
...@@ -191,10 +190,6 @@ RSpec.describe 'Expand and collapse diffs', :js do ...@@ -191,10 +190,6 @@ RSpec.describe 'Expand and collapse diffs', :js do
expect(small_diff).to have_selector('.code') expect(small_diff).to have_selector('.code')
expect(small_diff).not_to have_selector('.nothing-here-block') expect(small_diff).not_to have_selector('.nothing-here-block')
end end
it 'does not make a new HTTP request' do
expect(evaluate_script('ajaxUris')).not_to include(a_string_matching('small_diff.md'))
end
end end
end end
...@@ -264,7 +259,6 @@ RSpec.describe 'Expand and collapse diffs', :js do ...@@ -264,7 +259,6 @@ RSpec.describe 'Expand and collapse diffs', :js do
find('.note-textarea') find('.note-textarea')
wait_for_requests wait_for_requests
execute_script('window.ajaxUris = []; $(document).ajaxSend(function(event, xhr, settings) { ajaxUris.push(settings.url) });')
end end
it 'reloads the page with all diffs expanded' do it 'reloads the page with all diffs expanded' do
...@@ -300,10 +294,6 @@ RSpec.describe 'Expand and collapse diffs', :js do ...@@ -300,10 +294,6 @@ RSpec.describe 'Expand and collapse diffs', :js do
expect(small_diff).to have_selector('.code') expect(small_diff).to have_selector('.code')
expect(small_diff).not_to have_selector('.nothing-here-block') expect(small_diff).not_to have_selector('.nothing-here-block')
end end
it 'does not make a new HTTP request' do
expect(evaluate_script('ajaxUris')).not_to include(a_string_matching('small_diff.md'))
end
end end
end end
end end
......
import MockAdapter from 'axios-mock-adapter';
import $ from 'jquery';
import { setHTMLFixture } from 'helpers/fixtures';
import axios from '~/lib/utils/axios_utils';
import SingleFileDiff from '~/single_file_diff';
describe('SingleFileDiff', () => {
let mock = new MockAdapter(axios);
const blobDiffPath = '/mock-path';
beforeEach(() => {
mock = new MockAdapter(axios);
mock.onGet(blobDiffPath).replyOnce(200, { html: `<div class="diff-content">MOCKED</div>` });
});
afterEach(() => {
mock.restore();
});
it('loads diff via axios exactly once for collapsed diffs', async () => {
setHTMLFixture(`
<div class="diff-file">
<div class="js-file-title">
MOCK TITLE
</div>
<div class="diff-content">
<div class="diff-viewer" data-type="simple">
<div
class="nothing-here-block diff-collapsed"
data-diff-for-path="${blobDiffPath}"
>
MOCK CONTENT
</div>
</div>
</div>
</div>
`);
// Collapsed is the default state
const diff = new SingleFileDiff(document.querySelector('.diff-file'));
expect(diff.isOpen).toBe(false);
expect(diff.content).toBeNull();
expect(diff.diffForPath).toEqual(blobDiffPath);
// Opening for the first time
await diff.toggleDiff($(document.querySelector('.js-file-title')));
expect(diff.isOpen).toBe(true);
expect(diff.content).not.toBeNull();
// Collapsing again
await diff.toggleDiff($(document.querySelector('.js-file-title')));
expect(diff.isOpen).toBe(false);
expect(diff.content).not.toBeNull();
mock.onGet(blobDiffPath).replyOnce(400, '');
// Opening again
await diff.toggleDiff($(document.querySelector('.js-file-title')));
expect(diff.isOpen).toBe(true);
expect(diff.content).not.toBeNull();
expect(mock.history.get.length).toBe(1);
});
it('does not load diffs via axios for already expanded diffs', async () => {
setHTMLFixture(`
<div class="diff-file">
<div class="js-file-title">
MOCK TITLE
</div>
<div class="diff-content">
EXPANDED MOCK CONTENT
</div>
</div>
`);
// Opened is the default state
const diff = new SingleFileDiff(document.querySelector('.diff-file'));
expect(diff.isOpen).toBe(true);
expect(diff.content).not.toBeNull();
expect(diff.diffForPath).toEqual(undefined);
// Collapsing for the first time
await diff.toggleDiff($(document.querySelector('.js-file-title')));
expect(diff.isOpen).toBe(false);
expect(diff.content).not.toBeNull();
// Opening again
await diff.toggleDiff($(document.querySelector('.js-file-title')));
expect(diff.isOpen).toBe(true);
expect(mock.history.get.length).toBe(0);
});
});
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