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

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/package.json +9 -58
  3. package/.husky/pre-commit +0 -1
  4. package/.husky/pre-push +0 -1
  5. package/.prettierignore +0 -5
  6. package/.swcrc +0 -26
  7. package/.turbo/turbo-build.log +0 -17
  8. package/.turbo/turbo-test.log +0 -144
  9. package/.turbo/turbo-vite$colon$dist.log +0 -21
  10. package/coverage/coverage-final.json +0 -63
  11. package/coverage/lcov-report/base.css +0 -224
  12. package/coverage/lcov-report/block-navigation.js +0 -87
  13. package/coverage/lcov-report/favicon.png +0 -0
  14. package/coverage/lcov-report/index.html +0 -236
  15. package/coverage/lcov-report/prettify.css +0 -1
  16. package/coverage/lcov-report/prettify.js +0 -2
  17. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  18. package/coverage/lcov-report/sorter.js +0 -210
  19. package/coverage/lcov-report/src/index.html +0 -116
  20. package/coverage/lcov-report/src/index.ts.html +0 -238
  21. package/coverage/lcov-report/src/main/adapters/RegexAdapter.ts.html +0 -118
  22. package/coverage/lcov-report/src/main/adapters/index.html +0 -116
  23. package/coverage/lcov-report/src/main/config/NodeIcons.ts.html +0 -376
  24. package/coverage/lcov-report/src/main/config/RuleRegistry.ts.html +0 -646
  25. package/coverage/lcov-report/src/main/config/VariableIcons.ts.html +0 -253
  26. package/coverage/lcov-report/src/main/config/index.html +0 -146
  27. package/coverage/lcov-report/src/main/enums/MetaType.ts.html +0 -100
  28. package/coverage/lcov-report/src/main/enums/MetadataType.ts.html +0 -103
  29. package/coverage/lcov-report/src/main/enums/MetadataTypes.ts.html +0 -100
  30. package/coverage/lcov-report/src/main/enums/index.html +0 -116
  31. package/coverage/lcov-report/src/main/interfaces/IRulesConfig.ts.html +0 -133
  32. package/coverage/lcov-report/src/main/interfaces/index.html +0 -116
  33. package/coverage/lcov-report/src/main/internals/index.html +0 -116
  34. package/coverage/lcov-report/src/main/internals/internals.ts.html +0 -190
  35. package/coverage/lcov-report/src/main/libs/BuildFlow.ts.html +0 -127
  36. package/coverage/lcov-report/src/main/libs/Compiler.ts.html +0 -241
  37. package/coverage/lcov-report/src/main/libs/ConvertFlowNodes.ts.html +0 -97
  38. package/coverage/lcov-report/src/main/libs/DynamicRule.ts.html +0 -118
  39. package/coverage/lcov-report/src/main/libs/ExportDetails.ts.html +0 -256
  40. package/coverage/lcov-report/src/main/libs/ExportDiagram.ts.html +0 -331
  41. package/coverage/lcov-report/src/main/libs/ExportSarif.ts.html +0 -358
  42. package/coverage/lcov-report/src/main/libs/FixFlows.ts.html +0 -265
  43. package/coverage/lcov-report/src/main/libs/GenerateMarkdown.ts.html +0 -331
  44. package/coverage/lcov-report/src/main/libs/GetRuleDefinitions.ts.html +0 -274
  45. package/coverage/lcov-report/src/main/libs/ParseFlows.ts.html +0 -184
  46. package/coverage/lcov-report/src/main/libs/RuleDocumentation.ts.html +0 -190
  47. package/coverage/lcov-report/src/main/libs/ScanFlows.ts.html +0 -508
  48. package/coverage/lcov-report/src/main/libs/exportAsDetails.ts.html +0 -160
  49. package/coverage/lcov-report/src/main/libs/exportAsSarif.ts.html +0 -346
  50. package/coverage/lcov-report/src/main/libs/index.html +0 -251
  51. package/coverage/lcov-report/src/main/models/FlatViolation.ts.html +0 -106
  52. package/coverage/lcov-report/src/main/models/Flow.ts.html +0 -1057
  53. package/coverage/lcov-report/src/main/models/FlowAttribute.ts.html +0 -115
  54. package/coverage/lcov-report/src/main/models/FlowElement.ts.html +0 -133
  55. package/coverage/lcov-report/src/main/models/FlowElementConnector.ts.html +0 -169
  56. package/coverage/lcov-report/src/main/models/FlowGraph.ts.html +0 -1672
  57. package/coverage/lcov-report/src/main/models/FlowMetadata.ts.html +0 -106
  58. package/coverage/lcov-report/src/main/models/FlowNode.ts.html +0 -1252
  59. package/coverage/lcov-report/src/main/models/FlowResource.ts.html +0 -106
  60. package/coverage/lcov-report/src/main/models/FlowType.ts.html +0 -244
  61. package/coverage/lcov-report/src/main/models/FlowVariable.ts.html +0 -553
  62. package/coverage/lcov-report/src/main/models/LoopRuleCommon.ts.html +0 -235
  63. package/coverage/lcov-report/src/main/models/ParsedFlow.ts.html +0 -121
  64. package/coverage/lcov-report/src/main/models/RuleCommon.ts.html +0 -442
  65. package/coverage/lcov-report/src/main/models/RuleResult.ts.html +0 -172
  66. package/coverage/lcov-report/src/main/models/ScanResult.ts.html +0 -121
  67. package/coverage/lcov-report/src/main/models/Violation.ts.html +0 -316
  68. package/coverage/lcov-report/src/main/models/index.html +0 -341
  69. package/coverage/lcov-report/src/main/rules/APIVersion.ts.html +0 -361
  70. package/coverage/lcov-report/src/main/rules/ActionCallsInLoop.ts.html +0 -157
  71. package/coverage/lcov-report/src/main/rules/AutoLayout.ts.html +0 -220
  72. package/coverage/lcov-report/src/main/rules/CopyAPIName.ts.html +0 -175
  73. package/coverage/lcov-report/src/main/rules/CyclomaticComplexity.ts.html +0 -292
  74. package/coverage/lcov-report/src/main/rules/DMLStatementInLoop.ts.html +0 -163
  75. package/coverage/lcov-report/src/main/rules/DuplicateDMLOperation.ts.html +0 -334
  76. package/coverage/lcov-report/src/main/rules/FlowDescription.ts.html +0 -184
  77. package/coverage/lcov-report/src/main/rules/FlowName.ts.html +0 -229
  78. package/coverage/lcov-report/src/main/rules/GetRecordAllFields.ts.html +0 -280
  79. package/coverage/lcov-report/src/main/rules/HardcodedId.ts.html +0 -238
  80. package/coverage/lcov-report/src/main/rules/HardcodedSecret.ts.html +0 -238
  81. package/coverage/lcov-report/src/main/rules/HardcodedUrl.ts.html +0 -247
  82. package/coverage/lcov-report/src/main/rules/InactiveFlow.ts.html +0 -184
  83. package/coverage/lcov-report/src/main/rules/MissingFaultPath.ts.html +0 -397
  84. package/coverage/lcov-report/src/main/rules/MissingFilterRecordTrigger.ts.html +0 -229
  85. package/coverage/lcov-report/src/main/rules/MissingMetadataDescription.ts.html +0 -211
  86. package/coverage/lcov-report/src/main/rules/MissingNullHandler.ts.html +0 -460
  87. package/coverage/lcov-report/src/main/rules/MissingRecordTriggerFilter.ts.html +0 -235
  88. package/coverage/lcov-report/src/main/rules/ProcessBuilder.ts.html +0 -190
  89. package/coverage/lcov-report/src/main/rules/RecordIdAsString.ts.html +0 -274
  90. package/coverage/lcov-report/src/main/rules/RecursiveAfterUpdate.ts.html +0 -364
  91. package/coverage/lcov-report/src/main/rules/SOQLQueryInLoop.ts.html +0 -160
  92. package/coverage/lcov-report/src/main/rules/SameRecordFieldUpdates.ts.html +0 -283
  93. package/coverage/lcov-report/src/main/rules/TransformInsteadOfLoop.ts.html +0 -250
  94. package/coverage/lcov-report/src/main/rules/TriggerOrder.ts.html +0 -238
  95. package/coverage/lcov-report/src/main/rules/UnconnectedElement.ts.html +0 -178
  96. package/coverage/lcov-report/src/main/rules/UnsafeRunningContext.ts.html +0 -226
  97. package/coverage/lcov-report/src/main/rules/UnusedVariable.ts.html +0 -283
  98. package/coverage/lcov-report/src/main/rules/index.html +0 -521
  99. package/coverage/lcov-report/src/main/store/DefaultRuleStore.ts.html +0 -265
  100. package/coverage/lcov-report/src/main/store/RuleRegistry.ts.html +0 -118
  101. package/coverage/lcov-report/src/main/store/index.html +0 -116
  102. package/coverage/lcov.info +0 -6261
  103. package/eslint.config.mjs +0 -36
  104. package/jest.config.cjs +0 -32
  105. package/jest.env-setup.js +0 -101
  106. package/lint-staged.config.mjs +0 -8
  107. package/prettier.config.mjs +0 -5
  108. package/src/index.ts +0 -52
  109. package/src/main/config/NodeIcons.ts +0 -98
  110. package/src/main/config/RegexAdapter.ts +0 -98
  111. package/src/main/config/RuleRegistry.ts +0 -188
  112. package/src/main/config/VariableIcons.ts +0 -57
  113. package/src/main/enums/MetadataTypes.ts +0 -6
  114. package/src/main/interfaces/IExceptions.ts +0 -6
  115. package/src/main/interfaces/IRuleConfig.ts +0 -6
  116. package/src/main/interfaces/IRuleDefinition.ts +0 -15
  117. package/src/main/interfaces/IRuleOptions.ts +0 -5
  118. package/src/main/interfaces/IRulesConfig.ts +0 -17
  119. package/src/main/internals/internals.ts +0 -35
  120. package/src/main/libs/BuildFlow.ts +0 -14
  121. package/src/main/libs/Compiler.ts +0 -53
  122. package/src/main/libs/ExportDetails.ts +0 -58
  123. package/src/main/libs/ExportDiagram.ts +0 -83
  124. package/src/main/libs/ExportSarif.ts +0 -92
  125. package/src/main/libs/FixFlows.ts +0 -61
  126. package/src/main/libs/GetRuleDefinitions.ts +0 -64
  127. package/src/main/libs/ParseFlows.ts +0 -34
  128. package/src/main/libs/RuleDocumentation.ts +0 -35
  129. package/src/main/libs/ScanFlows.ts +0 -142
  130. package/src/main/models/FlatViolation.ts +0 -16
  131. package/src/main/models/Flow.ts +0 -325
  132. package/src/main/models/FlowAttribute.ts +0 -11
  133. package/src/main/models/FlowElement.ts +0 -16
  134. package/src/main/models/FlowElementConnector.ts +0 -28
  135. package/src/main/models/FlowGraph.ts +0 -530
  136. package/src/main/models/FlowMetadata.ts +0 -8
  137. package/src/main/models/FlowNode.ts +0 -390
  138. package/src/main/models/FlowResource.ts +0 -8
  139. package/src/main/models/FlowType.ts +0 -53
  140. package/src/main/models/FlowVariable.ts +0 -157
  141. package/src/main/models/LoopRuleCommon.ts +0 -51
  142. package/src/main/models/ParsedFlow.ts +0 -13
  143. package/src/main/models/RuleCommon.ts +0 -120
  144. package/src/main/models/RuleInfo.ts +0 -54
  145. package/src/main/models/RuleResult.ts +0 -29
  146. package/src/main/models/ScanResult.ts +0 -12
  147. package/src/main/models/Violation.ts +0 -78
  148. package/src/main/rules/APIVersion.ts +0 -93
  149. package/src/main/rules/ActionCallsInLoop.ts +0 -25
  150. package/src/main/rules/AutoLayout.ts +0 -46
  151. package/src/main/rules/CopyAPIName.ts +0 -31
  152. package/src/main/rules/CyclomaticComplexity.ts +0 -70
  153. package/src/main/rules/DMLStatementInLoop.ts +0 -26
  154. package/src/main/rules/DuplicateDMLOperation.ts +0 -83
  155. package/src/main/rules/FlowDescription.ts +0 -34
  156. package/src/main/rules/FlowName.ts +0 -49
  157. package/src/main/rules/GetRecordAllFields.ts +0 -65
  158. package/src/main/rules/HardcodedId.ts +0 -51
  159. package/src/main/rules/HardcodedSecret.ts +0 -51
  160. package/src/main/rules/HardcodedUrl.ts +0 -54
  161. package/src/main/rules/InactiveFlow.ts +0 -33
  162. package/src/main/rules/MissingFaultPath.ts +0 -105
  163. package/src/main/rules/MissingMetadataDescription.ts +0 -42
  164. package/src/main/rules/MissingNullHandler.ts +0 -126
  165. package/src/main/rules/MissingRecordTriggerFilter.ts +0 -51
  166. package/src/main/rules/ProcessBuilder.ts +0 -35
  167. package/src/main/rules/RecordIdAsString.ts +0 -64
  168. package/src/main/rules/RecursiveAfterUpdate.ts +0 -94
  169. package/src/main/rules/SOQLQueryInLoop.ts +0 -26
  170. package/src/main/rules/SameRecordFieldUpdates.ts +0 -66
  171. package/src/main/rules/TransformInsteadOfLoop.ts +0 -56
  172. package/src/main/rules/TriggerOrder.ts +0 -51
  173. package/src/main/rules/UnconnectedElement.ts +0 -32
  174. package/src/main/rules/UnsafeRunningContext.ts +0 -47
  175. package/src/main/rules/UnusedVariable.ts +0 -66
  176. package/stryker.config.mjs +0 -23
  177. package/tests/APIVersion.test.ts +0 -87
  178. package/tests/AutoLayout.test.ts +0 -41
  179. package/tests/Config.test.ts +0 -122
  180. package/tests/ConfigBetaMode.test.ts +0 -26
  181. package/tests/CopyAPIName.test.ts +0 -45
  182. package/tests/CyclomaticComplexity.test.ts +0 -125
  183. package/tests/DMLStatementInLoop.test.ts +0 -32
  184. package/tests/DuplicateDMLOperation.test.ts +0 -43
  185. package/tests/EnabledFalse.test.ts +0 -63
  186. package/tests/Exceptions.test.ts +0 -815
  187. package/tests/ExportSarif.test.ts +0 -62
  188. package/tests/FlowDescription.test.ts +0 -44
  189. package/tests/FlowDocumentation.test.ts +0 -74
  190. package/tests/FlowName.test.ts +0 -61
  191. package/tests/GetRecordElementAllFields.test.ts +0 -182
  192. package/tests/HardcodedId.test.ts +0 -16
  193. package/tests/HardcodedSecret.test.ts +0 -32
  194. package/tests/HardcodedUrl.test.ts +0 -253
  195. package/tests/InactiveFlow.test.ts +0 -103
  196. package/tests/MissingFaultPath.test.ts +0 -52
  197. package/tests/MissingMetadataDescription.test.ts +0 -25
  198. package/tests/MissingNullHandler.test.ts +0 -45
  199. package/tests/MissingRecordTriggerFilter.test.ts +0 -54
  200. package/tests/RecordIdAsString.test.ts +0 -60
  201. package/tests/RecursiveAfterUpdate.test.ts +0 -183
  202. package/tests/SOQLQueryInLoop.test.ts +0 -33
  203. package/tests/SameRecordFieldUpdates.test.ts +0 -205
  204. package/tests/SanityTest.test.ts +0 -15
  205. package/tests/TransformInsteadOfLoop.test.ts +0 -33
  206. package/tests/TriggerOrder.test.ts +0 -112
  207. package/tests/UnconnectedElement.test.ts +0 -76
  208. package/tests/UnsafeRunningContext.test.ts +0 -46
  209. package/tests/UnusedVariable.test.ts +0 -59
  210. package/tests/UnusedVariableExceptions.test.ts +0 -87
  211. package/tests/jsonfiles/MissingFaultPath_BeforeSave_Bypass.json +0 -128
  212. package/tests/jsonfiles/MissingFaultPath_WaitConditions.json +0 -102
  213. package/tests/jsonfiles/MissingFaultPath_WaitDate.json +0 -88
  214. package/tests/jsonfiles/MissingFaultPath_WaitDuration.json +0 -90
  215. package/tests/models/Flow.test.ts +0 -107
  216. package/tests/models/LoopRuleCommon.test.ts +0 -246
  217. package/tests/models/RuleCommon.test.ts +0 -41
  218. package/tsconfig.json +0 -28
  219. package/tsconfig.types.json +0 -26
  220. package/types/index.d.ts +0 -27
  221. package/types/index.d.ts.map +0 -1
  222. package/types/main/adapters/RegexAdapter.d.ts +0 -33
  223. package/types/main/adapters/RegexAdapter.d.ts.map +0 -1
  224. package/types/main/config/NodeIcons.d.ts +0 -25
  225. package/types/main/config/NodeIcons.d.ts.map +0 -1
  226. package/types/main/config/RegexAdapter.d.ts +0 -33
  227. package/types/main/config/RegexAdapter.d.ts.map +0 -1
  228. package/types/main/config/RuleRegistry.d.ts +0 -23
  229. package/types/main/config/RuleRegistry.d.ts.map +0 -1
  230. package/types/main/config/VariableIcons.d.ts +0 -26
  231. package/types/main/config/VariableIcons.d.ts.map +0 -1
  232. package/types/main/enums/MetadataTypes.d.ts +0 -7
  233. package/types/main/enums/MetadataTypes.d.ts.map +0 -1
  234. package/types/main/interfaces/IExceptions.d.ts +0 -6
  235. package/types/main/interfaces/IExceptions.d.ts.map +0 -1
  236. package/types/main/interfaces/IRuleConfig.d.ts +0 -7
  237. package/types/main/interfaces/IRuleConfig.d.ts.map +0 -1
  238. package/types/main/interfaces/IRuleDefinition.d.ts +0 -18
  239. package/types/main/interfaces/IRuleDefinition.d.ts.map +0 -1
  240. package/types/main/interfaces/IRuleOptions.d.ts +0 -5
  241. package/types/main/interfaces/IRuleOptions.d.ts.map +0 -1
  242. package/types/main/interfaces/IRulesConfig.d.ts +0 -16
  243. package/types/main/interfaces/IRulesConfig.d.ts.map +0 -1
  244. package/types/main/internals/internals.d.ts +0 -19
  245. package/types/main/internals/internals.d.ts.map +0 -1
  246. package/types/main/libs/BuildFlow.d.ts +0 -2
  247. package/types/main/libs/BuildFlow.d.ts.map +0 -1
  248. package/types/main/libs/Compiler.d.ts +0 -8
  249. package/types/main/libs/Compiler.d.ts.map +0 -1
  250. package/types/main/libs/ConvertFlowNodes.d.ts +0 -2
  251. package/types/main/libs/ConvertFlowNodes.d.ts.map +0 -1
  252. package/types/main/libs/DynamicRule.d.ts +0 -5
  253. package/types/main/libs/DynamicRule.d.ts.map +0 -1
  254. package/types/main/libs/ExportDetails.d.ts +0 -4
  255. package/types/main/libs/ExportDetails.d.ts.map +0 -1
  256. package/types/main/libs/ExportDiagram.d.ts +0 -42
  257. package/types/main/libs/ExportDiagram.d.ts.map +0 -1
  258. package/types/main/libs/ExportSarif.d.ts +0 -3
  259. package/types/main/libs/ExportSarif.d.ts.map +0 -1
  260. package/types/main/libs/FixFlows.d.ts +0 -4
  261. package/types/main/libs/FixFlows.d.ts.map +0 -1
  262. package/types/main/libs/GetRuleDefinitions.d.ts +0 -5
  263. package/types/main/libs/GetRuleDefinitions.d.ts.map +0 -1
  264. package/types/main/libs/ParseFlows.d.ts +0 -3
  265. package/types/main/libs/ParseFlows.d.ts.map +0 -1
  266. package/types/main/libs/RuleDocumentation.d.ts +0 -21
  267. package/types/main/libs/RuleDocumentation.d.ts.map +0 -1
  268. package/types/main/libs/ScanFlows.d.ts +0 -5
  269. package/types/main/libs/ScanFlows.d.ts.map +0 -1
  270. package/types/main/libs/exportAsDetails.d.ts +0 -4
  271. package/types/main/libs/exportAsDetails.d.ts.map +0 -1
  272. package/types/main/libs/exportAsSarif.d.ts +0 -3
  273. package/types/main/libs/exportAsSarif.d.ts.map +0 -1
  274. package/types/main/models/FlatViolation.d.ts +0 -16
  275. package/types/main/models/FlatViolation.d.ts.map +0 -1
  276. package/types/main/models/Flow.d.ts +0 -70
  277. package/types/main/models/Flow.d.ts.map +0 -1
  278. package/types/main/models/FlowAttribute.d.ts +0 -6
  279. package/types/main/models/FlowAttribute.d.ts.map +0 -1
  280. package/types/main/models/FlowElement.d.ts +0 -11
  281. package/types/main/models/FlowElement.d.ts.map +0 -1
  282. package/types/main/models/FlowElementConnector.d.ts +0 -16
  283. package/types/main/models/FlowElementConnector.d.ts.map +0 -1
  284. package/types/main/models/FlowGraph.d.ts +0 -86
  285. package/types/main/models/FlowGraph.d.ts.map +0 -1
  286. package/types/main/models/FlowMetadata.d.ts +0 -5
  287. package/types/main/models/FlowMetadata.d.ts.map +0 -1
  288. package/types/main/models/FlowNode.d.ts +0 -66
  289. package/types/main/models/FlowNode.d.ts.map +0 -1
  290. package/types/main/models/FlowResource.d.ts +0 -5
  291. package/types/main/models/FlowResource.d.ts.map +0 -1
  292. package/types/main/models/FlowType.d.ts +0 -24
  293. package/types/main/models/FlowType.d.ts.map +0 -1
  294. package/types/main/models/FlowVariable.d.ts +0 -64
  295. package/types/main/models/FlowVariable.d.ts.map +0 -1
  296. package/types/main/models/LoopRuleCommon.d.ts +0 -15
  297. package/types/main/models/LoopRuleCommon.d.ts.map +0 -1
  298. package/types/main/models/ParsedFlow.d.ts +0 -8
  299. package/types/main/models/ParsedFlow.d.ts.map +0 -1
  300. package/types/main/models/RuleCommon.d.ts +0 -58
  301. package/types/main/models/RuleCommon.d.ts.map +0 -1
  302. package/types/main/models/RuleInfo.d.ts +0 -50
  303. package/types/main/models/RuleInfo.d.ts.map +0 -1
  304. package/types/main/models/RuleResult.d.ts +0 -15
  305. package/types/main/models/RuleResult.d.ts.map +0 -1
  306. package/types/main/models/ScanResult.d.ts +0 -8
  307. package/types/main/models/ScanResult.d.ts.map +0 -1
  308. package/types/main/models/Violation.d.ts +0 -12
  309. package/types/main/models/Violation.d.ts.map +0 -1
  310. package/types/main/rules/APIVersion.d.ts +0 -10
  311. package/types/main/rules/APIVersion.d.ts.map +0 -1
  312. package/types/main/rules/ActionCallsInLoop.d.ts +0 -7
  313. package/types/main/rules/ActionCallsInLoop.d.ts.map +0 -1
  314. package/types/main/rules/AutoLayout.d.ts +0 -8
  315. package/types/main/rules/AutoLayout.d.ts.map +0 -1
  316. package/types/main/rules/CopyAPIName.d.ts +0 -8
  317. package/types/main/rules/CopyAPIName.d.ts.map +0 -1
  318. package/types/main/rules/CyclomaticComplexity.d.ts +0 -12
  319. package/types/main/rules/CyclomaticComplexity.d.ts.map +0 -1
  320. package/types/main/rules/DMLStatementInLoop.d.ts +0 -7
  321. package/types/main/rules/DMLStatementInLoop.d.ts.map +0 -1
  322. package/types/main/rules/DuplicateDMLOperation.d.ts +0 -9
  323. package/types/main/rules/DuplicateDMLOperation.d.ts.map +0 -1
  324. package/types/main/rules/FlowDescription.d.ts +0 -8
  325. package/types/main/rules/FlowDescription.d.ts.map +0 -1
  326. package/types/main/rules/FlowName.d.ts +0 -16
  327. package/types/main/rules/FlowName.d.ts.map +0 -1
  328. package/types/main/rules/GetRecordAllFields.d.ts +0 -8
  329. package/types/main/rules/GetRecordAllFields.d.ts.map +0 -1
  330. package/types/main/rules/HardcodedId.d.ts +0 -14
  331. package/types/main/rules/HardcodedId.d.ts.map +0 -1
  332. package/types/main/rules/HardcodedSecret.d.ts +0 -14
  333. package/types/main/rules/HardcodedSecret.d.ts.map +0 -1
  334. package/types/main/rules/HardcodedUrl.d.ts +0 -14
  335. package/types/main/rules/HardcodedUrl.d.ts.map +0 -1
  336. package/types/main/rules/InactiveFlow.d.ts +0 -8
  337. package/types/main/rules/InactiveFlow.d.ts.map +0 -1
  338. package/types/main/rules/MissingFaultPath.d.ts +0 -15
  339. package/types/main/rules/MissingFaultPath.d.ts.map +0 -1
  340. package/types/main/rules/MissingFilterRecordTrigger.d.ts +0 -8
  341. package/types/main/rules/MissingFilterRecordTrigger.d.ts.map +0 -1
  342. package/types/main/rules/MissingMetadataDescription.d.ts +0 -8
  343. package/types/main/rules/MissingMetadataDescription.d.ts.map +0 -1
  344. package/types/main/rules/MissingNullHandler.d.ts +0 -8
  345. package/types/main/rules/MissingNullHandler.d.ts.map +0 -1
  346. package/types/main/rules/MissingRecordTriggerFilter.d.ts +0 -8
  347. package/types/main/rules/MissingRecordTriggerFilter.d.ts.map +0 -1
  348. package/types/main/rules/ProcessBuilder.d.ts +0 -8
  349. package/types/main/rules/ProcessBuilder.d.ts.map +0 -1
  350. package/types/main/rules/RecordIdAsString.d.ts +0 -8
  351. package/types/main/rules/RecordIdAsString.d.ts.map +0 -1
  352. package/types/main/rules/RecursiveAfterUpdate.d.ts +0 -9
  353. package/types/main/rules/RecursiveAfterUpdate.d.ts.map +0 -1
  354. package/types/main/rules/SOQLQueryInLoop.d.ts +0 -7
  355. package/types/main/rules/SOQLQueryInLoop.d.ts.map +0 -1
  356. package/types/main/rules/SameRecordFieldUpdates.d.ts +0 -9
  357. package/types/main/rules/SameRecordFieldUpdates.d.ts.map +0 -1
  358. package/types/main/rules/TransformInsteadOfLoop.d.ts +0 -8
  359. package/types/main/rules/TransformInsteadOfLoop.d.ts.map +0 -1
  360. package/types/main/rules/TriggerOrder.d.ts +0 -8
  361. package/types/main/rules/TriggerOrder.d.ts.map +0 -1
  362. package/types/main/rules/UnconnectedElement.d.ts +0 -8
  363. package/types/main/rules/UnconnectedElement.d.ts.map +0 -1
  364. package/types/main/rules/UnsafeRunningContext.d.ts +0 -8
  365. package/types/main/rules/UnsafeRunningContext.d.ts.map +0 -1
  366. package/types/main/rules/UnusedVariable.d.ts +0 -8
  367. package/types/main/rules/UnusedVariable.d.ts.map +0 -1
  368. package/types/main/store/DefaultRuleStore.d.ts +0 -3
  369. package/types/main/store/DefaultRuleStore.d.ts.map +0 -1
  370. package/types/main/store/RuleRegistry.d.ts +0 -23
  371. package/types/main/store/RuleRegistry.d.ts.map +0 -1
  372. package/vite.config.ts +0 -33
  373. /package/{out/index.d.ts → index.d.ts} +0 -0
  374. /package/{out/index.js → index.js} +0 -0
  375. /package/{out/main → main}/config/NodeIcons.d.ts +0 -0
  376. /package/{out/main → main}/config/NodeIcons.js +0 -0
  377. /package/{out/main → main}/config/RegexAdapter.d.ts +0 -0
  378. /package/{out/main → main}/config/RegexAdapter.js +0 -0
  379. /package/{out/main → main}/config/RuleRegistry.d.ts +0 -0
  380. /package/{out/main → main}/config/RuleRegistry.js +0 -0
  381. /package/{out/main → main}/config/VariableIcons.d.ts +0 -0
  382. /package/{out/main → main}/config/VariableIcons.js +0 -0
  383. /package/{out/main → main}/enums/MetadataTypes.d.ts +0 -0
  384. /package/{out/main → main}/enums/MetadataTypes.js +0 -0
  385. /package/{out/main → main}/interfaces/IExceptions.d.ts +0 -0
  386. /package/{out/main → main}/interfaces/IExceptions.js +0 -0
  387. /package/{out/main → main}/interfaces/IRuleConfig.d.ts +0 -0
  388. /package/{out/main → main}/interfaces/IRuleConfig.js +0 -0
  389. /package/{out/main → main}/interfaces/IRuleDefinition.d.ts +0 -0
  390. /package/{out/main → main}/interfaces/IRuleDefinition.js +0 -0
  391. /package/{out/main → main}/interfaces/IRuleOptions.d.ts +0 -0
  392. /package/{out/main → main}/interfaces/IRuleOptions.js +0 -0
  393. /package/{out/main → main}/interfaces/IRulesConfig.d.ts +0 -0
  394. /package/{out/main → main}/interfaces/IRulesConfig.js +0 -0
  395. /package/{out/main → main}/internals/internals.d.ts +0 -0
  396. /package/{out/main → main}/internals/internals.js +0 -0
  397. /package/{out/main → main}/libs/BuildFlow.d.ts +0 -0
  398. /package/{out/main → main}/libs/BuildFlow.js +0 -0
  399. /package/{out/main → main}/libs/Compiler.d.ts +0 -0
  400. /package/{out/main → main}/libs/Compiler.js +0 -0
  401. /package/{out/main → main}/libs/ExportDetails.d.ts +0 -0
  402. /package/{out/main → main}/libs/ExportDetails.js +0 -0
  403. /package/{out/main → main}/libs/ExportDiagram.d.ts +0 -0
  404. /package/{out/main → main}/libs/ExportDiagram.js +0 -0
  405. /package/{out/main → main}/libs/ExportSarif.d.ts +0 -0
  406. /package/{out/main → main}/libs/ExportSarif.js +0 -0
  407. /package/{out/main → main}/libs/FixFlows.d.ts +0 -0
  408. /package/{out/main → main}/libs/FixFlows.js +0 -0
  409. /package/{out/main → main}/libs/GetRuleDefinitions.d.ts +0 -0
  410. /package/{out/main → main}/libs/GetRuleDefinitions.js +0 -0
  411. /package/{out/main → main}/libs/ParseFlows.d.ts +0 -0
  412. /package/{out/main → main}/libs/ParseFlows.js +0 -0
  413. /package/{out/main → main}/libs/RuleDocumentation.d.ts +0 -0
  414. /package/{out/main → main}/libs/RuleDocumentation.js +0 -0
  415. /package/{out/main → main}/libs/ScanFlows.d.ts +0 -0
  416. /package/{out/main → main}/libs/ScanFlows.js +0 -0
  417. /package/{out/main → main}/models/FlatViolation.d.ts +0 -0
  418. /package/{out/main → main}/models/FlatViolation.js +0 -0
  419. /package/{out/main → main}/models/Flow.d.ts +0 -0
  420. /package/{out/main → main}/models/Flow.js +0 -0
  421. /package/{out/main → main}/models/FlowAttribute.d.ts +0 -0
  422. /package/{out/main → main}/models/FlowAttribute.js +0 -0
  423. /package/{out/main → main}/models/FlowElement.d.ts +0 -0
  424. /package/{out/main → main}/models/FlowElement.js +0 -0
  425. /package/{out/main → main}/models/FlowElementConnector.d.ts +0 -0
  426. /package/{out/main → main}/models/FlowElementConnector.js +0 -0
  427. /package/{out/main → main}/models/FlowGraph.d.ts +0 -0
  428. /package/{out/main → main}/models/FlowGraph.js +0 -0
  429. /package/{out/main → main}/models/FlowMetadata.d.ts +0 -0
  430. /package/{out/main → main}/models/FlowMetadata.js +0 -0
  431. /package/{out/main → main}/models/FlowNode.d.ts +0 -0
  432. /package/{out/main → main}/models/FlowNode.js +0 -0
  433. /package/{out/main → main}/models/FlowResource.d.ts +0 -0
  434. /package/{out/main → main}/models/FlowResource.js +0 -0
  435. /package/{out/main → main}/models/FlowType.d.ts +0 -0
  436. /package/{out/main → main}/models/FlowType.js +0 -0
  437. /package/{out/main → main}/models/FlowVariable.d.ts +0 -0
  438. /package/{out/main → main}/models/FlowVariable.js +0 -0
  439. /package/{out/main → main}/models/LoopRuleCommon.d.ts +0 -0
  440. /package/{out/main → main}/models/LoopRuleCommon.js +0 -0
  441. /package/{out/main → main}/models/ParsedFlow.d.ts +0 -0
  442. /package/{out/main → main}/models/ParsedFlow.js +0 -0
  443. /package/{out/main → main}/models/RuleCommon.d.ts +0 -0
  444. /package/{out/main → main}/models/RuleCommon.js +0 -0
  445. /package/{out/main → main}/models/RuleInfo.d.ts +0 -0
  446. /package/{out/main → main}/models/RuleInfo.js +0 -0
  447. /package/{out/main → main}/models/RuleResult.d.ts +0 -0
  448. /package/{out/main → main}/models/RuleResult.js +0 -0
  449. /package/{out/main → main}/models/ScanResult.d.ts +0 -0
  450. /package/{out/main → main}/models/ScanResult.js +0 -0
  451. /package/{out/main → main}/models/Violation.d.ts +0 -0
  452. /package/{out/main → main}/models/Violation.js +0 -0
  453. /package/{out/main → main}/rules/APIVersion.d.ts +0 -0
  454. /package/{out/main → main}/rules/APIVersion.js +0 -0
  455. /package/{out/main → main}/rules/ActionCallsInLoop.d.ts +0 -0
  456. /package/{out/main → main}/rules/ActionCallsInLoop.js +0 -0
  457. /package/{out/main → main}/rules/AutoLayout.d.ts +0 -0
  458. /package/{out/main → main}/rules/AutoLayout.js +0 -0
  459. /package/{out/main → main}/rules/CopyAPIName.d.ts +0 -0
  460. /package/{out/main → main}/rules/CopyAPIName.js +0 -0
  461. /package/{out/main → main}/rules/CyclomaticComplexity.d.ts +0 -0
  462. /package/{out/main → main}/rules/CyclomaticComplexity.js +0 -0
  463. /package/{out/main → main}/rules/DMLStatementInLoop.d.ts +0 -0
  464. /package/{out/main → main}/rules/DMLStatementInLoop.js +0 -0
  465. /package/{out/main → main}/rules/DuplicateDMLOperation.d.ts +0 -0
  466. /package/{out/main → main}/rules/DuplicateDMLOperation.js +0 -0
  467. /package/{out/main → main}/rules/FlowDescription.d.ts +0 -0
  468. /package/{out/main → main}/rules/FlowDescription.js +0 -0
  469. /package/{out/main → main}/rules/FlowName.d.ts +0 -0
  470. /package/{out/main → main}/rules/FlowName.js +0 -0
  471. /package/{out/main → main}/rules/GetRecordAllFields.d.ts +0 -0
  472. /package/{out/main → main}/rules/GetRecordAllFields.js +0 -0
  473. /package/{out/main → main}/rules/HardcodedId.d.ts +0 -0
  474. /package/{out/main → main}/rules/HardcodedId.js +0 -0
  475. /package/{out/main → main}/rules/HardcodedSecret.d.ts +0 -0
  476. /package/{out/main → main}/rules/HardcodedSecret.js +0 -0
  477. /package/{out/main → main}/rules/HardcodedUrl.d.ts +0 -0
  478. /package/{out/main → main}/rules/HardcodedUrl.js +0 -0
  479. /package/{out/main → main}/rules/InactiveFlow.d.ts +0 -0
  480. /package/{out/main → main}/rules/InactiveFlow.js +0 -0
  481. /package/{out/main → main}/rules/MissingFaultPath.d.ts +0 -0
  482. /package/{out/main → main}/rules/MissingFaultPath.js +0 -0
  483. /package/{out/main → main}/rules/MissingMetadataDescription.d.ts +0 -0
  484. /package/{out/main → main}/rules/MissingMetadataDescription.js +0 -0
  485. /package/{out/main → main}/rules/MissingNullHandler.d.ts +0 -0
  486. /package/{out/main → main}/rules/MissingNullHandler.js +0 -0
  487. /package/{out/main → main}/rules/MissingRecordTriggerFilter.d.ts +0 -0
  488. /package/{out/main → main}/rules/MissingRecordTriggerFilter.js +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
- });