debian-mirror-gitlab/spec/frontend/ide/services/index_spec.js

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

346 lines
10 KiB
JavaScript
Raw Normal View History

2019-12-26 22:10:19 +05:30
import axios from 'axios';
import MockAdapter from 'axios-mock-adapter';
2021-04-17 20:07:23 +05:30
import getIdeProject from 'ee_else_ce/ide/queries/get_ide_project.query.graphql';
2019-07-31 22:56:46 +05:30
import Api from '~/api';
2021-06-08 01:23:25 +05:30
import dismissUserCallout from '~/graphql_shared/mutations/dismiss_user_callout.mutation.graphql';
2021-03-11 19:13:27 +05:30
import services from '~/ide/services';
2021-06-08 01:23:25 +05:30
import { query, mutate } from '~/ide/services/gql';
2023-04-23 21:23:45 +05:30
import { HTTP_STATUS_OK } from '~/lib/utils/http_status';
2020-01-01 13:55:28 +05:30
import { escapeFileUrl } from '~/lib/utils/url_utility';
2023-03-04 22:38:38 +05:30
import ciConfig from '~/ci/pipeline_editor/graphql/queries/ci_config.query.graphql';
2020-03-13 15:44:24 +05:30
import { projectData } from '../mock_data';
2019-07-31 22:56:46 +05:30
jest.mock('~/api');
2020-03-13 15:44:24 +05:30
jest.mock('~/ide/services/gql');
2019-07-31 22:56:46 +05:30
2020-03-13 15:44:24 +05:30
const TEST_NAMESPACE = 'alice';
const TEST_PROJECT = 'wonderland';
const TEST_PROJECT_ID = `${TEST_NAMESPACE}/${TEST_PROJECT}`;
2021-09-04 01:27:46 +05:30
const TEST_BRANCH = 'main-patch-123';
2019-07-31 22:56:46 +05:30
const TEST_COMMIT_SHA = '123456789';
2019-12-26 22:10:19 +05:30
const TEST_FILE_PATH = 'README2.md';
const TEST_FILE_OLD_PATH = 'OLD_README2.md';
const TEST_FILE_PATH_SPECIAL = 'READM?ME/abc';
const TEST_FILE_CONTENTS = 'raw file content';
2019-07-31 22:56:46 +05:30
describe('IDE services', () => {
describe('commit', () => {
let payload;
beforeEach(() => {
payload = {
branch: TEST_BRANCH,
commit_message: 'Hello world',
actions: [],
2019-10-12 21:52:04 +05:30
start_sha: TEST_COMMIT_SHA,
2019-07-31 22:56:46 +05:30
};
Api.commitMultiple.mockReturnValue(Promise.resolve());
});
2019-10-12 21:52:04 +05:30
it('should commit', () => {
services.commit(TEST_PROJECT_ID, payload);
2019-07-31 22:56:46 +05:30
2019-10-12 21:52:04 +05:30
expect(Api.commitMultiple).toHaveBeenCalledWith(TEST_PROJECT_ID, payload);
2019-07-31 22:56:46 +05:30
});
});
2019-12-26 22:10:19 +05:30
2020-04-22 19:07:51 +05:30
describe('getRawFileData', () => {
it("resolves with a file's content if its a tempfile and it isn't renamed", () => {
const file = {
path: 'file',
tempFile: true,
content: 'content',
raw: 'raw content',
};
2021-03-08 18:12:59 +05:30
return services.getRawFileData(file).then((raw) => {
2020-04-22 19:07:51 +05:30
expect(raw).toBe('content');
});
});
it('resolves with file.raw if the file is renamed', () => {
const file = {
path: 'file',
tempFile: true,
content: 'content',
prevPath: 'old_path',
raw: 'raw content',
};
2021-03-08 18:12:59 +05:30
return services.getRawFileData(file).then((raw) => {
2020-04-22 19:07:51 +05:30
expect(raw).toBe('raw content');
});
});
it('returns file.raw if it exists', () => {
const file = {
path: 'file',
content: 'content',
raw: 'raw content',
};
2021-03-08 18:12:59 +05:30
return services.getRawFileData(file).then((raw) => {
2020-04-22 19:07:51 +05:30
expect(raw).toBe('raw content');
});
});
it("returns file.raw if file.raw is empty but file.rawPath doesn't exist", () => {
const file = {
path: 'file',
content: 'content',
raw: '',
};
2021-03-08 18:12:59 +05:30
return services.getRawFileData(file).then((raw) => {
2020-04-22 19:07:51 +05:30
expect(raw).toBe('');
});
});
describe("if file.rawPath exists but file.raw doesn't exist", () => {
let file;
let mock;
beforeEach(() => {
file = {
path: 'file',
content: 'content',
raw: '',
rawPath: 'some_raw_path',
};
mock = new MockAdapter(axios);
2023-04-23 21:23:45 +05:30
mock.onGet(file.rawPath).reply(HTTP_STATUS_OK, 'raw content');
2020-04-22 19:07:51 +05:30
jest.spyOn(axios, 'get');
});
afterEach(() => {
mock.restore();
});
it('sends a request to file.rawPath', () => {
2021-03-08 18:12:59 +05:30
return services.getRawFileData(file).then((raw) => {
expect(axios.get).toHaveBeenCalledWith(file.rawPath, {
transformResponse: [expect.any(Function)],
});
expect(raw).toEqual('raw content');
});
});
it('returns arraybuffer for binary files', () => {
file.binary = true;
return services.getRawFileData(file).then((raw) => {
expect(axios.get).toHaveBeenCalledWith(file.rawPath, {
transformResponse: [expect.any(Function)],
responseType: 'arraybuffer',
});
2020-04-22 19:07:51 +05:30
expect(raw).toEqual('raw content');
});
});
});
});
2019-12-26 22:10:19 +05:30
describe('getBaseRawFileData', () => {
let file;
let mock;
beforeEach(() => {
file = {
mrChange: null,
projectId: TEST_PROJECT_ID,
path: TEST_FILE_PATH,
};
jest.spyOn(axios, 'get');
mock = new MockAdapter(axios);
});
afterEach(() => {
mock.restore();
});
it('gives back file.baseRaw for files with that property present', () => {
file.baseRaw = TEST_FILE_CONTENTS;
2021-03-08 18:12:59 +05:30
return services.getBaseRawFileData(file, TEST_PROJECT_ID, TEST_COMMIT_SHA).then((content) => {
2019-12-26 22:10:19 +05:30
expect(content).toEqual(TEST_FILE_CONTENTS);
});
});
it('gives back file.baseRaw for files for temp files', () => {
file.tempFile = true;
file.baseRaw = TEST_FILE_CONTENTS;
2021-03-08 18:12:59 +05:30
return services.getBaseRawFileData(file, TEST_PROJECT_ID, TEST_COMMIT_SHA).then((content) => {
2019-12-26 22:10:19 +05:30
expect(content).toEqual(TEST_FILE_CONTENTS);
});
});
describe.each`
relativeUrlRoot | filePath | isRenamed
${''} | ${TEST_FILE_PATH} | ${false}
${''} | ${TEST_FILE_OLD_PATH} | ${true}
${''} | ${TEST_FILE_PATH_SPECIAL} | ${false}
${''} | ${TEST_FILE_PATH_SPECIAL} | ${true}
${'gitlab'} | ${TEST_FILE_OLD_PATH} | ${true}
`(
'with relativeUrlRoot ($relativeUrlRoot) and filePath ($filePath) and isRenamed ($isRenamed)',
({ relativeUrlRoot, filePath, isRenamed }) => {
beforeEach(() => {
if (isRenamed) {
file.mrChange = {
renamed_file: true,
old_path: filePath,
};
} else {
file.path = filePath;
}
gon.relative_url_root = relativeUrlRoot;
mock
.onGet(
2020-03-13 15:44:24 +05:30
`${relativeUrlRoot}/${TEST_PROJECT_ID}/-/raw/${TEST_COMMIT_SHA}/${escapeFileUrl(
2019-12-26 22:10:19 +05:30
filePath,
)}`,
)
2023-04-23 21:23:45 +05:30
.reply(HTTP_STATUS_OK, TEST_FILE_CONTENTS);
2019-12-26 22:10:19 +05:30
});
it('fetches file content', () =>
2021-03-08 18:12:59 +05:30
services.getBaseRawFileData(file, TEST_PROJECT_ID, TEST_COMMIT_SHA).then((content) => {
2019-12-26 22:10:19 +05:30
expect(content).toEqual(TEST_FILE_CONTENTS);
}));
},
);
});
2020-03-13 15:44:24 +05:30
2020-05-24 23:13:21 +05:30
describe('getFiles', () => {
let mock;
let relativeUrlRoot;
const TEST_RELATIVE_URL_ROOT = 'blah-blah';
beforeEach(() => {
jest.spyOn(axios, 'get');
relativeUrlRoot = gon.relative_url_root;
gon.relative_url_root = TEST_RELATIVE_URL_ROOT;
mock = new MockAdapter(axios);
mock
.onGet(`${TEST_RELATIVE_URL_ROOT}/${TEST_PROJECT_ID}/-/files/${TEST_COMMIT_SHA}`)
2023-04-23 21:23:45 +05:30
.reply(HTTP_STATUS_OK, [TEST_FILE_PATH]);
2020-05-24 23:13:21 +05:30
});
afterEach(() => {
mock.restore();
gon.relative_url_root = relativeUrlRoot;
});
it('initates the api call based on the passed path and commit hash', () => {
return services.getFiles(TEST_PROJECT_ID, TEST_COMMIT_SHA).then(({ data }) => {
expect(axios.get).toHaveBeenCalledWith(
`${gon.relative_url_root}/${TEST_PROJECT_ID}/-/files/${TEST_COMMIT_SHA}`,
expect.any(Object),
);
expect(data).toEqual([TEST_FILE_PATH]);
});
});
});
describe('pingUsage', () => {
let mock;
let relativeUrlRoot;
const TEST_RELATIVE_URL_ROOT = 'blah-blah';
beforeEach(() => {
jest.spyOn(axios, 'post');
relativeUrlRoot = gon.relative_url_root;
gon.relative_url_root = TEST_RELATIVE_URL_ROOT;
mock = new MockAdapter(axios);
});
afterEach(() => {
mock.restore();
gon.relative_url_root = relativeUrlRoot;
});
it('posts to usage endpoint', () => {
const TEST_PROJECT_PATH = 'foo/bar';
2021-09-30 23:02:18 +05:30
const axiosURL = `${TEST_RELATIVE_URL_ROOT}/${TEST_PROJECT_PATH}/service_ping/web_ide_pipelines_count`;
2020-05-24 23:13:21 +05:30
2023-04-23 21:23:45 +05:30
mock.onPost(axiosURL).reply(HTTP_STATUS_OK);
2020-05-24 23:13:21 +05:30
return services.pingUsage(TEST_PROJECT_PATH).then(() => {
expect(axios.post).toHaveBeenCalledWith(axiosURL);
});
});
});
2021-06-08 01:23:25 +05:30
describe('getCiConfig', () => {
const TEST_PROJECT_PATH = 'foo/bar';
const TEST_CI_CONFIG = 'test config';
it('queries with the given CI config and project', () => {
const result = { data: { ciConfig: { test: 'data' } } };
query.mockResolvedValue(result);
return services.getCiConfig(TEST_PROJECT_PATH, TEST_CI_CONFIG).then((data) => {
expect(data).toEqual(result.data.ciConfig);
expect(query).toHaveBeenCalledWith({
query: ciConfig,
variables: { projectPath: TEST_PROJECT_PATH, content: TEST_CI_CONFIG },
});
});
});
});
describe('dismissUserCallout', () => {
it('mutates the callout to dismiss', () => {
const result = { data: { callouts: { test: 'data' } } };
mutate.mockResolvedValue(result);
return services.dismissUserCallout('test').then((data) => {
expect(data).toEqual(result.data);
expect(mutate).toHaveBeenCalledWith({
mutation: dismissUserCallout,
variables: { input: { featureName: 'test' } },
});
});
});
});
2022-01-26 12:08:38 +05:30
describe('getProjectPermissionsData', () => {
const TEST_PROJECT_PATH = 'foo/bar';
it('queries for the project permissions', () => {
const result = { data: { project: projectData } };
query.mockResolvedValue(result);
return services.getProjectPermissionsData(TEST_PROJECT_PATH).then((data) => {
expect(data).toEqual(result.data.project);
expect(query).toHaveBeenCalledWith(
expect.objectContaining({
query: getIdeProject,
variables: { projectPath: TEST_PROJECT_PATH },
}),
);
});
});
it('converts the returned GraphQL id to the regular ID number', () => {
const projectId = 2;
const gqlProjectData = {
id: `gid://gitlab/Project/${projectId}`,
userPermissions: {
bogus: true,
},
};
query.mockResolvedValue({ data: { project: gqlProjectData } });
return services.getProjectPermissionsData(TEST_PROJECT_PATH).then((data) => {
expect(data.id).toBe(projectId);
});
});
});
2019-07-31 22:56:46 +05:30
});