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.
Files changed (178) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +163 -0
  3. package/dist/credentials/SmartSuiteApi.credentials.d.ts +8 -0
  4. package/dist/credentials/SmartSuiteApi.credentials.js +38 -0
  5. package/dist/credentials/SmartSuiteApi.credentials.js.map +1 -0
  6. package/dist/credentials/SmartSuiteApi.svg +6 -0
  7. package/dist/index.d.ts +3 -0
  8. package/dist/index.js +12 -0
  9. package/dist/index.js.map +1 -0
  10. package/dist/nodes/SmartSuite/SmartSuite.node.d.ts +27 -0
  11. package/dist/nodes/SmartSuite/SmartSuite.node.js +108 -0
  12. package/dist/nodes/SmartSuite/SmartSuite.node.js.map +1 -0
  13. package/dist/nodes/SmartSuite/SmartSuite.node.json +48 -0
  14. package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.d.ts +23 -0
  15. package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.js +173 -0
  16. package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.js.map +1 -0
  17. package/dist/nodes/SmartSuite/SmartSuiteTrigger.node.json +14 -0
  18. package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.d.ts +1 -0
  19. package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.js +74 -0
  20. package/dist/nodes/SmartSuite/__tests__/actions/api/makeApiRequest.test.js.map +1 -0
  21. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.d.ts +1 -0
  22. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.js +22 -0
  23. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/getCurrentUser.test.js.map +1 -0
  24. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.d.ts +1 -0
  25. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.js +70 -0
  26. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listMembers.test.js.map +1 -0
  27. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.d.ts +1 -0
  28. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.js +43 -0
  29. package/dist/nodes/SmartSuite/__tests__/actions/orgManagement/listTeams.test.js.map +1 -0
  30. package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.d.ts +1 -0
  31. package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.js +178 -0
  32. package/dist/nodes/SmartSuite/__tests__/actions/record/createRecord.test.js.map +1 -0
  33. package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.d.ts +1 -0
  34. package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.js +159 -0
  35. package/dist/nodes/SmartSuite/__tests__/actions/record/deleteRecord.test.js.map +1 -0
  36. package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.d.ts +1 -0
  37. package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.js +127 -0
  38. package/dist/nodes/SmartSuite/__tests__/actions/record/getRecord.test.js.map +1 -0
  39. package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.d.ts +1 -0
  40. package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.js +162 -0
  41. package/dist/nodes/SmartSuite/__tests__/actions/record/listRecord.test.js.map +1 -0
  42. package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.d.ts +1 -0
  43. package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.js +210 -0
  44. package/dist/nodes/SmartSuite/__tests__/actions/record/searchRecord.test.js.map +1 -0
  45. package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.d.ts +1 -0
  46. package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.js +198 -0
  47. package/dist/nodes/SmartSuite/__tests__/actions/record/updateRecord.test.js.map +1 -0
  48. package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.d.ts +1 -0
  49. package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.js +138 -0
  50. package/dist/nodes/SmartSuite/__tests__/actions/record/upsertRecord.test.js.map +1 -0
  51. package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.d.ts +1 -0
  52. package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.js +57 -0
  53. package/dist/nodes/SmartSuite/__tests__/actions/solution/getSolution.test.js.map +1 -0
  54. package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.d.ts +1 -0
  55. package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.js +48 -0
  56. package/dist/nodes/SmartSuite/__tests__/actions/solution/listSolution.test.js.map +1 -0
  57. package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.d.ts +1 -0
  58. package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.js +50 -0
  59. package/dist/nodes/SmartSuite/__tests__/actions/table/createTable.test.js.map +1 -0
  60. package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.d.ts +1 -0
  61. package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.js +93 -0
  62. package/dist/nodes/SmartSuite/__tests__/actions/table/createTableField.test.js.map +1 -0
  63. package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.d.ts +1 -0
  64. package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.js +70 -0
  65. package/dist/nodes/SmartSuite/__tests__/actions/table/getTable.test.js.map +1 -0
  66. package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.d.ts +1 -0
  67. package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.js +78 -0
  68. package/dist/nodes/SmartSuite/__tests__/actions/table/listTable.test.js.map +1 -0
  69. package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.d.ts +10 -0
  70. package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.js +26 -0
  71. package/dist/nodes/SmartSuite/__tests__/helpers/mockResourceInputs.js.map +1 -0
  72. package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.d.ts +2 -0
  73. package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.js +185 -0
  74. package/dist/nodes/SmartSuite/actions/api/ApiRequestDescription.js.map +1 -0
  75. package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.d.ts +3 -0
  76. package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.js +65 -0
  77. package/dist/nodes/SmartSuite/actions/api/makeApiRequest.operation.js.map +1 -0
  78. package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.d.ts +2 -0
  79. package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.js +21 -0
  80. package/dist/nodes/SmartSuite/actions/orgManagement/OrgManagementDescription.js.map +1 -0
  81. package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.d.ts +18 -0
  82. package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.js +39 -0
  83. package/dist/nodes/SmartSuite/actions/orgManagement/getCurrentUser.operation.js.map +1 -0
  84. package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.d.ts +18 -0
  85. package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.js +41 -0
  86. package/dist/nodes/SmartSuite/actions/orgManagement/listMembers.operation.js.map +1 -0
  87. package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.d.ts +18 -0
  88. package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.js +41 -0
  89. package/dist/nodes/SmartSuite/actions/orgManagement/listTeams.operation.js.map +1 -0
  90. package/dist/nodes/SmartSuite/actions/record/RecordDescription.d.ts +2 -0
  91. package/dist/nodes/SmartSuite/actions/record/RecordDescription.js +370 -0
  92. package/dist/nodes/SmartSuite/actions/record/RecordDescription.js.map +1 -0
  93. package/dist/nodes/SmartSuite/actions/record/createRecord.operation.d.ts +87 -0
  94. package/dist/nodes/SmartSuite/actions/record/createRecord.operation.js +55 -0
  95. package/dist/nodes/SmartSuite/actions/record/createRecord.operation.js.map +1 -0
  96. package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.d.ts +24 -0
  97. package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.js +49 -0
  98. package/dist/nodes/SmartSuite/actions/record/deleteRecord.operation.js.map +1 -0
  99. package/dist/nodes/SmartSuite/actions/record/getRecord.operation.d.ts +2 -0
  100. package/dist/nodes/SmartSuite/actions/record/getRecord.operation.js +31 -0
  101. package/dist/nodes/SmartSuite/actions/record/getRecord.operation.js.map +1 -0
  102. package/dist/nodes/SmartSuite/actions/record/listRecord.operation.d.ts +2 -0
  103. package/dist/nodes/SmartSuite/actions/record/listRecord.operation.js +52 -0
  104. package/dist/nodes/SmartSuite/actions/record/listRecord.operation.js.map +1 -0
  105. package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.d.ts +2 -0
  106. package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.js +77 -0
  107. package/dist/nodes/SmartSuite/actions/record/searchRecord.operation.js.map +1 -0
  108. package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.d.ts +2 -0
  109. package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.js +42 -0
  110. package/dist/nodes/SmartSuite/actions/record/updateRecord.operation.js.map +1 -0
  111. package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.d.ts +2 -0
  112. package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.js +66 -0
  113. package/dist/nodes/SmartSuite/actions/record/upsertRecord.operation.js.map +1 -0
  114. package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.d.ts +2 -0
  115. package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.js +54 -0
  116. package/dist/nodes/SmartSuite/actions/solution/SolutionDescription.js.map +1 -0
  117. package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.d.ts +3 -0
  118. package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.js +25 -0
  119. package/dist/nodes/SmartSuite/actions/solution/getSolution.operation.js.map +1 -0
  120. package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.d.ts +3 -0
  121. package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.js +54 -0
  122. package/dist/nodes/SmartSuite/actions/solution/listSolution.operation.js.map +1 -0
  123. package/dist/nodes/SmartSuite/actions/table/TableDescription.d.ts +6 -0
  124. package/dist/nodes/SmartSuite/actions/table/TableDescription.js +153 -0
  125. package/dist/nodes/SmartSuite/actions/table/TableDescription.js.map +1 -0
  126. package/dist/nodes/SmartSuite/actions/table/createTable.operation.d.ts +2 -0
  127. package/dist/nodes/SmartSuite/actions/table/createTable.operation.js +45 -0
  128. package/dist/nodes/SmartSuite/actions/table/createTable.operation.js.map +1 -0
  129. package/dist/nodes/SmartSuite/actions/table/createTableField.operation.d.ts +2 -0
  130. package/dist/nodes/SmartSuite/actions/table/createTableField.operation.js +49 -0
  131. package/dist/nodes/SmartSuite/actions/table/createTableField.operation.js.map +1 -0
  132. package/dist/nodes/SmartSuite/actions/table/getTable.operation.d.ts +2 -0
  133. package/dist/nodes/SmartSuite/actions/table/getTable.operation.js +23 -0
  134. package/dist/nodes/SmartSuite/actions/table/getTable.operation.js.map +1 -0
  135. package/dist/nodes/SmartSuite/actions/table/listTable.operation.d.ts +2 -0
  136. package/dist/nodes/SmartSuite/actions/table/listTable.operation.js +42 -0
  137. package/dist/nodes/SmartSuite/actions/table/listTable.operation.js.map +1 -0
  138. package/dist/nodes/SmartSuite/helpers/getFilterOptions.d.ts +11 -0
  139. package/dist/nodes/SmartSuite/helpers/getFilterOptions.js +376 -0
  140. package/dist/nodes/SmartSuite/helpers/getFilterOptions.js.map +1 -0
  141. package/dist/nodes/SmartSuite/helpers/getValidFilters.d.ts +6 -0
  142. package/dist/nodes/SmartSuite/helpers/getValidFilters.js +47 -0
  143. package/dist/nodes/SmartSuite/helpers/getValidFilters.js.map +1 -0
  144. package/dist/nodes/SmartSuite/helpers/utils.d.ts +21 -0
  145. package/dist/nodes/SmartSuite/helpers/utils.js +62 -0
  146. package/dist/nodes/SmartSuite/helpers/utils.js.map +1 -0
  147. package/dist/nodes/SmartSuite/helpers/validation.d.ts +9 -0
  148. package/dist/nodes/SmartSuite/helpers/validation.js +41 -0
  149. package/dist/nodes/SmartSuite/helpers/validation.js.map +1 -0
  150. package/dist/nodes/SmartSuite/index.d.ts +2 -0
  151. package/dist/nodes/SmartSuite/index.js +12 -0
  152. package/dist/nodes/SmartSuite/index.js.map +1 -0
  153. package/dist/nodes/SmartSuite/methods/listSearch.d.ts +11 -0
  154. package/dist/nodes/SmartSuite/methods/listSearch.js +81 -0
  155. package/dist/nodes/SmartSuite/methods/listSearch.js.map +1 -0
  156. package/dist/nodes/SmartSuite/methods/loadOptions.d.ts +30 -0
  157. package/dist/nodes/SmartSuite/methods/loadOptions.js +133 -0
  158. package/dist/nodes/SmartSuite/methods/loadOptions.js.map +1 -0
  159. package/dist/nodes/SmartSuite/methods/resourceMapping.d.ts +48 -0
  160. package/dist/nodes/SmartSuite/methods/resourceMapping.js +122 -0
  161. package/dist/nodes/SmartSuite/methods/resourceMapping.js.map +1 -0
  162. package/dist/nodes/SmartSuite/methods/router.d.ts +2 -0
  163. package/dist/nodes/SmartSuite/methods/router.js +65 -0
  164. package/dist/nodes/SmartSuite/methods/router.js.map +1 -0
  165. package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.d.ts +9 -0
  166. package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.js +84 -0
  167. package/dist/nodes/SmartSuite/shared/__testHelpers__/mockExecuteFunctions.js.map +1 -0
  168. package/dist/nodes/SmartSuite/shared/resourceInputs.d.ts +15 -0
  169. package/dist/nodes/SmartSuite/shared/resourceInputs.js +112 -0
  170. package/dist/nodes/SmartSuite/shared/resourceInputs.js.map +1 -0
  171. package/dist/nodes/SmartSuite/smartsuite.svg +6 -0
  172. package/dist/nodes/SmartSuite/transport/smartSuiteApi.d.ts +12 -0
  173. package/dist/nodes/SmartSuite/transport/smartSuiteApi.js +111 -0
  174. package/dist/nodes/SmartSuite/transport/smartSuiteApi.js.map +1 -0
  175. package/dist/nodes/SmartSuite/types.d.ts +11 -0
  176. package/dist/nodes/SmartSuite/types.js +4 -0
  177. package/dist/nodes/SmartSuite/types.js.map +1 -0
  178. 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,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,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,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,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,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,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