Backquote/backtick symbol (`) is not escaped correctly

This commit is contained in:
Raman Savitski 2020-11-27 19:20:32 +03:00
parent 5559a15d2a
commit df9e447aa3
6 changed files with 28 additions and 2 deletions

View File

@ -0,0 +1,9 @@
import { escapeDescription } from './escapeDescription';
describe('escapeDescription', () => {
it('should escape', () => {
expect(escapeDescription('')).toEqual('');
expect(escapeDescription('fooBar')).toEqual('fooBar');
expect(escapeDescription('foo `test` bar')).toEqual('foo \\`test\\` bar');
});
});

View File

@ -0,0 +1,3 @@
export function escapeDescription(value: string): string {
return value.replace(/`/g, '\\`');
}

View File

@ -1,5 +1,6 @@
import type { OperationError } from '../../../client/interfaces/OperationError';
import type { OperationResponse } from '../../../client/interfaces/OperationResponse';
import { escapeDescription } from './escapeDescription';
export function getOperationErrors(operationResponses: OperationResponse[]): OperationError[] {
return operationResponses
@ -8,6 +9,6 @@ export function getOperationErrors(operationResponses: OperationResponse[]): Ope
})
.map(response => ({
code: response.code,
description: response.description!,
description: escapeDescription(response.description!),
}));
}

View File

@ -0,0 +1,9 @@
import { escapeDescription } from './escapeDescription';
describe('escapeDescription', () => {
it('should escape', () => {
expect(escapeDescription('')).toEqual('');
expect(escapeDescription('fooBar')).toEqual('fooBar');
expect(escapeDescription('foo `test` bar')).toEqual('foo \\`test\\` bar');
});
});

View File

@ -0,0 +1,3 @@
export function escapeDescription(value: string): string {
return value.replace(/`/g, '\\`');
}

View File

@ -1,5 +1,6 @@
import type { OperationError } from '../../../client/interfaces/OperationError';
import type { OperationResponse } from '../../../client/interfaces/OperationResponse';
import { escapeDescription } from './escapeDescription';
export function getOperationErrors(operationResponses: OperationResponse[]): OperationError[] {
return operationResponses
@ -8,6 +9,6 @@ export function getOperationErrors(operationResponses: OperationResponse[]): Ope
})
.map(response => ({
code: response.code,
description: response.description!,
description: escapeDescription(response.description!),
}));
}