debian-mirror-gitlab/spec/frontend/repository/log_tree_spec.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

142 lines
4.2 KiB
JavaScript
Raw Normal View History

2019-09-30 21:07:59 +05:30
import MockAdapter from 'axios-mock-adapter';
2021-09-30 23:02:18 +05:30
import { createMockClient } from 'helpers/mock_apollo_helper';
2019-09-30 21:07:59 +05:30
import axios from '~/lib/utils/axios_utils';
2023-04-23 21:23:45 +05:30
import { HTTP_STATUS_OK } from '~/lib/utils/http_status';
2019-12-26 22:10:19 +05:30
import { resolveCommit, fetchLogsTree } from '~/repository/log_tree';
2021-09-30 23:02:18 +05:30
import commitsQuery from '~/repository/queries/commits.query.graphql';
import projectPathQuery from '~/repository/queries/project_path.query.graphql';
import refQuery from '~/repository/queries/ref.query.graphql';
2019-09-30 21:07:59 +05:30
const mockData = [
{
commit: {
id: '123',
message: 'testing message',
committed_date: '2019-01-01',
},
commit_path: `https://test.com`,
2021-09-30 23:02:18 +05:30
commit_title_html: 'commit title',
2019-09-30 21:07:59 +05:30
file_name: 'index.js',
},
];
describe('resolveCommit', () => {
it('calls resolve when commit found', () => {
const resolver = {
2022-08-13 15:12:31 +05:30
entry: { name: 'index.js' },
2019-09-30 21:07:59 +05:30
resolve: jest.fn(),
};
2020-01-01 13:55:28 +05:30
const commits = [
2022-08-13 15:12:31 +05:30
{ fileName: 'index.js', filePath: '/index.js' },
{ fileName: 'index.js', filePath: '/app/assets/index.js' },
2020-01-01 13:55:28 +05:30
];
2022-10-11 01:57:18 +05:30
resolveCommit(commits, '/', resolver);
2020-01-01 13:55:28 +05:30
expect(resolver.resolve).toHaveBeenCalledWith({
fileName: 'index.js',
filePath: '/index.js',
});
2019-09-30 21:07:59 +05:30
});
});
describe('fetchLogsTree', () => {
let mock;
let client;
let resolver;
beforeEach(() => {
mock = new MockAdapter(axios);
2023-04-23 21:23:45 +05:30
mock.onGet(/(.*)/).reply(HTTP_STATUS_OK, mockData, {});
2019-09-30 21:07:59 +05:30
jest.spyOn(axios, 'get');
2019-12-26 22:10:19 +05:30
global.gon = { relative_url_root: '' };
2019-09-30 21:07:59 +05:30
resolver = {
2022-08-13 15:12:31 +05:30
entry: { name: 'index.js' },
2019-09-30 21:07:59 +05:30
resolve: jest.fn(),
};
2021-09-30 23:02:18 +05:30
client = createMockClient();
client.writeQuery({ query: projectPathQuery, data: { projectPath: 'gitlab-org/gitlab-foss' } });
client.writeQuery({ query: refQuery, data: { ref: 'main', escapedRef: 'main' } });
client.writeQuery({ query: commitsQuery, data: { commits: [] } });
2019-09-30 21:07:59 +05:30
});
afterEach(() => {
mock.restore();
});
2021-09-04 01:27:46 +05:30
it('persists the offset for a given page if offset is larger than maximum offset', async () => {
await fetchLogsTree(client, 'path', '1000', resolver, 900).then(() => {});
await fetchLogsTree(client, 'path', '1100', resolver, 1200).then(() => {
expect(axios.get).toHaveBeenCalledWith('/gitlab-org/gitlab-foss/-/refs/main/logs_tree/path', {
params: { format: 'json', offset: 975 },
});
});
});
it('does not call axios get if offset is larger than the maximum offset', () =>
fetchLogsTree(client, '', '1000', resolver, 900).then(() => {
expect(axios.get).not.toHaveBeenCalled();
}));
2019-09-30 21:07:59 +05:30
it('calls axios get', () =>
fetchLogsTree(client, '', '0', resolver).then(() => {
2021-06-08 01:23:25 +05:30
expect(axios.get).toHaveBeenCalledWith('/gitlab-org/gitlab-foss/-/refs/main/logs_tree/', {
2019-12-26 22:10:19 +05:30
params: { format: 'json', offset: '0' },
});
2019-09-30 21:07:59 +05:30
}));
it('calls axios get once', () =>
Promise.all([
fetchLogsTree(client, '', '0', resolver),
fetchLogsTree(client, '', '0', resolver),
]).then(() => {
expect(axios.get.mock.calls.length).toEqual(1);
}));
2021-01-03 14:25:43 +05:30
it('calls axios for each path', () =>
Promise.all([
fetchLogsTree(client, '', '0', resolver),
fetchLogsTree(client, '/test', '0', resolver),
]).then(() => {
expect(axios.get.mock.calls.length).toEqual(2);
}));
2019-09-30 21:07:59 +05:30
it('calls entry resolver', () =>
2022-10-11 01:57:18 +05:30
fetchLogsTree(client, 'test', '0', resolver).then(() => {
2020-05-05 14:28:15 +05:30
expect(resolver.resolve).toHaveBeenCalledWith(
expect.objectContaining({
__typename: 'LogTreeCommit',
commitPath: 'https://test.com',
committedDate: '2019-01-01',
fileName: 'index.js',
2022-10-11 01:57:18 +05:30
filePath: 'test/index.js',
2020-05-05 14:28:15 +05:30
message: 'testing message',
sha: '123',
}),
);
2019-09-30 21:07:59 +05:30
}));
2020-11-24 15:15:51 +05:30
it('writes query to client', async () => {
2022-10-11 01:57:18 +05:30
await fetchLogsTree(client, '/', '0', resolver);
2021-09-30 23:02:18 +05:30
expect(client.readQuery({ query: commitsQuery })).toEqual({
commits: [
expect.objectContaining({
commitPath: 'https://test.com',
committedDate: '2019-01-01',
fileName: 'index.js',
filePath: '/index.js',
message: 'testing message',
sha: '123',
titleHtml: 'commit title',
}),
],
2020-11-24 15:15:51 +05:30
});
});
2019-09-30 21:07:59 +05:30
});