feat(Microsoft SharePoint Node): New node (#13727)

This commit is contained in:
feelgood-interface
2025-05-16 09:55:10 +02:00
committed by GitHub
parent 64b3fa3d17
commit 954b66218f
57 changed files with 6284 additions and 12 deletions

View File

@@ -0,0 +1,476 @@
import type { MockProxy } from 'jest-mock-extended';
import { mock } from 'jest-mock-extended';
import type { ILoadOptionsFunctions } from 'n8n-workflow';
import { MicrosoftSharePoint } from '../../MicrosoftSharePoint.node';
import { credentials } from '../credentials';
describe('Microsoft SharePoint Node', () => {
describe('List search', () => {
let loadOptionsFunctions: MockProxy<ILoadOptionsFunctions>;
let mockRequestWithAuthentication: jest.Mock;
let node: MicrosoftSharePoint;
beforeEach(() => {
loadOptionsFunctions = mock<ILoadOptionsFunctions>();
mockRequestWithAuthentication = jest.fn();
loadOptionsFunctions.helpers.httpRequestWithAuthentication = mockRequestWithAuthentication;
loadOptionsFunctions.getCredentials.mockResolvedValue(
credentials.microsoftSharePointOAuth2Api,
);
node = new MicrosoftSharePoint();
});
afterEach(() => {
jest.resetAllMocks();
});
it('should list search files', async () => {
const mockResponse = {
'@odata.nextLink':
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
value: [
{
'@odata.etag': '"{70EC0A2F-6C3E-425F-BBE2-1D4E758F90EE},1"',
id: '01SPEVVYBPBLWHAPTML5BLXYQ5JZ2Y7EHO',
name: 'Folder1',
},
{
'@odata.etag': '"{10F06786-5AAF-434A-8A4E-3ED44DE4A987},6"',
id: '01SPEVVYEGM7YBBL22JJBYUTR62RG6JKMH',
name: 'file2.jpg',
file: {
hashes: {
quickXorHash: 'uFgaWYgAVo55sg4DIR9BTMzlmH8=',
},
irmEffectivelyEnabled: false,
irmEnabled: false,
mimeType: 'image/jpeg',
},
},
{
'@odata.etag': '"{0EC452E0-D0F7-4ECF-87D7-B738F865313B},1"',
id: '01SPEVVYHAKLCA556QZ5HIPV5XHD4GKMJ3',
name: 'file1.txt',
file: {
hashes: {
quickXorHash: 'AAAAAAAAAAAAAAAAAAAAAAAAAAA=',
},
irmEffectivelyEnabled: false,
irmEnabled: false,
mimeType: 'text/plain',
},
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('folder');
const listSearchResult = await node.methods.listSearch.getFiles.call(
loadOptionsFunctions,
'file',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
qs: {
$filter: "name eq 'file'",
},
});
expect(listSearchResult).toEqual({
results: [
{ name: 'file1.txt', value: '01SPEVVYHAKLCA556QZ5HIPV5XHD4GKMJ3' },
{ name: 'file2.jpg', value: '01SPEVVYEGM7YBBL22JJBYUTR62RG6JKMH' },
],
paginationToken:
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
});
it('should list search files with pagination', async () => {
const mockResponse = {
value: [
{
'@odata.etag': '"{0EC452E0-D0F7-4ECF-87D7-B738F865313B},1"',
id: '01SPEVVYHAKLCA556QZ5HIPV5XHD4GKMJ3',
name: 'file1.txt',
file: {
hashes: {
quickXorHash: 'AAAAAAAAAAAAAAAAAAAAAAAAAAA=',
},
irmEffectivelyEnabled: false,
irmEnabled: false,
mimeType: 'text/plain',
},
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('folder');
const listSearchResult = await node.methods.listSearch.getFiles.call(
loadOptionsFunctions,
undefined,
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
url: 'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
expect(listSearchResult).toEqual({
results: [{ name: 'file1.txt', value: '01SPEVVYHAKLCA556QZ5HIPV5XHD4GKMJ3' }],
});
});
it('should list search folders', async () => {
const mockResponse = {
'@odata.nextLink':
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
value: [
{
'@odata.etag': '"{529A466D-D708-4857-B771-24F467546A2A},1"',
id: '01SPEVVYDNI2NFECGXK5ELO4JE6RTVI2RK',
name: 'Folder2',
folder: {
childCount: 1,
view: {},
},
},
{
'@odata.etag': '"{A3B2AE2A-2099-4194-A38B-EC7182CA3000},1"',
id: '01SPEVVYBKV2ZKHGJASRA2HC7MOGBMUMAA',
name: 'Folder1',
folder: {
childCount: 7,
view: {},
},
},
{
'@odata.etag': '"{A6EF0C5E-0248-482A-AD79-0EFDB6622473},1"',
id: '01SPEVVYC6BTX2MSACFJEK26IO7W3GEJDT',
name: 'file.txt',
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
const listSearchResult = await node.methods.listSearch.getFolders.call(
loadOptionsFunctions,
'folder',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
qs: {
$filter: "name eq 'folder'",
},
});
expect(listSearchResult).toEqual({
results: [
{
name: 'Folder1',
value: '01SPEVVYBKV2ZKHGJASRA2HC7MOGBMUMAA',
},
{
name: 'Folder2',
value: '01SPEVVYDNI2NFECGXK5ELO4JE6RTVI2RK',
},
],
paginationToken:
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
});
it('should list search folders with pagination', async () => {
const mockResponse = {
value: [
{
'@odata.etag': '"{A3B2AE2A-2099-4194-A38B-EC7182CA3000},1"',
id: '01SPEVVYBKV2ZKHGJASRA2HC7MOGBMUMAA',
name: 'Folder1',
folder: {
childCount: 7,
view: {},
},
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
const listSearchResult = await node.methods.listSearch.getFolders.call(
loadOptionsFunctions,
undefined,
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
url: 'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/items?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
expect(listSearchResult).toEqual({
results: [
{
name: 'Folder1',
value: '01SPEVVYBKV2ZKHGJASRA2HC7MOGBMUMAA',
},
],
});
});
it('should list search items', async () => {
const mockResponse = {
'@odata.nextLink':
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/listItems?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
value: [
{
'@odata.etag': '"98af0386-66bd-4524-a653-80be05e0f14d,2"',
id: '2',
'fields@odata.navigationLink': 'fields',
fields: {
'@odata.etag': '"98af0386-66bd-4524-a653-80be05e0f14d,2"',
Title: 'Title 2',
},
},
{
'@odata.etag': '"0ea4148a-f8e5-4f2f-a815-2e2be693b164,4"',
id: '1',
'fields@odata.navigationLink': 'fields',
fields: {
'@odata.etag': '"0ea4148a-f8e5-4f2f-a815-2e2be693b164,4"',
Title: 'Title 1',
},
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('list');
const listSearchResult = await node.methods.listSearch.getItems.call(
loadOptionsFunctions,
'Title',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
qs: {
$filter: "fields/Title eq 'Title'",
},
});
expect(listSearchResult).toEqual({
results: [
{
name: 'Title 1',
value: '1',
},
{
name: 'Title 2',
value: '2',
},
],
paginationToken:
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/listItems?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
});
it('should list search items with pagination', async () => {
const mockResponse = {
value: [
{
'@odata.etag': '"0ea4148a-f8e5-4f2f-a815-2e2be693b164,4"',
id: '1',
'fields@odata.navigationLink': 'fields',
fields: {
'@odata.etag': '"0ea4148a-f8e5-4f2f-a815-2e2be693b164,4"',
},
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('list');
const listSearchResult = await node.methods.listSearch.getItems.call(
loadOptionsFunctions,
undefined,
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/listItems?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
url: 'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/listItems?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
expect(listSearchResult).toEqual({
results: [
{
name: '1',
value: '1',
},
],
});
});
it('should list search lists', async () => {
const mockResponse = {
'@odata.nextLink':
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/lists?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
value: [
{
'@odata.etag': '"58a279af-1f06-4392-a5ed-2b37fa1d6c1d,5"',
id: '58a279af-1f06-4392-a5ed-2b37fa1d6c1d',
displayName: 'List 2',
},
{
'@odata.etag': '"23af565a-da89-48f0-ae5f-2d4a7244b446,0"',
id: '23af565a-da89-48f0-ae5f-2d4a7244b446',
displayName: 'List 1',
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
const listSearchResult = await node.methods.listSearch.getLists.call(
loadOptionsFunctions,
'List',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
qs: {
$filter: "displayName eq 'List'",
},
});
expect(listSearchResult).toEqual({
results: [
{
name: 'List 1',
value: '23af565a-da89-48f0-ae5f-2d4a7244b446',
},
{
name: 'List 2',
value: '58a279af-1f06-4392-a5ed-2b37fa1d6c1d',
},
],
paginationToken:
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/lists?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
});
it('should list search lists with pagination', async () => {
const mockResponse = {
value: [
{
'@odata.etag': '"23af565a-da89-48f0-ae5f-2d4a7244b446,0"',
id: '23af565a-da89-48f0-ae5f-2d4a7244b446',
displayName: 'List 1',
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
const listSearchResult = await node.methods.listSearch.getLists.call(
loadOptionsFunctions,
undefined,
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/lists?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
url: 'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/lists?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
expect(listSearchResult).toEqual({
results: [
{
name: 'List 1',
value: '23af565a-da89-48f0-ae5f-2d4a7244b446',
},
],
});
});
it('should list search sites', async () => {
const mockResponse = {
'@odata.nextLink':
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/sites?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
value: [
{
id: 'mydomain.sharepoint.com,cf38a104-c767-48c7-93d0-c093e3909c78,3abe66fd-ec23-469f-abc6-332e3a95bf75',
title: 'Site 2',
},
{
id: 'mydomain.sharepoint.com,3286a459-bc45-4aab-8200-b9ba7edcca96,3abe66fd-ec23-469f-abc6-332e3a95bf75',
title: 'Site 1',
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
const listSearchResult = await node.methods.listSearch.getSites.call(
loadOptionsFunctions,
'Site',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
qs: {
$search: 'Site',
},
});
expect(listSearchResult).toEqual({
results: [
{
name: 'Site 1',
value:
'mydomain.sharepoint.com,3286a459-bc45-4aab-8200-b9ba7edcca96,3abe66fd-ec23-469f-abc6-332e3a95bf75',
},
{
name: 'Site 2',
value:
'mydomain.sharepoint.com,cf38a104-c767-48c7-93d0-c093e3909c78,3abe66fd-ec23-469f-abc6-332e3a95bf75',
},
],
paginationToken:
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/sites?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
});
it('should list search sites and pagination', async () => {
const mockResponse = {
value: [
{
id: 'mydomain.sharepoint.com,3286a459-bc45-4aab-8200-b9ba7edcca96,3abe66fd-ec23-469f-abc6-332e3a95bf75',
title: 'Site 1',
},
],
};
mockRequestWithAuthentication.mockReturnValue(mockResponse);
const listSearchResult = await node.methods.listSearch.getSites.call(
loadOptionsFunctions,
undefined,
'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/sites?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
);
expect(mockRequestWithAuthentication).toHaveBeenCalledTimes(1);
expect(mockRequestWithAuthentication.mock.calls[0][1]).toMatchObject({
url: 'https://mydomain.sharepoint.com/_api/v2.0/sites(%27mydomain.sharepoint.com,site1%27)/sites?%24skiptoken=aWQ9MjFFQkEzOUMtMkU3My00NzgwLUFBQzEtMTVDNzlDMTk4QjlB',
});
expect(listSearchResult).toEqual({
results: [
{
name: 'Site 1',
value:
'mydomain.sharepoint.com,3286a459-bc45-4aab-8200-b9ba7edcca96,3abe66fd-ec23-469f-abc6-332e3a95bf75',
},
],
});
});
});
});

View File

@@ -0,0 +1,886 @@
import type { MockProxy } from 'jest-mock-extended';
import { mock } from 'jest-mock-extended';
import type { ILoadOptionsFunctions } from 'n8n-workflow';
import { getMappingColumns } from '../../methods/resourceMapping';
describe('Microsoft SharePoint Node', () => {
describe('Resource mapping', () => {
let loadOptionsFunctions: MockProxy<ILoadOptionsFunctions>;
beforeEach(() => {
loadOptionsFunctions = mock<ILoadOptionsFunctions>();
});
afterEach(() => {
jest.resetAllMocks();
});
it('should map columns', async () => {
loadOptionsFunctions.getCredentials.mockResolvedValue({});
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('list');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('create');
const mockResponse = {
value: [
{
'@odata.etag': '"0"',
id: '0x0100362657F7588C5C438072A77E0EF184F4000272C0D1046D984B8097B3C00D199EDE',
description: 'Create a new list item.',
eTag: '"0"',
group: 'List Content Types',
hidden: false,
name: 'Item',
parentId: '0x01',
readOnly: false,
sealed: false,
columns: [
{
displayName: 'Title',
'@odata.etag': '"1"',
columnGroup: 'Custom Columns',
customFormatter: '',
description: 'Description Title',
enforceUniqueValues: true,
eTag: '"1"',
hidden: false,
id: 'fa564e0f-0c70-4ab9-b863-0177e6ddd247',
indexed: true,
isDeletable: false,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'Title',
readOnly: false,
required: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: true,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Othertitle',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Descriptio Othertitle',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '82642ec8-ef9b-478f-acf9-31f7d45fbc31',
indexed: false,
isDeletable: false,
isReorderable: false,
isSealed: false,
propagateChanges: false,
name: 'LinkTitle',
readOnly: true,
type: 'unknownFutureValue',
default: '',
},
{
displayName: 'Choice',
'@odata.etag': '"2"',
columnGroup: 'Custom Columns',
customFormatter:
'{"elmType":"div","style":{"flex-wrap":"wrap","display":"flex"},"children":[{"elmType":"div","style":{"box-sizing":"border-box","padding":"4px 8px 5px 8px","overflow":"hidden","text-overflow":"ellipsis","display":"flex","border-radius":"16px","height":"24px","align-items":"center","white-space":"nowrap","margin":"4px 4px 4px 4px"},"attributes":{"class":{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 1"]},"sp-css-backgroundColor-BgCornflowerBlue sp-css-color-CornflowerBlueFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 2"]},"sp-css-backgroundColor-BgMintGreen sp-css-color-MintGreenFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 3"]},"sp-css-backgroundColor-BgGold sp-css-color-GoldFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]",""]},"","sp-field-borderAllRegular sp-field-borderAllSolid sp-css-borderColor-neutralSecondary"]}]}]}]}},"children":[{"elmType":"span","style":{"overflow":"hidden","text-overflow":"ellipsis","padding":"0 3px"},"txtContent":"[$choice]","attributes":{"class":{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 1"]},"sp-css-color-CornflowerBlueFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 2"]},"sp-css-color-MintGreenFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]","Choice 3"]},"sp-css-color-GoldFont",{"operator":":","operands":[{"operator":"==","operands":["[$choice]",""]},"",""]}]}]}]}}}]}],"templateId":"BgColorChoicePill"}',
description: 'Description Choice',
enforceUniqueValues: false,
eTag: '"2"',
hidden: false,
id: '21d4577a-e5f2-461d-a9cf-f7956c502f4e',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'choice',
readOnly: false,
type: 'choice',
default: '',
choice: {
allowTextEntry: false,
choices: ['Choice 1', 'Choice 2', 'Choice 3'],
displayAs: 'dropDownMenu',
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Datetime',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Datetime',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '7e2cf00a-1df6-4c1c-8ea9-d92ef3c7760e',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'datetime',
readOnly: false,
type: 'dateTime',
default: '',
dateTime: {
displayAs: 'standard',
format: 'dateOnly',
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Person',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Person',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '574f4483-ec83-41a0-b772-67b331695c56',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'person',
readOnly: false,
type: 'user',
default: '',
personOrGroup: {
allowMultipleSelection: false,
displayAs: 'nameWithPresence',
format: 'peopleOnly',
hasPrefix: false,
noLookupFieldHeader: false,
},
},
{
displayName: 'Number',
'@odata.etag': '"2"',
columnGroup: 'Custom Columns',
description: 'Description Number',
enforceUniqueValues: false,
eTag: '"2"',
hidden: false,
id: 'c69c2fc9-b6fd-4a08-8750-a293b7c888a3',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'number',
readOnly: false,
type: 'number',
default: 0,
number: {
decimalPlaces: 'automatic',
displayAs: 'number',
maximum: 1.7976931348623157e308,
minimum: -1.7976931348623157e308,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Bool',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Whether Description Bool',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '955880c3-8c95-4609-93ef-cdbd2deef1b2',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'bool',
readOnly: false,
type: 'boolean',
default: false,
boolean: {},
defaultValue: {
value: '1',
},
},
{
displayName: 'Hyperlink',
'@odata.etag': '"2"',
columnGroup: 'Custom Columns',
description: 'Description Hyperlink',
enforceUniqueValues: false,
eTag: '"2"',
hidden: false,
id: 'a6352b41-95e7-4cbf-9184-aae4fe92d865',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'hyperlink',
readOnly: false,
type: 'url',
default: '',
hyperlinkOrPicture: {
isPicture: false,
},
},
{
displayName: 'Currency',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Currency',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '40d9b8f9-05e0-4105-bc35-0c969eeb0096',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'currency',
readOnly: false,
type: 'currency',
default: '',
currency: {
decimalPlaces: 'automatic',
displayAs: 'number',
locale: 'en-US',
maximum: 1.7976931348623157e308,
minimum: -1.7976931348623157e308,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Location',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '5bfb0a2c-04ed-4a59-ae6e-de0d97c8352b',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'location',
readOnly: false,
type: 'location',
default: '',
location: {},
},
{
displayName: 'location: Country/Region',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Country/Region',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: 'db61a63e-558b-4e41-b895-2da2f40a7a23',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'CountryOrRegion',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'location: State',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: State',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: 'c24ae779-ee80-4e8c-b291-c716f1fdce66',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'State',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'location: City',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: City',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '7fb3c8e7-8a8c-4488-a768-4db6922b53f4',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'City',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'location: Postal Code',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Postal Code',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '1fa93efa-579f-48cb-b1e3-f2a8fdb615fe',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'PostalCode',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'location: Street',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Street',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '1ce8048e-a619-40fb-86b2-c5963c0a7526',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'Street',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'location: Coordinates',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Coordinates',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '079b0670-2a3d-4a71-abe5-c0023a66879d',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'GeoLoc',
readOnly: true,
type: 'geolocation',
default: '',
geolocation: {},
},
{
displayName: 'location: Name',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Name',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '73a8bcce-484b-4fd6-84be-47ef648c9c45',
indexed: false,
isDeletable: true,
isReorderable: false,
isSealed: true,
propagateChanges: false,
name: 'DispName',
readOnly: true,
type: 'text',
default: '',
text: {
allowMultipleLines: false,
appendChangesToExistingText: false,
autoHyperLink: false,
linesForEditing: 0,
maxLength: 255,
},
validation: {
defaultLanguage: 'en-US',
descriptions: [
{
languageTag: 'en-US',
},
],
},
},
{
displayName: 'Image',
'@odata.etag': '"0"',
columnGroup: 'Custom Columns',
description: 'Description Location: Image',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: '2a485bec-bab9-493b-9214-2be0b8566a25',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'image',
readOnly: false,
type: 'thumbnail',
default: '',
thumbnail: {},
},
{
displayName: 'Metadata',
'@odata.etag': '"2"',
columnGroup: 'Custom Columns',
customFormatter: '',
description: 'Description Location: Metadata',
enforceUniqueValues: false,
eTag: '"2"',
hidden: false,
id: '2d8cb8ec-4a8f-43ae-87fa-e832b4631f0d',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'metadata',
readOnly: false,
staticName: 'metadata',
type: 'term',
default: '',
defaultValue: {
value: '',
},
term: {
allowMultipleValues: false,
showFullyQualifiedName: false,
},
},
{
displayName: 'Lookup',
'@odata.etag': '"2"',
columnGroup: 'Custom Columns',
description: 'Description Lookup',
enforceUniqueValues: false,
eTag: '"2"',
hidden: false,
id: '44bdab3a-ac89-4b40-acfd-707510f93719',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'lookup',
readOnly: false,
type: 'lookup',
default: '',
lookup: {
allowMultipleValues: false,
allowUnlimitedLength: false,
columnName: 'Title',
displayFormUrl:
'https://mydomain.sharepoint.com/sites/n8ntest10/_layouts/15/listform.aspx?PageType=4&ListId=58a279af-1f06-4392-a5ed-2b37fa1d6c1d',
listId: '58a279af-1f06-4392-a5ed-2b37fa1d6c1d',
},
},
{
displayName: 'Rating (0-5)',
'@odata.etag': '"1"',
columnGroup: 'Content Feedback',
description: 'Average value of all the ratings that have been submitted',
enforceUniqueValues: false,
eTag: '"1"',
hidden: false,
id: '5a14d1ab-1513-48c7-97b3-657a5ba6c742',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'AverageRating',
readOnly: false,
type: 'unknownFutureValue',
default: '',
},
{
displayName: 'Number of Ratings',
'@odata.etag': '"0"',
columnGroup: 'Content Feedback',
description: 'Number of ratings submitted',
enforceUniqueValues: false,
eTag: '"0"',
hidden: false,
id: 'b1996002-9167-45e5-a4df-b2c41c6723c7',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'RatingCount',
readOnly: false,
type: 'unknownFutureValue',
default: '',
},
{
displayName: 'Number of Likes',
'@odata.etag': '"1"',
columnGroup: 'Content Feedback',
description: 'Description Number of Likes',
enforceUniqueValues: false,
eTag: '"1"',
hidden: false,
id: '6e4d832b-f610-41a8-b3e0-239608efda41',
indexed: false,
isDeletable: true,
isReorderable: true,
isSealed: false,
propagateChanges: false,
name: 'LikesCount',
readOnly: false,
type: 'unknownFutureValue',
default: '',
},
],
},
],
};
loadOptionsFunctions.helpers.httpRequestWithAuthentication = jest
.fn()
.mockReturnValue(mockResponse);
const fields = await getMappingColumns.call(loadOptionsFunctions);
expect(fields).toEqual({
fields: [
{
id: 'Title',
canBeUsedToMatch: true,
defaultMatch: false,
display: true,
displayName: 'Title',
readOnly: false,
required: true,
type: 'string',
},
{
id: 'choice',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Choice',
readOnly: false,
required: undefined,
type: 'options',
options: [
{
name: 'Choice 1',
value: 'Choice 1',
},
{
name: 'Choice 2',
value: 'Choice 2',
},
{
name: 'Choice 3',
value: 'Choice 3',
},
],
},
{
id: 'datetime',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Datetime',
readOnly: false,
required: undefined,
type: 'dateTime',
},
{
id: 'person',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Person',
readOnly: false,
required: undefined,
type: 'string',
},
{
id: 'number',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Number',
readOnly: false,
required: undefined,
type: 'number',
},
{
id: 'bool',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Bool',
readOnly: false,
required: undefined,
type: 'boolean',
},
{
id: 'hyperlink',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Hyperlink',
readOnly: true,
required: undefined,
type: undefined,
},
{
id: 'currency',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Currency',
readOnly: false,
required: undefined,
type: 'number',
},
{
id: 'location',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Location',
readOnly: true,
required: undefined,
type: undefined,
},
{
id: 'image',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Image',
readOnly: false,
required: undefined,
type: 'object',
},
{
id: 'metadata',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Metadata',
readOnly: true,
required: undefined,
type: undefined,
},
{
id: 'lookup',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Lookup',
readOnly: false,
required: undefined,
type: 'string',
},
{
id: 'AverageRating',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Rating (0-5)',
readOnly: false,
required: undefined,
type: 'number',
},
{
id: 'RatingCount',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Number of Ratings',
readOnly: false,
required: undefined,
type: 'number',
},
{
id: 'LikesCount',
canBeUsedToMatch: false,
defaultMatch: false,
display: true,
displayName: 'Number of Likes',
readOnly: false,
required: undefined,
type: 'number',
},
],
});
});
it('should map columns with id for update', async () => {
loadOptionsFunctions.getCredentials.mockResolvedValue({});
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('site');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('list');
loadOptionsFunctions.getNodeParameter.mockReturnValueOnce('update');
const mockResponse = {
value: [
{
columns: [],
},
],
};
loadOptionsFunctions.helpers.httpRequestWithAuthentication = jest
.fn()
.mockReturnValue(mockResponse);
const fields = await getMappingColumns.call(loadOptionsFunctions);
expect(fields).toEqual({
fields: [
{
id: 'id',
canBeUsedToMatch: true,
defaultMatch: false,
display: true,
displayName: 'ID',
readOnly: true,
required: true,
type: 'string',
},
],
});
});
});
});