debian-mirror-gitlab/spec/frontend/api_spec.js

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

1745 lines
55 KiB
JavaScript
Raw Normal View History

2018-03-17 18:26:18 +05:30
import MockAdapter from 'axios-mock-adapter';
2022-01-26 12:08:38 +05:30
import Api, { DEFAULT_PER_PAGE } from '~/api';
2021-03-11 19:13:27 +05:30
import axios from '~/lib/utils/axios_utils';
2023-03-17 16:20:25 +05:30
import {
2023-03-04 22:38:38 +05:30
HTTP_STATUS_ACCEPTED,
HTTP_STATUS_CREATED,
2023-03-17 16:20:25 +05:30
HTTP_STATUS_INTERNAL_SERVER_ERROR,
2023-03-04 22:38:38 +05:30
HTTP_STATUS_NO_CONTENT,
2023-03-17 16:20:25 +05:30
HTTP_STATUS_NOT_FOUND,
HTTP_STATUS_OK,
2023-03-04 22:38:38 +05:30
} from '~/lib/utils/http_status';
2022-06-21 17:19:12 +05:30
jest.mock('~/flash');
2017-09-10 17:25:29 +05:30
describe('Api', () => {
const dummyApiVersion = 'v3000';
2019-07-31 22:56:46 +05:30
const dummyUrlRoot = '/gitlab';
2017-09-10 17:25:29 +05:30
const dummyGon = {
api_version: dummyApiVersion,
relative_url_root: dummyUrlRoot,
};
let originalGon;
2018-03-17 18:26:18 +05:30
let mock;
2017-09-10 17:25:29 +05:30
beforeEach(() => {
2018-03-17 18:26:18 +05:30
mock = new MockAdapter(axios);
2017-09-10 17:25:29 +05:30
originalGon = window.gon;
2020-05-24 23:13:21 +05:30
window.gon = { ...dummyGon };
2017-09-10 17:25:29 +05:30
});
afterEach(() => {
2018-03-17 18:26:18 +05:30
mock.restore();
2017-09-10 17:25:29 +05:30
window.gon = originalGon;
});
describe('buildUrl', () => {
it('adds URL root and fills in API version', () => {
const input = '/api/:version/foo/bar';
const expectedOutput = `${dummyUrlRoot}/api/${dummyApiVersion}/foo/bar`;
const builtUrl = Api.buildUrl(input);
expect(builtUrl).toEqual(expectedOutput);
});
2019-07-31 22:56:46 +05:30
2021-03-08 18:12:59 +05:30
[null, '', '/'].forEach((root) => {
2019-07-31 22:56:46 +05:30
it(`works when relative_url_root is ${root}`, () => {
window.gon.relative_url_root = root;
const input = '/api/:version/foo/bar';
const expectedOutput = `/api/${dummyApiVersion}/foo/bar`;
const builtUrl = Api.buildUrl(input);
expect(builtUrl).toEqual(expectedOutput);
});
});
2017-09-10 17:25:29 +05:30
});
2020-07-28 23:09:34 +05:30
describe('packages', () => {
const projectId = 'project_a';
const packageId = 'package_b';
const apiResponse = [{ id: 1, name: 'foo' }];
describe('groupPackages', () => {
const groupId = 'group_a';
it('fetch all group packages', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/packages`;
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, apiResponse);
2020-07-28 23:09:34 +05:30
return Api.groupPackages(groupId).then(({ data }) => {
expect(data).toEqual(apiResponse);
expect(axios.get).toHaveBeenCalledWith(expectedUrl, {});
});
});
});
describe('projectPackages', () => {
it('fetch all project packages', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/packages`;
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, apiResponse);
2020-07-28 23:09:34 +05:30
return Api.projectPackages(projectId).then(({ data }) => {
expect(data).toEqual(apiResponse);
expect(axios.get).toHaveBeenCalledWith(expectedUrl, {});
});
});
});
describe('buildProjectPackageUrl', () => {
it('returns the right url', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/packages/${packageId}`;
const url = Api.buildProjectPackageUrl(projectId, packageId);
expect(url).toEqual(expectedUrl);
});
});
describe('projectPackage', () => {
it('fetch package details', () => {
const expectedUrl = `foo`;
jest.spyOn(Api, 'buildProjectPackageUrl').mockReturnValue(expectedUrl);
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, apiResponse);
2020-07-28 23:09:34 +05:30
return Api.projectPackage(projectId, packageId).then(({ data }) => {
expect(data).toEqual(apiResponse);
expect(axios.get).toHaveBeenCalledWith(expectedUrl);
});
});
});
describe('deleteProjectPackage', () => {
it('delete a package', () => {
const expectedUrl = `foo`;
jest.spyOn(Api, 'buildProjectPackageUrl').mockReturnValue(expectedUrl);
jest.spyOn(axios, 'delete');
2023-03-17 16:20:25 +05:30
mock.onDelete(expectedUrl).replyOnce(HTTP_STATUS_OK, true);
2020-07-28 23:09:34 +05:30
return Api.deleteProjectPackage(projectId, packageId).then(({ data }) => {
expect(data).toEqual(true);
expect(axios.delete).toHaveBeenCalledWith(expectedUrl);
});
});
});
2021-09-04 01:27:46 +05:30
describe('deleteProjectPackageFile', () => {
const packageFileId = 'package_file_id';
it('delete a package', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/packages/${packageId}/package_files/${packageFileId}`;
jest.spyOn(axios, 'delete');
2023-03-17 16:20:25 +05:30
mock.onDelete(expectedUrl).replyOnce(HTTP_STATUS_OK, true);
2021-09-04 01:27:46 +05:30
return Api.deleteProjectPackageFile(projectId, packageId, packageFileId).then(
({ data }) => {
expect(data).toEqual(true);
expect(axios.delete).toHaveBeenCalledWith(expectedUrl);
},
);
});
});
2020-07-28 23:09:34 +05:30
});
2021-01-29 00:20:46 +05:30
describe('container registry', () => {
describe('containerRegistryDetails', () => {
it('fetch container registry details', async () => {
const expectedUrl = `foo`;
const apiResponse = {};
jest.spyOn(axios, 'get');
jest.spyOn(Api, 'buildUrl').mockReturnValueOnce(expectedUrl);
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, apiResponse);
2021-01-29 00:20:46 +05:30
const { data } = await Api.containerRegistryDetails(1);
expect(data).toEqual(apiResponse);
expect(axios.get).toHaveBeenCalledWith(expectedUrl, {});
});
});
});
2017-09-10 17:25:29 +05:30
describe('group', () => {
2022-06-21 17:19:12 +05:30
it('fetches a group', () => {
2017-09-10 17:25:29 +05:30
const groupId = '123456';
2018-03-17 18:26:18 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2018-03-17 18:26:18 +05:30
name: 'test',
2017-09-10 17:25:29 +05:30
});
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.group(groupId, (response) => {
expect(response.name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
});
2019-03-02 22:35:43 +05:30
describe('groupMembers', () => {
2022-06-21 17:19:12 +05:30
it('fetches group members', () => {
2019-03-02 22:35:43 +05:30
const groupId = '54321';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/members`;
const expectedData = [{ id: 7 }];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, expectedData);
2019-03-02 22:35:43 +05:30
2022-06-21 17:19:12 +05:30
return Api.groupMembers(groupId).then(({ data }) => {
expect(data).toEqual(expectedData);
2021-03-08 18:12:59 +05:30
});
});
});
2022-06-21 17:19:12 +05:30
describe('inviteGroupMembers', () => {
2021-03-08 18:12:59 +05:30
it('invites a new email address to create a new User and become a Group Member', () => {
const groupId = 1;
const email = 'email@example.com';
2022-06-21 17:19:12 +05:30
const userId = '1';
2021-03-08 18:12:59 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/1/invitations`;
const params = {
email,
2022-06-21 17:19:12 +05:30
userId,
2021-03-08 18:12:59 +05:30
access_level: 10,
expires_at: undefined,
};
mock.onPost(expectedUrl).reply(200, {
status: 'success',
});
2022-06-21 17:19:12 +05:30
return Api.inviteGroupMembers(groupId, params).then(({ data }) => {
2021-03-08 18:12:59 +05:30
expect(data.status).toBe('success');
});
});
});
2020-10-24 23:57:45 +05:30
describe('groupMilestones', () => {
2022-06-21 17:19:12 +05:30
it('fetches group milestones', () => {
2020-10-24 23:57:45 +05:30
const groupId = '16';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/milestones`;
const expectedData = [
{
id: 12,
iid: 3,
group_id: 16,
title: '10.0',
description: 'Version',
due_date: '2013-11-29',
start_date: '2013-11-10',
state: 'active',
updated_at: '2013-10-02T09:24:18Z',
created_at: '2013-10-02T09:24:18Z',
web_url: 'https://gitlab.com/groups/gitlab-org/-/milestones/42',
},
];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, expectedData);
2020-10-24 23:57:45 +05:30
2022-06-21 17:19:12 +05:30
return Api.groupMilestones(groupId).then(({ data }) => {
expect(data).toEqual(expectedData);
});
2020-10-24 23:57:45 +05:30
});
});
2017-09-10 17:25:29 +05:30
describe('groups', () => {
2022-06-21 17:19:12 +05:30
it('fetches groups', () => {
2017-09-10 17:25:29 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups.json`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.groups(query, options, (response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
});
2021-03-11 19:13:27 +05:30
describe('groupLabels', () => {
2022-06-21 17:19:12 +05:30
it('fetches group labels', () => {
2021-03-11 19:13:27 +05:30
const options = { params: { search: 'foo' } };
const expectedGroup = 'gitlab-org';
2021-04-29 21:17:54 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${expectedGroup}/labels`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2021-03-11 19:13:27 +05:30
{
id: 1,
2021-04-29 21:17:54 +05:30
name: 'Foo Label',
2021-03-11 19:13:27 +05:30
},
]);
2022-06-21 17:19:12 +05:30
return Api.groupLabels(expectedGroup, options).then((res) => {
expect(res.length).toBe(1);
expect(res[0].name).toBe('Foo Label');
});
2021-03-11 19:13:27 +05:30
});
});
2017-09-10 17:25:29 +05:30
describe('namespaces', () => {
2022-06-21 17:19:12 +05:30
it('fetches namespaces', () => {
2017-09-10 17:25:29 +05:30
const query = 'dummy query';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/namespaces.json`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.namespaces(query, (response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
});
describe('projects', () => {
2022-06-21 17:19:12 +05:30
it('fetches projects with membership when logged in', () => {
2017-09-10 17:25:29 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
2018-03-17 18:26:18 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects.json`;
window.gon.current_user_id = 1;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2018-03-17 18:26:18 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.projects(query, options, (response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
2018-03-17 18:26:18 +05:30
});
2022-06-21 17:19:12 +05:30
it('fetches projects without membership when not logged in', () => {
2018-03-17 18:26:18 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects.json`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.projects(query, options, (response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
});
2020-03-13 15:44:24 +05:30
describe('updateProject', () => {
2022-06-21 17:19:12 +05:30
it('update a project with the given payload', () => {
2020-03-13 15:44:24 +05:30
const projectPath = 'foo';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}`;
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl).reply(HTTP_STATUS_OK, { foo: 'bar' });
2020-03-13 15:44:24 +05:30
2022-06-21 17:19:12 +05:30
return Api.updateProject(projectPath, { foo: 'bar' }).then(({ data }) => {
expect(data.foo).toBe('bar');
});
2020-03-13 15:44:24 +05:30
});
});
2019-12-04 20:38:33 +05:30
describe('projectUsers', () => {
2022-06-21 17:19:12 +05:30
it('fetches all users of a particular project', () => {
2019-12-04 20:38:33 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const projectPath = 'gitlab-org%2Fgitlab-ce';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/users`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2019-12-04 20:38:33 +05:30
{
name: 'test',
},
]);
2022-06-21 17:19:12 +05:30
return Api.projectUsers('gitlab-org/gitlab-ce', query, options).then((response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
});
2019-12-04 20:38:33 +05:30
});
});
2019-07-07 11:18:12 +05:30
describe('projectMergeRequests', () => {
const projectPath = 'abc';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests`;
2022-06-21 17:19:12 +05:30
it('fetches all merge requests for a project', () => {
2019-07-07 11:18:12 +05:30
const mockData = [{ source_branch: 'foo' }, { source_branch: 'bar' }];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, mockData);
2022-06-21 17:19:12 +05:30
return Api.projectMergeRequests(projectPath).then(({ data }) => {
expect(data.length).toEqual(2);
expect(data[0].source_branch).toBe('foo');
expect(data[1].source_branch).toBe('bar');
});
2019-07-07 11:18:12 +05:30
});
2022-06-21 17:19:12 +05:30
it('fetches merge requests filtered with passed params', () => {
2019-07-07 11:18:12 +05:30
const params = {
source_branch: 'bar',
};
const mockData = [{ source_branch: 'bar' }];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl, { params }).reply(HTTP_STATUS_OK, mockData);
2019-07-07 11:18:12 +05:30
2022-06-21 17:19:12 +05:30
return Api.projectMergeRequests(projectPath, params).then(({ data }) => {
expect(data.length).toEqual(1);
expect(data[0].source_branch).toBe('bar');
});
2019-07-07 11:18:12 +05:30
});
});
2019-02-15 15:39:39 +05:30
describe('projectMergeRequest', () => {
2022-06-21 17:19:12 +05:30
it('fetches a merge request', () => {
2018-05-09 12:01:36 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2018-05-09 12:01:36 +05:30
title: 'test',
});
2022-06-21 17:19:12 +05:30
return Api.projectMergeRequest(projectPath, mergeRequestId).then(({ data }) => {
expect(data.title).toBe('test');
});
2018-05-09 12:01:36 +05:30
});
});
2019-02-15 15:39:39 +05:30
describe('projectMergeRequestChanges', () => {
2022-06-21 17:19:12 +05:30
it('fetches the changes of a merge request', () => {
2018-05-09 12:01:36 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}/changes`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2018-05-09 12:01:36 +05:30
title: 'test',
});
2022-06-21 17:19:12 +05:30
return Api.projectMergeRequestChanges(projectPath, mergeRequestId).then(({ data }) => {
expect(data.title).toBe('test');
});
2018-05-09 12:01:36 +05:30
});
});
2019-02-15 15:39:39 +05:30
describe('projectMergeRequestVersions', () => {
2022-06-21 17:19:12 +05:30
it('fetches the versions of a merge request', () => {
2018-05-09 12:01:36 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}/versions`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
id: 123,
},
]);
2022-06-21 17:19:12 +05:30
return Api.projectMergeRequestVersions(projectPath, mergeRequestId).then(({ data }) => {
expect(data.length).toBe(1);
expect(data[0].id).toBe(123);
});
2018-05-09 12:01:36 +05:30
});
});
2019-02-15 15:39:39 +05:30
describe('projectRunners', () => {
2022-06-21 17:19:12 +05:30
it('fetches the runners of a project', () => {
2019-02-15 15:39:39 +05:30
const projectPath = 7;
const params = { scope: 'active' };
const mockData = [{ id: 4 }];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/runners`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl, { params }).reply(HTTP_STATUS_OK, mockData);
2019-02-15 15:39:39 +05:30
2022-06-21 17:19:12 +05:30
return Api.projectRunners(projectPath, { params }).then(({ data }) => {
expect(data).toEqual(mockData);
});
2019-02-15 15:39:39 +05:30
});
});
2021-04-17 20:07:23 +05:30
describe('projectShareWithGroup', () => {
it('invites a group to share access with the authenticated project', () => {
const projectId = 1;
const sharedGroupId = 99;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/share`;
const options = {
group_id: sharedGroupId,
group_access: 10,
expires_at: undefined,
};
jest.spyOn(axios, 'post');
mock.onPost(expectedUrl).reply(200, {
status: 'success',
});
return Api.projectShareWithGroup(projectId, options).then(({ data }) => {
expect(data.status).toBe('success');
expect(axios.post).toHaveBeenCalledWith(expectedUrl, options);
});
});
});
2020-11-24 15:15:51 +05:30
describe('projectMilestones', () => {
2022-06-21 17:19:12 +05:30
it('fetches project milestones', () => {
2020-11-24 15:15:51 +05:30
const projectId = 1;
const options = { state: 'active' };
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/1/milestones`;
mock.onGet(expectedUrl).reply(200, [
{
id: 1,
title: 'milestone1',
state: 'active',
},
]);
2022-06-21 17:19:12 +05:30
return Api.projectMilestones(projectId, options).then(({ data }) => {
expect(data.length).toBe(1);
expect(data[0].title).toBe('milestone1');
});
2020-11-24 15:15:51 +05:30
});
});
2021-01-03 14:25:43 +05:30
describe('addProjectIssueAsTodo', () => {
it('adds issue ID as a todo', () => {
const projectId = 1;
const issueIid = 11;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/1/issues/11/todo`;
mock.onPost(expectedUrl).reply(200, {
id: 112,
project: {
id: 1,
},
});
return Api.addProjectIssueAsTodo(projectId, issueIid).then(({ data }) => {
expect(data.id).toBe(112);
expect(data.project.id).toBe(projectId);
});
});
});
2022-06-21 17:19:12 +05:30
describe('inviteProjectMembers', () => {
2021-03-08 18:12:59 +05:30
it('invites a new email address to create a new User and become a Project Member', () => {
const projectId = 1;
2022-06-21 17:19:12 +05:30
const email = 'email@example.com';
const userId = '1';
2021-03-08 18:12:59 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/1/invitations`;
const params = {
2022-06-21 17:19:12 +05:30
email,
userId,
2021-03-08 18:12:59 +05:30
access_level: 10,
expires_at: undefined,
};
mock.onPost(expectedUrl).reply(200, {
status: 'success',
});
2022-06-21 17:19:12 +05:30
return Api.inviteProjectMembers(projectId, params).then(({ data }) => {
2021-03-08 18:12:59 +05:30
expect(data.status).toBe('success');
});
});
});
2017-09-10 17:25:29 +05:30
describe('newLabel', () => {
2022-06-21 17:19:12 +05:30
it('creates a new project label', () => {
2017-09-10 17:25:29 +05:30
const namespace = 'some namespace';
const project = 'some project';
const labelData = { some: 'data' };
2019-09-04 21:01:54 +05:30
const expectedUrl = `${dummyUrlRoot}/${namespace}/${project}/-/labels`;
2017-09-10 17:25:29 +05:30
const expectedData = {
label: labelData,
};
2021-03-08 18:12:59 +05:30
mock.onPost(expectedUrl).reply((config) => {
2018-03-17 18:26:18 +05:30
expect(config.data).toBe(JSON.stringify(expectedData));
2018-05-09 12:01:36 +05:30
return [
2023-03-17 16:20:25 +05:30
HTTP_STATUS_OK,
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
];
2017-09-10 17:25:29 +05:30
});
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.newLabel(namespace, project, labelData, (response) => {
expect(response.name).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
2018-03-27 19:54:05 +05:30
2022-06-21 17:19:12 +05:30
it('creates a new group label', () => {
2018-03-27 19:54:05 +05:30
const namespace = 'group/subgroup';
2021-04-29 21:17:54 +05:30
const labelData = { name: 'Foo', color: '#000000' };
2019-09-04 21:01:54 +05:30
const expectedUrl = Api.buildUrl(Api.groupLabelsPath).replace(':namespace_path', namespace);
2021-03-08 18:12:59 +05:30
mock.onPost(expectedUrl).reply((config) => {
2021-04-29 21:17:54 +05:30
expect(config.data).toBe(JSON.stringify({ color: labelData.color }));
2018-03-27 19:54:05 +05:30
2018-05-09 12:01:36 +05:30
return [
2023-03-17 16:20:25 +05:30
HTTP_STATUS_OK,
2018-05-09 12:01:36 +05:30
{
2021-04-29 21:17:54 +05:30
...labelData,
2018-05-09 12:01:36 +05:30
},
];
2018-03-27 19:54:05 +05:30
});
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.newLabel(namespace, undefined, labelData, (response) => {
expect(response.name).toBe('Foo');
resolve();
});
2018-03-27 19:54:05 +05:30
});
});
2017-09-10 17:25:29 +05:30
});
describe('groupProjects', () => {
2022-06-21 17:19:12 +05:30
it('fetches group projects', () => {
2017-09-10 17:25:29 +05:30
const groupId = '123456';
const query = 'dummy query';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/projects.json`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2017-09-10 17:25:29 +05:30
2022-07-23 23:45:48 +05:30
return Api.groupProjects(groupId, query, {}).then((response) => {
expect(response.data.length).toBe(1);
expect(response.data[0].name).toBe('test');
2017-09-10 17:25:29 +05:30
});
2022-06-21 17:19:12 +05:30
});
it('NOT uses flesh on error with param useCustomErrorHandler', async () => {
const groupId = '123456';
const query = 'dummy query';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/projects.json`;
mock.onGet(expectedUrl).reply(500, null);
2022-07-23 23:45:48 +05:30
const apiCall = Api.groupProjects(groupId, query, {});
2022-06-21 17:19:12 +05:30
await expect(apiCall).rejects.toThrow();
2017-09-10 17:25:29 +05:30
});
});
2021-04-17 20:07:23 +05:30
describe('groupShareWithGroup', () => {
it('invites a group to share access with the authenticated group', () => {
const groupId = 1;
const sharedGroupId = 99;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/share`;
const options = {
group_id: sharedGroupId,
group_access: 10,
expires_at: undefined,
};
jest.spyOn(axios, 'post');
mock.onPost(expectedUrl).reply(200, {
status: 'success',
});
return Api.groupShareWithGroup(groupId, options).then(({ data }) => {
expect(data.status).toBe('success');
expect(axios.post).toHaveBeenCalledWith(expectedUrl, options);
});
});
});
2020-07-28 23:09:34 +05:30
describe('commit', () => {
const projectId = 'user/project';
const sha = 'abcd0123';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
projectId,
)}/repository/commits/${sha}`;
it('fetches a single commit', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, { id: sha });
2020-07-28 23:09:34 +05:30
return Api.commit(projectId, sha).then(({ data: commit }) => {
expect(commit.id).toBe(sha);
});
});
it('fetches a single commit without stats', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl, { params: { stats: false } }).reply(HTTP_STATUS_OK, { id: sha });
2020-07-28 23:09:34 +05:30
return Api.commit(projectId, sha, { stats: false }).then(({ data: commit }) => {
expect(commit.id).toBe(sha);
});
});
});
2018-12-05 23:21:45 +05:30
describe('issueTemplate', () => {
2021-01-29 00:20:46 +05:30
const namespace = 'some namespace';
const project = 'some project';
const templateKey = ' template #%?.key ';
const templateType = 'template type';
const expectedUrl = `${dummyUrlRoot}/${namespace}/${project}/templates/${templateType}/${encodeURIComponent(
templateKey,
)}`;
2022-06-21 17:19:12 +05:30
it('fetches an issue template', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, 'test');
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.issueTemplate(namespace, project, templateKey, templateType, (_, response) => {
expect(response).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
2021-01-29 00:20:46 +05:30
describe('when an error occurs while fetching an issue template', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2021-01-29 00:20:46 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.issueTemplate(namespace, project, templateKey, templateType, () => {
expect(mock.history.get).toHaveLength(1);
resolve();
});
2021-01-29 00:20:46 +05:30
});
});
});
});
describe('issueTemplates', () => {
const namespace = 'some namespace';
const project = 'some project';
const templateType = 'template type';
const expectedUrl = `${dummyUrlRoot}/${namespace}/${project}/templates/${templateType}`;
2022-06-21 17:19:12 +05:30
it('fetches all templates by type', () => {
2021-01-29 00:20:46 +05:30
const expectedData = [
{ key: 'Template1', name: 'Template 1', content: 'This is template 1!' },
];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, expectedData);
2021-01-29 00:20:46 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.issueTemplates(namespace, project, templateType, (_, response) => {
expect(response.length).toBe(1);
const { key, name, content } = response[0];
expect(key).toBe('Template1');
expect(name).toBe('Template 1');
expect(content).toBe('This is template 1!');
resolve();
});
2021-01-29 00:20:46 +05:30
});
});
describe('when an error occurs while fetching issue templates', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2021-01-29 00:20:46 +05:30
Api.issueTemplates(namespace, project, templateType, () => {
expect(mock.history.get).toHaveLength(1);
});
});
});
2017-09-10 17:25:29 +05:30
});
2018-12-05 23:21:45 +05:30
describe('projectTemplates', () => {
2022-06-21 17:19:12 +05:30
it('fetches a list of templates', () => {
2018-12-05 23:21:45 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/gitlab-org%2Fgitlab-ce/templates/licenses`;
2017-09-10 17:25:29 +05:30
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, 'test');
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.projectTemplates('gitlab-org/gitlab-ce', 'licenses', {}, (response) => {
expect(response).toBe('test');
resolve();
});
2017-09-10 17:25:29 +05:30
});
});
});
2018-12-05 23:21:45 +05:30
describe('projectTemplate', () => {
2022-06-21 17:19:12 +05:30
it('fetches a single template', () => {
2018-12-05 23:21:45 +05:30
const data = { unused: 'option' };
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/gitlab-org%2Fgitlab-ce/templates/licenses/test%20license`;
2017-09-10 17:25:29 +05:30
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, 'test');
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.projectTemplate(
'gitlab-org/gitlab-ce',
'licenses',
'test license',
data,
(response) => {
expect(response).toBe('test');
resolve();
},
);
2017-09-10 17:25:29 +05:30
});
});
});
describe('users', () => {
2022-06-21 17:19:12 +05:30
it('fetches users', () => {
2017-09-10 17:25:29 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/users.json`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-05-09 12:01:36 +05:30
{
name: 'test',
},
]);
2017-09-10 17:25:29 +05:30
2022-06-21 17:19:12 +05:30
return Api.users(query, options).then(({ data }) => {
expect(data.length).toBe(1);
expect(data[0].name).toBe('test');
});
2017-09-10 17:25:29 +05:30
});
});
2018-11-08 19:23:39 +05:30
2019-02-15 15:39:39 +05:30
describe('user', () => {
2022-06-21 17:19:12 +05:30
it('fetches single user', () => {
2019-02-15 15:39:39 +05:30
const userId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/users/${userId}`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2019-02-15 15:39:39 +05:30
name: 'testuser',
});
2022-06-21 17:19:12 +05:30
return Api.user(userId).then(({ data }) => {
expect(data.name).toBe('testuser');
});
2019-02-15 15:39:39 +05:30
});
});
2019-09-30 21:07:59 +05:30
describe('user counts', () => {
2022-06-21 17:19:12 +05:30
it('fetches single user counts', () => {
2019-09-30 21:07:59 +05:30
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/user_counts`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2019-09-30 21:07:59 +05:30
merge_requests: 4,
});
2022-06-21 17:19:12 +05:30
return Api.userCounts().then(({ data }) => {
expect(data.merge_requests).toBe(4);
});
2019-09-30 21:07:59 +05:30
});
});
2019-02-15 15:39:39 +05:30
describe('user status', () => {
2022-06-21 17:19:12 +05:30
it('fetches single user status', () => {
2019-02-15 15:39:39 +05:30
const userId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/users/${userId}/status`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, {
2019-02-15 15:39:39 +05:30
message: 'testmessage',
});
2022-06-21 17:19:12 +05:30
return Api.userStatus(userId).then(({ data }) => {
expect(data.message).toBe('testmessage');
});
2019-02-15 15:39:39 +05:30
});
});
2019-12-26 22:10:19 +05:30
describe('user projects', () => {
2022-06-21 17:19:12 +05:30
it('fetches all projects that belong to a particular user', () => {
2019-12-26 22:10:19 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const userId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/users/${userId}/projects`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2019-12-26 22:10:19 +05:30
{
name: 'test',
},
]);
2022-06-21 17:19:12 +05:30
return new Promise((resolve) => {
Api.userProjects(userId, query, options, (response) => {
expect(response.length).toBe(1);
expect(response[0].name).toBe('test');
resolve();
});
2019-12-26 22:10:19 +05:30
});
});
});
2018-11-08 19:23:39 +05:30
describe('commitPipelines', () => {
2022-06-21 17:19:12 +05:30
it('fetches pipelines for a given commit', () => {
2018-11-08 19:23:39 +05:30
const projectId = 'example/foobar';
const commitSha = 'abc123def';
const expectedUrl = `${dummyUrlRoot}/${projectId}/commit/${commitSha}/pipelines`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2018-11-08 19:23:39 +05:30
{
name: 'test',
},
]);
2022-06-21 17:19:12 +05:30
return Api.commitPipelines(projectId, commitSha).then(({ data }) => {
expect(data.length).toBe(1);
expect(data[0].name).toBe('test');
});
2018-11-08 19:23:39 +05:30
});
});
2021-01-03 14:25:43 +05:30
describe('pipelineJobs', () => {
2021-01-29 00:20:46 +05:30
it.each([undefined, {}, { foo: true }])(
'fetches the jobs for a given pipeline given %p params',
2021-03-08 18:12:59 +05:30
async (params) => {
2021-01-29 00:20:46 +05:30
const projectId = 123;
const pipelineId = 456;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/pipelines/${pipelineId}/jobs`;
const payload = [
{
name: 'test',
},
];
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl, { params }).reply(HTTP_STATUS_OK, payload);
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
const { data } = await Api.pipelineJobs(projectId, pipelineId, params);
expect(data).toEqual(payload);
},
);
2021-01-03 14:25:43 +05:30
});
2018-11-08 19:23:39 +05:30
describe('createBranch', () => {
2022-06-21 17:19:12 +05:30
it('creates new branch', () => {
2021-06-08 01:23:25 +05:30
const ref = 'main';
2018-11-08 19:23:39 +05:30
const branch = 'new-branch-name';
const dummyProjectPath = 'gitlab-org/gitlab-ce';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
dummyProjectPath,
)}/repository/branches`;
2019-09-04 21:01:54 +05:30
jest.spyOn(axios, 'post');
2018-11-08 19:23:39 +05:30
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).replyOnce(HTTP_STATUS_OK, {
2018-11-08 19:23:39 +05:30
name: branch,
});
2022-06-21 17:19:12 +05:30
return Api.createBranch(dummyProjectPath, { ref, branch }).then(({ data }) => {
expect(data.name).toBe(branch);
expect(axios.post).toHaveBeenCalledWith(expectedUrl, { ref, branch });
});
2018-11-08 19:23:39 +05:30
});
});
2019-09-30 21:07:59 +05:30
describe('projectForks', () => {
2022-06-21 17:19:12 +05:30
it('gets forked projects', () => {
2019-09-30 21:07:59 +05:30
const dummyProjectPath = 'gitlab-org/gitlab-ce';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
dummyProjectPath,
)}/forks`;
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, ['fork']);
2019-09-30 21:07:59 +05:30
2022-06-21 17:19:12 +05:30
return Api.projectForks(dummyProjectPath, { visibility: 'private' }).then(({ data }) => {
expect(data).toEqual(['fork']);
expect(axios.get).toHaveBeenCalledWith(expectedUrl, {
params: { visibility: 'private' },
});
});
2019-09-30 21:07:59 +05:30
});
});
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('createContextCommits', () => {
2022-06-21 17:19:12 +05:30
it('creates a new context commit', () => {
2020-10-24 23:57:45 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const commitsData = ['abcdefg'];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}/context_commits`;
const expectedData = {
commits: commitsData,
};
jest.spyOn(axios, 'post');
mock.onPost(expectedUrl).replyOnce(200, [
{
id: 'abcdefghijklmnop',
short_id: 'abcdefg',
title: 'Dummy commit',
},
]);
2022-06-21 17:19:12 +05:30
return Api.createContextCommits(projectPath, mergeRequestId, expectedData).then(
({ data }) => {
2020-10-24 23:57:45 +05:30
expect(data[0].title).toBe('Dummy commit');
2022-06-21 17:19:12 +05:30
},
);
2020-10-24 23:57:45 +05:30
});
});
describe('allContextCommits', () => {
2022-06-21 17:19:12 +05:30
it('gets all context commits', () => {
2020-10-24 23:57:45 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}/context_commits`;
jest.spyOn(axios, 'get');
mock
.onGet(expectedUrl)
.replyOnce(200, [{ id: 'abcdef', short_id: 'abcdefghi', title: 'Dummy commit title' }]);
2022-06-21 17:19:12 +05:30
return Api.allContextCommits(projectPath, mergeRequestId).then(({ data }) => {
expect(data[0].title).toBe('Dummy commit title');
});
2020-10-24 23:57:45 +05:30
});
});
describe('removeContextCommits', () => {
2022-06-21 17:19:12 +05:30
it('removes context commits', () => {
2020-10-24 23:57:45 +05:30
const projectPath = 'abc';
const mergeRequestId = '123456';
const commitsData = ['abcdefg'];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectPath}/merge_requests/${mergeRequestId}/context_commits`;
const expectedData = {
commits: commitsData,
};
jest.spyOn(axios, 'delete');
mock.onDelete(expectedUrl).replyOnce(204);
2022-06-21 17:19:12 +05:30
return Api.removeContextCommits(projectPath, mergeRequestId, expectedData).then(() => {
expect(axios.delete).toHaveBeenCalledWith(expectedUrl, { data: expectedData });
});
2020-10-24 23:57:45 +05:30
});
});
describe('release-related methods', () => {
2020-04-22 19:07:51 +05:30
const dummyProjectPath = 'gitlab-org/gitlab';
2020-10-24 23:57:45 +05:30
const dummyTagName = 'v1.3';
const baseReleaseUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
2020-04-22 19:07:51 +05:30
dummyProjectPath,
2020-10-24 23:57:45 +05:30
)}/releases`;
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('releases', () => {
const expectedUrl = baseReleaseUrl;
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('when releases are successfully returned', () => {
it('resolves the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK);
2020-10-24 23:57:45 +05:30
return Api.releases(dummyProjectPath).then(() => {
expect(mock.history.get).toHaveLength(1);
});
});
});
describe('when an error occurs while fetching releases', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.releases(dummyProjectPath).catch(() => {
expect(mock.history.get).toHaveLength(1);
});
2020-04-22 19:07:51 +05:30
});
});
});
2020-10-24 23:57:45 +05:30
describe('release', () => {
const expectedUrl = `${baseReleaseUrl}/${encodeURIComponent(dummyTagName)}`;
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('when the release is successfully returned', () => {
it('resolves the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK);
2020-10-24 23:57:45 +05:30
return Api.release(dummyProjectPath, dummyTagName).then(() => {
expect(mock.history.get).toHaveLength(1);
});
});
});
describe('when an error occurs while fetching the release', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.release(dummyProjectPath, dummyTagName).catch(() => {
expect(mock.history.get).toHaveLength(1);
});
2020-04-22 19:07:51 +05:30
});
});
});
2020-10-24 23:57:45 +05:30
describe('createRelease', () => {
const expectedUrl = baseReleaseUrl;
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
const release = {
name: 'Version 1.0',
};
describe('when the release is successfully created', () => {
it('resolves the Promise', () => {
2023-03-04 22:38:38 +05:30
mock.onPost(expectedUrl, release).replyOnce(HTTP_STATUS_CREATED);
2020-10-24 23:57:45 +05:30
return Api.createRelease(dummyProjectPath, release).then(() => {
expect(mock.history.post).toHaveLength(1);
});
});
});
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('when an error occurs while creating the release', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl, release).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.createRelease(dummyProjectPath, release).catch(() => {
expect(mock.history.post).toHaveLength(1);
});
2020-04-22 19:07:51 +05:30
});
});
});
2020-10-24 23:57:45 +05:30
describe('updateRelease', () => {
const expectedUrl = `${baseReleaseUrl}/${encodeURIComponent(dummyTagName)}`;
const release = {
name: 'Version 1.0',
};
describe('when the release is successfully updated', () => {
it('resolves the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl, release).replyOnce(HTTP_STATUS_OK);
2020-10-24 23:57:45 +05:30
return Api.updateRelease(dummyProjectPath, dummyTagName, release).then(() => {
expect(mock.history.put).toHaveLength(1);
});
});
});
2020-04-22 19:07:51 +05:30
2020-10-24 23:57:45 +05:30
describe('when an error occurs while updating the release', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl, release).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.updateRelease(dummyProjectPath, dummyTagName, release).catch(() => {
expect(mock.history.put).toHaveLength(1);
});
});
});
});
describe('createReleaseLink', () => {
const expectedUrl = `${baseReleaseUrl}/${dummyTagName}/assets/links`;
const expectedLink = {
url: 'https://example.com',
name: 'An example link',
};
describe('when the Release is successfully created', () => {
it('resolves the Promise', () => {
2023-03-04 22:38:38 +05:30
mock.onPost(expectedUrl, expectedLink).replyOnce(HTTP_STATUS_CREATED);
2020-10-24 23:57:45 +05:30
return Api.createReleaseLink(dummyProjectPath, dummyTagName, expectedLink).then(() => {
expect(mock.history.post).toHaveLength(1);
});
});
});
describe('when an error occurs while creating the Release', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl, expectedLink).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.createReleaseLink(dummyProjectPath, dummyTagName, expectedLink).catch(() => {
expect(mock.history.post).toHaveLength(1);
});
});
});
});
describe('deleteReleaseLink', () => {
const dummyLinkId = '4';
const expectedUrl = `${baseReleaseUrl}/${dummyTagName}/assets/links/${dummyLinkId}`;
describe('when the Release is successfully deleted', () => {
it('resolves the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onDelete(expectedUrl).replyOnce(HTTP_STATUS_OK);
2020-10-24 23:57:45 +05:30
return Api.deleteReleaseLink(dummyProjectPath, dummyTagName, dummyLinkId).then(() => {
expect(mock.history.delete).toHaveLength(1);
});
});
});
describe('when an error occurs while deleting the Release', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onDelete(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-10-24 23:57:45 +05:30
return Api.deleteReleaseLink(dummyProjectPath, dummyTagName, dummyLinkId).catch(() => {
expect(mock.history.delete).toHaveLength(1);
});
2020-04-22 19:07:51 +05:30
});
});
});
});
describe('getRawFile', () => {
const dummyProjectPath = 'gitlab-org/gitlab';
const dummyFilePath = 'doc/CONTRIBUTING.md';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
dummyProjectPath,
)}/repository/files/${encodeURIComponent(dummyFilePath)}/raw`;
describe('when the raw file is successfully fetched', () => {
2021-04-29 21:17:54 +05:30
beforeEach(() => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK);
2021-04-29 21:17:54 +05:30
});
2020-04-22 19:07:51 +05:30
2021-04-29 21:17:54 +05:30
it('resolves the Promise', () => {
2020-04-22 19:07:51 +05:30
return Api.getRawFile(dummyProjectPath, dummyFilePath).then(() => {
expect(mock.history.get).toHaveLength(1);
});
});
2021-04-29 21:17:54 +05:30
describe('when the method is called with params', () => {
it('sets the params on the request', () => {
const params = { ref: 'main' };
jest.spyOn(axios, 'get');
Api.getRawFile(dummyProjectPath, dummyFilePath, params);
expect(axios.get).toHaveBeenCalledWith(expectedUrl, { params });
});
});
2020-04-22 19:07:51 +05:30
});
describe('when an error occurs while getting a raw file', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-04-22 19:07:51 +05:30
return Api.getRawFile(dummyProjectPath, dummyFilePath).catch(() => {
expect(mock.history.get).toHaveLength(1);
});
});
});
});
describe('createProjectMergeRequest', () => {
const dummyProjectPath = 'gitlab-org/gitlab';
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${encodeURIComponent(
dummyProjectPath,
)}/merge_requests`;
const options = {
source_branch: 'feature',
2021-06-08 01:23:25 +05:30
target_branch: 'main',
2020-04-22 19:07:51 +05:30
title: 'Add feature',
};
describe('when the merge request is successfully created', () => {
it('resolves the Promise', () => {
2023-03-04 22:38:38 +05:30
mock.onPost(expectedUrl, options).replyOnce(HTTP_STATUS_CREATED);
2020-04-22 19:07:51 +05:30
return Api.createProjectMergeRequest(dummyProjectPath, options).then(() => {
expect(mock.history.post).toHaveLength(1);
});
});
});
describe('when an error occurs while getting a raw file', () => {
it('rejects the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).replyOnce(HTTP_STATUS_INTERNAL_SERVER_ERROR);
2020-04-22 19:07:51 +05:30
return Api.createProjectMergeRequest(dummyProjectPath).catch(() => {
expect(mock.history.post).toHaveLength(1);
});
});
});
});
2020-06-23 00:09:42 +05:30
describe('updateIssue', () => {
2022-06-21 17:19:12 +05:30
it('update an issue with the given payload', () => {
2020-06-23 00:09:42 +05:30
const projectId = 8;
const issue = 1;
const expectedArray = [1, 2, 3];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/issues/${issue}`;
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl).reply(HTTP_STATUS_OK, { assigneeIds: expectedArray });
2020-06-23 00:09:42 +05:30
2022-06-21 17:19:12 +05:30
return Api.updateIssue(projectId, issue, { assigneeIds: expectedArray }).then(({ data }) => {
expect(data.assigneeIds).toEqual(expectedArray);
});
2020-06-23 00:09:42 +05:30
});
});
describe('updateMergeRequest', () => {
2022-06-21 17:19:12 +05:30
it('update an issue with the given payload', () => {
2020-06-23 00:09:42 +05:30
const projectId = 8;
const mergeRequest = 1;
const expectedArray = [1, 2, 3];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/merge_requests/${mergeRequest}`;
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl).reply(HTTP_STATUS_OK, { assigneeIds: expectedArray });
2020-06-23 00:09:42 +05:30
2022-06-21 17:19:12 +05:30
return Api.updateMergeRequest(projectId, mergeRequest, { assigneeIds: expectedArray }).then(
({ data }) => {
2020-06-23 00:09:42 +05:30
expect(data.assigneeIds).toEqual(expectedArray);
2022-06-21 17:19:12 +05:30
},
);
2020-06-23 00:09:42 +05:30
});
});
describe('tags', () => {
2022-06-21 17:19:12 +05:30
it('fetches all tags of a particular project', () => {
2020-06-23 00:09:42 +05:30
const query = 'dummy query';
const options = { unused: 'option' };
const projectId = 8;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/repository/tags`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [
2020-06-23 00:09:42 +05:30
{
name: 'test',
},
]);
2022-06-21 17:19:12 +05:30
return Api.tags(projectId, query, options).then(({ data }) => {
expect(data.length).toBe(1);
expect(data[0].name).toBe('test');
});
2020-06-23 00:09:42 +05:30
});
});
2020-10-24 23:57:45 +05:30
describe('freezePeriods', () => {
it('fetches freezePeriods', () => {
const projectId = 8;
const freezePeriod = {
id: 3,
freeze_start: '5 4 * * *',
freeze_end: '5 9 * 8 *',
cron_timezone: 'America/New_York',
created_at: '2020-07-10T05:10:35.122Z',
updated_at: '2020-07-10T05:10:35.122Z',
};
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/freeze_periods`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, [freezePeriod]);
2020-10-24 23:57:45 +05:30
return Api.freezePeriods(projectId).then(({ data }) => {
expect(data[0]).toStrictEqual(freezePeriod);
});
});
});
describe('createFreezePeriod', () => {
const projectId = 8;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/freeze_periods`;
const options = {
freeze_start: '* * * * *',
freeze_end: '* * * * *',
cron_timezone: 'America/Juneau',
};
const expectedResult = {
id: 10,
freeze_start: '* * * * *',
freeze_end: '* * * * *',
cron_timezone: 'America/Juneau',
created_at: '2020-07-11T07:04:50.153Z',
updated_at: '2020-07-11T07:04:50.153Z',
};
describe('when the freeze period is successfully created', () => {
it('resolves the Promise', () => {
2023-03-04 22:38:38 +05:30
mock.onPost(expectedUrl, options).replyOnce(HTTP_STATUS_CREATED, expectedResult);
2020-10-24 23:57:45 +05:30
return Api.createFreezePeriod(projectId, options).then(({ data }) => {
expect(data).toStrictEqual(expectedResult);
});
});
});
});
2021-04-29 21:17:54 +05:30
describe('updateFreezePeriod', () => {
const options = {
id: 10,
freeze_start: '* * * * *',
freeze_end: '* * * * *',
cron_timezone: 'America/Juneau',
created_at: '2020-07-11T07:04:50.153Z',
updated_at: '2020-07-11T07:04:50.153Z',
};
const projectId = 8;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/freeze_periods/${options.id}`;
const expectedResult = {
id: 10,
freeze_start: '* * * * *',
freeze_end: '* * * * *',
cron_timezone: 'America/Juneau',
created_at: '2020-07-11T07:04:50.153Z',
updated_at: '2020-07-11T07:04:50.153Z',
};
describe('when the freeze period is successfully updated', () => {
it('resolves the Promise', () => {
2023-03-17 16:20:25 +05:30
mock.onPut(expectedUrl, options).replyOnce(HTTP_STATUS_OK, expectedResult);
2021-04-29 21:17:54 +05:30
return Api.updateFreezePeriod(projectId, options).then(({ data }) => {
expect(data).toStrictEqual(expectedResult);
});
});
});
});
2020-10-24 23:57:45 +05:30
describe('createPipeline', () => {
it('creates new pipeline', () => {
const redirectUrl = 'ci-project/-/pipelines/95';
const projectId = 8;
const postData = {
ref: 'tag-1',
variables: [
{ key: 'test_file', value: 'test_file_val', variable_type: 'file' },
{ key: 'test_var', value: 'test_var_val', variable_type: 'env_var' },
],
};
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/pipeline`;
jest.spyOn(axios, 'post');
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).replyOnce(HTTP_STATUS_OK, {
2020-10-24 23:57:45 +05:30
web_url: redirectUrl,
});
return Api.createPipeline(projectId, postData).then(({ data }) => {
expect(data.web_url).toBe(redirectUrl);
expect(axios.post).toHaveBeenCalledWith(expectedUrl, postData, {
headers: {
'Content-Type': 'application/json',
},
});
});
});
});
2021-01-03 14:25:43 +05:30
2021-02-22 17:27:13 +05:30
describe('trackRedisCounterEvent', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/usage_data/increment_counter`;
const event = 'dummy_event';
const postData = { event };
const headers = {
'Content-Type': 'application/json',
};
2021-09-30 23:02:18 +05:30
describe('when service data increment counter is called with feature flag disabled', () => {
2021-02-22 17:27:13 +05:30
beforeEach(() => {
gon.features = { ...gon.features, usageDataApi: false };
});
it('returns null', () => {
jest.spyOn(axios, 'post');
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).replyOnce(HTTP_STATUS_OK, true);
2021-02-22 17:27:13 +05:30
expect(axios.post).toHaveBeenCalledTimes(0);
expect(Api.trackRedisCounterEvent(event)).toEqual(null);
});
});
2021-09-30 23:02:18 +05:30
describe('when service data increment counter is called', () => {
2021-02-22 17:27:13 +05:30
beforeEach(() => {
gon.features = { ...gon.features, usageDataApi: true };
});
it('resolves the Promise', () => {
jest.spyOn(axios, 'post');
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl, { event }).replyOnce(HTTP_STATUS_OK, true);
2021-02-22 17:27:13 +05:30
return Api.trackRedisCounterEvent(event).then(({ data }) => {
expect(data).toEqual(true);
expect(axios.post).toHaveBeenCalledWith(expectedUrl, postData, { headers });
});
});
});
});
2021-01-03 14:25:43 +05:30
describe('trackRedisHllUserEvent', () => {
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/usage_data/increment_unique_users`;
const event = 'dummy_event';
const postData = { event };
const headers = {
'Content-Type': 'application/json',
};
2021-09-04 01:27:46 +05:30
describe('when user is set', () => {
2021-01-03 14:25:43 +05:30
beforeEach(() => {
2021-09-04 01:27:46 +05:30
window.gon.current_user_id = 1;
2021-01-03 14:25:43 +05:30
});
2021-09-30 23:02:18 +05:30
describe('when service data increment unique users is called with feature flag disabled', () => {
2021-09-04 01:27:46 +05:30
beforeEach(() => {
gon.features = { ...gon.features, usageDataApi: false };
});
2021-01-03 14:25:43 +05:30
2021-09-04 01:27:46 +05:30
it('returns null and does not call the endpoint', () => {
jest.spyOn(axios, 'post');
const result = Api.trackRedisHllUserEvent(event);
expect(result).toEqual(null);
expect(axios.post).toHaveBeenCalledTimes(0);
});
});
2021-09-30 23:02:18 +05:30
describe('when service data increment unique users is called', () => {
2021-09-04 01:27:46 +05:30
beforeEach(() => {
gon.features = { ...gon.features, usageDataApi: true };
});
it('resolves the Promise', () => {
jest.spyOn(axios, 'post');
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl, { event }).replyOnce(HTTP_STATUS_OK, true);
2021-09-04 01:27:46 +05:30
return Api.trackRedisHllUserEvent(event).then(({ data }) => {
expect(data).toEqual(true);
expect(axios.post).toHaveBeenCalledWith(expectedUrl, postData, { headers });
});
});
2021-01-03 14:25:43 +05:30
});
});
2021-09-04 01:27:46 +05:30
describe('when user is not set and feature flag enabled', () => {
2021-01-03 14:25:43 +05:30
beforeEach(() => {
gon.features = { ...gon.features, usageDataApi: true };
});
2021-09-04 01:27:46 +05:30
it('returns null and does not call the endpoint', () => {
2021-01-03 14:25:43 +05:30
jest.spyOn(axios, 'post');
2021-09-04 01:27:46 +05:30
const result = Api.trackRedisHllUserEvent(event);
expect(result).toEqual(null);
expect(axios.post).toHaveBeenCalledTimes(0);
2021-01-03 14:25:43 +05:30
});
});
});
2021-01-29 00:20:46 +05:30
2022-01-26 12:08:38 +05:30
describe('deployKeys', () => {
it('fetches deploy keys', async () => {
const deployKeys = [
{
id: 7,
title: 'My title 1',
created_at: '2021-10-29T16:59:55.229Z',
expires_at: null,
key:
'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAAAgQDLvQzRX960N7dxPdge9o5a96+M4GEGQ7rxT2D3wAQDtQFjQV5ZcKb5wfeLtYLe3kRVI4lCO10PXeQppb1XBaYmVO31IaRkcgmMEPVyfp76Dp4CJZz6aMEbbcqfaHkDre0Fa8kzTXnBJVh2NeDbBfGMjFM5NRQLhKykodNsepO6dQ== dummy@gitlab.com',
fingerprint: '81:93:63:b9:1e:24:a2:aa:e0:87:d3:3f:42:81:f2:c2',
projects_with_write_access: [
{
id: 11,
description: null,
name: 'project1',
name_with_namespace: 'John Doe3 / project1',
path: 'project1',
path_with_namespace: 'namespace1/project1',
created_at: '2021-10-29T16:59:54.668Z',
},
{
id: 12,
description: null,
name: 'project2',
name_with_namespace: 'John Doe4 / project2',
path: 'project2',
path_with_namespace: 'namespace2/project2',
created_at: '2021-10-29T16:59:55.116Z',
},
],
},
];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/deploy_keys`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, deployKeys);
2022-01-26 12:08:38 +05:30
const params = { page: 2, public: true };
const { data } = await Api.deployKeys(params);
expect(data).toEqual(deployKeys);
expect(mock.history.get[0].params).toEqual({ ...params, per_page: DEFAULT_PER_PAGE });
});
});
2022-05-07 20:08:51 +05:30
describe('projectSecureFiles', () => {
it('fetches secure files for a project', async () => {
const projectId = 1;
const secureFiles = [
{
id: projectId,
title: 'File Name',
permissions: 'read_only',
checksum: '12345',
checksum_algorithm: 'sha256',
created_at: '2022-02-21T15:27:18',
},
];
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/secure_files`;
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).reply(HTTP_STATUS_OK, secureFiles);
2022-05-07 20:08:51 +05:30
const { data } = await Api.projectSecureFiles(projectId, {});
expect(data).toEqual(secureFiles);
});
});
2022-07-16 23:28:13 +05:30
describe('uploadProjectSecureFile', () => {
it('uploads a secure file to a project', async () => {
const projectId = 1;
const secureFile = {
id: projectId,
title: 'File Name',
permissions: 'read_only',
checksum: '12345',
checksum_algorithm: 'sha256',
created_at: '2022-02-21T15:27:18',
};
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/secure_files`;
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl).reply(HTTP_STATUS_OK, secureFile);
2022-07-16 23:28:13 +05:30
const { data } = await Api.uploadProjectSecureFile(projectId, 'some data');
expect(data).toEqual(secureFile);
});
});
describe('deleteProjectSecureFile', () => {
it('removes a secure file from a project', async () => {
const projectId = 1;
const secureFileId = 2;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/secure_files/${secureFileId}`;
2023-03-04 22:38:38 +05:30
mock.onDelete(expectedUrl).reply(HTTP_STATUS_NO_CONTENT, '');
2022-07-16 23:28:13 +05:30
const { data } = await Api.deleteProjectSecureFile(projectId, secureFileId);
expect(data).toEqual('');
});
});
2022-06-21 17:19:12 +05:30
describe('dependency proxy cache', () => {
it('schedules the cache list for deletion', async () => {
const groupId = 1;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/groups/${groupId}/dependency_proxy/cache`;
2023-03-04 22:38:38 +05:30
mock.onDelete(expectedUrl).reply(HTTP_STATUS_ACCEPTED);
2022-06-21 17:19:12 +05:30
const { status } = await Api.deleteDependencyProxyCacheList(groupId, {});
2023-03-04 22:38:38 +05:30
expect(status).toBe(HTTP_STATUS_ACCEPTED);
2022-06-21 17:19:12 +05:30
});
});
2021-01-29 00:20:46 +05:30
describe('Feature Flag User List', () => {
let expectedUrl;
let projectId;
let mockUserList;
beforeEach(() => {
projectId = 1000;
expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${projectId}/feature_flags_user_lists`;
mockUserList = {
name: 'mock_user_list',
user_xids: '1,2,3,4',
project_id: 1,
id: 1,
iid: 1,
};
});
describe('fetchFeatureFlagUserLists', () => {
it('GETs the right url', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, []);
2021-01-29 00:20:46 +05:30
return Api.fetchFeatureFlagUserLists(projectId).then(({ data }) => {
expect(data).toEqual([]);
});
});
});
describe('searchFeatureFlagUserLists', () => {
it('GETs the right url', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl, { params: { search: 'test' } }).replyOnce(HTTP_STATUS_OK, []);
2021-01-29 00:20:46 +05:30
return Api.searchFeatureFlagUserLists(projectId, 'test').then(({ data }) => {
expect(data).toEqual([]);
});
});
});
describe('createFeatureFlagUserList', () => {
it('POSTs data to the right url', () => {
const mockUserListData = {
name: 'mock_user_list',
user_xids: '1,2,3,4',
};
2023-03-17 16:20:25 +05:30
mock.onPost(expectedUrl, mockUserListData).replyOnce(HTTP_STATUS_OK, mockUserList);
2021-01-29 00:20:46 +05:30
return Api.createFeatureFlagUserList(projectId, mockUserListData).then(({ data }) => {
expect(data).toEqual(mockUserList);
});
});
});
describe('fetchFeatureFlagUserList', () => {
it('GETs the right url', () => {
2023-03-17 16:20:25 +05:30
mock.onGet(`${expectedUrl}/1`).replyOnce(HTTP_STATUS_OK, mockUserList);
2021-01-29 00:20:46 +05:30
return Api.fetchFeatureFlagUserList(projectId, 1).then(({ data }) => {
expect(data).toEqual(mockUserList);
});
});
});
describe('updateFeatureFlagUserList', () => {
it('PUTs the right url', () => {
mock
.onPut(`${expectedUrl}/1`)
2023-03-17 16:20:25 +05:30
.replyOnce(HTTP_STATUS_OK, { ...mockUserList, user_xids: '5' });
2021-01-29 00:20:46 +05:30
return Api.updateFeatureFlagUserList(projectId, {
...mockUserList,
user_xids: '5',
}).then(({ data }) => {
expect(data).toEqual({ ...mockUserList, user_xids: '5' });
});
});
});
describe('deleteFeatureFlagUserList', () => {
it('DELETEs the right url', () => {
2023-03-17 16:20:25 +05:30
mock.onDelete(`${expectedUrl}/1`).replyOnce(HTTP_STATUS_OK, 'deleted');
2021-01-29 00:20:46 +05:30
return Api.deleteFeatureFlagUserList(projectId, 1).then(({ data }) => {
expect(data).toBe('deleted');
});
});
});
});
2022-06-21 17:19:12 +05:30
describe('projectProtectedBranch', () => {
const branchName = 'new-branch-name';
const dummyProjectId = 5;
const expectedUrl = `${dummyUrlRoot}/api/${dummyApiVersion}/projects/${dummyProjectId}/protected_branches/${branchName}`;
it('returns 404 for non-existing branch', () => {
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_NOT_FOUND, {
2022-06-21 17:19:12 +05:30
message: '404 Not found',
});
return Api.projectProtectedBranch(dummyProjectId, branchName).catch((error) => {
2023-03-17 16:20:25 +05:30
expect(error.response.status).toBe(HTTP_STATUS_NOT_FOUND);
2022-06-21 17:19:12 +05:30
expect(axios.get).toHaveBeenCalledWith(expectedUrl);
});
});
it('returns 200 with branch information', () => {
const expectedObj = { name: branchName };
jest.spyOn(axios, 'get');
2023-03-17 16:20:25 +05:30
mock.onGet(expectedUrl).replyOnce(HTTP_STATUS_OK, expectedObj);
2022-06-21 17:19:12 +05:30
return Api.projectProtectedBranch(dummyProjectId, branchName).then((data) => {
expect(data).toEqual(expectedObj);
expect(axios.get).toHaveBeenCalledWith(expectedUrl);
});
});
});
2017-09-10 17:25:29 +05:30
});