n8n-nodes-smartsuite 2.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +163 -0
- package/dist/credentials/SmartSuiteApi.credentials.d.ts +8 -0
- package/dist/credentials/SmartSuiteApi.credentials.js +38 -0
- package/dist/credentials/SmartSuiteApi.credentials.js.map +1 -0
- package/dist/credentials/SmartSuiteApi.svg +6 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/nodes/SmartSuite/SmartSuite.node.d.ts +27 -0
- package/dist/nodes/SmartSuite/SmartSuite.node.js +108 -0
- package/dist/nodes/SmartSuite/SmartSuite.node.js.map +1 -0
- package/dist/nodes/SmartSuite/SmartSuite.node.json +48 -0
- package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.d.ts +23 -0
- package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.js +173 -0
- package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.js.map +1 -0
- package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.json +14 -0
- package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.js +74 -0
- package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.js +22 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.js +70 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.js +43 -0
- package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.js +178 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.js +159 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.js +127 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.js +162 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.js +210 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.js +198 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.js +138 -0
- package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.js +57 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.js +48 -0
- package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.js +50 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.js +93 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.js +70 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.d.ts +1 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.js +78 -0
- package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.js.map +1 -0
- package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.d.ts +10 -0
- package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.js +26 -0
- package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.js +185 -0
- package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.d.ts +3 -0
- package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.js +65 -0
- package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.js +21 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.d.ts +18 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.js +39 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.d.ts +18 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.js +41 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.d.ts +18 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.js +41 -0
- package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/RecordDescription.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/RecordDescription.js +370 -0
- package/dist/nodes/SmartSuite/actions/record/RecordDescription.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/createRecord.operation.d.ts +87 -0
- package/dist/nodes/SmartSuite/actions/record/createRecord.operation.js +55 -0
- package/dist/nodes/SmartSuite/actions/record/createRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.d.ts +24 -0
- package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.js +49 -0
- package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/getRecord.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/getRecord.operation.js +31 -0
- package/dist/nodes/SmartSuite/actions/record/getRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/listRecord.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/listRecord.operation.js +52 -0
- package/dist/nodes/SmartSuite/actions/record/listRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.js +77 -0
- package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.js +42 -0
- package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.js +66 -0
- package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.js +54 -0
- package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.d.ts +3 -0
- package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.js +25 -0
- package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.d.ts +3 -0
- package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.js +54 -0
- package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/table/TableDescription.d.ts +6 -0
- package/dist/nodes/SmartSuite/actions/table/TableDescription.js +153 -0
- package/dist/nodes/SmartSuite/actions/table/TableDescription.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/table/createTable.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/table/createTable.operation.js +45 -0
- package/dist/nodes/SmartSuite/actions/table/createTable.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/table/createTableField.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/table/createTableField.operation.js +49 -0
- package/dist/nodes/SmartSuite/actions/table/createTableField.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/table/getTable.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/table/getTable.operation.js +23 -0
- package/dist/nodes/SmartSuite/actions/table/getTable.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/actions/table/listTable.operation.d.ts +2 -0
- package/dist/nodes/SmartSuite/actions/table/listTable.operation.js +42 -0
- package/dist/nodes/SmartSuite/actions/table/listTable.operation.js.map +1 -0
- package/dist/nodes/SmartSuite/helpers/getFilterOptions.d.ts +11 -0
- package/dist/nodes/SmartSuite/helpers/getFilterOptions.js +376 -0
- package/dist/nodes/SmartSuite/helpers/getFilterOptions.js.map +1 -0
- package/dist/nodes/SmartSuite/helpers/getValidFilters.d.ts +6 -0
- package/dist/nodes/SmartSuite/helpers/getValidFilters.js +47 -0
- package/dist/nodes/SmartSuite/helpers/getValidFilters.js.map +1 -0
- package/dist/nodes/SmartSuite/helpers/utils.d.ts +21 -0
- package/dist/nodes/SmartSuite/helpers/utils.js +62 -0
- package/dist/nodes/SmartSuite/helpers/utils.js.map +1 -0
- package/dist/nodes/SmartSuite/helpers/validation.d.ts +9 -0
- package/dist/nodes/SmartSuite/helpers/validation.js +41 -0
- package/dist/nodes/SmartSuite/helpers/validation.js.map +1 -0
- package/dist/nodes/SmartSuite/index.d.ts +2 -0
- package/dist/nodes/SmartSuite/index.js +12 -0
- package/dist/nodes/SmartSuite/index.js.map +1 -0
- package/dist/nodes/SmartSuite/methods/listSearch.d.ts +11 -0
- package/dist/nodes/SmartSuite/methods/listSearch.js +81 -0
- package/dist/nodes/SmartSuite/methods/listSearch.js.map +1 -0
- package/dist/nodes/SmartSuite/methods/loadOptions.d.ts +30 -0
- package/dist/nodes/SmartSuite/methods/loadOptions.js +133 -0
- package/dist/nodes/SmartSuite/methods/loadOptions.js.map +1 -0
- package/dist/nodes/SmartSuite/methods/resourceMapping.d.ts +48 -0
- package/dist/nodes/SmartSuite/methods/resourceMapping.js +122 -0
- package/dist/nodes/SmartSuite/methods/resourceMapping.js.map +1 -0
- package/dist/nodes/SmartSuite/methods/router.d.ts +2 -0
- package/dist/nodes/SmartSuite/methods/router.js +65 -0
- package/dist/nodes/SmartSuite/methods/router.js.map +1 -0
- package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.d.ts +9 -0
- package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.js +84 -0
- package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.js.map +1 -0
- package/dist/nodes/SmartSuite/shared/resourceInputs.d.ts +15 -0
- package/dist/nodes/SmartSuite/shared/resourceInputs.js +112 -0
- package/dist/nodes/SmartSuite/shared/resourceInputs.js.map +1 -0
- package/dist/nodes/SmartSuite/smartsuite.svg +6 -0
- package/dist/nodes/SmartSuite/transport/smartSuiteApi.d.ts +12 -0
- package/dist/nodes/SmartSuite/transport/smartSuiteApi.js +111 -0
- package/dist/nodes/SmartSuite/transport/smartSuiteApi.js.map +1 -0
- package/dist/nodes/SmartSuite/types.d.ts +11 -0
- package/dist/nodes/SmartSuite/types.js +4 -0
- package/dist/nodes/SmartSuite/types.js.map +1 -0
- package/package.json +99 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SmartSuiteTrigger.node.js","sourceRoot":"","sources":["../../../src/nodes/SmartSuite/SmartSuiteTrigger.node.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
{
|
|
2
|
+
"node": "n8n-nodes-smartsuite.smartSuiteTrigger",
|
|
3
|
+
"nodeVersion": "1.0",
|
|
4
|
+
"codexVersion": "1.0",
|
|
5
|
+
"categories": ["Triggers"],
|
|
6
|
+
"subcategories": ["No-Code", "Database"],
|
|
7
|
+
"aliases": ["Smart Suite"],
|
|
8
|
+
"keywords": ["smartsuite","no-code","database","records","tables","automation"],
|
|
9
|
+
"resources": {
|
|
10
|
+
"primaryDocumentation": [
|
|
11
|
+
{ "url": "https://developers.smartsuite.com/docs/intro" }
|
|
12
|
+
]
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// src/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.ts
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
const makeApiRequest_operation_1 = require("../../../actions/api/makeApiRequest.operation");
|
|
38
|
+
const smartSuiteApi = __importStar(require("../../../transport/smartSuiteApi"));
|
|
39
|
+
const mockExecuteFunctions_1 = require("../../../shared/__testHelpers__/mockExecuteFunctions");
|
|
40
|
+
describe('SmartSuite – makeApiRequest Operation', () => {
|
|
41
|
+
let executeMock;
|
|
42
|
+
const fakeResponse = { foo: 'bar' };
|
|
43
|
+
beforeAll(() => {
|
|
44
|
+
executeMock = (0, mockExecuteFunctions_1.mockExecuteFunctions)({
|
|
45
|
+
apiRequestResponse: fakeResponse,
|
|
46
|
+
});
|
|
47
|
+
// stub out getNodeParameter for all parameters
|
|
48
|
+
jest.spyOn(executeMock, 'getNodeParameter')
|
|
49
|
+
.mockImplementation((name, _itemIndex) => {
|
|
50
|
+
switch (name) {
|
|
51
|
+
case 'operation': return 'POST';
|
|
52
|
+
case 'url': return '/some/endpoint';
|
|
53
|
+
case 'sendQuery': return true;
|
|
54
|
+
case 'specifyQuery': return 'json';
|
|
55
|
+
case 'jsonQuery': return { q: 'test' };
|
|
56
|
+
case 'sendHeaders': return true;
|
|
57
|
+
case 'specifyHeaders': return 'json';
|
|
58
|
+
case 'jsonHeaders': return { 'X-Custom': 'value' };
|
|
59
|
+
case 'sendBody': return true;
|
|
60
|
+
case 'specifyBody': return 'json';
|
|
61
|
+
case 'jsonBody': return { hello: 'world' };
|
|
62
|
+
default: return undefined;
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
// mock the transport-layer apiRequest call
|
|
66
|
+
jest.spyOn(smartSuiteApi, 'apiRequest').mockResolvedValue(fakeResponse);
|
|
67
|
+
});
|
|
68
|
+
it('should call apiRequest with the right args and return its result', async () => {
|
|
69
|
+
const items = await makeApiRequest_operation_1.executeMakeApiRequest.call(executeMock, 0);
|
|
70
|
+
expect(smartSuiteApi.apiRequest).toHaveBeenCalledWith('POST', '/some/endpoint', { hello: 'world' }, { q: 'test' }, { 'X-Custom': 'value' });
|
|
71
|
+
expect(items).toEqual([{ json: fakeResponse }]);
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
//# sourceMappingURL=makeApiRequest.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"makeApiRequest.test.js","sourceRoot":"","sources":["../../../../../../src/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.ts"],"names":[],"mappings":";AAAA,oEAAoE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGpE,4FAAsF;AACtF,gFAAkE;AAClE,+FAA4F;AAE5F,QAAQ,CAAC,uCAAuC,EAAE,GAAG,EAAE;IACrD,IAAI,WAA8B,CAAC;IACnC,MAAM,YAAY,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;IAEpC,SAAS,CAAC,GAAG,EAAE;QACb,WAAW,GAAG,IAAA,2CAAoB,EAAC;YACjC,kBAAkB,EAAE,YAAY;SACjC,CAAC,CAAC;QAEH,+CAA+C;QAC/C,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,kBAAkB,CAAC;aACxC,kBAAkB,CAAC,CAAC,IAAY,EAAE,UAAmB,EAAE,EAAE;YACxD,QAAQ,IAAI,EAAE,CAAC;gBACb,KAAK,WAAW,CAAC,CAAC,OAAO,MAAM,CAAC;gBAChC,KAAK,KAAK,CAAC,CAAC,OAAO,gBAAgB,CAAC;gBACpC,KAAK,WAAW,CAAC,CAAC,OAAO,IAAI,CAAC;gBAC9B,KAAK,cAAc,CAAC,CAAC,OAAO,MAAM,CAAC;gBACnC,KAAK,WAAW,CAAC,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC;gBACvC,KAAK,aAAa,CAAC,CAAC,OAAO,IAAI,CAAC;gBAChC,KAAK,gBAAgB,CAAC,CAAC,OAAO,MAAM,CAAC;gBACrC,KAAK,aAAa,CAAC,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;gBACnD,KAAK,UAAU,CAAC,CAAC,OAAO,IAAI,CAAC;gBAC7B,KAAK,aAAa,CAAC,CAAC,OAAO,MAAM,CAAC;gBAClC,KAAK,UAAU,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;gBAC3C,OAAO,CAAC,CAAC,OAAO,SAAS,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEL,2CAA2C;QAC3C,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kEAAkE,EAAE,KAAK,IAAI,EAAE;QAChF,MAAM,KAAK,GAAG,MAAM,gDAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAE/D,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,oBAAoB,CACnD,MAAM,EACN,gBAAgB,EAChB,EAAE,KAAK,EAAE,OAAO,EAAE,EAClB,EAAE,CAAC,EAAE,MAAM,EAAE,EACb,EAAE,UAAU,EAAE,OAAO,EAAE,CACxB,CAAC;QACF,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,YAAY,EAAwB,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// src/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.ts
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
const getCurrentUser_operation_1 = require("../../../actions/orgManagement/getCurrentUser.operation");
|
|
5
|
+
const mockExecuteFunctions_1 = require("../../../shared/__testHelpers__/mockExecuteFunctions");
|
|
6
|
+
describe('SmartSuite – getCurrentUser Operation', () => {
|
|
7
|
+
let executeMock;
|
|
8
|
+
beforeAll(() => {
|
|
9
|
+
executeMock = (0, mockExecuteFunctions_1.mockExecuteFunctions)({
|
|
10
|
+
apiRequestResponse: { id: 'u-123', name: 'Alice Admin', email: 'alice@example.com' }, // Mock valid response
|
|
11
|
+
});
|
|
12
|
+
});
|
|
13
|
+
it('should return the current user as a single output item', async () => {
|
|
14
|
+
const [item] = await getCurrentUser_operation_1.execute.call(executeMock);
|
|
15
|
+
expect(item.json).toMatchObject({
|
|
16
|
+
id: 'u-123',
|
|
17
|
+
name: 'Alice Admin',
|
|
18
|
+
email: 'alice@example.com',
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
//# sourceMappingURL=getCurrentUser.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getCurrentUser.test.js","sourceRoot":"","sources":["../../../../../../src/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.ts"],"names":[],"mappings":";AAAA,8EAA8E;;AAG9E,sGAAoG;AACpG,+FAA4F;AAE5F,QAAQ,CAAC,uCAAuC,EAAE,GAAG,EAAE;IACrD,IAAI,WAA8B,CAAC;IAEnC,SAAS,CAAC,GAAG,EAAE;QACb,WAAW,GAAG,IAAA,2CAAoB,EAAC;YACjC,kBAAkB,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,mBAAmB,EAAE,EAAG,sBAAsB;SAC9G,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;QACtE,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,kCAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC;YAC9B,EAAE,EAAE,OAAO;YACX,IAAI,EAAE,aAAa;YACnB,KAAK,EAAE,mBAAmB;SAC3B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const transport = __importStar(require("../../../transport/smartSuiteApi"));
|
|
37
|
+
const utils = __importStar(require("../../../helpers/utils"));
|
|
38
|
+
const listMembers_operation_1 = require("../../../actions/orgManagement/listMembers.operation");
|
|
39
|
+
describe('SmartSuite – listMembers Operation', () => {
|
|
40
|
+
let nodeMock;
|
|
41
|
+
const fakeMembers = [
|
|
42
|
+
{ id: '1', name: 'Alice' },
|
|
43
|
+
{ id: '2', name: 'Bob' },
|
|
44
|
+
];
|
|
45
|
+
beforeEach(() => {
|
|
46
|
+
nodeMock = {
|
|
47
|
+
getNode: jest.fn(),
|
|
48
|
+
helpers: {
|
|
49
|
+
returnJsonArray: jest.fn((data) => data.map(item => ({ json: item }))),
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
// Stub the API
|
|
53
|
+
jest.spyOn(transport, 'apiRequest').mockResolvedValue({ items: fakeMembers });
|
|
54
|
+
// Silence debug logging
|
|
55
|
+
jest.spyOn(utils, 'debugLog').mockImplementation(() => { });
|
|
56
|
+
});
|
|
57
|
+
it('should return each member as a separate output item', async () => {
|
|
58
|
+
// <<— cast to any so TS stops complaining about missing props
|
|
59
|
+
const result = await listMembers_operation_1.execute.call(nodeMock);
|
|
60
|
+
// 1) API call was made correctly
|
|
61
|
+
expect(transport.apiRequest).toHaveBeenCalledWith('POST', '/members/list/');
|
|
62
|
+
// 2) Helper was invoked with our fake members
|
|
63
|
+
expect(nodeMock.helpers.returnJsonArray).toHaveBeenCalledWith(fakeMembers);
|
|
64
|
+
// 3) Final output matches
|
|
65
|
+
expect(Array.isArray(result)).toBe(true);
|
|
66
|
+
expect(result).toHaveLength(fakeMembers.length);
|
|
67
|
+
expect(result.map(r => r.json)).toEqual(fakeMembers);
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
//# sourceMappingURL=listMembers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listMembers.test.js","sourceRoot":"","sources":["../../../../../../src/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,4EAA8D;AAC9D,8DAAgD;AAChD,gGAA8F;AAE9F,QAAQ,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAClD,IAAI,QAKF,CAAC;IAEH,MAAM,WAAW,GAAkB;QACjC,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE;QAC1B,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE;KACzB,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACd,QAAQ,GAAG;YACT,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE;YAClB,OAAO,EAAE;gBACP,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAmB,EAAE,EAAE,CAC/C,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CACnC;aACF;SACF,CAAC;QAEF,eAAe;QACf,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QAE9E,wBAAwB;QACxB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,8DAA8D;QAC9D,MAAM,MAAM,GAAG,MAAM,+BAAW,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;QAEvD,iCAAiC;QACjC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAE5E,8CAA8C;QAC9C,MAAM,CAAC,QAAQ,CAAC,OAAQ,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAC;QAE5E,0BAA0B;QAC1B,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
// Pull in your transport and utils via require() to avoid TS export issues
|
|
4
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
5
|
+
const transport = require('../../../transport/smartSuiteApi');
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
7
|
+
const utils = require('../../../helpers/utils');
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
9
|
+
const listTeamsModule = require('../../../actions/orgManagement/listTeams.operation');
|
|
10
|
+
// Grab whichever export holds your function
|
|
11
|
+
const listTeams = listTeamsModule.execute ?? listTeamsModule.default ?? listTeamsModule.listTeams;
|
|
12
|
+
describe('SmartSuite – listTeams Operation', () => {
|
|
13
|
+
const fakeTeams = [
|
|
14
|
+
{ id: 'team-1', name: 'Team Alpha' },
|
|
15
|
+
{ id: 'team-2', name: 'Team Beta' },
|
|
16
|
+
];
|
|
17
|
+
let ctx;
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
ctx = {
|
|
20
|
+
getNode: jest.fn(),
|
|
21
|
+
helpers: {
|
|
22
|
+
returnJsonArray: jest.fn((data) => data.map(item => ({ json: item }))),
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
// Stub the API to return our fake teams
|
|
26
|
+
jest.spyOn(transport, 'apiRequest').mockResolvedValue({ items: fakeTeams });
|
|
27
|
+
// Silence any debug logs
|
|
28
|
+
jest.spyOn(utils, 'debugLog').mockImplementation(() => { });
|
|
29
|
+
});
|
|
30
|
+
it('should return each team as a separate output item', async () => {
|
|
31
|
+
// cast to any so TS ignores missing IExecuteFunctions props
|
|
32
|
+
const result = await listTeams.call(ctx);
|
|
33
|
+
// 1) Was the API called with the correct endpoint?
|
|
34
|
+
expect(transport.apiRequest).toHaveBeenCalledWith('POST', '/teams/list/');
|
|
35
|
+
// 2) Did we hand the raw array to returnJsonArray?
|
|
36
|
+
expect(ctx.helpers.returnJsonArray).toHaveBeenCalledWith(fakeTeams);
|
|
37
|
+
// 3) Does the final output match our fakeTeams?
|
|
38
|
+
expect(Array.isArray(result)).toBe(true);
|
|
39
|
+
expect(result).toHaveLength(fakeTeams.length);
|
|
40
|
+
expect(result.map((r) => r.json)).toEqual(fakeTeams);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=listTeams.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listTeams.test.js","sourceRoot":"","sources":["../../../../../../src/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.ts"],"names":[],"mappings":";;AAGA,2EAA2E;AAC3E,8DAA8D;AAC9D,MAAM,SAAS,GACb,OAAO,CAAC,kCAAkC,CAAC,CAAC;AAC9C,8DAA8D;AAC9D,MAAM,KAAK,GAA4B,OAAO,CAAC,wBAAwB,CAAC,CAAC;AACzE,8DAA8D;AAC9D,MAAM,eAAe,GAAQ,OAAO,CAAC,oDAAoD,CAAC,CAAC;AAE3F,4CAA4C;AAC5C,MAAM,SAAS,GACb,eAAe,CAAC,OAAO,IAAI,eAAe,CAAC,OAAO,IAAI,eAAe,CAAC,SAAS,CAAC;AAElF,QAAQ,CAAC,kCAAkC,EAAE,GAAG,EAAE;IAChD,MAAM,SAAS,GAAkB;QAC/B,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,EAAE;QACpC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE;KACpC,CAAC;IAEF,IAAI,GAKH,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACd,GAAG,GAAG;YACJ,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE;YAClB,OAAO,EAAE;gBACP,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAmB,EAAE,EAAE,CAC/C,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CACnC;aACF;SACF,CAAC;QAEF,wCAAwC;QACxC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QAC5E,yBAAyB;QACzB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACjE,4DAA4D;QAC5D,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,GAAU,CAAC,CAAC;QAEhD,mDAAmD;QACnD,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QAE1E,mDAAmD;QACnD,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAEpE,gDAAgD;QAChD,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC9C,MAAM,CACJ,MAAM,CAAC,GAAG,CAAC,CAAC,CAAqB,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAC9C,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// src/nodes/SmartSuite/__tests__/actions/record/createRecord.test.ts
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
const createRecord_operation_1 = require("../../../actions/record/createRecord.operation");
|
|
38
|
+
const utils = __importStar(require("../../../helpers/utils"));
|
|
39
|
+
const mockResourceInputs_1 = require("../../../__tests__/helpers/mockResourceInputs"); // Import the helper function
|
|
40
|
+
// Mock validation helpers
|
|
41
|
+
jest.mock('../../../helpers/validation', () => ({
|
|
42
|
+
getSolutionId: jest.fn().mockResolvedValue('dummy-solution-id'),
|
|
43
|
+
getTableId: jest.fn().mockResolvedValue('dummy-table-id'),
|
|
44
|
+
}));
|
|
45
|
+
// Mock transport apiRequest
|
|
46
|
+
jest.mock('../../../transport/smartSuiteApi', () => ({
|
|
47
|
+
apiRequest: jest.fn().mockResolvedValue({ id: 'record-id', foo: 'bar' }),
|
|
48
|
+
}));
|
|
49
|
+
const smartSuiteApi_1 = require("../../../transport/smartSuiteApi");
|
|
50
|
+
describe('SmartSuite – createRecord Operation', () => {
|
|
51
|
+
let executeMock;
|
|
52
|
+
beforeEach(() => {
|
|
53
|
+
jest.clearAllMocks();
|
|
54
|
+
});
|
|
55
|
+
it('should call apiRequest with correct args and return the created record', async () => {
|
|
56
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
57
|
+
parameters: {
|
|
58
|
+
'fieldsUi': {
|
|
59
|
+
fieldsValues: [{ field: 'Field1', value: 'Value1' }],
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
apiRequestResponse: { id: 'record-id', foo: 'bar' },
|
|
63
|
+
inputData: [{ json: {} }],
|
|
64
|
+
});
|
|
65
|
+
const result = await createRecord_operation_1.execute.call(executeMock);
|
|
66
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledWith('POST', '/applications/dummy-table-id/records/', { [utils.asIdString('Field1')]: 'Value1' });
|
|
67
|
+
expect(result).toEqual([{ json: { id: 'record-id', foo: 'bar' } }]);
|
|
68
|
+
});
|
|
69
|
+
it('should throw error if no fields provided', async () => {
|
|
70
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
71
|
+
apiRequestResponse: {},
|
|
72
|
+
inputData: [{ json: {} }],
|
|
73
|
+
parameters: {
|
|
74
|
+
'fieldsUi': {
|
|
75
|
+
fieldsValues: [],
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
await expect(createRecord_operation_1.execute.call(executeMock)).rejects.toThrow('You must provide at least one field to create a record.');
|
|
80
|
+
});
|
|
81
|
+
it('should throw error for reserved field', async () => {
|
|
82
|
+
const isReservedSpy = jest.spyOn(utils, 'isReservedField').mockReturnValue(true);
|
|
83
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
84
|
+
apiRequestResponse: {},
|
|
85
|
+
inputData: [{ json: {} }],
|
|
86
|
+
parameters: {
|
|
87
|
+
'fieldsUi': {
|
|
88
|
+
fieldsValues: [{ field: 'AnyField', value: 'Val' }],
|
|
89
|
+
},
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
await expect(createRecord_operation_1.execute.call(executeMock)).rejects.toThrow(/Cannot set system field/);
|
|
93
|
+
isReservedSpy.mockRestore();
|
|
94
|
+
});
|
|
95
|
+
it('should process multiple items correctly', async () => {
|
|
96
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
97
|
+
apiRequestResponse: { id: 'record-id', foo: 'bar' },
|
|
98
|
+
inputData: [{ json: {} }, { json: {} }],
|
|
99
|
+
parameters: {
|
|
100
|
+
'fieldsUi': {
|
|
101
|
+
fieldsValues: [{ field: 'FieldA', value: 'A' }],
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
const result = await createRecord_operation_1.execute.call(executeMock);
|
|
106
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledTimes(2);
|
|
107
|
+
expect(result).toHaveLength(2);
|
|
108
|
+
});
|
|
109
|
+
it('should slugify field names in payload', async () => {
|
|
110
|
+
const asIdSpy = jest.spyOn(utils, 'asIdString').mockImplementation((input) => {
|
|
111
|
+
const val = String(input);
|
|
112
|
+
return val
|
|
113
|
+
.toLowerCase()
|
|
114
|
+
.replace(/[^a-z0-9]+/g, '_')
|
|
115
|
+
.replace(/^_|_$/g, '');
|
|
116
|
+
});
|
|
117
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
118
|
+
apiRequestResponse: { id: 'record-id' },
|
|
119
|
+
inputData: [{ json: {} }],
|
|
120
|
+
parameters: {
|
|
121
|
+
'fieldsUi': {
|
|
122
|
+
fieldsValues: [{ field: 'My Field', value: 'Val' }],
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
});
|
|
126
|
+
await createRecord_operation_1.execute.call(executeMock);
|
|
127
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledWith('POST', '/applications/dummy-table-id/records/', { my_field: 'Val' });
|
|
128
|
+
asIdSpy.mockRestore();
|
|
129
|
+
});
|
|
130
|
+
it('should wrap non-object response as empty object', async () => {
|
|
131
|
+
smartSuiteApi_1.apiRequest.mockResolvedValue('not-an-object');
|
|
132
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
133
|
+
apiRequestResponse: 'not-an-object',
|
|
134
|
+
inputData: [{ json: {} }],
|
|
135
|
+
parameters: {
|
|
136
|
+
'fieldsUi': {
|
|
137
|
+
fieldsValues: [{ field: 'FieldX', value: 'X' }],
|
|
138
|
+
},
|
|
139
|
+
},
|
|
140
|
+
});
|
|
141
|
+
const result = await createRecord_operation_1.execute.call(executeMock);
|
|
142
|
+
expect(result).toEqual([{ json: {} }]);
|
|
143
|
+
});
|
|
144
|
+
it('should build payload for multiple fields in a single item', async () => {
|
|
145
|
+
const fieldsValues = [
|
|
146
|
+
{ field: 'Field1', value: 'V1' },
|
|
147
|
+
{ field: 'Field2', value: 'V2' },
|
|
148
|
+
];
|
|
149
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
150
|
+
apiRequestResponse: { id: 'record-id' },
|
|
151
|
+
inputData: [{ json: {} }],
|
|
152
|
+
parameters: {
|
|
153
|
+
'fieldsUi': {
|
|
154
|
+
fieldsValues: fieldsValues,
|
|
155
|
+
},
|
|
156
|
+
},
|
|
157
|
+
});
|
|
158
|
+
await createRecord_operation_1.execute.call(executeMock);
|
|
159
|
+
const expectedPayload = Object.fromEntries(fieldsValues.map(({ field, value }) => [utils.asIdString(field), value]));
|
|
160
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledWith('POST', '/applications/dummy-table-id/records/', expectedPayload);
|
|
161
|
+
});
|
|
162
|
+
it('should call getSolutionId and getTableId once per execution', async () => {
|
|
163
|
+
const { getSolutionId, getTableId } = require('../../../helpers/validation');
|
|
164
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
165
|
+
apiRequestResponse: { id: 'record-id' },
|
|
166
|
+
inputData: [{ json: {} }],
|
|
167
|
+
parameters: {
|
|
168
|
+
'fieldsUi': {
|
|
169
|
+
fieldsValues: [{ field: 'Field1', value: 'Value1' }],
|
|
170
|
+
},
|
|
171
|
+
},
|
|
172
|
+
});
|
|
173
|
+
await createRecord_operation_1.execute.call(executeMock);
|
|
174
|
+
expect(getSolutionId).toHaveBeenCalledTimes(1);
|
|
175
|
+
expect(getTableId).toHaveBeenCalledTimes(1);
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
//# sourceMappingURL=createRecord.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createRecord.test.js","sourceRoot":"","sources":["../../../../../../src/nodes/SmartSuite/__tests__/actions/record/createRecord.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// src/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.ts
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
const deleteRecord_operation_1 = require("../../../actions/record/deleteRecord.operation");
|
|
38
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
39
|
+
const utils = __importStar(require("../../../helpers/utils"));
|
|
40
|
+
const validation = __importStar(require("../../../helpers/validation"));
|
|
41
|
+
const mockResourceInputs_1 = require("../../../__tests__/helpers/mockResourceInputs");
|
|
42
|
+
// Mock the validation helper to return a dummy table ID
|
|
43
|
+
jest.mock('../../../helpers/validation', () => ({
|
|
44
|
+
getTableId: jest.fn().mockResolvedValue('dummy-table-id'),
|
|
45
|
+
}));
|
|
46
|
+
// Mock the transport apiRequest function
|
|
47
|
+
jest.mock('../../../transport/smartSuiteApi', () => ({
|
|
48
|
+
apiRequest: jest.fn(),
|
|
49
|
+
}));
|
|
50
|
+
const smartSuiteApi_1 = require("../../../transport/smartSuiteApi");
|
|
51
|
+
describe('SmartSuite – deleteRecord Operation', () => {
|
|
52
|
+
let executeMock;
|
|
53
|
+
const fakeRecordId = 'record-id';
|
|
54
|
+
beforeEach(() => {
|
|
55
|
+
jest.clearAllMocks();
|
|
56
|
+
smartSuiteApi_1.apiRequest.mockResolvedValue({}); // Default mock response for apiRequest
|
|
57
|
+
});
|
|
58
|
+
it('should call apiRequest with correct args and return success', async () => {
|
|
59
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
60
|
+
parameters: { recordId: fakeRecordId },
|
|
61
|
+
apiRequestResponse: {},
|
|
62
|
+
inputData: [{ json: {} }],
|
|
63
|
+
});
|
|
64
|
+
const result = await deleteRecord_operation_1.execute.call(executeMock);
|
|
65
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledWith('DELETE', `/applications/dummy-table-id/records/${fakeRecordId}/`);
|
|
66
|
+
expect(result).toEqual([{ json: { success: true } }]);
|
|
67
|
+
});
|
|
68
|
+
it('should return empty array when no items passed', async () => {
|
|
69
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
70
|
+
apiRequestResponse: {},
|
|
71
|
+
inputData: [],
|
|
72
|
+
});
|
|
73
|
+
const result = await deleteRecord_operation_1.execute.call(executeMock);
|
|
74
|
+
expect(result).toEqual([]);
|
|
75
|
+
});
|
|
76
|
+
it('should call debugLog at start', async () => {
|
|
77
|
+
const debugSpy = jest.spyOn(utils, 'debugLog');
|
|
78
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
79
|
+
parameters: { recordId: fakeRecordId },
|
|
80
|
+
apiRequestResponse: {},
|
|
81
|
+
inputData: [{ json: {} }],
|
|
82
|
+
});
|
|
83
|
+
await deleteRecord_operation_1.execute.call(executeMock);
|
|
84
|
+
expect(debugSpy).toHaveBeenCalledWith('[Record] deleteRecord.execute called', executeMock.getNode().parameters);
|
|
85
|
+
});
|
|
86
|
+
it('should only resolve tableId once', async () => {
|
|
87
|
+
const tableIdSpy = jest.spyOn(validation, 'getTableId');
|
|
88
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
89
|
+
apiRequestResponse: {},
|
|
90
|
+
inputData: [{ json: {} }, { json: {} }],
|
|
91
|
+
});
|
|
92
|
+
// override recordId for valid inputs
|
|
93
|
+
// @ts-ignore
|
|
94
|
+
executeMock.getNodeParameter = (_name, _i) => 'id';
|
|
95
|
+
await deleteRecord_operation_1.execute.call(executeMock);
|
|
96
|
+
expect(tableIdSpy).toHaveBeenCalledTimes(1);
|
|
97
|
+
expect(tableIdSpy).toHaveBeenCalledWith(0);
|
|
98
|
+
});
|
|
99
|
+
it('should throw if recordId is blank or whitespace', async () => {
|
|
100
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
101
|
+
parameters: { recordId: ' ' },
|
|
102
|
+
apiRequestResponse: {},
|
|
103
|
+
inputData: [{ json: {} }],
|
|
104
|
+
});
|
|
105
|
+
await expect(deleteRecord_operation_1.execute.call(executeMock)).rejects.toThrow('Record ID is required for Delete Record operation.');
|
|
106
|
+
});
|
|
107
|
+
it('should throw "Record ID is not valid" when API returns 404 status', async () => {
|
|
108
|
+
smartSuiteApi_1.apiRequest.mockRejectedValueOnce({ status: 404 });
|
|
109
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
110
|
+
parameters: { recordId: 'missing-id' },
|
|
111
|
+
apiRequestResponse: {},
|
|
112
|
+
inputData: [{ json: {} }],
|
|
113
|
+
});
|
|
114
|
+
await expect(deleteRecord_operation_1.execute.call(executeMock)).rejects.toThrow('Record ID is not valid');
|
|
115
|
+
});
|
|
116
|
+
it('should throw raw API error for non-404 failures', async () => {
|
|
117
|
+
const err = new Error('Unexpected failure');
|
|
118
|
+
smartSuiteApi_1.apiRequest.mockRejectedValueOnce(err);
|
|
119
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
120
|
+
parameters: { recordId: 'bad-id' },
|
|
121
|
+
apiRequestResponse: {},
|
|
122
|
+
inputData: [{ json: {} }],
|
|
123
|
+
});
|
|
124
|
+
await expect(deleteRecord_operation_1.execute.call(executeMock)).rejects.toThrow('Unexpected failure');
|
|
125
|
+
});
|
|
126
|
+
it('should surface correct itemIndex on blank-ID error for second item', async () => {
|
|
127
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
128
|
+
apiRequestResponse: {},
|
|
129
|
+
inputData: [{ json: {} }, { json: {} }],
|
|
130
|
+
});
|
|
131
|
+
// override so index 1 returns blank
|
|
132
|
+
// @ts-ignore
|
|
133
|
+
executeMock.getNodeParameter = (_name, idx) => (idx === 1 ? ' ' : 'good-id');
|
|
134
|
+
try {
|
|
135
|
+
await deleteRecord_operation_1.execute.call(executeMock);
|
|
136
|
+
}
|
|
137
|
+
catch (error) {
|
|
138
|
+
expect(error).toBeInstanceOf(n8n_workflow_1.NodeOperationError);
|
|
139
|
+
expect(error.context?.itemIndex).toBe(1);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
it('should delete multiple records when multiple items passed', async () => {
|
|
143
|
+
const ids = ['one', 'two', 'three'];
|
|
144
|
+
executeMock = (0, mockResourceInputs_1.createMockExecuteWithResources)({
|
|
145
|
+
apiRequestResponse: {},
|
|
146
|
+
inputData: ids.map(() => ({ json: {} })),
|
|
147
|
+
});
|
|
148
|
+
// override recordId per index
|
|
149
|
+
const originalGetNodeParam = executeMock.getNodeParameter.bind(executeMock);
|
|
150
|
+
// @ts-ignore
|
|
151
|
+
executeMock.getNodeParameter = (name, index) => ids[index];
|
|
152
|
+
const result = await deleteRecord_operation_1.execute.call(executeMock);
|
|
153
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenCalledTimes(ids.length);
|
|
154
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenNthCalledWith(1, 'DELETE', `/applications/dummy-table-id/records/${ids[0]}/`);
|
|
155
|
+
expect(smartSuiteApi_1.apiRequest).toHaveBeenNthCalledWith(ids.length, 'DELETE', `/applications/dummy-table-id/records/${ids[ids.length - 1]}/`);
|
|
156
|
+
expect(result).toEqual(ids.map(() => ({ json: { success: true } })));
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
//# sourceMappingURL=deleteRecord.test.js.map
|