2019-06-25 10:26:55 -04:00
|
|
|
import MockAdapter from 'axios-mock-adapter';
|
2021-07-13 20:09:11 -04:00
|
|
|
import { createMockClient } from 'helpers/mock_apollo_helper';
|
2019-06-25 10:26:55 -04:00
|
|
|
import axios from '~/lib/utils/axios_utils';
|
2019-11-15 13:06:24 -05:00
|
|
|
import { resolveCommit, fetchLogsTree } from '~/repository/log_tree';
|
2021-07-13 20:09:11 -04:00
|
|
|
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-06-25 10:26:55 -04:00
|
|
|
|
|
|
|
const mockData = [
|
|
|
|
{
|
|
|
|
commit: {
|
|
|
|
id: '123',
|
|
|
|
message: 'testing message',
|
|
|
|
committed_date: '2019-01-01',
|
|
|
|
},
|
|
|
|
commit_path: `https://test.com`,
|
2021-07-13 20:09:11 -04:00
|
|
|
commit_title_html: 'commit title',
|
2019-06-25 10:26:55 -04:00
|
|
|
file_name: 'index.js',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
describe('resolveCommit', () => {
|
|
|
|
it('calls resolve when commit found', () => {
|
|
|
|
const resolver = {
|
2022-07-12 14:08:46 -04:00
|
|
|
entry: { name: 'index.js' },
|
2019-06-25 10:26:55 -04:00
|
|
|
resolve: jest.fn(),
|
|
|
|
};
|
2019-11-25 07:06:13 -05:00
|
|
|
const commits = [
|
2022-07-12 14:08:46 -04:00
|
|
|
{ fileName: 'index.js', filePath: '/index.js' },
|
|
|
|
{ fileName: 'index.js', filePath: '/app/assets/index.js' },
|
2019-11-25 07:06:13 -05:00
|
|
|
];
|
|
|
|
|
2022-09-14 14:12:48 -04:00
|
|
|
resolveCommit(commits, '/', resolver);
|
2019-11-25 07:06:13 -05:00
|
|
|
|
|
|
|
expect(resolver.resolve).toHaveBeenCalledWith({
|
|
|
|
fileName: 'index.js',
|
|
|
|
filePath: '/index.js',
|
|
|
|
});
|
2019-06-25 10:26:55 -04:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('fetchLogsTree', () => {
|
|
|
|
let mock;
|
|
|
|
let client;
|
|
|
|
let resolver;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
mock = new MockAdapter(axios);
|
|
|
|
|
|
|
|
mock.onGet(/(.*)/).reply(200, mockData, {});
|
|
|
|
|
|
|
|
jest.spyOn(axios, 'get');
|
|
|
|
|
2019-11-18 13:06:53 -05:00
|
|
|
global.gon = { relative_url_root: '' };
|
2019-06-25 10:26:55 -04:00
|
|
|
|
|
|
|
resolver = {
|
2022-07-12 14:08:46 -04:00
|
|
|
entry: { name: 'index.js' },
|
2019-06-25 10:26:55 -04:00
|
|
|
resolve: jest.fn(),
|
|
|
|
};
|
2021-07-13 20:09:11 -04:00
|
|
|
|
|
|
|
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-06-25 10:26:55 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
mock.restore();
|
|
|
|
});
|
|
|
|
|
2021-06-14 08:10:13 -04:00
|
|
|
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 },
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-06-11 08:09:49 -04:00
|
|
|
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-06-25 10:26:55 -04:00
|
|
|
it('calls axios get', () =>
|
|
|
|
fetchLogsTree(client, '', '0', resolver).then(() => {
|
2021-04-21 08:09:16 -04:00
|
|
|
expect(axios.get).toHaveBeenCalledWith('/gitlab-org/gitlab-foss/-/refs/main/logs_tree/', {
|
2019-11-18 13:06:53 -05:00
|
|
|
params: { format: 'json', offset: '0' },
|
|
|
|
});
|
2019-06-25 10:26:55 -04:00
|
|
|
}));
|
|
|
|
|
|
|
|
it('calls axios get once', () =>
|
|
|
|
Promise.all([
|
|
|
|
fetchLogsTree(client, '', '0', resolver),
|
|
|
|
fetchLogsTree(client, '', '0', resolver),
|
|
|
|
]).then(() => {
|
|
|
|
expect(axios.get.mock.calls.length).toEqual(1);
|
|
|
|
}));
|
|
|
|
|
2020-09-22 11:09:37 -04:00
|
|
|
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-06-25 10:26:55 -04:00
|
|
|
it('calls entry resolver', () =>
|
2022-09-14 14:12:48 -04:00
|
|
|
fetchLogsTree(client, 'test', '0', resolver).then(() => {
|
2020-04-29 08:10:00 -04:00
|
|
|
expect(resolver.resolve).toHaveBeenCalledWith(
|
|
|
|
expect.objectContaining({
|
|
|
|
__typename: 'LogTreeCommit',
|
|
|
|
commitPath: 'https://test.com',
|
|
|
|
committedDate: '2019-01-01',
|
|
|
|
fileName: 'index.js',
|
2022-09-14 14:12:48 -04:00
|
|
|
filePath: 'test/index.js',
|
2020-04-29 08:10:00 -04:00
|
|
|
message: 'testing message',
|
|
|
|
sha: '123',
|
|
|
|
}),
|
|
|
|
);
|
2019-06-25 10:26:55 -04:00
|
|
|
}));
|
|
|
|
|
2020-09-08 11:08:41 -04:00
|
|
|
it('writes query to client', async () => {
|
2022-09-14 14:12:48 -04:00
|
|
|
await fetchLogsTree(client, '/', '0', resolver);
|
2021-07-13 20:09:11 -04:00
|
|
|
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-09-08 11:08:41 -04:00
|
|
|
});
|
|
|
|
});
|
2019-06-25 10:26:55 -04:00
|
|
|
});
|