fix(Elasticsearch Node): Fix issue stopping search queries being sent (#11464)

This commit is contained in:
Jon 2024-12-18 10:55:40 +00:00 committed by GitHub
parent 54b02acdd7
commit 388a83dfbd
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 117 additions and 5 deletions

View file

@ -56,7 +56,7 @@ export class ElasticsearchApi implements ICredentialType {
test: ICredentialTestRequest = {
request: {
baseURL: '={{$credentials.baseUrl}}',
baseURL: '={{$credentials.baseUrl}}'.replace(/\/$/, ''),
url: '/_xpack?human=false',
skipSslCertificateValidation: '={{$credentials.ignoreSSLIssues}}',
},

View file

@ -172,7 +172,7 @@ export class Elasticsearch implements INodeType {
} else {
responseData = await elasticsearchApiRequest.call(
this,
'GET',
'POST',
`/${indexId}/_search`,
body,
qs,
@ -184,7 +184,7 @@ export class Elasticsearch implements INodeType {
responseData = await elasticsearchApiRequest.call(
this,
'GET',
'POST',
`/${indexId}/_search`,
body,
qs,

View file

@ -20,7 +20,7 @@ export async function elasticsearchBulkApiRequest(this: IExecuteFunctions, body:
method: 'POST',
headers: { 'Content-Type': 'application/x-ndjson' },
body: bulkBody,
url: `${baseUrl}/_bulk`,
url: `${baseUrl.replace(/\/$/, '')}/_bulk`,
skipSslCertificateValidation: ignoreSSLIssues,
returnFullResponse: true,
ignoreHttpStatusErrors: true,
@ -66,7 +66,7 @@ export async function elasticsearchApiRequest(
method,
body,
qs,
url: `${baseUrl}${endpoint}`,
url: `${baseUrl.replace(/\/$/, '')}${endpoint}`,
json: true,
skipSslCertificateValidation: ignoreSSLIssues,
};

View file

@ -0,0 +1,112 @@
import { type IExecuteFunctions, NodeApiError } from 'n8n-workflow';
import { elasticsearchApiRequest } from '../GenericFunctions';
describe('Elasticsearch -> elasticsearchApiRequest', () => {
let mockExecuteFunctions: IExecuteFunctions;
const mockHttpRequestWithAuthentication = jest.fn();
const setupMockFunctions = () => {
mockExecuteFunctions = {
getCredentials: jest.fn().mockResolvedValue({
baseUrl: 'https://example.com',
ignoreSSLIssues: false,
}),
helpers: {
httpRequestWithAuthentication: mockHttpRequestWithAuthentication,
},
getNode: jest.fn().mockReturnValue({}),
} as unknown as IExecuteFunctions;
jest.clearAllMocks();
};
beforeEach(() => {
setupMockFunctions();
mockHttpRequestWithAuthentication.mockClear();
});
const response = { success: true };
it('should make a successful GET API request', async () => {
mockHttpRequestWithAuthentication.mockResolvedValue(response);
const result = await elasticsearchApiRequest.call(
mockExecuteFunctions,
'GET',
'/test-endpoint',
);
expect(result).toEqual(response);
expect(mockExecuteFunctions.helpers.httpRequestWithAuthentication).toHaveBeenCalledWith(
'elasticsearchApi',
expect.objectContaining({
method: 'GET',
url: 'https://example.com/test-endpoint',
json: true,
skipSslCertificateValidation: false,
}),
);
});
it('should make a successful POST API request', async () => {
const body = { key: 'value' };
mockHttpRequestWithAuthentication.mockResolvedValue(response);
const result = await elasticsearchApiRequest.call(
mockExecuteFunctions,
'POST',
'/test-endpoint',
body,
);
expect(result).toEqual(response);
expect(mockExecuteFunctions.helpers.httpRequestWithAuthentication).toHaveBeenCalledWith(
'elasticsearchApi',
expect.objectContaining({
body,
method: 'POST',
url: 'https://example.com/test-endpoint',
json: true,
skipSslCertificateValidation: false,
}),
);
});
it('should handle API request errors', async () => {
const errorResponse = { message: 'Error occurred' };
mockHttpRequestWithAuthentication.mockRejectedValue(errorResponse);
await expect(
elasticsearchApiRequest.call(mockExecuteFunctions, 'GET', '/test-endpoint'),
).rejects.toThrow(NodeApiError);
expect(mockExecuteFunctions.helpers.httpRequestWithAuthentication).toHaveBeenCalledWith(
'elasticsearchApi',
expect.objectContaining({
method: 'GET',
url: 'https://example.com/test-endpoint',
json: true,
skipSslCertificateValidation: false,
}),
);
});
it('should ignore trailing slashes in the base URL', async () => {
mockHttpRequestWithAuthentication.mockResolvedValue(response);
mockExecuteFunctions.getCredentials = jest.fn().mockResolvedValue({
baseUrl: 'https://elastic.domain.com/',
ignoreSSLIssues: false,
});
await elasticsearchApiRequest.call(mockExecuteFunctions, 'GET', '/test-endpoint');
expect(mockExecuteFunctions.helpers.httpRequestWithAuthentication).toHaveBeenCalledWith(
'elasticsearchApi',
expect.objectContaining({
url: 'https://elastic.domain.com/test-endpoint',
}),
);
});
});