mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-20 03:12:15 +00:00
fix(Spotify Node): Fix issue with null values breaking the response (#12080)
This commit is contained in:
@@ -0,0 +1,62 @@
|
||||
import type { IExecuteFunctions, IHookFunctions } from 'n8n-workflow';
|
||||
import { NodeApiError } from 'n8n-workflow';
|
||||
|
||||
import { spotifyApiRequest } from '../GenericFunctions';
|
||||
|
||||
describe('Spotify -> GenericFunctions', () => {
|
||||
let mockThis: IHookFunctions | IExecuteFunctions;
|
||||
|
||||
beforeEach(() => {
|
||||
mockThis = {
|
||||
helpers: {
|
||||
httpRequestWithAuthentication: jest.fn(),
|
||||
},
|
||||
getNode: jest.fn().mockReturnValue({}),
|
||||
} as unknown as IHookFunctions | IExecuteFunctions;
|
||||
});
|
||||
|
||||
it('should make a request with the correct options', async () => {
|
||||
const method = 'GET';
|
||||
const endpoint = '/me';
|
||||
const body = {};
|
||||
const query = { limit: 10 };
|
||||
const response = { data: 'test' };
|
||||
|
||||
(mockThis.helpers.httpRequestWithAuthentication as jest.Mock).mockResolvedValue(response);
|
||||
|
||||
const result = await spotifyApiRequest.call(mockThis, method, endpoint, body, query);
|
||||
|
||||
expect(mockThis.helpers.httpRequestWithAuthentication).toHaveBeenCalledWith(
|
||||
'spotifyOAuth2Api',
|
||||
{
|
||||
method,
|
||||
headers: {
|
||||
'User-Agent': 'n8n',
|
||||
'Content-Type': 'text/plain',
|
||||
Accept: ' application/json',
|
||||
},
|
||||
qs: query,
|
||||
url: `https://api.spotify.com/v1${endpoint}`,
|
||||
json: true,
|
||||
},
|
||||
);
|
||||
|
||||
expect(result).toEqual(response);
|
||||
});
|
||||
|
||||
it('should throw a NodeApiError on request failure', async () => {
|
||||
const method = 'GET';
|
||||
const endpoint = '/me';
|
||||
const body = {};
|
||||
const query = { limit: 10 };
|
||||
const error = new Error('Request failed');
|
||||
|
||||
(mockThis.helpers.httpRequestWithAuthentication as jest.Mock).mockRejectedValue(error);
|
||||
|
||||
await expect(spotifyApiRequest.call(mockThis, method, endpoint, body, query)).rejects.toThrow(
|
||||
NodeApiError,
|
||||
);
|
||||
|
||||
expect(mockThis.getNode).toHaveBeenCalled();
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user