@flow-scanner/lightning-flow-scanner-core 6.17.1 → 6.17.3

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 (508) hide show
  1. package/README.md +642 -0
  2. package/{types/main → main}/models/FlowGraph.d.ts +11 -1
  3. package/{out/main → main}/models/FlowGraph.js +18 -7
  4. package/{out/main → main}/rules/MissingRecordTriggerFilter.js +4 -2
  5. package/package.json +9 -58
  6. package/.husky/pre-commit +0 -1
  7. package/.husky/pre-push +0 -1
  8. package/.prettierignore +0 -5
  9. package/.swcrc +0 -26
  10. package/.turbo/turbo-build.log +0 -17
  11. package/.turbo/turbo-test.log +0 -144
  12. package/.turbo/turbo-vite$colon$dist.log +0 -21
  13. package/coverage/coverage-final.json +0 -63
  14. package/coverage/lcov-report/base.css +0 -224
  15. package/coverage/lcov-report/block-navigation.js +0 -87
  16. package/coverage/lcov-report/favicon.png +0 -0
  17. package/coverage/lcov-report/index.html +0 -236
  18. package/coverage/lcov-report/prettify.css +0 -1
  19. package/coverage/lcov-report/prettify.js +0 -2
  20. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  21. package/coverage/lcov-report/sorter.js +0 -210
  22. package/coverage/lcov-report/src/index.html +0 -116
  23. package/coverage/lcov-report/src/index.ts.html +0 -238
  24. package/coverage/lcov-report/src/main/adapters/RegexAdapter.ts.html +0 -118
  25. package/coverage/lcov-report/src/main/adapters/index.html +0 -116
  26. package/coverage/lcov-report/src/main/config/NodeIcons.ts.html +0 -376
  27. package/coverage/lcov-report/src/main/config/RuleRegistry.ts.html +0 -646
  28. package/coverage/lcov-report/src/main/config/VariableIcons.ts.html +0 -253
  29. package/coverage/lcov-report/src/main/config/index.html +0 -146
  30. package/coverage/lcov-report/src/main/enums/MetaType.ts.html +0 -100
  31. package/coverage/lcov-report/src/main/enums/MetadataType.ts.html +0 -103
  32. package/coverage/lcov-report/src/main/enums/MetadataTypes.ts.html +0 -100
  33. package/coverage/lcov-report/src/main/enums/index.html +0 -116
  34. package/coverage/lcov-report/src/main/interfaces/IRulesConfig.ts.html +0 -133
  35. package/coverage/lcov-report/src/main/interfaces/index.html +0 -116
  36. package/coverage/lcov-report/src/main/internals/index.html +0 -116
  37. package/coverage/lcov-report/src/main/internals/internals.ts.html +0 -190
  38. package/coverage/lcov-report/src/main/libs/BuildFlow.ts.html +0 -127
  39. package/coverage/lcov-report/src/main/libs/Compiler.ts.html +0 -241
  40. package/coverage/lcov-report/src/main/libs/ConvertFlowNodes.ts.html +0 -97
  41. package/coverage/lcov-report/src/main/libs/DynamicRule.ts.html +0 -118
  42. package/coverage/lcov-report/src/main/libs/ExportDetails.ts.html +0 -256
  43. package/coverage/lcov-report/src/main/libs/ExportDiagram.ts.html +0 -331
  44. package/coverage/lcov-report/src/main/libs/ExportSarif.ts.html +0 -358
  45. package/coverage/lcov-report/src/main/libs/FixFlows.ts.html +0 -265
  46. package/coverage/lcov-report/src/main/libs/GenerateMarkdown.ts.html +0 -331
  47. package/coverage/lcov-report/src/main/libs/GetRuleDefinitions.ts.html +0 -274
  48. package/coverage/lcov-report/src/main/libs/ParseFlows.ts.html +0 -184
  49. package/coverage/lcov-report/src/main/libs/RuleDocumentation.ts.html +0 -190
  50. package/coverage/lcov-report/src/main/libs/ScanFlows.ts.html +0 -508
  51. package/coverage/lcov-report/src/main/libs/exportAsDetails.ts.html +0 -160
  52. package/coverage/lcov-report/src/main/libs/exportAsSarif.ts.html +0 -346
  53. package/coverage/lcov-report/src/main/libs/index.html +0 -251
  54. package/coverage/lcov-report/src/main/models/FlatViolation.ts.html +0 -106
  55. package/coverage/lcov-report/src/main/models/Flow.ts.html +0 -1057
  56. package/coverage/lcov-report/src/main/models/FlowAttribute.ts.html +0 -115
  57. package/coverage/lcov-report/src/main/models/FlowElement.ts.html +0 -133
  58. package/coverage/lcov-report/src/main/models/FlowElementConnector.ts.html +0 -169
  59. package/coverage/lcov-report/src/main/models/FlowGraph.ts.html +0 -1672
  60. package/coverage/lcov-report/src/main/models/FlowMetadata.ts.html +0 -106
  61. package/coverage/lcov-report/src/main/models/FlowNode.ts.html +0 -1252
  62. package/coverage/lcov-report/src/main/models/FlowResource.ts.html +0 -106
  63. package/coverage/lcov-report/src/main/models/FlowType.ts.html +0 -244
  64. package/coverage/lcov-report/src/main/models/FlowVariable.ts.html +0 -553
  65. package/coverage/lcov-report/src/main/models/LoopRuleCommon.ts.html +0 -235
  66. package/coverage/lcov-report/src/main/models/ParsedFlow.ts.html +0 -121
  67. package/coverage/lcov-report/src/main/models/RuleCommon.ts.html +0 -442
  68. package/coverage/lcov-report/src/main/models/RuleResult.ts.html +0 -172
  69. package/coverage/lcov-report/src/main/models/ScanResult.ts.html +0 -121
  70. package/coverage/lcov-report/src/main/models/Violation.ts.html +0 -316
  71. package/coverage/lcov-report/src/main/models/index.html +0 -341
  72. package/coverage/lcov-report/src/main/rules/APIVersion.ts.html +0 -361
  73. package/coverage/lcov-report/src/main/rules/ActionCallsInLoop.ts.html +0 -157
  74. package/coverage/lcov-report/src/main/rules/AutoLayout.ts.html +0 -220
  75. package/coverage/lcov-report/src/main/rules/CopyAPIName.ts.html +0 -175
  76. package/coverage/lcov-report/src/main/rules/CyclomaticComplexity.ts.html +0 -292
  77. package/coverage/lcov-report/src/main/rules/DMLStatementInLoop.ts.html +0 -163
  78. package/coverage/lcov-report/src/main/rules/DuplicateDMLOperation.ts.html +0 -334
  79. package/coverage/lcov-report/src/main/rules/FlowDescription.ts.html +0 -184
  80. package/coverage/lcov-report/src/main/rules/FlowName.ts.html +0 -229
  81. package/coverage/lcov-report/src/main/rules/GetRecordAllFields.ts.html +0 -280
  82. package/coverage/lcov-report/src/main/rules/HardcodedId.ts.html +0 -238
  83. package/coverage/lcov-report/src/main/rules/HardcodedSecret.ts.html +0 -238
  84. package/coverage/lcov-report/src/main/rules/HardcodedUrl.ts.html +0 -247
  85. package/coverage/lcov-report/src/main/rules/InactiveFlow.ts.html +0 -184
  86. package/coverage/lcov-report/src/main/rules/MissingFaultPath.ts.html +0 -397
  87. package/coverage/lcov-report/src/main/rules/MissingFilterRecordTrigger.ts.html +0 -229
  88. package/coverage/lcov-report/src/main/rules/MissingMetadataDescription.ts.html +0 -211
  89. package/coverage/lcov-report/src/main/rules/MissingNullHandler.ts.html +0 -460
  90. package/coverage/lcov-report/src/main/rules/MissingRecordTriggerFilter.ts.html +0 -235
  91. package/coverage/lcov-report/src/main/rules/ProcessBuilder.ts.html +0 -190
  92. package/coverage/lcov-report/src/main/rules/RecordIdAsString.ts.html +0 -274
  93. package/coverage/lcov-report/src/main/rules/RecursiveAfterUpdate.ts.html +0 -364
  94. package/coverage/lcov-report/src/main/rules/SOQLQueryInLoop.ts.html +0 -160
  95. package/coverage/lcov-report/src/main/rules/SameRecordFieldUpdates.ts.html +0 -283
  96. package/coverage/lcov-report/src/main/rules/TransformInsteadOfLoop.ts.html +0 -250
  97. package/coverage/lcov-report/src/main/rules/TriggerOrder.ts.html +0 -238
  98. package/coverage/lcov-report/src/main/rules/UnconnectedElement.ts.html +0 -178
  99. package/coverage/lcov-report/src/main/rules/UnsafeRunningContext.ts.html +0 -226
  100. package/coverage/lcov-report/src/main/rules/UnusedVariable.ts.html +0 -283
  101. package/coverage/lcov-report/src/main/rules/index.html +0 -521
  102. package/coverage/lcov-report/src/main/store/DefaultRuleStore.ts.html +0 -265
  103. package/coverage/lcov-report/src/main/store/RuleRegistry.ts.html +0 -118
  104. package/coverage/lcov-report/src/main/store/index.html +0 -116
  105. package/coverage/lcov.info +0 -6261
  106. package/eslint.config.mjs +0 -36
  107. package/jest.config.cjs +0 -32
  108. package/jest.env-setup.js +0 -101
  109. package/lint-staged.config.mjs +0 -8
  110. package/out/main/models/FlowGraph.d.ts +0 -85
  111. package/prettier.config.mjs +0 -5
  112. package/src/index.ts +0 -52
  113. package/src/main/config/NodeIcons.ts +0 -98
  114. package/src/main/config/RegexAdapter.ts +0 -98
  115. package/src/main/config/RuleRegistry.ts +0 -188
  116. package/src/main/config/VariableIcons.ts +0 -57
  117. package/src/main/enums/MetadataTypes.ts +0 -6
  118. package/src/main/interfaces/IExceptions.ts +0 -6
  119. package/src/main/interfaces/IRuleConfig.ts +0 -6
  120. package/src/main/interfaces/IRuleDefinition.ts +0 -15
  121. package/src/main/interfaces/IRuleOptions.ts +0 -5
  122. package/src/main/interfaces/IRulesConfig.ts +0 -17
  123. package/src/main/internals/internals.ts +0 -35
  124. package/src/main/libs/BuildFlow.ts +0 -14
  125. package/src/main/libs/Compiler.ts +0 -53
  126. package/src/main/libs/ExportDetails.ts +0 -58
  127. package/src/main/libs/ExportDiagram.ts +0 -83
  128. package/src/main/libs/ExportSarif.ts +0 -92
  129. package/src/main/libs/FixFlows.ts +0 -61
  130. package/src/main/libs/GetRuleDefinitions.ts +0 -64
  131. package/src/main/libs/ParseFlows.ts +0 -34
  132. package/src/main/libs/RuleDocumentation.ts +0 -35
  133. package/src/main/libs/ScanFlows.ts +0 -142
  134. package/src/main/models/FlatViolation.ts +0 -16
  135. package/src/main/models/Flow.ts +0 -325
  136. package/src/main/models/FlowAttribute.ts +0 -11
  137. package/src/main/models/FlowElement.ts +0 -16
  138. package/src/main/models/FlowElementConnector.ts +0 -28
  139. package/src/main/models/FlowGraph.ts +0 -530
  140. package/src/main/models/FlowMetadata.ts +0 -8
  141. package/src/main/models/FlowNode.ts +0 -390
  142. package/src/main/models/FlowResource.ts +0 -8
  143. package/src/main/models/FlowType.ts +0 -53
  144. package/src/main/models/FlowVariable.ts +0 -157
  145. package/src/main/models/LoopRuleCommon.ts +0 -51
  146. package/src/main/models/ParsedFlow.ts +0 -13
  147. package/src/main/models/RuleCommon.ts +0 -120
  148. package/src/main/models/RuleInfo.ts +0 -54
  149. package/src/main/models/RuleResult.ts +0 -29
  150. package/src/main/models/ScanResult.ts +0 -12
  151. package/src/main/models/Violation.ts +0 -78
  152. package/src/main/rules/APIVersion.ts +0 -93
  153. package/src/main/rules/ActionCallsInLoop.ts +0 -25
  154. package/src/main/rules/AutoLayout.ts +0 -46
  155. package/src/main/rules/CopyAPIName.ts +0 -31
  156. package/src/main/rules/CyclomaticComplexity.ts +0 -70
  157. package/src/main/rules/DMLStatementInLoop.ts +0 -26
  158. package/src/main/rules/DuplicateDMLOperation.ts +0 -83
  159. package/src/main/rules/FlowDescription.ts +0 -34
  160. package/src/main/rules/FlowName.ts +0 -49
  161. package/src/main/rules/GetRecordAllFields.ts +0 -65
  162. package/src/main/rules/HardcodedId.ts +0 -51
  163. package/src/main/rules/HardcodedSecret.ts +0 -51
  164. package/src/main/rules/HardcodedUrl.ts +0 -54
  165. package/src/main/rules/InactiveFlow.ts +0 -33
  166. package/src/main/rules/MissingFaultPath.ts +0 -105
  167. package/src/main/rules/MissingMetadataDescription.ts +0 -42
  168. package/src/main/rules/MissingNullHandler.ts +0 -126
  169. package/src/main/rules/MissingRecordTriggerFilter.ts +0 -51
  170. package/src/main/rules/ProcessBuilder.ts +0 -35
  171. package/src/main/rules/RecordIdAsString.ts +0 -64
  172. package/src/main/rules/RecursiveAfterUpdate.ts +0 -94
  173. package/src/main/rules/SOQLQueryInLoop.ts +0 -26
  174. package/src/main/rules/SameRecordFieldUpdates.ts +0 -66
  175. package/src/main/rules/TransformInsteadOfLoop.ts +0 -56
  176. package/src/main/rules/TriggerOrder.ts +0 -51
  177. package/src/main/rules/UnconnectedElement.ts +0 -32
  178. package/src/main/rules/UnsafeRunningContext.ts +0 -47
  179. package/src/main/rules/UnusedVariable.ts +0 -66
  180. package/stryker.config.mjs +0 -23
  181. package/tests/APIVersion.test.ts +0 -87
  182. package/tests/AutoLayout.test.ts +0 -41
  183. package/tests/Config.test.ts +0 -122
  184. package/tests/ConfigBetaMode.test.ts +0 -26
  185. package/tests/CopyAPIName.test.ts +0 -45
  186. package/tests/CyclomaticComplexity.test.ts +0 -125
  187. package/tests/DMLStatementInLoop.test.ts +0 -32
  188. package/tests/DuplicateDMLOperation.test.ts +0 -43
  189. package/tests/EnabledFalse.test.ts +0 -63
  190. package/tests/Exceptions.test.ts +0 -815
  191. package/tests/ExportSarif.test.ts +0 -62
  192. package/tests/FlowDescription.test.ts +0 -44
  193. package/tests/FlowDocumentation.test.ts +0 -74
  194. package/tests/FlowName.test.ts +0 -61
  195. package/tests/GetRecordElementAllFields.test.ts +0 -182
  196. package/tests/HardcodedId.test.ts +0 -16
  197. package/tests/HardcodedSecret.test.ts +0 -32
  198. package/tests/HardcodedUrl.test.ts +0 -253
  199. package/tests/InactiveFlow.test.ts +0 -103
  200. package/tests/MissingFaultPath.test.ts +0 -52
  201. package/tests/MissingMetadataDescription.test.ts +0 -25
  202. package/tests/MissingNullHandler.test.ts +0 -45
  203. package/tests/MissingRecordTriggerFilter.test.ts +0 -54
  204. package/tests/RecordIdAsString.test.ts +0 -60
  205. package/tests/RecursiveAfterUpdate.test.ts +0 -183
  206. package/tests/SOQLQueryInLoop.test.ts +0 -33
  207. package/tests/SameRecordFieldUpdates.test.ts +0 -205
  208. package/tests/SanityTest.test.ts +0 -15
  209. package/tests/TransformInsteadOfLoop.test.ts +0 -33
  210. package/tests/TriggerOrder.test.ts +0 -112
  211. package/tests/UnconnectedElement.test.ts +0 -76
  212. package/tests/UnsafeRunningContext.test.ts +0 -46
  213. package/tests/UnusedVariable.test.ts +0 -59
  214. package/tests/UnusedVariableExceptions.test.ts +0 -87
  215. package/tests/jsonfiles/MissingFaultPath_BeforeSave_Bypass.json +0 -128
  216. package/tests/jsonfiles/MissingFaultPath_WaitConditions.json +0 -102
  217. package/tests/jsonfiles/MissingFaultPath_WaitDate.json +0 -88
  218. package/tests/jsonfiles/MissingFaultPath_WaitDuration.json +0 -90
  219. package/tests/models/Flow.test.ts +0 -107
  220. package/tests/models/LoopRuleCommon.test.ts +0 -246
  221. package/tests/models/RuleCommon.test.ts +0 -41
  222. package/tsconfig.json +0 -28
  223. package/tsconfig.types.json +0 -26
  224. package/types/index.d.ts +0 -27
  225. package/types/index.d.ts.map +0 -1
  226. package/types/main/adapters/RegexAdapter.d.ts +0 -33
  227. package/types/main/adapters/RegexAdapter.d.ts.map +0 -1
  228. package/types/main/config/NodeIcons.d.ts +0 -25
  229. package/types/main/config/NodeIcons.d.ts.map +0 -1
  230. package/types/main/config/RegexAdapter.d.ts +0 -33
  231. package/types/main/config/RegexAdapter.d.ts.map +0 -1
  232. package/types/main/config/RuleRegistry.d.ts +0 -23
  233. package/types/main/config/RuleRegistry.d.ts.map +0 -1
  234. package/types/main/config/VariableIcons.d.ts +0 -26
  235. package/types/main/config/VariableIcons.d.ts.map +0 -1
  236. package/types/main/enums/MetadataTypes.d.ts +0 -7
  237. package/types/main/enums/MetadataTypes.d.ts.map +0 -1
  238. package/types/main/interfaces/IExceptions.d.ts +0 -6
  239. package/types/main/interfaces/IExceptions.d.ts.map +0 -1
  240. package/types/main/interfaces/IRuleConfig.d.ts +0 -7
  241. package/types/main/interfaces/IRuleConfig.d.ts.map +0 -1
  242. package/types/main/interfaces/IRuleDefinition.d.ts +0 -18
  243. package/types/main/interfaces/IRuleDefinition.d.ts.map +0 -1
  244. package/types/main/interfaces/IRuleOptions.d.ts +0 -5
  245. package/types/main/interfaces/IRuleOptions.d.ts.map +0 -1
  246. package/types/main/interfaces/IRulesConfig.d.ts +0 -16
  247. package/types/main/interfaces/IRulesConfig.d.ts.map +0 -1
  248. package/types/main/internals/internals.d.ts +0 -19
  249. package/types/main/internals/internals.d.ts.map +0 -1
  250. package/types/main/libs/BuildFlow.d.ts +0 -2
  251. package/types/main/libs/BuildFlow.d.ts.map +0 -1
  252. package/types/main/libs/Compiler.d.ts +0 -8
  253. package/types/main/libs/Compiler.d.ts.map +0 -1
  254. package/types/main/libs/ConvertFlowNodes.d.ts +0 -2
  255. package/types/main/libs/ConvertFlowNodes.d.ts.map +0 -1
  256. package/types/main/libs/DynamicRule.d.ts +0 -5
  257. package/types/main/libs/DynamicRule.d.ts.map +0 -1
  258. package/types/main/libs/ExportDetails.d.ts +0 -4
  259. package/types/main/libs/ExportDetails.d.ts.map +0 -1
  260. package/types/main/libs/ExportDiagram.d.ts +0 -42
  261. package/types/main/libs/ExportDiagram.d.ts.map +0 -1
  262. package/types/main/libs/ExportSarif.d.ts +0 -3
  263. package/types/main/libs/ExportSarif.d.ts.map +0 -1
  264. package/types/main/libs/FixFlows.d.ts +0 -4
  265. package/types/main/libs/FixFlows.d.ts.map +0 -1
  266. package/types/main/libs/GetRuleDefinitions.d.ts +0 -5
  267. package/types/main/libs/GetRuleDefinitions.d.ts.map +0 -1
  268. package/types/main/libs/ParseFlows.d.ts +0 -3
  269. package/types/main/libs/ParseFlows.d.ts.map +0 -1
  270. package/types/main/libs/RuleDocumentation.d.ts +0 -21
  271. package/types/main/libs/RuleDocumentation.d.ts.map +0 -1
  272. package/types/main/libs/ScanFlows.d.ts +0 -5
  273. package/types/main/libs/ScanFlows.d.ts.map +0 -1
  274. package/types/main/libs/exportAsDetails.d.ts +0 -4
  275. package/types/main/libs/exportAsDetails.d.ts.map +0 -1
  276. package/types/main/libs/exportAsSarif.d.ts +0 -3
  277. package/types/main/libs/exportAsSarif.d.ts.map +0 -1
  278. package/types/main/models/FlatViolation.d.ts +0 -16
  279. package/types/main/models/FlatViolation.d.ts.map +0 -1
  280. package/types/main/models/Flow.d.ts +0 -70
  281. package/types/main/models/Flow.d.ts.map +0 -1
  282. package/types/main/models/FlowAttribute.d.ts +0 -6
  283. package/types/main/models/FlowAttribute.d.ts.map +0 -1
  284. package/types/main/models/FlowElement.d.ts +0 -11
  285. package/types/main/models/FlowElement.d.ts.map +0 -1
  286. package/types/main/models/FlowElementConnector.d.ts +0 -16
  287. package/types/main/models/FlowElementConnector.d.ts.map +0 -1
  288. package/types/main/models/FlowGraph.d.ts.map +0 -1
  289. package/types/main/models/FlowMetadata.d.ts +0 -5
  290. package/types/main/models/FlowMetadata.d.ts.map +0 -1
  291. package/types/main/models/FlowNode.d.ts +0 -66
  292. package/types/main/models/FlowNode.d.ts.map +0 -1
  293. package/types/main/models/FlowResource.d.ts +0 -5
  294. package/types/main/models/FlowResource.d.ts.map +0 -1
  295. package/types/main/models/FlowType.d.ts +0 -24
  296. package/types/main/models/FlowType.d.ts.map +0 -1
  297. package/types/main/models/FlowVariable.d.ts +0 -64
  298. package/types/main/models/FlowVariable.d.ts.map +0 -1
  299. package/types/main/models/LoopRuleCommon.d.ts +0 -15
  300. package/types/main/models/LoopRuleCommon.d.ts.map +0 -1
  301. package/types/main/models/ParsedFlow.d.ts +0 -8
  302. package/types/main/models/ParsedFlow.d.ts.map +0 -1
  303. package/types/main/models/RuleCommon.d.ts +0 -58
  304. package/types/main/models/RuleCommon.d.ts.map +0 -1
  305. package/types/main/models/RuleInfo.d.ts +0 -50
  306. package/types/main/models/RuleInfo.d.ts.map +0 -1
  307. package/types/main/models/RuleResult.d.ts +0 -15
  308. package/types/main/models/RuleResult.d.ts.map +0 -1
  309. package/types/main/models/ScanResult.d.ts +0 -8
  310. package/types/main/models/ScanResult.d.ts.map +0 -1
  311. package/types/main/models/Violation.d.ts +0 -12
  312. package/types/main/models/Violation.d.ts.map +0 -1
  313. package/types/main/rules/APIVersion.d.ts +0 -10
  314. package/types/main/rules/APIVersion.d.ts.map +0 -1
  315. package/types/main/rules/ActionCallsInLoop.d.ts +0 -7
  316. package/types/main/rules/ActionCallsInLoop.d.ts.map +0 -1
  317. package/types/main/rules/AutoLayout.d.ts +0 -8
  318. package/types/main/rules/AutoLayout.d.ts.map +0 -1
  319. package/types/main/rules/CopyAPIName.d.ts +0 -8
  320. package/types/main/rules/CopyAPIName.d.ts.map +0 -1
  321. package/types/main/rules/CyclomaticComplexity.d.ts +0 -12
  322. package/types/main/rules/CyclomaticComplexity.d.ts.map +0 -1
  323. package/types/main/rules/DMLStatementInLoop.d.ts +0 -7
  324. package/types/main/rules/DMLStatementInLoop.d.ts.map +0 -1
  325. package/types/main/rules/DuplicateDMLOperation.d.ts +0 -9
  326. package/types/main/rules/DuplicateDMLOperation.d.ts.map +0 -1
  327. package/types/main/rules/FlowDescription.d.ts +0 -8
  328. package/types/main/rules/FlowDescription.d.ts.map +0 -1
  329. package/types/main/rules/FlowName.d.ts +0 -16
  330. package/types/main/rules/FlowName.d.ts.map +0 -1
  331. package/types/main/rules/GetRecordAllFields.d.ts +0 -8
  332. package/types/main/rules/GetRecordAllFields.d.ts.map +0 -1
  333. package/types/main/rules/HardcodedId.d.ts +0 -14
  334. package/types/main/rules/HardcodedId.d.ts.map +0 -1
  335. package/types/main/rules/HardcodedSecret.d.ts +0 -14
  336. package/types/main/rules/HardcodedSecret.d.ts.map +0 -1
  337. package/types/main/rules/HardcodedUrl.d.ts +0 -14
  338. package/types/main/rules/HardcodedUrl.d.ts.map +0 -1
  339. package/types/main/rules/InactiveFlow.d.ts +0 -8
  340. package/types/main/rules/InactiveFlow.d.ts.map +0 -1
  341. package/types/main/rules/MissingFaultPath.d.ts +0 -15
  342. package/types/main/rules/MissingFaultPath.d.ts.map +0 -1
  343. package/types/main/rules/MissingFilterRecordTrigger.d.ts +0 -8
  344. package/types/main/rules/MissingFilterRecordTrigger.d.ts.map +0 -1
  345. package/types/main/rules/MissingMetadataDescription.d.ts +0 -8
  346. package/types/main/rules/MissingMetadataDescription.d.ts.map +0 -1
  347. package/types/main/rules/MissingNullHandler.d.ts +0 -8
  348. package/types/main/rules/MissingNullHandler.d.ts.map +0 -1
  349. package/types/main/rules/MissingRecordTriggerFilter.d.ts +0 -8
  350. package/types/main/rules/MissingRecordTriggerFilter.d.ts.map +0 -1
  351. package/types/main/rules/ProcessBuilder.d.ts +0 -8
  352. package/types/main/rules/ProcessBuilder.d.ts.map +0 -1
  353. package/types/main/rules/RecordIdAsString.d.ts +0 -8
  354. package/types/main/rules/RecordIdAsString.d.ts.map +0 -1
  355. package/types/main/rules/RecursiveAfterUpdate.d.ts +0 -9
  356. package/types/main/rules/RecursiveAfterUpdate.d.ts.map +0 -1
  357. package/types/main/rules/SOQLQueryInLoop.d.ts +0 -7
  358. package/types/main/rules/SOQLQueryInLoop.d.ts.map +0 -1
  359. package/types/main/rules/SameRecordFieldUpdates.d.ts +0 -9
  360. package/types/main/rules/SameRecordFieldUpdates.d.ts.map +0 -1
  361. package/types/main/rules/TransformInsteadOfLoop.d.ts +0 -8
  362. package/types/main/rules/TransformInsteadOfLoop.d.ts.map +0 -1
  363. package/types/main/rules/TriggerOrder.d.ts +0 -8
  364. package/types/main/rules/TriggerOrder.d.ts.map +0 -1
  365. package/types/main/rules/UnconnectedElement.d.ts +0 -8
  366. package/types/main/rules/UnconnectedElement.d.ts.map +0 -1
  367. package/types/main/rules/UnsafeRunningContext.d.ts +0 -8
  368. package/types/main/rules/UnsafeRunningContext.d.ts.map +0 -1
  369. package/types/main/rules/UnusedVariable.d.ts +0 -8
  370. package/types/main/rules/UnusedVariable.d.ts.map +0 -1
  371. package/types/main/store/DefaultRuleStore.d.ts +0 -3
  372. package/types/main/store/DefaultRuleStore.d.ts.map +0 -1
  373. package/types/main/store/RuleRegistry.d.ts +0 -23
  374. package/types/main/store/RuleRegistry.d.ts.map +0 -1
  375. package/vite.config.ts +0 -33
  376. /package/{out/index.d.ts → index.d.ts} +0 -0
  377. /package/{out/index.js → index.js} +0 -0
  378. /package/{out/main → main}/config/NodeIcons.d.ts +0 -0
  379. /package/{out/main → main}/config/NodeIcons.js +0 -0
  380. /package/{out/main → main}/config/RegexAdapter.d.ts +0 -0
  381. /package/{out/main → main}/config/RegexAdapter.js +0 -0
  382. /package/{out/main → main}/config/RuleRegistry.d.ts +0 -0
  383. /package/{out/main → main}/config/RuleRegistry.js +0 -0
  384. /package/{out/main → main}/config/VariableIcons.d.ts +0 -0
  385. /package/{out/main → main}/config/VariableIcons.js +0 -0
  386. /package/{out/main → main}/enums/MetadataTypes.d.ts +0 -0
  387. /package/{out/main → main}/enums/MetadataTypes.js +0 -0
  388. /package/{out/main → main}/interfaces/IExceptions.d.ts +0 -0
  389. /package/{out/main → main}/interfaces/IExceptions.js +0 -0
  390. /package/{out/main → main}/interfaces/IRuleConfig.d.ts +0 -0
  391. /package/{out/main → main}/interfaces/IRuleConfig.js +0 -0
  392. /package/{out/main → main}/interfaces/IRuleDefinition.d.ts +0 -0
  393. /package/{out/main → main}/interfaces/IRuleDefinition.js +0 -0
  394. /package/{out/main → main}/interfaces/IRuleOptions.d.ts +0 -0
  395. /package/{out/main → main}/interfaces/IRuleOptions.js +0 -0
  396. /package/{out/main → main}/interfaces/IRulesConfig.d.ts +0 -0
  397. /package/{out/main → main}/interfaces/IRulesConfig.js +0 -0
  398. /package/{out/main → main}/internals/internals.d.ts +0 -0
  399. /package/{out/main → main}/internals/internals.js +0 -0
  400. /package/{out/main → main}/libs/BuildFlow.d.ts +0 -0
  401. /package/{out/main → main}/libs/BuildFlow.js +0 -0
  402. /package/{out/main → main}/libs/Compiler.d.ts +0 -0
  403. /package/{out/main → main}/libs/Compiler.js +0 -0
  404. /package/{out/main → main}/libs/ExportDetails.d.ts +0 -0
  405. /package/{out/main → main}/libs/ExportDetails.js +0 -0
  406. /package/{out/main → main}/libs/ExportDiagram.d.ts +0 -0
  407. /package/{out/main → main}/libs/ExportDiagram.js +0 -0
  408. /package/{out/main → main}/libs/ExportSarif.d.ts +0 -0
  409. /package/{out/main → main}/libs/ExportSarif.js +0 -0
  410. /package/{out/main → main}/libs/FixFlows.d.ts +0 -0
  411. /package/{out/main → main}/libs/FixFlows.js +0 -0
  412. /package/{out/main → main}/libs/GetRuleDefinitions.d.ts +0 -0
  413. /package/{out/main → main}/libs/GetRuleDefinitions.js +0 -0
  414. /package/{out/main → main}/libs/ParseFlows.d.ts +0 -0
  415. /package/{out/main → main}/libs/ParseFlows.js +0 -0
  416. /package/{out/main → main}/libs/RuleDocumentation.d.ts +0 -0
  417. /package/{out/main → main}/libs/RuleDocumentation.js +0 -0
  418. /package/{out/main → main}/libs/ScanFlows.d.ts +0 -0
  419. /package/{out/main → main}/libs/ScanFlows.js +0 -0
  420. /package/{out/main → main}/models/FlatViolation.d.ts +0 -0
  421. /package/{out/main → main}/models/FlatViolation.js +0 -0
  422. /package/{out/main → main}/models/Flow.d.ts +0 -0
  423. /package/{out/main → main}/models/Flow.js +0 -0
  424. /package/{out/main → main}/models/FlowAttribute.d.ts +0 -0
  425. /package/{out/main → main}/models/FlowAttribute.js +0 -0
  426. /package/{out/main → main}/models/FlowElement.d.ts +0 -0
  427. /package/{out/main → main}/models/FlowElement.js +0 -0
  428. /package/{out/main → main}/models/FlowElementConnector.d.ts +0 -0
  429. /package/{out/main → main}/models/FlowElementConnector.js +0 -0
  430. /package/{out/main → main}/models/FlowMetadata.d.ts +0 -0
  431. /package/{out/main → main}/models/FlowMetadata.js +0 -0
  432. /package/{out/main → main}/models/FlowNode.d.ts +0 -0
  433. /package/{out/main → main}/models/FlowNode.js +0 -0
  434. /package/{out/main → main}/models/FlowResource.d.ts +0 -0
  435. /package/{out/main → main}/models/FlowResource.js +0 -0
  436. /package/{out/main → main}/models/FlowType.d.ts +0 -0
  437. /package/{out/main → main}/models/FlowType.js +0 -0
  438. /package/{out/main → main}/models/FlowVariable.d.ts +0 -0
  439. /package/{out/main → main}/models/FlowVariable.js +0 -0
  440. /package/{out/main → main}/models/LoopRuleCommon.d.ts +0 -0
  441. /package/{out/main → main}/models/LoopRuleCommon.js +0 -0
  442. /package/{out/main → main}/models/ParsedFlow.d.ts +0 -0
  443. /package/{out/main → main}/models/ParsedFlow.js +0 -0
  444. /package/{out/main → main}/models/RuleCommon.d.ts +0 -0
  445. /package/{out/main → main}/models/RuleCommon.js +0 -0
  446. /package/{out/main → main}/models/RuleInfo.d.ts +0 -0
  447. /package/{out/main → main}/models/RuleInfo.js +0 -0
  448. /package/{out/main → main}/models/RuleResult.d.ts +0 -0
  449. /package/{out/main → main}/models/RuleResult.js +0 -0
  450. /package/{out/main → main}/models/ScanResult.d.ts +0 -0
  451. /package/{out/main → main}/models/ScanResult.js +0 -0
  452. /package/{out/main → main}/models/Violation.d.ts +0 -0
  453. /package/{out/main → main}/models/Violation.js +0 -0
  454. /package/{out/main → main}/rules/APIVersion.d.ts +0 -0
  455. /package/{out/main → main}/rules/APIVersion.js +0 -0
  456. /package/{out/main → main}/rules/ActionCallsInLoop.d.ts +0 -0
  457. /package/{out/main → main}/rules/ActionCallsInLoop.js +0 -0
  458. /package/{out/main → main}/rules/AutoLayout.d.ts +0 -0
  459. /package/{out/main → main}/rules/AutoLayout.js +0 -0
  460. /package/{out/main → main}/rules/CopyAPIName.d.ts +0 -0
  461. /package/{out/main → main}/rules/CopyAPIName.js +0 -0
  462. /package/{out/main → main}/rules/CyclomaticComplexity.d.ts +0 -0
  463. /package/{out/main → main}/rules/CyclomaticComplexity.js +0 -0
  464. /package/{out/main → main}/rules/DMLStatementInLoop.d.ts +0 -0
  465. /package/{out/main → main}/rules/DMLStatementInLoop.js +0 -0
  466. /package/{out/main → main}/rules/DuplicateDMLOperation.d.ts +0 -0
  467. /package/{out/main → main}/rules/DuplicateDMLOperation.js +0 -0
  468. /package/{out/main → main}/rules/FlowDescription.d.ts +0 -0
  469. /package/{out/main → main}/rules/FlowDescription.js +0 -0
  470. /package/{out/main → main}/rules/FlowName.d.ts +0 -0
  471. /package/{out/main → main}/rules/FlowName.js +0 -0
  472. /package/{out/main → main}/rules/GetRecordAllFields.d.ts +0 -0
  473. /package/{out/main → main}/rules/GetRecordAllFields.js +0 -0
  474. /package/{out/main → main}/rules/HardcodedId.d.ts +0 -0
  475. /package/{out/main → main}/rules/HardcodedId.js +0 -0
  476. /package/{out/main → main}/rules/HardcodedSecret.d.ts +0 -0
  477. /package/{out/main → main}/rules/HardcodedSecret.js +0 -0
  478. /package/{out/main → main}/rules/HardcodedUrl.d.ts +0 -0
  479. /package/{out/main → main}/rules/HardcodedUrl.js +0 -0
  480. /package/{out/main → main}/rules/InactiveFlow.d.ts +0 -0
  481. /package/{out/main → main}/rules/InactiveFlow.js +0 -0
  482. /package/{out/main → main}/rules/MissingFaultPath.d.ts +0 -0
  483. /package/{out/main → main}/rules/MissingFaultPath.js +0 -0
  484. /package/{out/main → main}/rules/MissingMetadataDescription.d.ts +0 -0
  485. /package/{out/main → main}/rules/MissingMetadataDescription.js +0 -0
  486. /package/{out/main → main}/rules/MissingNullHandler.d.ts +0 -0
  487. /package/{out/main → main}/rules/MissingNullHandler.js +0 -0
  488. /package/{out/main → main}/rules/MissingRecordTriggerFilter.d.ts +0 -0
  489. /package/{out/main → main}/rules/ProcessBuilder.d.ts +0 -0
  490. /package/{out/main → main}/rules/ProcessBuilder.js +0 -0
  491. /package/{out/main → main}/rules/RecordIdAsString.d.ts +0 -0
  492. /package/{out/main → main}/rules/RecordIdAsString.js +0 -0
  493. /package/{out/main → main}/rules/RecursiveAfterUpdate.d.ts +0 -0
  494. /package/{out/main → main}/rules/RecursiveAfterUpdate.js +0 -0
  495. /package/{out/main → main}/rules/SOQLQueryInLoop.d.ts +0 -0
  496. /package/{out/main → main}/rules/SOQLQueryInLoop.js +0 -0
  497. /package/{out/main → main}/rules/SameRecordFieldUpdates.d.ts +0 -0
  498. /package/{out/main → main}/rules/SameRecordFieldUpdates.js +0 -0
  499. /package/{out/main → main}/rules/TransformInsteadOfLoop.d.ts +0 -0
  500. /package/{out/main → main}/rules/TransformInsteadOfLoop.js +0 -0
  501. /package/{out/main → main}/rules/TriggerOrder.d.ts +0 -0
  502. /package/{out/main → main}/rules/TriggerOrder.js +0 -0
  503. /package/{out/main → main}/rules/UnconnectedElement.d.ts +0 -0
  504. /package/{out/main → main}/rules/UnconnectedElement.js +0 -0
  505. /package/{out/main → main}/rules/UnsafeRunningContext.d.ts +0 -0
  506. /package/{out/main → main}/rules/UnsafeRunningContext.js +0 -0
  507. /package/{out/main → main}/rules/UnusedVariable.d.ts +0 -0
  508. /package/{out/main → main}/rules/UnusedVariable.js +0 -0
@@ -1,41 +0,0 @@
1
- import * as core from "../src";
2
- import * as path from "path";
3
-
4
- import { describe, it, expect } from "@jest/globals";
5
-
6
- describe("Autolayout", () => {
7
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/Missing_Auto_Layout.flow-meta.xml");
8
- const fixed_uri = path.join(__dirname, "../../../example-flows/force-app/testing/Outdated_API_Version_Fixed.flow-meta.xml");
9
-
10
- it("should have a result when CanvasMode is set to FREE_FORM_CANVAS", async () => {
11
- const flows = await core.parse([example_uri]);
12
- const ruleConfig = {
13
- ruleMode: "isolated",
14
- rules: {
15
- AutoLayout: {
16
- severity: "error",
17
- },
18
- },
19
- };
20
-
21
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
22
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
23
- expect(occurringResults).toHaveLength(1);
24
- expect(occurringResults.find((res) => res.ruleName === "AutoLayout")).toBeTruthy();
25
- });
26
-
27
- it("should not have result when autolayout is configured", async () => {
28
- const flows = await core.parse([fixed_uri]);
29
- const ruleConfig = {
30
- rules: {
31
- ruleMode: "isolated",
32
- AutoLayout: {
33
- severity: "error",
34
- },
35
- },
36
- };
37
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
38
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
39
- expect(occurringResults).toHaveLength(0);
40
- });
41
- });
@@ -1,122 +0,0 @@
1
- import { describe, expect, it } from "@jest/globals";
2
- import * as path from "path";
3
-
4
- import * as core from "../src";
5
-
6
- describe("Rule Configurations ", () => {
7
- const example_uri1 = path.join(__dirname, "../../../example-flows/force-app/demo/Unreachable_Element.flow-meta.xml");
8
-
9
- // eslint-disable-next-line jest/no-disabled-tests
10
- it.skip("should use default when no configuration is provided", async () => {
11
- const flows = await core.parse([example_uri1]);
12
- const results: core.ScanResult[] = core.scan(flows, undefined);
13
- const rules = [...core.getRules(), ...core.getBetaRules()];
14
- const allRuleNames = rules.map((r) => r.name);
15
- const allRuleResults = results[0].ruleResults.map((r) => r.ruleName);
16
- expect(allRuleNames).toEqual(allRuleResults);
17
- expect(results[0].ruleResults).toHaveLength(rules.length);
18
- });
19
-
20
- // eslint-disable-next-line jest/no-disabled-tests
21
- it.skip("should use default when no rules are specified", async () => {
22
- const flows = await core.parse([example_uri1]);
23
- const ruleConfig = {
24
- exceptions: {
25
- CreateANewAccountWithChild: { DuplicateDMLOperation: ["ViewAccountId"] },
26
- },
27
- rules: {},
28
- };
29
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
30
- const rules = [...core.getRules(), ...core.getBetaRules()];
31
- const allRuleNames = rules.map((r) => r.name);
32
- const allRuleResults = results[0].ruleResults.map((r) => r.ruleName);
33
- expect(allRuleNames).toEqual(allRuleResults);
34
- expect(results[0].ruleResults).toHaveLength(rules.length);
35
- });
36
-
37
- it("incorrect rule severity configurations are defaulted", async () => {
38
- const flows = await core.parse([example_uri1]);
39
- const ruleConfig = {
40
- ruleMode: "isolated",
41
- rules: {
42
- MissingNullHandler: {
43
- severity: "errorr",
44
- },
45
- },
46
- };
47
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
48
- expect(results[0].ruleResults).toHaveLength(1);
49
- });
50
-
51
- it("incorrect rule configurations are skipped", async () => {
52
- const flows = await core.parse([example_uri1]);
53
- jest.spyOn(global.console, "error").mockImplementation(() => {});
54
- jest.spyOn(global.console, "log").mockImplementation(() => {});
55
-
56
- const ruleConfig = {
57
- exceptions: {
58
- CreateANewAccountWithChild: { DuplicateDMLOperation: ["ViewAccountId"] },
59
- },
60
- ruleMode: "isolated",
61
- rules: {
62
- MissingNullHandler: {
63
- severity: "error",
64
- },
65
- MissingNullHandler2: {
66
- severity: "error",
67
- },
68
- },
69
- };
70
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
71
- expect(results[0].ruleResults).toHaveLength(1);
72
- });
73
-
74
- it("Multiple Expressions are individually checked", async () => {
75
- const flows = await core.parse([example_uri1]);
76
- const ruleConfig = {
77
- ruleMode: "isolated",
78
- rules: {
79
- APIVersion: {
80
- expression: ">50",
81
- severity: "error",
82
- },
83
- CopyAPIName: {
84
- severity: "error",
85
- },
86
- DMLStatementInLoop: {
87
- severity: "error",
88
- },
89
- DuplicateDMLOperation: {
90
- severity: "error",
91
- },
92
- FlowDescription: {
93
- severity: "error",
94
- },
95
- FlowName: {
96
- expression: "[A-Za-z0-9]+_[A-Za-z0-9]+",
97
- severity: "error",
98
- },
99
- HardcodedId: {
100
- severity: "error",
101
- },
102
- MissingFaultPath: {
103
- severity: "error",
104
- },
105
- MissingNullHandler: {
106
- severity: "error",
107
- },
108
- SOQLQueryInLoop: {
109
- severity: "error",
110
- },
111
- UnconnectedElement: {
112
- severity: "error",
113
- },
114
- UnusedVariable: {
115
- severity: "error",
116
- },
117
- },
118
- };
119
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
120
- expect(results[0].ruleResults.find((r) => r.ruleName === "FlowName")?.occurs).toBe(false);
121
- });
122
- });
@@ -1,26 +0,0 @@
1
- import { describe, expect, it } from "@jest/globals";
2
- import * as path from "path";
3
-
4
- import * as core from "../src";
5
- import { MissingMetadataDescription } from "../src/main/rules/MissingMetadataDescription";
6
-
7
- describe("Beta Rule Handling", () => {
8
- const example_uri1 = path.join(__dirname, "../../../example-flows/force-app/demo/Unreachable_Element.flow-meta.xml");
9
-
10
- it("should include beta rule when betaMode is true and no rules are specified", async () => {
11
- const flows = await core.parse([example_uri1]);
12
- const results = core.scan(flows, { betaMode: true, rules: {} });
13
-
14
- // There should be at least 1 rule result (from beta rules)
15
- expect(results[0].ruleResults.length).toBeGreaterThan(0);
16
- });
17
-
18
- it("should not include beta rule if betaMode is false even if rule exists in beta", async () => {
19
- const flows = await core.parse([example_uri1]);
20
- const results = core.scan(flows, { betaMode: false });
21
-
22
- // If the rule is only in beta and betaMode is false, it should not appear
23
- const ruleNames = results[0].ruleResults.map(r => r.ruleName);
24
- expect(ruleNames).not.toContain("MissingMetadataDescription");
25
- });
26
- });
@@ -1,45 +0,0 @@
1
- import * as core from "../src";
2
- import * as path from "path";
3
-
4
- import { describe, it, expect } from "@jest/globals";
5
-
6
- describe("CopyAPIName ", () => {
7
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/Unclear_API_Name.flow-meta.xml");
8
- const fixed_uri = path.join(__dirname, "../../../example-flows/force-app/testing/Copy_API_Name_Fixed.flow-meta.xml");
9
-
10
- it("CopyAPIName should have a result", async () => {
11
- const flows = await core.parse([example_uri]);
12
- const ruleConfig = {
13
- ruleMode: "isolated",
14
- rules: {
15
- CopyAPIName: {
16
- severity: "error",
17
- },
18
- },
19
- };
20
-
21
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
22
-
23
- expect(results[0].ruleResults).toHaveLength(1);
24
- expect(results[0].ruleResults[0].ruleName).toBe("CopyAPIName");
25
- expect(results[0].ruleResults[0].occurs).toBe(true);
26
- });
27
-
28
- it("CopyAPIName should have no result", async () => {
29
- const flows = await core.parse([fixed_uri]);
30
- const ruleConfig = {
31
- ruleMode: "isolated",
32
- rules: {
33
- CopyAPIName: {
34
- severity: "error",
35
- },
36
- },
37
- };
38
-
39
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
40
-
41
- expect(results[0].ruleResults).toHaveLength(1);
42
- expect(results[0].ruleResults[0].ruleName).toBe("CopyAPIName");
43
- expect(results[0].ruleResults[0].occurs).toBe(false);
44
- });
45
- });
@@ -1,125 +0,0 @@
1
- import * as path from "path";
2
- import { describe, it, expect } from "@jest/globals";
3
-
4
- import * as core from "../src";
5
- import { CyclomaticComplexity } from "../src/main/rules/CyclomaticComplexity";
6
-
7
- describe("CyclomaticComplexity ", () => {
8
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/Excessive_Cyclomatic_Complexity.flow-meta.xml");
9
- const other_uri = path.join(__dirname, "../../../example-flows/force-app/demo/SOQL_Query_In_A_Loop.flow-meta.xml");
10
- const defaultConfig = {
11
- ruleMode: "isolated",
12
- rules: {
13
- CyclomaticComplexity: {
14
- severity: "error",
15
- },
16
- },
17
- };
18
-
19
- it("should have a result when there are more than 25 decision options", async () => {
20
- const flows = await core.parse([example_uri]);
21
- debugger;
22
- const results: core.ScanResult[] = core.scan(flows, defaultConfig);
23
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
24
- expect(occurringResults).toHaveLength(1);
25
- expect(occurringResults[0].ruleName).toBe("CyclomaticComplexity");
26
- });
27
-
28
- it("should have no result when value is below threshold", async () => {
29
- const flows = await core.parse([other_uri]);
30
-
31
- const results: core.ScanResult[] = core.scan(flows, defaultConfig);
32
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
33
- expect(occurringResults).toHaveLength(0);
34
- });
35
-
36
- it("should have a result when value surpasses a configured threshold", async () => {
37
- const flows = await core.parse([other_uri]);
38
- const ruleConfig = {
39
- ruleMode: "isolated",
40
- rules: {
41
- CyclomaticComplexity: {
42
- threshold: 1,
43
- severity: "error",
44
- },
45
- },
46
- };
47
-
48
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
49
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
50
- expect(occurringResults).toHaveLength(1);
51
- expect(occurringResults[0].ruleName).toBe("CyclomaticComplexity");
52
- });
53
-
54
- it("should correctly count the number of decisions and underlying rules one level", () => {
55
- const sut = new CyclomaticComplexity();
56
- const raw = {
57
- elements: [
58
- {
59
- subtype: "decisions",
60
- element: {
61
- rules: [{}, {}, {}],
62
- },
63
- },
64
- ],
65
- } as Partial<core.Flow>;
66
- const given = raw as core.Flow;
67
- sut.execute(given);
68
- expect(sut["cyclomaticComplexityUnit"]).toBe(5);
69
- });
70
-
71
- it("should correctly count the number of decisions and underlying rules multi level", () => {
72
- const sut = new CyclomaticComplexity();
73
- const raw = {
74
- elements: [
75
- {
76
- subtype: "decisions",
77
- element: {
78
- rules: [{}, {}, {}],
79
- },
80
- },
81
- { subtype: "decisions", element: { rules: [{}] } },
82
- ],
83
- } as Partial<core.Flow>;
84
- const given = raw as core.Flow;
85
- sut.execute(given);
86
- expect(sut["cyclomaticComplexityUnit"]).toBe(7);
87
- });
88
-
89
- it("should not throw an exception when theres no elements at all", () => {
90
- const sut = new CyclomaticComplexity();
91
- const raw = {
92
- elements: [],
93
- } as Partial<core.Flow>;
94
- const given = raw as core.Flow;
95
- expect(() => {
96
- sut.execute(given);
97
- }).not.toThrow();
98
- });
99
-
100
- it("should not throw an exception when element isn't present", () => {
101
- const sut = new CyclomaticComplexity();
102
- const raw = {} as Partial<core.Flow>;
103
- const given = raw as core.Flow;
104
- expect(() => {
105
- sut.execute(given);
106
- }).not.toThrow();
107
- });
108
-
109
- it("should correctly count the number of loops", () => {
110
- const sut = new CyclomaticComplexity();
111
- const raw = {
112
- elements: [
113
- {
114
- subtype: "loops",
115
- },
116
- {
117
- subtype: "loops",
118
- },
119
- ],
120
- } as Partial<core.Flow>;
121
- const given = raw as core.Flow;
122
- sut.execute(given);
123
- expect(sut["cyclomaticComplexityUnit"]).toBe(3);
124
- });
125
- });
@@ -1,32 +0,0 @@
1
- import { describe, expect, it } from "@jest/globals";
2
- import * as path from "path";
3
-
4
- import * as core from "../src";
5
-
6
- describe("DMLStatementInLoop ", () => {
7
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/DML_Statement_In_A_Loop.flow-meta.xml");
8
- const fixed_uri = path.join(__dirname, "../../../example-flows/force-app/testing/Duplicate_DML_Operation_Fixed.flow-meta.xml");
9
- const config = {
10
- ruleMode: "isolated",
11
- rules: {
12
- DMLStatementInLoop: {
13
- severity: "error",
14
- },
15
- },
16
- };
17
-
18
- it("there should be one result for the rule DMLStatementInLoop", async () => {
19
- const flows = await core.parse([example_uri]);
20
- const results: core.ScanResult[] = core.scan(flows, config);
21
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
22
- expect(occurringResults).toHaveLength(1);
23
- expect(occurringResults[0].ruleName).toBe("DMLStatementInLoop");
24
- });
25
-
26
- it("there should be no result for the rule DMLStatementInLoop", async () => {
27
- const flows = await core.parse([fixed_uri]);
28
- const results: core.ScanResult[] = core.scan(flows, config);
29
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
30
- expect(occurringResults).toHaveLength(0);
31
- });
32
- });
@@ -1,43 +0,0 @@
1
- import { describe, expect, it } from "@jest/globals";
2
- import * as path from "path";
3
-
4
- import * as core from "../src";
5
-
6
- describe("DuplicateDMLOperation ", () => {
7
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/Duplicate_DML_Operation.flow-meta.xml");
8
- const fixed_uri = path.join(__dirname, "../../../example-flows/force-app/testing/Duplicate_DML_Operation_Fixed.flow-meta.xml");
9
-
10
- it("should have 1 result in a flow with a DML statement inbetween screens ", async () => {
11
- const flows = await core.parse([example_uri]);
12
-
13
- const ruleConfig = {
14
- ruleMode: "isolated",
15
- rules: {
16
- DuplicateDMLOperation: {
17
- severity: "error",
18
- },
19
- },
20
- };
21
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
22
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
23
- expect(occurringResults).toHaveLength(1);
24
- expect(occurringResults[0].ruleName).toBe("DuplicateDMLOperation");
25
- });
26
-
27
- it("should have no results in the fixed example", async () => {
28
- const flows = await core.parse([fixed_uri]);
29
-
30
- const ruleConfig = {
31
- ruleMode: "isolated",
32
- rules: {
33
- DuplicateDMLOperation: {
34
- severity: "error",
35
- },
36
- },
37
- };
38
-
39
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
40
- const occurringResults = results[0].ruleResults.filter((rule) => rule.occurs);
41
- expect(occurringResults).toHaveLength(0);
42
- });
43
- });
@@ -1,63 +0,0 @@
1
- import * as core from "../src";
2
- import * as path from "path";
3
- import { describe, it, expect } from "@jest/globals";
4
-
5
- describe("Rule Enabled Flag", () => {
6
- const example_uri = path.join(
7
- __dirname,
8
- "../../../example-flows/force-app/demo/Invalid_API_Version.flow-meta.xml"
9
- );
10
-
11
- it("should not run a rule when enabled is set to false", async () => {
12
- const flows = await core.parse([example_uri]);
13
- const ruleConfig = {
14
- ruleMode: "isolated",
15
- rules: {
16
- APIVersion: {
17
- enabled: false,
18
- severity: "error",
19
- },
20
- },
21
- };
22
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
23
-
24
- // No rules should be executed since the only rule is disabled
25
- expect(results[0].ruleResults).toHaveLength(0);
26
- });
27
-
28
- it("should run other rules when one is disabled in merged mode", async () => {
29
- const flows = await core.parse([example_uri]);
30
- const ruleConfig = {
31
- ruleMode: "merged",
32
- rules: {
33
- APIVersion: {
34
- enabled: false,
35
- },
36
- },
37
- };
38
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
39
-
40
- // Should have results from other default rules, but not APIVersion
41
- expect(results[0].ruleResults.length).toBeGreaterThan(0);
42
- const apiVersionResult = results[0].ruleResults.find(r => r.ruleName === "APIVersion");
43
- expect(apiVersionResult).toBeUndefined();
44
- });
45
-
46
- it("should run a rule when enabled is explicitly set to true", async () => {
47
- const flows = await core.parse([example_uri]);
48
- const ruleConfig = {
49
- ruleMode: "isolated",
50
- rules: {
51
- APIVersion: {
52
- enabled: true,
53
- severity: "error",
54
- },
55
- },
56
- };
57
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
58
-
59
- expect(results[0].ruleResults).toHaveLength(1);
60
- expect(results[0].ruleResults[0].ruleName).toBe("APIVersion");
61
- expect(results[0].ruleResults[0].occurs).toBe(true);
62
- });
63
- });