@zzzen/pyright-internal 1.1.255 → 1.2.0-dev.20220703

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 (1456) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -0
  3. package/dist/analyzer/aliasDeclarationUtils.js +2 -2
  4. package/dist/analyzer/analyzerFileInfo.d.ts +1 -1
  5. package/dist/analyzer/analyzerNodeInfo.d.ts +4 -1
  6. package/dist/analyzer/analyzerNodeInfo.js +12 -1
  7. package/dist/analyzer/analyzerNodeInfo.js.map +1 -1
  8. package/dist/analyzer/backgroundAnalysisProgram.d.ts +1 -0
  9. package/dist/analyzer/backgroundAnalysisProgram.js +3 -0
  10. package/dist/analyzer/backgroundAnalysisProgram.js.map +1 -1
  11. package/dist/analyzer/binder.d.ts +6 -1
  12. package/dist/analyzer/binder.js +142 -32
  13. package/dist/analyzer/binder.js.map +1 -1
  14. package/dist/analyzer/checker.d.ts +4 -1
  15. package/dist/analyzer/checker.js +144 -73
  16. package/dist/analyzer/checker.js.map +1 -1
  17. package/dist/analyzer/codeFlowUtils.js +33 -0
  18. package/dist/analyzer/codeFlowUtils.js.map +1 -1
  19. package/dist/analyzer/constraintSolver.js +6 -3
  20. package/dist/analyzer/constraintSolver.js.map +1 -1
  21. package/dist/analyzer/dataClasses.js +6 -4
  22. package/dist/analyzer/dataClasses.js.map +1 -1
  23. package/dist/analyzer/declaration.d.ts +18 -6
  24. package/dist/analyzer/declaration.js +25 -5
  25. package/dist/analyzer/declaration.js.map +1 -1
  26. package/dist/analyzer/declarationUtils.d.ts +1 -1
  27. package/dist/analyzer/declarationUtils.js +19 -16
  28. package/dist/analyzer/declarationUtils.js.map +1 -1
  29. package/dist/analyzer/importResult.js +7 -0
  30. package/dist/analyzer/importResult.js.map +1 -1
  31. package/dist/analyzer/importStatementUtils.js +10 -1
  32. package/dist/analyzer/importStatementUtils.js.map +1 -1
  33. package/dist/analyzer/namedTuples.js +1 -1
  34. package/dist/analyzer/namedTuples.js.map +1 -1
  35. package/dist/analyzer/packageTypeReport.js +10 -1
  36. package/dist/analyzer/packageTypeReport.js.map +1 -1
  37. package/dist/analyzer/packageTypeVerifier.js +6 -6
  38. package/dist/analyzer/parseTreeUtils.d.ts +3 -3
  39. package/dist/analyzer/parseTreeUtils.js +27 -13
  40. package/dist/analyzer/parseTreeUtils.js.map +1 -1
  41. package/dist/analyzer/parseTreeWalker.d.ts +4 -1
  42. package/dist/analyzer/parseTreeWalker.js +19 -1
  43. package/dist/analyzer/parseTreeWalker.js.map +1 -1
  44. package/dist/analyzer/program.d.ts +2 -1
  45. package/dist/analyzer/program.js +27 -23
  46. package/dist/analyzer/program.js.map +1 -1
  47. package/dist/analyzer/properties.js +2 -0
  48. package/dist/analyzer/properties.js.map +1 -1
  49. package/dist/analyzer/protocols.d.ts +0 -1
  50. package/dist/analyzer/protocols.js +4 -64
  51. package/dist/analyzer/protocols.js.map +1 -1
  52. package/dist/analyzer/scope.js +22 -1
  53. package/dist/analyzer/scope.js.map +1 -1
  54. package/dist/analyzer/service.d.ts +20 -8
  55. package/dist/analyzer/service.js +39 -19
  56. package/dist/analyzer/service.js.map +1 -1
  57. package/dist/analyzer/sourceFile.js +1 -1
  58. package/dist/analyzer/sourceFile.js.map +1 -1
  59. package/dist/analyzer/sourceFileInfoUtils.d.ts +2 -0
  60. package/dist/analyzer/sourceFileInfoUtils.js +15 -0
  61. package/dist/analyzer/sourceFileInfoUtils.js.map +1 -0
  62. package/dist/analyzer/symbol.d.ts +3 -1
  63. package/dist/analyzer/symbol.js +39 -1
  64. package/dist/analyzer/symbol.js.map +1 -1
  65. package/dist/analyzer/tracePrinter.js +8 -4
  66. package/dist/analyzer/tracePrinter.js.map +1 -1
  67. package/dist/analyzer/typeDocStringUtils.js +11 -3
  68. package/dist/analyzer/typeDocStringUtils.js.map +1 -1
  69. package/dist/analyzer/typeEvaluator.js +610 -208
  70. package/dist/analyzer/typeEvaluator.js.map +1 -1
  71. package/dist/analyzer/typeEvaluatorTypes.d.ts +2 -1
  72. package/dist/analyzer/typeEvaluatorTypes.js +65 -1
  73. package/dist/analyzer/typeEvaluatorTypes.js.map +1 -1
  74. package/dist/analyzer/typeEvaluatorWithTracker.js +2 -0
  75. package/dist/analyzer/typeEvaluatorWithTracker.js.map +1 -1
  76. package/dist/analyzer/typeGuards.d.ts +2 -0
  77. package/dist/analyzer/typeGuards.js +113 -69
  78. package/dist/analyzer/typeGuards.js.map +1 -1
  79. package/dist/analyzer/typePrinter.js +27 -2
  80. package/dist/analyzer/typePrinter.js.map +1 -1
  81. package/dist/analyzer/typeStubWriter.d.ts +4 -1
  82. package/dist/analyzer/typeStubWriter.js +36 -0
  83. package/dist/analyzer/typeStubWriter.js.map +1 -1
  84. package/dist/analyzer/typeUtils.js +129 -33
  85. package/dist/analyzer/typeUtils.js.map +1 -1
  86. package/dist/analyzer/typedDicts.js +2 -1
  87. package/dist/analyzer/typedDicts.js.map +1 -1
  88. package/dist/analyzer/types.d.ts +12 -4
  89. package/dist/analyzer/types.js +215 -6
  90. package/dist/analyzer/types.js.map +1 -1
  91. package/dist/backgroundAnalysisBase.d.ts +1 -1
  92. package/dist/commands/commands.js +9 -0
  93. package/dist/commands/commands.js.map +1 -1
  94. package/dist/common/commandLineOptions.js +8 -1
  95. package/dist/common/commandLineOptions.js.map +1 -1
  96. package/dist/common/core.js +7 -1
  97. package/dist/common/core.js.map +1 -1
  98. package/dist/common/diagnostic.js +9 -1
  99. package/dist/common/diagnostic.js.map +1 -1
  100. package/dist/common/host.js +7 -1
  101. package/dist/common/host.js.map +1 -1
  102. package/dist/common/pathUtils.d.ts +1 -0
  103. package/dist/common/pathUtils.js +34 -1
  104. package/dist/common/pathUtils.js.map +1 -1
  105. package/dist/common/stringUtils.d.ts +1 -0
  106. package/dist/common/stringUtils.js +8 -1
  107. package/dist/common/stringUtils.js.map +1 -1
  108. package/dist/languageServerBase.d.ts +10 -3
  109. package/dist/languageServerBase.js +40 -14
  110. package/dist/languageServerBase.js.map +1 -1
  111. package/dist/languageService/analyzerServiceExecutor.js +3 -0
  112. package/dist/languageService/analyzerServiceExecutor.js.map +1 -1
  113. package/dist/languageService/autoImporter.js +2 -1
  114. package/dist/languageService/autoImporter.js.map +1 -1
  115. package/dist/languageService/callHierarchyProvider.js +9 -9
  116. package/dist/languageService/completionProvider.d.ts +2 -2
  117. package/dist/languageService/completionProvider.js +22 -18
  118. package/dist/languageService/completionProvider.js.map +1 -1
  119. package/dist/languageService/definitionProvider.js +3 -3
  120. package/dist/languageService/documentSymbolCollector.js +1 -1
  121. package/dist/languageService/documentSymbolProvider.js +10 -7
  122. package/dist/languageService/documentSymbolProvider.js.map +1 -1
  123. package/dist/languageService/hoverProvider.js +19 -5
  124. package/dist/languageService/hoverProvider.js.map +1 -1
  125. package/dist/languageService/referencesProvider.js +8 -5
  126. package/dist/languageService/referencesProvider.js.map +1 -1
  127. package/dist/languageService/tooltipUtils.js +1 -1
  128. package/dist/localization/localize.d.ts +27 -0
  129. package/dist/localization/localize.js +16 -0
  130. package/dist/localization/localize.js.map +1 -1
  131. package/dist/localization/package.nls.en-us.json +18 -2
  132. package/dist/parser/parseNodes.d.ts +44 -5
  133. package/dist/parser/parseNodes.js +191 -4
  134. package/dist/parser/parseNodes.js.map +1 -1
  135. package/dist/parser/parser.d.ts +3 -1
  136. package/dist/parser/parser.js +155 -24
  137. package/dist/parser/parser.js.map +1 -1
  138. package/dist/parser/stringTokenUtils.js +8 -1
  139. package/dist/parser/stringTokenUtils.js.map +1 -1
  140. package/dist/parser/tokenizer.js +4 -3
  141. package/dist/parser/tokenizer.js.map +1 -1
  142. package/dist/parser/tokenizerTypes.d.ts +5 -3
  143. package/dist/parser/tokenizerTypes.js +157 -1
  144. package/dist/parser/tokenizerTypes.js.map +1 -1
  145. package/dist/pyright.js +6 -1
  146. package/dist/pyright.js.map +1 -1
  147. package/dist/tests/chainedSourceFiles.test.js +12 -9
  148. package/dist/tests/chainedSourceFiles.test.js.map +1 -1
  149. package/dist/tests/checker.test.js +4 -0
  150. package/dist/tests/checker.test.js.map +1 -1
  151. package/dist/tests/config.test.js +14 -13
  152. package/dist/tests/config.test.js.map +1 -1
  153. package/dist/tests/debug.test.js +6 -0
  154. package/dist/tests/debug.test.js.map +1 -1
  155. package/dist/tests/fourslash/completions.autoimport.lib.alias.fourslash.d.ts +1 -0
  156. package/dist/tests/fourslash/completions.autoimport.lib.alias.fourslash.js +53 -0
  157. package/dist/tests/fourslash/completions.autoimport.lib.alias.fourslash.js.map +1 -0
  158. package/dist/tests/fourslash/fourslash.d.ts +16 -0
  159. package/dist/tests/fourslash/hover.class.docString.fourslash.d.ts +1 -0
  160. package/dist/tests/fourslash/hover.class.docString.fourslash.js +24 -0
  161. package/dist/tests/fourslash/hover.class.docString.fourslash.js.map +1 -0
  162. package/dist/tests/harness/fourslash/fourSlashParser.js +6 -0
  163. package/dist/tests/harness/fourslash/fourSlashParser.js.map +1 -1
  164. package/dist/tests/harness/fourslash/fourSlashTypes.js +19 -1
  165. package/dist/tests/harness/fourslash/fourSlashTypes.js.map +1 -1
  166. package/dist/tests/harness/fourslash/testLanguageService.js +9 -1
  167. package/dist/tests/harness/fourslash/testLanguageService.js.map +1 -1
  168. package/dist/tests/harness/fourslash/testState.Consts.d.ts +1 -0
  169. package/dist/tests/harness/fourslash/testState.Consts.js +1 -0
  170. package/dist/tests/harness/fourslash/testState.Consts.js.map +1 -1
  171. package/dist/tests/harness/fourslash/testState.d.ts +4 -3
  172. package/dist/tests/harness/fourslash/testState.js +27 -11
  173. package/dist/tests/harness/fourslash/testState.js.map +1 -1
  174. package/dist/tests/harness/vfs/pathValidation.js +25 -1
  175. package/dist/tests/harness/vfs/pathValidation.js.map +1 -1
  176. package/dist/tests/pathUtils.test.js +17 -0
  177. package/dist/tests/pathUtils.test.js.map +1 -1
  178. package/dist/tests/testUtils.js +1 -1
  179. package/dist/tests/testUtils.js.map +1 -1
  180. package/dist/tests/typeEvaluator1.test.js +9 -1
  181. package/dist/tests/typeEvaluator1.test.js.map +1 -1
  182. package/dist/tests/typeEvaluator2.test.js +9 -1
  183. package/dist/tests/typeEvaluator2.test.js.map +1 -1
  184. package/dist/tests/typeEvaluator3.test.js +4 -0
  185. package/dist/tests/typeEvaluator3.test.js.map +1 -1
  186. package/dist/tests/typeEvaluator5.test.d.ts +1 -0
  187. package/dist/tests/typeEvaluator5.test.js +112 -0
  188. package/dist/tests/typeEvaluator5.test.js.map +1 -0
  189. package/dist/workspaceMap.d.ts +2 -1
  190. package/dist/workspaceMap.js +25 -3
  191. package/dist/workspaceMap.js.map +1 -1
  192. package/package.json +45 -45
  193. package/src/analyzer/aliasDeclarationUtils.ts +0 -169
  194. package/src/analyzer/analysis.ts +0 -92
  195. package/src/analyzer/analyzerFileInfo.ts +0 -56
  196. package/src/analyzer/analyzerNodeInfo.ts +0 -198
  197. package/src/analyzer/backgroundAnalysisProgram.ts +0 -311
  198. package/src/analyzer/binder.ts +0 -4081
  199. package/src/analyzer/checker.ts +0 -5507
  200. package/src/analyzer/circularDependency.ts +0 -52
  201. package/src/analyzer/codeFlowEngine.ts +0 -1548
  202. package/src/analyzer/codeFlowTypes.ts +0 -266
  203. package/src/analyzer/codeFlowUtils.ts +0 -436
  204. package/src/analyzer/commentUtils.ts +0 -174
  205. package/src/analyzer/constraintSolver.ts +0 -926
  206. package/src/analyzer/constructorTransform.ts +0 -317
  207. package/src/analyzer/dataClasses.ts +0 -999
  208. package/src/analyzer/declaration.ts +0 -252
  209. package/src/analyzer/declarationUtils.ts +0 -238
  210. package/src/analyzer/docStringConversion.ts +0 -850
  211. package/src/analyzer/docStringUtils.ts +0 -112
  212. package/src/analyzer/functionTransform.ts +0 -137
  213. package/src/analyzer/importResolver.ts +0 -2308
  214. package/src/analyzer/importResult.ts +0 -98
  215. package/src/analyzer/importStatementUtils.ts +0 -834
  216. package/src/analyzer/namedTuples.ts +0 -422
  217. package/src/analyzer/packageTypeReport.ts +0 -108
  218. package/src/analyzer/packageTypeVerifier.ts +0 -1466
  219. package/src/analyzer/parentDirectoryCache.ts +0 -88
  220. package/src/analyzer/parseTreeCleaner.ts +0 -35
  221. package/src/analyzer/parseTreeUtils.ts +0 -2165
  222. package/src/analyzer/parseTreeWalker.ts +0 -663
  223. package/src/analyzer/patternMatching.ts +0 -1356
  224. package/src/analyzer/program.ts +0 -2778
  225. package/src/analyzer/properties.ts +0 -534
  226. package/src/analyzer/protocols.ts +0 -660
  227. package/src/analyzer/pyTypedUtils.ts +0 -52
  228. package/src/analyzer/pythonPathUtils.ts +0 -201
  229. package/src/analyzer/scope.ts +0 -202
  230. package/src/analyzer/scopeUtils.ts +0 -81
  231. package/src/analyzer/service.ts +0 -1679
  232. package/src/analyzer/sourceFile.ts +0 -1401
  233. package/src/analyzer/sourceMapper.ts +0 -717
  234. package/src/analyzer/staticExpressions.ts +0 -308
  235. package/src/analyzer/symbol.ts +0 -249
  236. package/src/analyzer/symbolNameUtils.ts +0 -50
  237. package/src/analyzer/symbolUtils.ts +0 -49
  238. package/src/analyzer/testWalker.ts +0 -101
  239. package/src/analyzer/tracePrinter.ts +0 -264
  240. package/src/analyzer/typeCache.ts +0 -181
  241. package/src/analyzer/typeDocStringUtils.ts +0 -371
  242. package/src/analyzer/typeEvaluator.ts +0 -23395
  243. package/src/analyzer/typeEvaluatorTypes.ts +0 -452
  244. package/src/analyzer/typeEvaluatorWithTracker.ts +0 -161
  245. package/src/analyzer/typeGuards.ts +0 -1828
  246. package/src/analyzer/typePrinter.ts +0 -807
  247. package/src/analyzer/typeStubWriter.ts +0 -727
  248. package/src/analyzer/typeUtils.ts +0 -3126
  249. package/src/analyzer/typeVarContext.ts +0 -330
  250. package/src/analyzer/typedDicts.ts +0 -950
  251. package/src/analyzer/types.ts +0 -2857
  252. package/src/backgroundAnalysis.ts +0 -49
  253. package/src/backgroundAnalysisBase.ts +0 -606
  254. package/src/backgroundThreadBase.ts +0 -143
  255. package/src/commands/commandController.ts +0 -62
  256. package/src/commands/commandResult.ts +0 -21
  257. package/src/commands/commands.ts +0 -16
  258. package/src/commands/createTypeStub.ts +0 -56
  259. package/src/commands/quickActionCommand.ts +0 -40
  260. package/src/commands/restartServer.ts +0 -20
  261. package/src/common/cancellationUtils.ts +0 -71
  262. package/src/common/chokidarFileWatcherProvider.ts +0 -74
  263. package/src/common/collectionUtils.ts +0 -379
  264. package/src/common/commandLineOptions.ts +0 -132
  265. package/src/common/configOptions.ts +0 -1291
  266. package/src/common/console.ts +0 -201
  267. package/src/common/core.ts +0 -152
  268. package/src/common/crypto.ts +0 -60
  269. package/src/common/debug.ts +0 -144
  270. package/src/common/deferred.ts +0 -78
  271. package/src/common/diagnostic.ts +0 -191
  272. package/src/common/diagnosticRules.ts +0 -80
  273. package/src/common/diagnosticSink.ts +0 -150
  274. package/src/common/editAction.ts +0 -46
  275. package/src/common/extensibility.ts +0 -35
  276. package/src/common/extensions.ts +0 -21
  277. package/src/common/fileBasedCancellationUtils.ts +0 -274
  278. package/src/common/fileSystem.ts +0 -152
  279. package/src/common/fullAccessHost.ts +0 -203
  280. package/src/common/host.ts +0 -49
  281. package/src/common/logTracker.ts +0 -157
  282. package/src/common/lspUtils.ts +0 -18
  283. package/src/common/memUtils.ts +0 -36
  284. package/src/common/pathConsts.ts +0 -16
  285. package/src/common/pathUtils.ts +0 -987
  286. package/src/common/positionUtils.ts +0 -78
  287. package/src/common/progressReporter.ts +0 -53
  288. package/src/common/pythonVersion.ts +0 -74
  289. package/src/common/realFileSystem.ts +0 -433
  290. package/src/common/stringUtils.ts +0 -161
  291. package/src/common/textEditUtils.ts +0 -31
  292. package/src/common/textRange.ts +0 -225
  293. package/src/common/textRangeCollection.ts +0 -122
  294. package/src/common/timing.ts +0 -105
  295. package/src/common/uriParser.ts +0 -26
  296. package/src/common/workspaceEditUtils.ts +0 -100
  297. package/src/languageServerBase.ts +0 -1556
  298. package/src/languageService/analyzerServiceExecutor.ts +0 -144
  299. package/src/languageService/autoImporter.ts +0 -926
  300. package/src/languageService/callHierarchyProvider.ts +0 -476
  301. package/src/languageService/codeActionProvider.ts +0 -85
  302. package/src/languageService/completionProvider.ts +0 -3103
  303. package/src/languageService/definitionProvider.ts +0 -235
  304. package/src/languageService/documentHighlightProvider.ts +0 -61
  305. package/src/languageService/documentSymbolCollector.ts +0 -466
  306. package/src/languageService/documentSymbolProvider.ts +0 -466
  307. package/src/languageService/hoverProvider.ts +0 -499
  308. package/src/languageService/importAdder.ts +0 -437
  309. package/src/languageService/importSorter.ts +0 -196
  310. package/src/languageService/indentationUtils.ts +0 -813
  311. package/src/languageService/quickActions.ts +0 -113
  312. package/src/languageService/referencesProvider.ts +0 -316
  313. package/src/languageService/renameModuleProvider.ts +0 -1400
  314. package/src/languageService/signatureHelpProvider.ts +0 -227
  315. package/src/languageService/tooltipUtils.ts +0 -147
  316. package/src/localization/localize.ts +0 -1272
  317. package/src/localization/package.nls.de.json +0 -3
  318. package/src/localization/package.nls.en-us.json +0 -636
  319. package/src/localization/package.nls.es.json +0 -3
  320. package/src/localization/package.nls.fr.json +0 -3
  321. package/src/localization/package.nls.ja.json +0 -3
  322. package/src/localization/package.nls.ru.json +0 -3
  323. package/src/localization/package.nls.zh-cn.json +0 -3
  324. package/src/localization/package.nls.zh-tw.json +0 -3
  325. package/src/nodeMain.ts +0 -21
  326. package/src/nodeServer.ts +0 -30
  327. package/src/parser/characterStream.ts +0 -145
  328. package/src/parser/characters.ts +0 -285
  329. package/src/parser/parseNodes.ts +0 -2338
  330. package/src/parser/parser.ts +0 -4859
  331. package/src/parser/stringTokenUtils.ts +0 -564
  332. package/src/parser/tokenizer.ts +0 -1379
  333. package/src/parser/tokenizerTypes.ts +0 -420
  334. package/src/parser/unicode.ts +0 -2917
  335. package/src/pyright.ts +0 -824
  336. package/src/pyrightFileSystem.ts +0 -237
  337. package/src/readonlyAugmentedFileSystem.ts +0 -204
  338. package/src/server.ts +0 -298
  339. package/src/tests/chainedSourceFiles.test.ts +0 -183
  340. package/src/tests/checker.test.ts +0 -445
  341. package/src/tests/collectionUtils.test.ts +0 -178
  342. package/src/tests/common.test.ts +0 -117
  343. package/src/tests/config.test.ts +0 -291
  344. package/src/tests/debug.test.ts +0 -120
  345. package/src/tests/deferred.test.ts +0 -54
  346. package/src/tests/diagnosticOverrides.test.ts +0 -104
  347. package/src/tests/docStringConversion.test.ts +0 -823
  348. package/src/tests/docStringUtils.test.ts +0 -57
  349. package/src/tests/documentSymbolCollector.test.ts +0 -735
  350. package/src/tests/filesystem.test.ts +0 -215
  351. package/src/tests/fourSlashParser.test.ts +0 -330
  352. package/src/tests/fourSlashRunner.test.ts +0 -36
  353. package/src/tests/fourslash/completions.autoimport.Lib.Found.Type.fourslash.ts +0 -33
  354. package/src/tests/fourslash/completions.autoimport.Lib.Found.duplication.fourslash.ts +0 -47
  355. package/src/tests/fourslash/completions.autoimport.Lib.NotFound.fourslash.ts +0 -14
  356. package/src/tests/fourslash/completions.autoimport.disabled.fourslash.ts +0 -25
  357. package/src/tests/fourslash/completions.autoimport.duplicates.fourslash.ts +0 -36
  358. package/src/tests/fourslash/completions.autoimport.fourslash.ts +0 -29
  359. package/src/tests/fourslash/completions.autoimport.fromImport.fourslash.ts +0 -130
  360. package/src/tests/fourslash/completions.autoimport.plainText.fourslash.ts +0 -29
  361. package/src/tests/fourslash/completions.autoimport.shadow.fourslash.ts +0 -48
  362. package/src/tests/fourslash/completions.autoimport.submodule.fourslash.ts +0 -31
  363. package/src/tests/fourslash/completions.autoimport.topLevel.fourslash.ts +0 -57
  364. package/src/tests/fourslash/completions.builtinDocstrings.fourslash.ts +0 -117
  365. package/src/tests/fourslash/completions.builtinOverride.fourslash.ts +0 -22
  366. package/src/tests/fourslash/completions.call.stringLiteral.fourslash.ts +0 -55
  367. package/src/tests/fourslash/completions.call.typedDict.fourslash.ts +0 -247
  368. package/src/tests/fourslash/completions.call.typedDict.list.fourslash.ts +0 -163
  369. package/src/tests/fourslash/completions.call.typedDict.states.fourslash.ts +0 -135
  370. package/src/tests/fourslash/completions.classVariable.fourslash.ts +0 -37
  371. package/src/tests/fourslash/completions.comment.fourslash.ts +0 -28
  372. package/src/tests/fourslash/completions.declNames.class.fourslash.ts +0 -35
  373. package/src/tests/fourslash/completions.declNames.exception.fourslash.ts +0 -18
  374. package/src/tests/fourslash/completions.declNames.for.fourslash.ts +0 -30
  375. package/src/tests/fourslash/completions.declNames.importAlias.fourslash.ts +0 -15
  376. package/src/tests/fourslash/completions.declNames.lambda.fourslash.ts +0 -45
  377. package/src/tests/fourslash/completions.declNames.method.fourslash.ts +0 -71
  378. package/src/tests/fourslash/completions.declNames.overload.fourslash.ts +0 -156
  379. package/src/tests/fourslash/completions.declNames.topLevelOverload.fourslash.ts +0 -141
  380. package/src/tests/fourslash/completions.dictionary.keys.complex.fourslash.ts +0 -76
  381. package/src/tests/fourslash/completions.dictionary.keys.expression.fourslash.ts +0 -63
  382. package/src/tests/fourslash/completions.dictionary.keys.literalTypes.fourslash.ts +0 -161
  383. package/src/tests/fourslash/completions.dictionary.keys.simple.fourslash.ts +0 -151
  384. package/src/tests/fourslash/completions.dictionary.keys.stringLiterals.fourslash.ts +0 -116
  385. package/src/tests/fourslash/completions.dictionary.keys.symbols.fourslash.ts +0 -53
  386. package/src/tests/fourslash/completions.enums.members.fourslash.ts +0 -44
  387. package/src/tests/fourslash/completions.excluded.fourslash.ts +0 -12
  388. package/src/tests/fourslash/completions.fourslash.ts +0 -51
  389. package/src/tests/fourslash/completions.fstring.fourslash.ts +0 -33
  390. package/src/tests/fourslash/completions.fstring.stringLiteral.fourslash.ts +0 -96
  391. package/src/tests/fourslash/completions.fuzzyMatching.fourslash.ts +0 -30
  392. package/src/tests/fourslash/completions.importDunderNames.fourslash.ts +0 -31
  393. package/src/tests/fourslash/completions.importSubmodule.fourslash.ts +0 -26
  394. package/src/tests/fourslash/completions.importsDuplicates.fourslash.ts +0 -23
  395. package/src/tests/fourslash/completions.inList.fourslash.ts +0 -33
  396. package/src/tests/fourslash/completions.included.fourslash.ts +0 -12
  397. package/src/tests/fourslash/completions.indexer.keys.getitem.fourslash.ts +0 -57
  398. package/src/tests/fourslash/completions.inherited.function.docFromStub.fourslash.ts +0 -28
  399. package/src/tests/fourslash/completions.inherited.overload.docFromScrWithStub.fourslash.ts +0 -52
  400. package/src/tests/fourslash/completions.inherited.overload.docFromStub.fourslash.ts +0 -53
  401. package/src/tests/fourslash/completions.inherited.property.docFromSrc.fourslash.ts +0 -104
  402. package/src/tests/fourslash/completions.inherited.property.docFromStub.fourslash.ts +0 -108
  403. package/src/tests/fourslash/completions.keywords.pythonVersion.fourslash.ts +0 -72
  404. package/src/tests/fourslash/completions.libCodeAndStub.fourslash.ts +0 -79
  405. package/src/tests/fourslash/completions.libCodeNoStub.fourslash.ts +0 -69
  406. package/src/tests/fourslash/completions.libStub.fourslash.ts +0 -69
  407. package/src/tests/fourslash/completions.literals.fourslash.ts +0 -33
  408. package/src/tests/fourslash/completions.localCode.fourslash.ts +0 -74
  409. package/src/tests/fourslash/completions.moduleContext.UnknownMemberOnInstance.fourslash.ts +0 -17
  410. package/src/tests/fourslash/completions.moduleContext.UnknownStaticFunctionOnClass.fourslash.ts +0 -57
  411. package/src/tests/fourslash/completions.moduleContext.libCodeNoStub.fourslash.ts +0 -30
  412. package/src/tests/fourslash/completions.overloads.fourslash.ts +0 -40
  413. package/src/tests/fourslash/completions.override.default.fourslash.ts +0 -47
  414. package/src/tests/fourslash/completions.override.default.importStub.ts +0 -50
  415. package/src/tests/fourslash/completions.override.default.imported.fourslash.ts +0 -61
  416. package/src/tests/fourslash/completions.override.default.stub.fourslash.ts +0 -47
  417. package/src/tests/fourslash/completions.override.fourslash.ts +0 -47
  418. package/src/tests/fourslash/completions.override.property.fourslash.ts +0 -31
  419. package/src/tests/fourslash/completions.override.property.stub.fourslash.ts +0 -31
  420. package/src/tests/fourslash/completions.override.staticAndClassmethod.fourslash.ts +0 -64
  421. package/src/tests/fourslash/completions.override.stub.fourslash.ts +0 -47
  422. package/src/tests/fourslash/completions.override2.fourslash.ts +0 -71
  423. package/src/tests/fourslash/completions.parameters.fourslash.ts +0 -23
  424. package/src/tests/fourslash/completions.params.fourslash.ts +0 -24
  425. package/src/tests/fourslash/completions.parentFolder.fourslash.ts +0 -17
  426. package/src/tests/fourslash/completions.parentFolders.fourslash.ts +0 -77
  427. package/src/tests/fourslash/completions.plainText.fourslash.ts +0 -34
  428. package/src/tests/fourslash/completions.private.fourslash.ts +0 -64
  429. package/src/tests/fourslash/completions.property.fourslash.ts +0 -28
  430. package/src/tests/fourslash/completions.propertyDocStrings.fourslash.ts +0 -64
  431. package/src/tests/fourslash/completions.self.fourslash.ts +0 -43
  432. package/src/tests/fourslash/completions.stringLiteral.escape.fourslash.ts +0 -71
  433. package/src/tests/fourslash/completions.stringLiteral.fourslash.ts +0 -79
  434. package/src/tests/fourslash/completions.typeAlias.fourslash.ts +0 -29
  435. package/src/tests/fourslash/completions.typeshed.fourslash.ts +0 -9
  436. package/src/tests/fourslash/completions.vardecls.fourslash.ts +0 -40
  437. package/src/tests/fourslash/completions.variableDocStrings.fourslash.ts +0 -69
  438. package/src/tests/fourslash/completions.wildcardimports.fourslash.ts +0 -116
  439. package/src/tests/fourslash/completions.with.fourslash.ts +0 -26
  440. package/src/tests/fourslash/diagnostics.missingModuleSource.fourslash.ts +0 -69
  441. package/src/tests/fourslash/findDefinitions.builtinClass.fourslash.ts +0 -29
  442. package/src/tests/fourslash/findDefinitions.classes.fourslash.ts +0 -101
  443. package/src/tests/fourslash/findDefinitions.definitionFilter.preferSource.fourslash.ts +0 -29
  444. package/src/tests/fourslash/findDefinitions.definitionFilter.preferSource.onlyStubs.ts +0 -24
  445. package/src/tests/fourslash/findDefinitions.definitionFilter.preferStub.fourslash.ts +0 -29
  446. package/src/tests/fourslash/findDefinitions.definitionFilter.preferStub.onlySource.fourslash.ts +0 -25
  447. package/src/tests/fourslash/findDefinitions.fields.fourslash.ts +0 -131
  448. package/src/tests/fourslash/findDefinitions.functions.fourslash.ts +0 -87
  449. package/src/tests/fourslash/findDefinitions.methods.fourslash.ts +0 -162
  450. package/src/tests/fourslash/findDefinitions.modules.fourslash.ts +0 -50
  451. package/src/tests/fourslash/findDefinitions.namespaceImport.fourslash.ts +0 -40
  452. package/src/tests/fourslash/findDefinitions.overloads.fourslash.ts +0 -223
  453. package/src/tests/fourslash/findDefinitions.parameters.fourslash.ts +0 -162
  454. package/src/tests/fourslash/findDefinitions.sourceAndStub.function.fourslash.ts +0 -26
  455. package/src/tests/fourslash/findDefinitions.sourceAndStub.innerClass.fourslash.ts +0 -32
  456. package/src/tests/fourslash/findDefinitions.sourceAndStub.innerClassMethod.fourslash.ts +0 -33
  457. package/src/tests/fourslash/findDefinitions.sourceAndStub.outerClass.fourslash.ts +0 -28
  458. package/src/tests/fourslash/findDefinitions.sourceAndStub.outerClassMethod.fourslash.ts +0 -29
  459. package/src/tests/fourslash/findDefinitions.sourceAndStub.outerClassPropertyReadOnly.fourslash.ts +0 -31
  460. package/src/tests/fourslash/findDefinitions.sourceAndStub.outerClassPropertyReadWrite.fourslash.ts +0 -36
  461. package/src/tests/fourslash/findDefinitions.sourceOnly.class.fourslash.ts +0 -29
  462. package/src/tests/fourslash/findDefinitions.sourceOnly.function1.fourslash.ts +0 -28
  463. package/src/tests/fourslash/findDefinitions.sourceOnly.function2.fourslash.ts +0 -28
  464. package/src/tests/fourslash/findDefinitions.sourceOnly.relativeImport1.fourslash.ts +0 -22
  465. package/src/tests/fourslash/findDefinitions.sourceOnly.relativeImport2.fourslash.ts +0 -22
  466. package/src/tests/fourslash/findDefinitions.stubOnly.fourslash.ts +0 -61
  467. package/src/tests/fourslash/findDefinitions.stubPackages.fourslash.ts +0 -71
  468. package/src/tests/fourslash/findDefinitions.typedDict.keys.fourslash.ts +0 -99
  469. package/src/tests/fourslash/findDefinitions.variables.fourslash.ts +0 -88
  470. package/src/tests/fourslash/findDefinitions.wildcardimports.fourslash.ts +0 -117
  471. package/src/tests/fourslash/findTypeDefinitions.builtinClass.fourslash.ts +0 -26
  472. package/src/tests/fourslash/findTypeDefinitions.classes.fourslash.ts +0 -72
  473. package/src/tests/fourslash/findTypeDefinitions.unions.fourslash.ts +0 -26
  474. package/src/tests/fourslash/findallreferences.classPropertyReadWrite.ts +0 -39
  475. package/src/tests/fourslash/findallreferences.fourslash.ts +0 -34
  476. package/src/tests/fourslash/findallreferences.importalias.fourslash.ts +0 -34
  477. package/src/tests/fourslash/findallreferences.invokedFromLibrary.fourslash.ts +0 -52
  478. package/src/tests/fourslash/findallreferences.module.nested.fourslash.ts +0 -67
  479. package/src/tests/fourslash/findallreferences.modules.duplicated.fourslash.ts +0 -59
  480. package/src/tests/fourslash/findallreferences.modules.fourslash.ts +0 -46
  481. package/src/tests/fourslash/findallreferences.modules.shadow.fourslash.ts +0 -95
  482. package/src/tests/fourslash/findallreferences.openFiles.fourslash.ts +0 -37
  483. package/src/tests/fourslash/findallreferences.parameter.fourslash.ts +0 -24
  484. package/src/tests/fourslash/findallreferences.sourceAndStub.class.fourslash.ts +0 -33
  485. package/src/tests/fourslash/findallreferences.sourceAndStub.classMethod.fourslash.ts +0 -37
  486. package/src/tests/fourslash/findallreferences.sourceAndStub.classPropertyReadOnly.fourslash.ts +0 -40
  487. package/src/tests/fourslash/findallreferences.sourceAndStub.classPropertyReadWrite.fourslash.skip.ts +0 -48
  488. package/src/tests/fourslash/findallreferences.sourceAndStub.function.fourslash.ts +0 -35
  489. package/src/tests/fourslash/findallreferences.variable.fourslash.ts +0 -24
  490. package/src/tests/fourslash/fourslash.ts +0 -411
  491. package/src/tests/fourslash/highlightreferences.attributes.fourslash.ts +0 -31
  492. package/src/tests/fourslash/hover.builtinDocstrings.fourslash.ts +0 -64
  493. package/src/tests/fourslash/hover.classNoInit.fourslash.ts +0 -14
  494. package/src/tests/fourslash/hover.docFromScr.stringFormat.fourslash.ts +0 -52
  495. package/src/tests/fourslash/hover.docFromSrc.fourslash.ts +0 -83
  496. package/src/tests/fourslash/hover.docFromSrc.pkg-vs-module1.fourslash.ts +0 -26
  497. package/src/tests/fourslash/hover.docFromSrc.pkg-vs-module2.fourslash.ts +0 -26
  498. package/src/tests/fourslash/hover.docFromSrc.relativeImport1.fourslash.ts +0 -23
  499. package/src/tests/fourslash/hover.docFromSrc.relativeImport2.fourslash.ts +0 -22
  500. package/src/tests/fourslash/hover.docFromSrc.relativeImport3.fourslash.ts +0 -46
  501. package/src/tests/fourslash/hover.docFromSrc.stubs-package.fourslash.ts +0 -29
  502. package/src/tests/fourslash/hover.docFromSrc.typeshed.fourslash.ts +0 -20
  503. package/src/tests/fourslash/hover.docstring.links.fourslash.ts +0 -12
  504. package/src/tests/fourslash/hover.docstring.overloads.fourslash.ts +0 -41
  505. package/src/tests/fourslash/hover.docstring.split.fourslash.ts +0 -24
  506. package/src/tests/fourslash/hover.fourslash.ts +0 -20
  507. package/src/tests/fourslash/hover.import.django.view.fourslash.ts +0 -27
  508. package/src/tests/fourslash/hover.import.fourslash.ts +0 -11
  509. package/src/tests/fourslash/hover.inherited.docFromSrc.fourslash.ts +0 -63
  510. package/src/tests/fourslash/hover.inherited.docFromSrcWithStub.fourslash.ts +0 -54
  511. package/src/tests/fourslash/hover.inherited.docFromStub.fourslash.ts +0 -42
  512. package/src/tests/fourslash/hover.inherited.overload.docFromSrcWithStub.fourslash.ts +0 -46
  513. package/src/tests/fourslash/hover.inherited.overload.docFromStub.fourslash.ts +0 -47
  514. package/src/tests/fourslash/hover.inherited.property.docFromSrcWithStub.fourslash.ts +0 -87
  515. package/src/tests/fourslash/hover.inherited.property.docFromStub.fourslash.ts +0 -91
  516. package/src/tests/fourslash/hover.init.fourslash.ts +0 -39
  517. package/src/tests/fourslash/hover.libCodeAndStub.fourslash.ts +0 -52
  518. package/src/tests/fourslash/hover.libCodeNoStub.fourslash.ts +0 -41
  519. package/src/tests/fourslash/hover.libStub.fourslash.ts +0 -41
  520. package/src/tests/fourslash/hover.optionalAliasParameter.fourslash.ts +0 -14
  521. package/src/tests/fourslash/hover.plainText.fourslash.ts +0 -21
  522. package/src/tests/fourslash/hover.typedDict.key.fourslash.ts +0 -51
  523. package/src/tests/fourslash/hover.variable.docString.fourslash.ts +0 -41
  524. package/src/tests/fourslash/hover.wildcardimports.fourslash.ts +0 -80
  525. package/src/tests/fourslash/import.publicSymbols.fourslash.ts +0 -65
  526. package/src/tests/fourslash/import.pytyped.dunderAll.fourslash.ts +0 -77
  527. package/src/tests/fourslash/import.pytyped.privateSymbols.fourslash.ts +0 -65
  528. package/src/tests/fourslash/import.pytyped.typeCheckingBasic.fourslash.ts +0 -38
  529. package/src/tests/fourslash/import.pytyped.typeCheckingOff.fourslash.ts +0 -38
  530. package/src/tests/fourslash/import.wildcard.fourslash.ts +0 -27
  531. package/src/tests/fourslash/importnotresolved.fourslash.ts +0 -13
  532. package/src/tests/fourslash/missingModuleSource.disablingInStrictMode.fourslash.ts +0 -20
  533. package/src/tests/fourslash/missingModuleSource.fourslash.ts +0 -14
  534. package/src/tests/fourslash/missingTypeStub.codeAction.fourslash.ts +0 -33
  535. package/src/tests/fourslash/missingTypeStub.command.multipart.fourslash.ts +0 -48
  536. package/src/tests/fourslash/missingTypeStub.command.singlefile.fourslash.ts +0 -38
  537. package/src/tests/fourslash/missingTypeStub.command.singlepart.fourslash.ts +0 -38
  538. package/src/tests/fourslash/missingTypeStub.fourslash.ts +0 -20
  539. package/src/tests/fourslash/missingTypeStub.invokeCodeAction.fourslash.ts +0 -36
  540. package/src/tests/fourslash/noerrors.fourslash.ts +0 -9
  541. package/src/tests/fourslash/orderImports1.command.fourslash.ts +0 -20
  542. package/src/tests/fourslash/orderImports2.command.fourslash.ts +0 -24
  543. package/src/tests/fourslash/rename.externallyHidden.fourslash.ts +0 -24
  544. package/src/tests/fourslash/rename.externallyHidden.params.fourslash.ts +0 -24
  545. package/src/tests/fourslash/rename.fourslash.ts +0 -29
  546. package/src/tests/fourslash/rename.library.fourslash.ts +0 -29
  547. package/src/tests/fourslash/rename.library.sourceAndStub.fourslash.ts +0 -33
  548. package/src/tests/fourslash/rename.multipleDecl.fourslash.ts +0 -21
  549. package/src/tests/fourslash/rename.sourceAndStub.fourslash.ts +0 -37
  550. package/src/tests/fourslash/rename.string.excluded.fourslash.ts +0 -43
  551. package/src/tests/fourslash/rename.string.fourslash.ts +0 -26
  552. package/src/tests/fourslash/signature.builtinDocstrings.fourslash.ts +0 -63
  553. package/src/tests/fourslash/signature.complicated.fourslash.ts +0 -100
  554. package/src/tests/fourslash/signature.cornercases.fourslash.ts +0 -23
  555. package/src/tests/fourslash/signature.docstrings.fourslash.ts +0 -43
  556. package/src/tests/fourslash/signature.docstrings.overloaded.fourslash.ts +0 -50
  557. package/src/tests/fourslash/signature.docstrings.wildcardimports.fourslash.ts +0 -122
  558. package/src/tests/fourslash/signature.overload.fourslash.ts +0 -64
  559. package/src/tests/fourslash/signature.simple.fourslash.ts +0 -104
  560. package/src/tests/harness/fourslash/fourSlashParser.ts +0 -441
  561. package/src/tests/harness/fourslash/fourSlashTypes.ts +0 -134
  562. package/src/tests/harness/fourslash/runner.ts +0 -99
  563. package/src/tests/harness/fourslash/testLanguageService.ts +0 -142
  564. package/src/tests/harness/fourslash/testState.Consts.ts +0 -29
  565. package/src/tests/harness/fourslash/testState.ts +0 -1993
  566. package/src/tests/harness/testAccessHost.ts +0 -23
  567. package/src/tests/harness/testHost.ts +0 -177
  568. package/src/tests/harness/utils.ts +0 -355
  569. package/src/tests/harness/vfs/factory.ts +0 -199
  570. package/src/tests/harness/vfs/filesystem.ts +0 -1893
  571. package/src/tests/harness/vfs/pathValidation.ts +0 -154
  572. package/src/tests/importAdder.test.ts +0 -1361
  573. package/src/tests/importResolver.test.ts +0 -534
  574. package/src/tests/importStatementUtils.test.ts +0 -526
  575. package/src/tests/indentationUtils.ptvs.test.ts +0 -388
  576. package/src/tests/indentationUtils.reindent.test.ts +0 -403
  577. package/src/tests/indentationUtils.test.ts +0 -455
  578. package/src/tests/ipythonMode.test.ts +0 -365
  579. package/src/tests/localizer.test.ts +0 -47
  580. package/src/tests/parseTreeUtils.test.ts +0 -281
  581. package/src/tests/parser.test.ts +0 -99
  582. package/src/tests/pathUtils.test.ts +0 -321
  583. package/src/tests/pyrightFileSystem.test.ts +0 -183
  584. package/src/tests/renameModule.folder.test.ts +0 -261
  585. package/src/tests/renameModule.fromImports.test.ts +0 -952
  586. package/src/tests/renameModule.imports.test.ts +0 -450
  587. package/src/tests/renameModule.misc.test.ts +0 -765
  588. package/src/tests/renameModule.relativePath.test.ts +0 -277
  589. package/src/tests/renameModuleTestUtils.ts +0 -210
  590. package/src/tests/samples/abstractClass1.py +0 -51
  591. package/src/tests/samples/abstractClass2.py +0 -25
  592. package/src/tests/samples/abstractClass3.py +0 -30
  593. package/src/tests/samples/abstractClass4.py +0 -30
  594. package/src/tests/samples/abstractClass5.py +0 -42
  595. package/src/tests/samples/abstractClass6.py +0 -25
  596. package/src/tests/samples/abstractClass7.py +0 -22
  597. package/src/tests/samples/abstractClass8.py +0 -27
  598. package/src/tests/samples/annotated1.py +0 -72
  599. package/src/tests/samples/annotatedVar1.py +0 -22
  600. package/src/tests/samples/annotatedVar2.py +0 -28
  601. package/src/tests/samples/annotatedVar3.py +0 -54
  602. package/src/tests/samples/annotatedVar4.py +0 -24
  603. package/src/tests/samples/annotatedVar5.py +0 -37
  604. package/src/tests/samples/annotatedVar6.py +0 -22
  605. package/src/tests/samples/annotatedVar7.py +0 -13
  606. package/src/tests/samples/annotatedVar8.py +0 -29
  607. package/src/tests/samples/annotations1.py +0 -98
  608. package/src/tests/samples/annotations2.py +0 -33
  609. package/src/tests/samples/annotations3.py +0 -43
  610. package/src/tests/samples/annotations4.py +0 -54
  611. package/src/tests/samples/annotations5.py +0 -9
  612. package/src/tests/samples/annotations6.py +0 -29
  613. package/src/tests/samples/assert1.py +0 -22
  614. package/src/tests/samples/assertType1.py +0 -46
  615. package/src/tests/samples/assignment1.py +0 -58
  616. package/src/tests/samples/assignment10.py +0 -14
  617. package/src/tests/samples/assignment2.py +0 -40
  618. package/src/tests/samples/assignment3.py +0 -46
  619. package/src/tests/samples/assignment4.py +0 -20
  620. package/src/tests/samples/assignment5.py +0 -16
  621. package/src/tests/samples/assignment6.py +0 -25
  622. package/src/tests/samples/assignment7.py +0 -13
  623. package/src/tests/samples/assignment8.py +0 -40
  624. package/src/tests/samples/assignment9.py +0 -25
  625. package/src/tests/samples/assignmentExpr1.py +0 -23
  626. package/src/tests/samples/assignmentExpr2.py +0 -49
  627. package/src/tests/samples/assignmentExpr3.py +0 -27
  628. package/src/tests/samples/assignmentExpr4.py +0 -49
  629. package/src/tests/samples/assignmentExpr5.py +0 -15
  630. package/src/tests/samples/assignmentExpr6.py +0 -10
  631. package/src/tests/samples/assignmentExpr7.py +0 -13
  632. package/src/tests/samples/assignmentExpr8.py +0 -11
  633. package/src/tests/samples/assignmentExpr9.py +0 -28
  634. package/src/tests/samples/async1.py +0 -49
  635. package/src/tests/samples/augmentedAssignment1.py +0 -62
  636. package/src/tests/samples/augmentedAssignment2.py +0 -23
  637. package/src/tests/samples/augmentedAssignment3.py +0 -8
  638. package/src/tests/samples/await1.py +0 -23
  639. package/src/tests/samples/await2.py +0 -25
  640. package/src/tests/samples/badToken1.py +0 -6
  641. package/src/tests/samples/builtins1.py +0 -2
  642. package/src/tests/samples/call1.py +0 -93
  643. package/src/tests/samples/call2.py +0 -118
  644. package/src/tests/samples/call3.py +0 -168
  645. package/src/tests/samples/call4.py +0 -13
  646. package/src/tests/samples/call5.py +0 -95
  647. package/src/tests/samples/call6.py +0 -35
  648. package/src/tests/samples/call7.py +0 -57
  649. package/src/tests/samples/callSite1.py +0 -6
  650. package/src/tests/samples/callSite2.py +0 -12
  651. package/src/tests/samples/callable1.py +0 -53
  652. package/src/tests/samples/callable2.py +0 -58
  653. package/src/tests/samples/callable3.py +0 -28
  654. package/src/tests/samples/callable4.py +0 -32
  655. package/src/tests/samples/callable5.py +0 -40
  656. package/src/tests/samples/callable6.py +0 -83
  657. package/src/tests/samples/callbackProtocol1.py +0 -119
  658. package/src/tests/samples/callbackProtocol2.py +0 -29
  659. package/src/tests/samples/callbackProtocol3.py +0 -23
  660. package/src/tests/samples/callbackProtocol4.py +0 -73
  661. package/src/tests/samples/callbackProtocol5.py +0 -66
  662. package/src/tests/samples/callbackProtocol6.py +0 -66
  663. package/src/tests/samples/callbackProtocol7.py +0 -16
  664. package/src/tests/samples/callbackProtocol8.py +0 -16
  665. package/src/tests/samples/capturedVariable1.py +0 -106
  666. package/src/tests/samples/circular1.py +0 -16
  667. package/src/tests/samples/circular2.py +0 -38
  668. package/src/tests/samples/circularBaseClass.py +0 -17
  669. package/src/tests/samples/classGetItem1.py +0 -30
  670. package/src/tests/samples/classVar1.py +0 -41
  671. package/src/tests/samples/classVar2.py +0 -29
  672. package/src/tests/samples/classVar3.py +0 -46
  673. package/src/tests/samples/classVar4.py +0 -36
  674. package/src/tests/samples/classes1.py +0 -50
  675. package/src/tests/samples/classes3.py +0 -48
  676. package/src/tests/samples/classes4.py +0 -15
  677. package/src/tests/samples/classes5.py +0 -260
  678. package/src/tests/samples/classes6.py +0 -16
  679. package/src/tests/samples/classes7.py +0 -18
  680. package/src/tests/samples/classes8.py +0 -47
  681. package/src/tests/samples/codeFlow1.py +0 -65
  682. package/src/tests/samples/codeFlow2.py +0 -26
  683. package/src/tests/samples/codeFlow3.py +0 -8
  684. package/src/tests/samples/codeFlow4.py +0 -133
  685. package/src/tests/samples/codeFlow5.py +0 -10
  686. package/src/tests/samples/codeFlow6.py +0 -35
  687. package/src/tests/samples/codeFlow7.py +0 -35
  688. package/src/tests/samples/comparison1.py +0 -77
  689. package/src/tests/samples/comparison2.py +0 -37
  690. package/src/tests/samples/complex1.py +0 -17
  691. package/src/tests/samples/constant1.py +0 -40
  692. package/src/tests/samples/constants1.py +0 -64
  693. package/src/tests/samples/constructor1.py +0 -30
  694. package/src/tests/samples/constructor10.py +0 -19
  695. package/src/tests/samples/constructor11.py +0 -32
  696. package/src/tests/samples/constructor12.py +0 -20
  697. package/src/tests/samples/constructor13.py +0 -15
  698. package/src/tests/samples/constructor2.py +0 -180
  699. package/src/tests/samples/constructor3.py +0 -18
  700. package/src/tests/samples/constructor4.py +0 -25
  701. package/src/tests/samples/constructor5.py +0 -25
  702. package/src/tests/samples/constructor6.py +0 -70
  703. package/src/tests/samples/constructor7.py +0 -11
  704. package/src/tests/samples/constructor8.py +0 -99
  705. package/src/tests/samples/constructor9.py +0 -19
  706. package/src/tests/samples/coroutines1.py +0 -60
  707. package/src/tests/samples/coroutines2.py +0 -20
  708. package/src/tests/samples/coroutines3.py +0 -37
  709. package/src/tests/samples/dataclass1.py +0 -44
  710. package/src/tests/samples/dataclass10.py +0 -45
  711. package/src/tests/samples/dataclass11.py +0 -53
  712. package/src/tests/samples/dataclass12.py +0 -32
  713. package/src/tests/samples/dataclass13.py +0 -42
  714. package/src/tests/samples/dataclass14.py +0 -38
  715. package/src/tests/samples/dataclass15.py +0 -58
  716. package/src/tests/samples/dataclass16.py +0 -21
  717. package/src/tests/samples/dataclass17.py +0 -46
  718. package/src/tests/samples/dataclass18.py +0 -57
  719. package/src/tests/samples/dataclass19.py +0 -44
  720. package/src/tests/samples/dataclass2.py +0 -30
  721. package/src/tests/samples/dataclass20.py +0 -71
  722. package/src/tests/samples/dataclass21.py +0 -13
  723. package/src/tests/samples/dataclass3.py +0 -18
  724. package/src/tests/samples/dataclass4.py +0 -64
  725. package/src/tests/samples/dataclass5.py +0 -81
  726. package/src/tests/samples/dataclass6.py +0 -29
  727. package/src/tests/samples/dataclass7.py +0 -93
  728. package/src/tests/samples/dataclass8.py +0 -22
  729. package/src/tests/samples/dataclass9.py +0 -24
  730. package/src/tests/samples/dataclassPostInit1.py +0 -61
  731. package/src/tests/samples/dataclassTransform1.py +0 -71
  732. package/src/tests/samples/dataclassTransform2.py +0 -78
  733. package/src/tests/samples/dataclassTransform3.py +0 -83
  734. package/src/tests/samples/dataclassTransform4.py +0 -87
  735. package/src/tests/samples/decorator1.py +0 -20
  736. package/src/tests/samples/decorator2.py +0 -31
  737. package/src/tests/samples/decorator3.py +0 -27
  738. package/src/tests/samples/decorator4.py +0 -37
  739. package/src/tests/samples/decorator5.py +0 -29
  740. package/src/tests/samples/decorator6.py +0 -34
  741. package/src/tests/samples/defaultInitializer1.py +0 -26
  742. package/src/tests/samples/deprecated1.py +0 -37
  743. package/src/tests/samples/descriptor1.py +0 -134
  744. package/src/tests/samples/descriptor2.py +0 -29
  745. package/src/tests/samples/dictionary1.py +0 -42
  746. package/src/tests/samples/dictionary2.py +0 -14
  747. package/src/tests/samples/dictionary3.py +0 -30
  748. package/src/tests/samples/dictionary4.py +0 -106
  749. package/src/tests/samples/dunderAll1.py +0 -32
  750. package/src/tests/samples/dunderAll2.py +0 -16
  751. package/src/tests/samples/dunderAll3.pyi +0 -16
  752. package/src/tests/samples/duplicateDeclaration1.py +0 -115
  753. package/src/tests/samples/duplicateDeclaration2.py +0 -45
  754. package/src/tests/samples/duplicateImports1.py +0 -13
  755. package/src/tests/samples/ellipsis1.pyi +0 -48
  756. package/src/tests/samples/emptyContainers1.py +0 -89
  757. package/src/tests/samples/enums1.py +0 -52
  758. package/src/tests/samples/enums2.py +0 -15
  759. package/src/tests/samples/enums3.py +0 -24
  760. package/src/tests/samples/enums4.py +0 -23
  761. package/src/tests/samples/enums5.py +0 -16
  762. package/src/tests/samples/enums6.py +0 -33
  763. package/src/tests/samples/enums7.py +0 -54
  764. package/src/tests/samples/enums8.py +0 -14
  765. package/src/tests/samples/expressions1.py +0 -54
  766. package/src/tests/samples/expressions2.py +0 -29
  767. package/src/tests/samples/expressions3.py +0 -26
  768. package/src/tests/samples/expressions4.py +0 -23
  769. package/src/tests/samples/expressions5.py +0 -70
  770. package/src/tests/samples/expressions6.py +0 -14
  771. package/src/tests/samples/expressions7.py +0 -40
  772. package/src/tests/samples/expressions8.py +0 -26
  773. package/src/tests/samples/expressions9.py +0 -14
  774. package/src/tests/samples/final1.py +0 -14
  775. package/src/tests/samples/final2.py +0 -86
  776. package/src/tests/samples/final3.py +0 -179
  777. package/src/tests/samples/final4.pyi +0 -21
  778. package/src/tests/samples/final5.py +0 -18
  779. package/src/tests/samples/forLoop1.py +0 -88
  780. package/src/tests/samples/forLoop2.py +0 -48
  781. package/src/tests/samples/fstring1.py +0 -66
  782. package/src/tests/samples/fstring2.py +0 -12
  783. package/src/tests/samples/fstring3.py +0 -35
  784. package/src/tests/samples/fstring4.py +0 -17
  785. package/src/tests/samples/fstring5.py +0 -17
  786. package/src/tests/samples/fstring6.py +0 -14
  787. package/src/tests/samples/function1.py +0 -12
  788. package/src/tests/samples/function10.py +0 -20
  789. package/src/tests/samples/function11.py +0 -36
  790. package/src/tests/samples/function2.py +0 -7
  791. package/src/tests/samples/function3.py +0 -82
  792. package/src/tests/samples/function4.py +0 -13
  793. package/src/tests/samples/function6.py +0 -24
  794. package/src/tests/samples/function7.py +0 -13
  795. package/src/tests/samples/function8.py +0 -38
  796. package/src/tests/samples/function9.py +0 -75
  797. package/src/tests/samples/functionAnnotation1.py +0 -61
  798. package/src/tests/samples/functionAnnotation2.py +0 -26
  799. package/src/tests/samples/functionAnnotation3.py +0 -37
  800. package/src/tests/samples/functionAnnotation4.py +0 -22
  801. package/src/tests/samples/functionMember1.py +0 -18
  802. package/src/tests/samples/functionMember2.py +0 -45
  803. package/src/tests/samples/generators1.py +0 -122
  804. package/src/tests/samples/generators10.py +0 -18
  805. package/src/tests/samples/generators11.py +0 -27
  806. package/src/tests/samples/generators12.py +0 -25
  807. package/src/tests/samples/generators13.py +0 -65
  808. package/src/tests/samples/generators14.py +0 -19
  809. package/src/tests/samples/generators15.py +0 -26
  810. package/src/tests/samples/generators2.py +0 -31
  811. package/src/tests/samples/generators3.py +0 -42
  812. package/src/tests/samples/generators4.py +0 -33
  813. package/src/tests/samples/generators5.py +0 -24
  814. package/src/tests/samples/generators6.py +0 -14
  815. package/src/tests/samples/generators7.py +0 -18
  816. package/src/tests/samples/generators8.py +0 -12
  817. package/src/tests/samples/generators9.py +0 -19
  818. package/src/tests/samples/generic1.py +0 -41
  819. package/src/tests/samples/genericTypes1.py +0 -12
  820. package/src/tests/samples/genericTypes10.py +0 -38
  821. package/src/tests/samples/genericTypes11.py +0 -26
  822. package/src/tests/samples/genericTypes12.py +0 -14
  823. package/src/tests/samples/genericTypes13.py +0 -27
  824. package/src/tests/samples/genericTypes14.py +0 -22
  825. package/src/tests/samples/genericTypes15.py +0 -13
  826. package/src/tests/samples/genericTypes16.py +0 -15
  827. package/src/tests/samples/genericTypes17.py +0 -24
  828. package/src/tests/samples/genericTypes18.py +0 -135
  829. package/src/tests/samples/genericTypes19.py +0 -32
  830. package/src/tests/samples/genericTypes2.py +0 -40
  831. package/src/tests/samples/genericTypes20.py +0 -44
  832. package/src/tests/samples/genericTypes21.py +0 -29
  833. package/src/tests/samples/genericTypes22.py +0 -23
  834. package/src/tests/samples/genericTypes23.py +0 -27
  835. package/src/tests/samples/genericTypes24.py +0 -32
  836. package/src/tests/samples/genericTypes25.py +0 -37
  837. package/src/tests/samples/genericTypes26.py +0 -31
  838. package/src/tests/samples/genericTypes27.py +0 -14
  839. package/src/tests/samples/genericTypes28.py +0 -51
  840. package/src/tests/samples/genericTypes29.py +0 -24
  841. package/src/tests/samples/genericTypes3.py +0 -13
  842. package/src/tests/samples/genericTypes30.py +0 -32
  843. package/src/tests/samples/genericTypes31.py +0 -30
  844. package/src/tests/samples/genericTypes32.py +0 -25
  845. package/src/tests/samples/genericTypes33.py +0 -46
  846. package/src/tests/samples/genericTypes34.py +0 -54
  847. package/src/tests/samples/genericTypes35.py +0 -45
  848. package/src/tests/samples/genericTypes36.py +0 -35
  849. package/src/tests/samples/genericTypes37.py +0 -26
  850. package/src/tests/samples/genericTypes38.py +0 -15
  851. package/src/tests/samples/genericTypes39.py +0 -82
  852. package/src/tests/samples/genericTypes4.py +0 -37
  853. package/src/tests/samples/genericTypes40.py +0 -38
  854. package/src/tests/samples/genericTypes41.py +0 -16
  855. package/src/tests/samples/genericTypes42.py +0 -32
  856. package/src/tests/samples/genericTypes43.py +0 -24
  857. package/src/tests/samples/genericTypes44.py +0 -33
  858. package/src/tests/samples/genericTypes45.py +0 -43
  859. package/src/tests/samples/genericTypes46.py +0 -66
  860. package/src/tests/samples/genericTypes47.py +0 -39
  861. package/src/tests/samples/genericTypes48.py +0 -18
  862. package/src/tests/samples/genericTypes49.py +0 -41
  863. package/src/tests/samples/genericTypes5.py +0 -42
  864. package/src/tests/samples/genericTypes50.py +0 -62
  865. package/src/tests/samples/genericTypes51.py +0 -55
  866. package/src/tests/samples/genericTypes52.py +0 -34
  867. package/src/tests/samples/genericTypes53.py +0 -42
  868. package/src/tests/samples/genericTypes54.py +0 -31
  869. package/src/tests/samples/genericTypes55.py +0 -61
  870. package/src/tests/samples/genericTypes56.py +0 -19
  871. package/src/tests/samples/genericTypes57.py +0 -30
  872. package/src/tests/samples/genericTypes58.py +0 -52
  873. package/src/tests/samples/genericTypes59.py +0 -71
  874. package/src/tests/samples/genericTypes6.py +0 -49
  875. package/src/tests/samples/genericTypes60.py +0 -27
  876. package/src/tests/samples/genericTypes61.py +0 -34
  877. package/src/tests/samples/genericTypes62.py +0 -26
  878. package/src/tests/samples/genericTypes63.py +0 -32
  879. package/src/tests/samples/genericTypes64.py +0 -16
  880. package/src/tests/samples/genericTypes65.py +0 -15
  881. package/src/tests/samples/genericTypes66.py +0 -30
  882. package/src/tests/samples/genericTypes67.py +0 -57
  883. package/src/tests/samples/genericTypes68.py +0 -14
  884. package/src/tests/samples/genericTypes69.py +0 -45
  885. package/src/tests/samples/genericTypes7.py +0 -24
  886. package/src/tests/samples/genericTypes70.py +0 -31
  887. package/src/tests/samples/genericTypes71.py +0 -72
  888. package/src/tests/samples/genericTypes72.py +0 -24
  889. package/src/tests/samples/genericTypes73.py +0 -14
  890. package/src/tests/samples/genericTypes74.py +0 -23
  891. package/src/tests/samples/genericTypes75.py +0 -45
  892. package/src/tests/samples/genericTypes76.py +0 -107
  893. package/src/tests/samples/genericTypes77.py +0 -26
  894. package/src/tests/samples/genericTypes78.py +0 -23
  895. package/src/tests/samples/genericTypes79.py +0 -37
  896. package/src/tests/samples/genericTypes8.py +0 -26
  897. package/src/tests/samples/genericTypes80.py +0 -10
  898. package/src/tests/samples/genericTypes81.py +0 -32
  899. package/src/tests/samples/genericTypes82.py +0 -19
  900. package/src/tests/samples/genericTypes83.py +0 -28
  901. package/src/tests/samples/genericTypes84.py +0 -11
  902. package/src/tests/samples/genericTypes85.py +0 -20
  903. package/src/tests/samples/genericTypes86.py +0 -15
  904. package/src/tests/samples/genericTypes87.py +0 -21
  905. package/src/tests/samples/genericTypes88.py +0 -25
  906. package/src/tests/samples/genericTypes89.py +0 -17
  907. package/src/tests/samples/genericTypes9.py +0 -109
  908. package/src/tests/samples/genericTypes90.py +0 -12
  909. package/src/tests/samples/genericTypes91.py +0 -20
  910. package/src/tests/samples/import1.py +0 -7
  911. package/src/tests/samples/import10.py +0 -11
  912. package/src/tests/samples/import11.py +0 -11
  913. package/src/tests/samples/import12.py +0 -5
  914. package/src/tests/samples/import13.py +0 -6
  915. package/src/tests/samples/import14.py +0 -10
  916. package/src/tests/samples/import2.py +0 -27
  917. package/src/tests/samples/import3.py +0 -8
  918. package/src/tests/samples/import4.py +0 -15
  919. package/src/tests/samples/import5.py +0 -6
  920. package/src/tests/samples/import6.py +0 -17
  921. package/src/tests/samples/import7.py +0 -14
  922. package/src/tests/samples/import8.py +0 -7
  923. package/src/tests/samples/import9.py +0 -7
  924. package/src/tests/samples/inconsistentConstructor1.py +0 -23
  925. package/src/tests/samples/inconsistentSpaceTab1.py +0 -9
  926. package/src/tests/samples/inconsistentSpaceTab2.py +0 -10
  927. package/src/tests/samples/index1.py +0 -97
  928. package/src/tests/samples/inferredTypes1.py +0 -25
  929. package/src/tests/samples/initVar1.py +0 -23
  930. package/src/tests/samples/initsubclass1.py +0 -46
  931. package/src/tests/samples/initsubclass2.py +0 -16
  932. package/src/tests/samples/isinstance1.py +0 -57
  933. package/src/tests/samples/isinstance10.py +0 -15
  934. package/src/tests/samples/isinstance2.py +0 -28
  935. package/src/tests/samples/isinstance3.py +0 -59
  936. package/src/tests/samples/isinstance4.py +0 -57
  937. package/src/tests/samples/isinstance5.py +0 -8
  938. package/src/tests/samples/isinstance6.py +0 -19
  939. package/src/tests/samples/isinstance7.py +0 -42
  940. package/src/tests/samples/isinstance9.py +0 -26
  941. package/src/tests/samples/kwargsUnpack1.py +0 -116
  942. package/src/tests/samples/lambda1.py +0 -77
  943. package/src/tests/samples/lambda2.py +0 -26
  944. package/src/tests/samples/lambda3.py +0 -34
  945. package/src/tests/samples/lambda4.py +0 -70
  946. package/src/tests/samples/lambda5.py +0 -23
  947. package/src/tests/samples/lambda6.py +0 -15
  948. package/src/tests/samples/lines1.py +0 -14
  949. package/src/tests/samples/list1.py +0 -90
  950. package/src/tests/samples/listComprehension1.py +0 -45
  951. package/src/tests/samples/listComprehension2.py +0 -17
  952. package/src/tests/samples/listComprehension3.py +0 -12
  953. package/src/tests/samples/listComprehension4.py +0 -15
  954. package/src/tests/samples/listComprehension5.py +0 -20
  955. package/src/tests/samples/listComprehension6.py +0 -14
  956. package/src/tests/samples/listComprehension7.py +0 -15
  957. package/src/tests/samples/listComprehension8.py +0 -15
  958. package/src/tests/samples/literalString1.py +0 -43
  959. package/src/tests/samples/literals1.py +0 -48
  960. package/src/tests/samples/literals2.py +0 -30
  961. package/src/tests/samples/literals3.py +0 -40
  962. package/src/tests/samples/literals4.py +0 -10
  963. package/src/tests/samples/literals5.py +0 -28
  964. package/src/tests/samples/literals6.py +0 -90
  965. package/src/tests/samples/literals7.py +0 -38
  966. package/src/tests/samples/loops1.py +0 -45
  967. package/src/tests/samples/loops10.py +0 -11
  968. package/src/tests/samples/loops11.py +0 -22
  969. package/src/tests/samples/loops12.py +0 -18
  970. package/src/tests/samples/loops13.py +0 -13
  971. package/src/tests/samples/loops14.py +0 -22
  972. package/src/tests/samples/loops15.py +0 -22
  973. package/src/tests/samples/loops16.py +0 -322
  974. package/src/tests/samples/loops17.py +0 -9
  975. package/src/tests/samples/loops18.py +0 -23
  976. package/src/tests/samples/loops19.py +0 -14
  977. package/src/tests/samples/loops2.py +0 -25
  978. package/src/tests/samples/loops20.py +0 -41
  979. package/src/tests/samples/loops21.py +0 -18
  980. package/src/tests/samples/loops22.py +0 -21
  981. package/src/tests/samples/loops23.py +0 -16
  982. package/src/tests/samples/loops24.py +0 -12
  983. package/src/tests/samples/loops25.py +0 -45
  984. package/src/tests/samples/loops26.py +0 -12
  985. package/src/tests/samples/loops3.py +0 -11
  986. package/src/tests/samples/loops4.py +0 -17
  987. package/src/tests/samples/loops5.py +0 -14
  988. package/src/tests/samples/loops6.py +0 -25
  989. package/src/tests/samples/loops7.py +0 -14
  990. package/src/tests/samples/loops8.py +0 -17
  991. package/src/tests/samples/loops9.py +0 -25
  992. package/src/tests/samples/match1.py +0 -190
  993. package/src/tests/samples/match10.py +0 -67
  994. package/src/tests/samples/match2.py +0 -340
  995. package/src/tests/samples/match3.py +0 -364
  996. package/src/tests/samples/match4.py +0 -100
  997. package/src/tests/samples/match5.py +0 -70
  998. package/src/tests/samples/match6.py +0 -64
  999. package/src/tests/samples/match7.py +0 -65
  1000. package/src/tests/samples/match8.py +0 -19
  1001. package/src/tests/samples/match9.py +0 -53
  1002. package/src/tests/samples/maxParseDepth1.py +0 -499
  1003. package/src/tests/samples/maxParseDepth2.py +0 -16
  1004. package/src/tests/samples/memberAccess1.py +0 -70
  1005. package/src/tests/samples/memberAccess10.py +0 -65
  1006. package/src/tests/samples/memberAccess11.py +0 -37
  1007. package/src/tests/samples/memberAccess12.py +0 -36
  1008. package/src/tests/samples/memberAccess13.py +0 -17
  1009. package/src/tests/samples/memberAccess14.py +0 -63
  1010. package/src/tests/samples/memberAccess15.py +0 -20
  1011. package/src/tests/samples/memberAccess16.py +0 -12
  1012. package/src/tests/samples/memberAccess17.py +0 -31
  1013. package/src/tests/samples/memberAccess18.py +0 -31
  1014. package/src/tests/samples/memberAccess2.py +0 -45
  1015. package/src/tests/samples/memberAccess3.py +0 -64
  1016. package/src/tests/samples/memberAccess4.py +0 -91
  1017. package/src/tests/samples/memberAccess5.py +0 -26
  1018. package/src/tests/samples/memberAccess6.py +0 -52
  1019. package/src/tests/samples/memberAccess7.py +0 -36
  1020. package/src/tests/samples/memberAccess8.py +0 -75
  1021. package/src/tests/samples/memberAccess9.py +0 -11
  1022. package/src/tests/samples/metaclass1.py +0 -7
  1023. package/src/tests/samples/metaclass2.py +0 -35
  1024. package/src/tests/samples/metaclass3.py +0 -43
  1025. package/src/tests/samples/metaclass4.py +0 -26
  1026. package/src/tests/samples/metaclass5.py +0 -33
  1027. package/src/tests/samples/metaclass6.py +0 -15
  1028. package/src/tests/samples/metaclass7.py +0 -38
  1029. package/src/tests/samples/metaclass8.py +0 -20
  1030. package/src/tests/samples/metaclass9.py +0 -77
  1031. package/src/tests/samples/methodOverride1.py +0 -507
  1032. package/src/tests/samples/methodOverride2.py +0 -74
  1033. package/src/tests/samples/methodOverride3.py +0 -111
  1034. package/src/tests/samples/methodOverride4.py +0 -36
  1035. package/src/tests/samples/missingSuper1.py +0 -73
  1036. package/src/tests/samples/module1.py +0 -13
  1037. package/src/tests/samples/module2.py +0 -7
  1038. package/src/tests/samples/mro1.py +0 -16
  1039. package/src/tests/samples/mro2.py +0 -45
  1040. package/src/tests/samples/mro3.py +0 -30
  1041. package/src/tests/samples/mro4.py +0 -30
  1042. package/src/tests/samples/nameBindings1.py +0 -48
  1043. package/src/tests/samples/nameBindings2.py +0 -9
  1044. package/src/tests/samples/nameBindings3.py +0 -36
  1045. package/src/tests/samples/nameBindings4.py +0 -10
  1046. package/src/tests/samples/nameBindings5.py +0 -53
  1047. package/src/tests/samples/namedTuples1.py +0 -103
  1048. package/src/tests/samples/namedTuples2.py +0 -56
  1049. package/src/tests/samples/namedTuples3.py +0 -15
  1050. package/src/tests/samples/namedTuples4.py +0 -24
  1051. package/src/tests/samples/namedTuples5.py +0 -15
  1052. package/src/tests/samples/namedTuples6.py +0 -31
  1053. package/src/tests/samples/namedTuples7.py +0 -27
  1054. package/src/tests/samples/never1.py +0 -12
  1055. package/src/tests/samples/never2.py +0 -43
  1056. package/src/tests/samples/newType1.py +0 -34
  1057. package/src/tests/samples/newType2.py +0 -25
  1058. package/src/tests/samples/newType3.py +0 -34
  1059. package/src/tests/samples/newType4.py +0 -8
  1060. package/src/tests/samples/none1.py +0 -29
  1061. package/src/tests/samples/none2.py +0 -22
  1062. package/src/tests/samples/noreturn1.py +0 -78
  1063. package/src/tests/samples/noreturn2.py +0 -37
  1064. package/src/tests/samples/noreturn3.py +0 -16
  1065. package/src/tests/samples/noreturn4.py +0 -29
  1066. package/src/tests/samples/operators1.py +0 -101
  1067. package/src/tests/samples/operators2.py +0 -30
  1068. package/src/tests/samples/operators3.py +0 -8
  1069. package/src/tests/samples/operators4.py +0 -22
  1070. package/src/tests/samples/operators5.py +0 -5
  1071. package/src/tests/samples/operators6.py +0 -10
  1072. package/src/tests/samples/operators7.py +0 -24
  1073. package/src/tests/samples/operators8.py +0 -125
  1074. package/src/tests/samples/optional1.py +0 -77
  1075. package/src/tests/samples/optional2.py +0 -23
  1076. package/src/tests/samples/overload1.py +0 -50
  1077. package/src/tests/samples/overload10.py +0 -48
  1078. package/src/tests/samples/overload2.py +0 -37
  1079. package/src/tests/samples/overload3.py +0 -29
  1080. package/src/tests/samples/overload4.py +0 -46
  1081. package/src/tests/samples/overload5.py +0 -333
  1082. package/src/tests/samples/overload6.py +0 -64
  1083. package/src/tests/samples/overload7.py +0 -376
  1084. package/src/tests/samples/overload8.py +0 -89
  1085. package/src/tests/samples/overload9.py +0 -19
  1086. package/src/tests/samples/package1/__init__.py +0 -3
  1087. package/src/tests/samples/package1/psyche/pysche.py +0 -4
  1088. package/src/tests/samples/package1/psyche.py +0 -4
  1089. package/src/tests/samples/package1/sub/__init__.py +0 -5
  1090. package/src/tests/samples/package1/sub.py +0 -4
  1091. package/src/tests/samples/package1/sub.pyi +0 -2
  1092. package/src/tests/samples/paramInference1.py +0 -27
  1093. package/src/tests/samples/paramNames1.py +0 -39
  1094. package/src/tests/samples/paramSpec1.py +0 -64
  1095. package/src/tests/samples/paramSpec10.py +0 -57
  1096. package/src/tests/samples/paramSpec11.py +0 -36
  1097. package/src/tests/samples/paramSpec12.py +0 -88
  1098. package/src/tests/samples/paramSpec13.py +0 -112
  1099. package/src/tests/samples/paramSpec14.py +0 -30
  1100. package/src/tests/samples/paramSpec15.py +0 -28
  1101. package/src/tests/samples/paramSpec16.py +0 -28
  1102. package/src/tests/samples/paramSpec17.py +0 -34
  1103. package/src/tests/samples/paramSpec18.py +0 -43
  1104. package/src/tests/samples/paramSpec19.py +0 -93
  1105. package/src/tests/samples/paramSpec2.py +0 -29
  1106. package/src/tests/samples/paramSpec20.py +0 -87
  1107. package/src/tests/samples/paramSpec21.py +0 -58
  1108. package/src/tests/samples/paramSpec22.py +0 -26
  1109. package/src/tests/samples/paramSpec23.py +0 -21
  1110. package/src/tests/samples/paramSpec24.py +0 -67
  1111. package/src/tests/samples/paramSpec25.py +0 -36
  1112. package/src/tests/samples/paramSpec26.py +0 -25
  1113. package/src/tests/samples/paramSpec27.py +0 -57
  1114. package/src/tests/samples/paramSpec28.py +0 -39
  1115. package/src/tests/samples/paramSpec29.py +0 -37
  1116. package/src/tests/samples/paramSpec3.py +0 -71
  1117. package/src/tests/samples/paramSpec30.py +0 -49
  1118. package/src/tests/samples/paramSpec31.py +0 -16
  1119. package/src/tests/samples/paramSpec32.py +0 -57
  1120. package/src/tests/samples/paramSpec33.py +0 -29
  1121. package/src/tests/samples/paramSpec34.py +0 -29
  1122. package/src/tests/samples/paramSpec35.py +0 -24
  1123. package/src/tests/samples/paramSpec36.py +0 -43
  1124. package/src/tests/samples/paramSpec37.py +0 -25
  1125. package/src/tests/samples/paramSpec4.py +0 -109
  1126. package/src/tests/samples/paramSpec5.py +0 -29
  1127. package/src/tests/samples/paramSpec6.py +0 -17
  1128. package/src/tests/samples/paramSpec7.py +0 -22
  1129. package/src/tests/samples/paramSpec8.py +0 -45
  1130. package/src/tests/samples/paramSpec9.py +0 -57
  1131. package/src/tests/samples/paramType1.py +0 -71
  1132. package/src/tests/samples/parameters1.py +0 -16
  1133. package/src/tests/samples/partial1.py +0 -163
  1134. package/src/tests/samples/partial2.py +0 -31
  1135. package/src/tests/samples/private1.py +0 -55
  1136. package/src/tests/samples/private2.py +0 -11
  1137. package/src/tests/samples/project1/pyrightconfig.json +0 -5
  1138. package/src/tests/samples/project1/sample1.py +0 -0
  1139. package/src/tests/samples/project1/subfolder1/sample2.py +0 -0
  1140. package/src/tests/samples/project1/subfolder1/subfolder1-1/sample3.py +0 -0
  1141. package/src/tests/samples/project2/pyrightconfig.json +0 -3
  1142. package/src/tests/samples/project3/pyrightconfig.json +0 -7
  1143. package/src/tests/samples/project4/presentfile.py +0 -0
  1144. package/src/tests/samples/project4/pyrightconfig.json +0 -11
  1145. package/src/tests/samples/project4/subfolder/presentfile2.py +0 -0
  1146. package/src/tests/samples/project4/subfolder/presentfile3.py +0 -0
  1147. package/src/tests/samples/project5/pyrightconfig.json +0 -4
  1148. package/src/tests/samples/project6/app1.py +0 -0
  1149. package/src/tests/samples/project6/app2.py +0 -0
  1150. package/src/tests/samples/project6/projectA/foo/__init__.py +0 -0
  1151. package/src/tests/samples/project6/projectA/foo/bar/__init__.py +0 -0
  1152. package/src/tests/samples/project6/projectB/foo/__init__.py +0 -0
  1153. package/src/tests/samples/project6/projectB/foo/baz/__init__.py +0 -0
  1154. package/src/tests/samples/project_src/src/module1.py +0 -0
  1155. package/src/tests/samples/project_src_is_pkg/src/__init__.py +0 -0
  1156. package/src/tests/samples/project_src_is_pkg/src/module1.py +0 -0
  1157. package/src/tests/samples/project_src_with_config_extra_paths/pyrightconfig.json +0 -3
  1158. package/src/tests/samples/project_src_with_config_extra_paths/src/module1.py +0 -0
  1159. package/src/tests/samples/project_src_with_config_no_extra_paths/pyrightconfig.json +0 -2
  1160. package/src/tests/samples/project_src_with_config_no_extra_paths/src/module1.py +0 -0
  1161. package/src/tests/samples/project_src_with_extra_paths/src/_vendored/vendored1.py +0 -1
  1162. package/src/tests/samples/project_src_with_extra_paths/src/module1.py +0 -2
  1163. package/src/tests/samples/project_with_pyproject_toml/pyproject.toml +0 -7
  1164. package/src/tests/samples/project_with_venv_auto_detect_exclude/myvenv/Lib/site-packages/library1.py +0 -0
  1165. package/src/tests/samples/project_with_venv_auto_detect_exclude/myvenv/pyvenv.cfg +0 -0
  1166. package/src/tests/samples/project_with_venv_auto_detect_exclude/pyrightconfig.json +0 -2
  1167. package/src/tests/samples/project_with_venv_auto_detect_exclude/sample1.py +0 -0
  1168. package/src/tests/samples/project_with_venv_auto_detect_exclude/subfolder1/sample2.py +0 -0
  1169. package/src/tests/samples/project_with_venv_auto_detect_exclude/subfolder1/subfolder1-1/sample3.py +0 -0
  1170. package/src/tests/samples/project_with_venv_auto_detect_include/excluded/excluded1.py +0 -0
  1171. package/src/tests/samples/project_with_venv_auto_detect_include/myvenv/Lib/site-packages/library1.py +0 -0
  1172. package/src/tests/samples/project_with_venv_auto_detect_include/myvenv/pyvenv.cfg +0 -0
  1173. package/src/tests/samples/project_with_venv_auto_detect_include/pyrightconfig.json +0 -3
  1174. package/src/tests/samples/project_with_venv_auto_detect_include/sample1.py +0 -0
  1175. package/src/tests/samples/project_with_venv_auto_detect_include/subfolder1/sample2.py +0 -0
  1176. package/src/tests/samples/project_with_venv_auto_detect_include/subfolder1/subfolder1-1/sample3.py +0 -0
  1177. package/src/tests/samples/properties1.py +0 -64
  1178. package/src/tests/samples/properties10.py +0 -19
  1179. package/src/tests/samples/properties11.py +0 -45
  1180. package/src/tests/samples/properties12.py +0 -23
  1181. package/src/tests/samples/properties13.py +0 -15
  1182. package/src/tests/samples/properties2.py +0 -34
  1183. package/src/tests/samples/properties3.py +0 -93
  1184. package/src/tests/samples/properties4.py +0 -17
  1185. package/src/tests/samples/properties5.py +0 -29
  1186. package/src/tests/samples/properties6.py +0 -35
  1187. package/src/tests/samples/properties7.py +0 -30
  1188. package/src/tests/samples/properties8.py +0 -26
  1189. package/src/tests/samples/properties9.py +0 -24
  1190. package/src/tests/samples/protocol1.py +0 -132
  1191. package/src/tests/samples/protocol10.py +0 -36
  1192. package/src/tests/samples/protocol11.py +0 -32
  1193. package/src/tests/samples/protocol12.py +0 -12
  1194. package/src/tests/samples/protocol13.py +0 -26
  1195. package/src/tests/samples/protocol14.py +0 -27
  1196. package/src/tests/samples/protocol15.py +0 -27
  1197. package/src/tests/samples/protocol16.py +0 -22
  1198. package/src/tests/samples/protocol17.py +0 -94
  1199. package/src/tests/samples/protocol18.py +0 -27
  1200. package/src/tests/samples/protocol19.py +0 -39
  1201. package/src/tests/samples/protocol2.py +0 -38
  1202. package/src/tests/samples/protocol20.py +0 -22
  1203. package/src/tests/samples/protocol21.py +0 -26
  1204. package/src/tests/samples/protocol22.py +0 -43
  1205. package/src/tests/samples/protocol23.py +0 -41
  1206. package/src/tests/samples/protocol24.py +0 -74
  1207. package/src/tests/samples/protocol25.py +0 -31
  1208. package/src/tests/samples/protocol26.py +0 -40
  1209. package/src/tests/samples/protocol27.py +0 -76
  1210. package/src/tests/samples/protocol28.py +0 -32
  1211. package/src/tests/samples/protocol29.py +0 -26
  1212. package/src/tests/samples/protocol3.py +0 -110
  1213. package/src/tests/samples/protocol30.py +0 -30
  1214. package/src/tests/samples/protocol31.py +0 -22
  1215. package/src/tests/samples/protocol32.py +0 -67
  1216. package/src/tests/samples/protocol33.py +0 -39
  1217. package/src/tests/samples/protocol34.py +0 -21
  1218. package/src/tests/samples/protocol4.py +0 -22
  1219. package/src/tests/samples/protocol5.py +0 -25
  1220. package/src/tests/samples/protocol6.py +0 -65
  1221. package/src/tests/samples/protocol7.py +0 -24
  1222. package/src/tests/samples/protocol8.py +0 -34
  1223. package/src/tests/samples/protocol9.py +0 -35
  1224. package/src/tests/samples/protocolModule1.py +0 -15
  1225. package/src/tests/samples/protocolModule2.py +0 -83
  1226. package/src/tests/samples/protocolModule3.py +0 -14
  1227. package/src/tests/samples/protocolModule4.py +0 -26
  1228. package/src/tests/samples/pseudoGeneric1.py +0 -20
  1229. package/src/tests/samples/pyrightIgnore1.py +0 -11
  1230. package/src/tests/samples/pyrightIgnore2.py +0 -24
  1231. package/src/tests/samples/python2.py +0 -31
  1232. package/src/tests/samples/recursiveTypeAlias1.py +0 -79
  1233. package/src/tests/samples/recursiveTypeAlias2.py +0 -32
  1234. package/src/tests/samples/recursiveTypeAlias3.py +0 -26
  1235. package/src/tests/samples/recursiveTypeAlias4.py +0 -55
  1236. package/src/tests/samples/recursiveTypeAlias5.pyi +0 -10
  1237. package/src/tests/samples/recursiveTypeAlias6.py +0 -25
  1238. package/src/tests/samples/recursiveTypeAlias7.py +0 -15
  1239. package/src/tests/samples/recursiveTypeAlias8.py +0 -38
  1240. package/src/tests/samples/recursiveTypeAlias9.py +0 -22
  1241. package/src/tests/samples/required1.py +0 -47
  1242. package/src/tests/samples/required2.py +0 -56
  1243. package/src/tests/samples/required3.py +0 -22
  1244. package/src/tests/samples/returnTypes1.py +0 -26
  1245. package/src/tests/samples/revealedType1.py +0 -30
  1246. package/src/tests/samples/sample1.py +0 -6
  1247. package/src/tests/samples/self1.py +0 -93
  1248. package/src/tests/samples/self2.py +0 -195
  1249. package/src/tests/samples/self3.py +0 -9
  1250. package/src/tests/samples/self4.py +0 -18
  1251. package/src/tests/samples/self5.py +0 -26
  1252. package/src/tests/samples/setComprehension1.py +0 -34
  1253. package/src/tests/samples/slots1.py +0 -63
  1254. package/src/tests/samples/slots2.py +0 -38
  1255. package/src/tests/samples/slots3.py +0 -35
  1256. package/src/tests/samples/specialization1.py +0 -78
  1257. package/src/tests/samples/specialization2.py +0 -51
  1258. package/src/tests/samples/staticExpressions1.py +0 -52
  1259. package/src/tests/samples/strings1.py +0 -22
  1260. package/src/tests/samples/subscript1.py +0 -74
  1261. package/src/tests/samples/subscript2.py +0 -55
  1262. package/src/tests/samples/subscript3.py +0 -135
  1263. package/src/tests/samples/suiteExpectedColon1.py +0 -4
  1264. package/src/tests/samples/suiteExpectedColon2.py +0 -2
  1265. package/src/tests/samples/suiteExpectedColon3.py +0 -2
  1266. package/src/tests/samples/super1.py +0 -57
  1267. package/src/tests/samples/super2.py +0 -29
  1268. package/src/tests/samples/super3.py +0 -10
  1269. package/src/tests/samples/super4.py +0 -24
  1270. package/src/tests/samples/super5.py +0 -28
  1271. package/src/tests/samples/super6.py +0 -17
  1272. package/src/tests/samples/super7.py +0 -52
  1273. package/src/tests/samples/super8.py +0 -7
  1274. package/src/tests/samples/super9.py +0 -36
  1275. package/src/tests/samples/test_file1.py +0 -0
  1276. package/src/tests/samples/threePartVersion1.py +0 -33
  1277. package/src/tests/samples/totalOrdering1.py +0 -52
  1278. package/src/tests/samples/tryExcept1.py +0 -39
  1279. package/src/tests/samples/tryExcept10.py +0 -12
  1280. package/src/tests/samples/tryExcept2.py +0 -16
  1281. package/src/tests/samples/tryExcept3.py +0 -12
  1282. package/src/tests/samples/tryExcept4.py +0 -28
  1283. package/src/tests/samples/tryExcept5.py +0 -30
  1284. package/src/tests/samples/tryExcept6.py +0 -27
  1285. package/src/tests/samples/tryExcept7.py +0 -17
  1286. package/src/tests/samples/tryExcept8.py +0 -69
  1287. package/src/tests/samples/tryExcept9.py +0 -42
  1288. package/src/tests/samples/tupleUnpack1.py +0 -63
  1289. package/src/tests/samples/tupleUnpack2.py +0 -56
  1290. package/src/tests/samples/tupleUnpack3.py +0 -28
  1291. package/src/tests/samples/tuples1.py +0 -185
  1292. package/src/tests/samples/tuples10.py +0 -30
  1293. package/src/tests/samples/tuples11.py +0 -21
  1294. package/src/tests/samples/tuples12.py +0 -31
  1295. package/src/tests/samples/tuples13.py +0 -26
  1296. package/src/tests/samples/tuples15.py +0 -16
  1297. package/src/tests/samples/tuples16.py +0 -14
  1298. package/src/tests/samples/tuples2.py +0 -23
  1299. package/src/tests/samples/tuples3.py +0 -15
  1300. package/src/tests/samples/tuples4.py +0 -21
  1301. package/src/tests/samples/tuples5.py +0 -16
  1302. package/src/tests/samples/tuples6.py +0 -56
  1303. package/src/tests/samples/tuples7.py +0 -61
  1304. package/src/tests/samples/tuples8.py +0 -98
  1305. package/src/tests/samples/tuples9.py +0 -17
  1306. package/src/tests/samples/typeAlias1.py +0 -37
  1307. package/src/tests/samples/typeAlias10.py +0 -45
  1308. package/src/tests/samples/typeAlias11.py +0 -37
  1309. package/src/tests/samples/typeAlias12.py +0 -20
  1310. package/src/tests/samples/typeAlias13.py +0 -53
  1311. package/src/tests/samples/typeAlias14.py +0 -29
  1312. package/src/tests/samples/typeAlias15.py +0 -24
  1313. package/src/tests/samples/typeAlias16.py +0 -24
  1314. package/src/tests/samples/typeAlias2.py +0 -26
  1315. package/src/tests/samples/typeAlias3.py +0 -35
  1316. package/src/tests/samples/typeAlias4.py +0 -68
  1317. package/src/tests/samples/typeAlias5.py +0 -56
  1318. package/src/tests/samples/typeAlias6.py +0 -51
  1319. package/src/tests/samples/typeAlias7.py +0 -50
  1320. package/src/tests/samples/typeAlias8.py +0 -24
  1321. package/src/tests/samples/typeAlias9.py +0 -35
  1322. package/src/tests/samples/typeGuard1.py +0 -68
  1323. package/src/tests/samples/typeGuard2.py +0 -58
  1324. package/src/tests/samples/typeGuard3.py +0 -98
  1325. package/src/tests/samples/typeIgnore1.py +0 -10
  1326. package/src/tests/samples/typeIgnore2.py +0 -20
  1327. package/src/tests/samples/typeIgnore3.py +0 -22
  1328. package/src/tests/samples/typeIgnore4.py +0 -10
  1329. package/src/tests/samples/typeIgnore5.py +0 -7
  1330. package/src/tests/samples/typeNarrowing1.py +0 -56
  1331. package/src/tests/samples/typeNarrowing2.py +0 -14
  1332. package/src/tests/samples/typeNarrowing3.py +0 -47
  1333. package/src/tests/samples/typeNarrowing4.py +0 -24
  1334. package/src/tests/samples/typeNarrowing5.py +0 -19
  1335. package/src/tests/samples/typeNarrowing6.py +0 -27
  1336. package/src/tests/samples/typeNarrowing7.py +0 -71
  1337. package/src/tests/samples/typeNarrowingAssert1.py +0 -24
  1338. package/src/tests/samples/typeNarrowingCallable1.py +0 -78
  1339. package/src/tests/samples/typeNarrowingEnum1.py +0 -58
  1340. package/src/tests/samples/typeNarrowingEnum2.py +0 -71
  1341. package/src/tests/samples/typeNarrowingFalsy1.py +0 -50
  1342. package/src/tests/samples/typeNarrowingIn1.py +0 -97
  1343. package/src/tests/samples/typeNarrowingIsNone1.py +0 -56
  1344. package/src/tests/samples/typeNarrowingIsNone2.py +0 -8
  1345. package/src/tests/samples/typeNarrowingIsNoneTuple1.py +0 -42
  1346. package/src/tests/samples/typeNarrowingIsNoneTuple2.py +0 -35
  1347. package/src/tests/samples/typeNarrowingIsinstance1.py +0 -162
  1348. package/src/tests/samples/typeNarrowingIsinstance2.py +0 -14
  1349. package/src/tests/samples/typeNarrowingIsinstance3.py +0 -78
  1350. package/src/tests/samples/typeNarrowingIsinstance4.py +0 -50
  1351. package/src/tests/samples/typeNarrowingIsinstance5.py +0 -39
  1352. package/src/tests/samples/typeNarrowingIsinstance6.py +0 -77
  1353. package/src/tests/samples/typeNarrowingIsinstance7.py +0 -19
  1354. package/src/tests/samples/typeNarrowingIsinstance8.py +0 -19
  1355. package/src/tests/samples/typeNarrowingLiteral1.py +0 -35
  1356. package/src/tests/samples/typeNarrowingLiteral2.py +0 -63
  1357. package/src/tests/samples/typeNarrowingLiteralMember1.py +0 -140
  1358. package/src/tests/samples/typeNarrowingLocalConst1.py +0 -136
  1359. package/src/tests/samples/typeNarrowingNoneMember1.py +0 -102
  1360. package/src/tests/samples/typeNarrowingTuple1.py +0 -23
  1361. package/src/tests/samples/typeNarrowingTupleLength1.py +0 -47
  1362. package/src/tests/samples/typeNarrowingTypeIs1.py +0 -95
  1363. package/src/tests/samples/typeNarrowingTypedDict1.py +0 -99
  1364. package/src/tests/samples/typeNarrowingTypedDict2.py +0 -35
  1365. package/src/tests/samples/typeNarrowingTypedDict3.py +0 -45
  1366. package/src/tests/samples/typePromotions1.py +0 -30
  1367. package/src/tests/samples/typeVar1.py +0 -23
  1368. package/src/tests/samples/typeVar10.py +0 -21
  1369. package/src/tests/samples/typeVar11.py +0 -12
  1370. package/src/tests/samples/typeVar2.py +0 -26
  1371. package/src/tests/samples/typeVar3.py +0 -73
  1372. package/src/tests/samples/typeVar4.py +0 -45
  1373. package/src/tests/samples/typeVar5.py +0 -75
  1374. package/src/tests/samples/typeVar6.py +0 -115
  1375. package/src/tests/samples/typeVar7.py +0 -171
  1376. package/src/tests/samples/typeVar8.py +0 -30
  1377. package/src/tests/samples/typeVar9.py +0 -118
  1378. package/src/tests/samples/typedDict1.py +0 -63
  1379. package/src/tests/samples/typedDict10.py +0 -34
  1380. package/src/tests/samples/typedDict11.py +0 -12
  1381. package/src/tests/samples/typedDict12.py +0 -103
  1382. package/src/tests/samples/typedDict13.py +0 -14
  1383. package/src/tests/samples/typedDict14.py +0 -25
  1384. package/src/tests/samples/typedDict15.py +0 -53
  1385. package/src/tests/samples/typedDict16.py +0 -103
  1386. package/src/tests/samples/typedDict17.py +0 -24
  1387. package/src/tests/samples/typedDict18.py +0 -43
  1388. package/src/tests/samples/typedDict2.py +0 -56
  1389. package/src/tests/samples/typedDict3.py +0 -40
  1390. package/src/tests/samples/typedDict4.py +0 -68
  1391. package/src/tests/samples/typedDict5.py +0 -50
  1392. package/src/tests/samples/typedDict6.py +0 -77
  1393. package/src/tests/samples/typedDict7.py +0 -22
  1394. package/src/tests/samples/typedDict8.py +0 -19
  1395. package/src/tests/samples/typedDict9.py +0 -22
  1396. package/src/tests/samples/unbound1.py +0 -18
  1397. package/src/tests/samples/unbound2.py +0 -12
  1398. package/src/tests/samples/unbound3.py +0 -13
  1399. package/src/tests/samples/unbound4.py +0 -25
  1400. package/src/tests/samples/unicode1.py +0 -39
  1401. package/src/tests/samples/uninitializedVariable1.py +0 -27
  1402. package/src/tests/samples/unions1.py +0 -79
  1403. package/src/tests/samples/unions2.py +0 -15
  1404. package/src/tests/samples/unions3.py +0 -48
  1405. package/src/tests/samples/unions4.py +0 -20
  1406. package/src/tests/samples/unions5.py +0 -43
  1407. package/src/tests/samples/unnecessaryCast1.py +0 -13
  1408. package/src/tests/samples/unnecessaryIsInstance1.py +0 -91
  1409. package/src/tests/samples/unnecessaryIsSubclass1.py +0 -22
  1410. package/src/tests/samples/unpack1.py +0 -56
  1411. package/src/tests/samples/unpack2.py +0 -27
  1412. package/src/tests/samples/unpack3.py +0 -16
  1413. package/src/tests/samples/unpack4.py +0 -15
  1414. package/src/tests/samples/unreachable1.py +0 -112
  1415. package/src/tests/samples/unusedCallResult1.py +0 -67
  1416. package/src/tests/samples/unusedCoroutine1.py +0 -23
  1417. package/src/tests/samples/unusedExpression1.py +0 -34
  1418. package/src/tests/samples/unusedVariable1.py +0 -21
  1419. package/src/tests/samples/variadicTypeVar1.py +0 -51
  1420. package/src/tests/samples/variadicTypeVar10.py +0 -65
  1421. package/src/tests/samples/variadicTypeVar11.py +0 -72
  1422. package/src/tests/samples/variadicTypeVar12.py +0 -26
  1423. package/src/tests/samples/variadicTypeVar13.py +0 -35
  1424. package/src/tests/samples/variadicTypeVar14.py +0 -72
  1425. package/src/tests/samples/variadicTypeVar2.py +0 -63
  1426. package/src/tests/samples/variadicTypeVar3.py +0 -86
  1427. package/src/tests/samples/variadicTypeVar4.py +0 -71
  1428. package/src/tests/samples/variadicTypeVar5.py +0 -131
  1429. package/src/tests/samples/variadicTypeVar6.py +0 -78
  1430. package/src/tests/samples/variadicTypeVar7.py +0 -59
  1431. package/src/tests/samples/variadicTypeVar8.py +0 -116
  1432. package/src/tests/samples/variadicTypeVar9.py +0 -38
  1433. package/src/tests/samples/with1.py +0 -117
  1434. package/src/tests/samples/with2.py +0 -63
  1435. package/src/tests/samples/with3.py +0 -66
  1436. package/src/tests/samples/with4.py +0 -24
  1437. package/src/tests/samples/with5.py +0 -33
  1438. package/src/tests/samples/zipfs/bad.egg +0 -1
  1439. package/src/tests/samples/zipfs/bad.zip +0 -1
  1440. package/src/tests/samples/zipfs/basic.egg +0 -0
  1441. package/src/tests/samples/zipfs/basic.zip +0 -0
  1442. package/src/tests/samples/zipfs/corrupt.egg +0 -0
  1443. package/src/tests/samples/zipfs/corrupt.zip +0 -0
  1444. package/src/tests/sourceFile.test.ts +0 -25
  1445. package/src/tests/stringUtils.test.ts +0 -63
  1446. package/src/tests/symbolNameUtils.test.ts +0 -77
  1447. package/src/tests/testState.test.ts +0 -579
  1448. package/src/tests/testUtils.ts +0 -251
  1449. package/src/tests/tokenizer.test.ts +0 -1534
  1450. package/src/tests/typeEvaluator1.test.ts +0 -1372
  1451. package/src/tests/typeEvaluator2.test.ts +0 -1253
  1452. package/src/tests/typeEvaluator3.test.ts +0 -1279
  1453. package/src/tests/typeEvaluator4.test.ts +0 -1178
  1454. package/src/tests/updateSymbolReference.test.ts +0 -1107
  1455. package/src/tests/zipfs.test.ts +0 -116
  1456. package/src/workspaceMap.ts +0 -76
@@ -1,1993 +0,0 @@
1
- /*
2
- * testState.ts
3
- * Copyright (c) Microsoft Corporation.
4
- * Licensed under the MIT license.
5
- *
6
- * TestState wraps currently test states and provides a way to query and manipulate
7
- * the test states.
8
- */
9
-
10
- import assert from 'assert';
11
- import * as JSONC from 'jsonc-parser';
12
- import Char from 'typescript-char';
13
- import {
14
- AnnotatedTextEdit,
15
- CancellationToken,
16
- ChangeAnnotation,
17
- CodeAction,
18
- Command,
19
- CompletionItem,
20
- CreateFile,
21
- DeleteFile,
22
- Diagnostic,
23
- DocumentHighlight,
24
- DocumentHighlightKind,
25
- ExecuteCommandParams,
26
- MarkupContent,
27
- MarkupKind,
28
- OptionalVersionedTextDocumentIdentifier,
29
- RenameFile,
30
- TextDocumentEdit,
31
- TextEdit,
32
- WorkspaceEdit,
33
- } from 'vscode-languageserver';
34
-
35
- import { ImportResolver, ImportResolverFactory } from '../../../analyzer/importResolver';
36
- import { findNodeByOffset } from '../../../analyzer/parseTreeUtils';
37
- import { Program } from '../../../analyzer/program';
38
- import { AnalyzerService, configFileNames } from '../../../analyzer/service';
39
- import { appendArray } from '../../../common/collectionUtils';
40
- import { ConfigOptions } from '../../../common/configOptions';
41
- import { ConsoleInterface, NullConsole } from '../../../common/console';
42
- import { Comparison, isNumber, isString, toBoolean } from '../../../common/core';
43
- import * as debug from '../../../common/debug';
44
- import { createDeferred } from '../../../common/deferred';
45
- import { DiagnosticCategory } from '../../../common/diagnostic';
46
- import { FileEditAction } from '../../../common/editAction';
47
- import {
48
- combinePaths,
49
- comparePaths,
50
- convertPathToUri,
51
- getBaseFileName,
52
- getDirectoryPath,
53
- getFileExtension,
54
- getFileSpec,
55
- normalizePath,
56
- normalizeSlashes,
57
- } from '../../../common/pathUtils';
58
- import { convertOffsetToPosition, convertPositionToOffset } from '../../../common/positionUtils';
59
- import { getStringComparer } from '../../../common/stringUtils';
60
- import { DocumentRange, Position, Range as PositionRange, rangesAreEqual, TextRange } from '../../../common/textRange';
61
- import { TextRangeCollection } from '../../../common/textRangeCollection';
62
- import { LanguageServerInterface, WorkspaceServiceInstance } from '../../../languageServerBase';
63
- import { AbbreviationInfo } from '../../../languageService/autoImporter';
64
- import { DefinitionFilter } from '../../../languageService/definitionProvider';
65
- import { convertHoverResults } from '../../../languageService/hoverProvider';
66
- import { ParseNode } from '../../../parser/parseNodes';
67
- import { ParseResults } from '../../../parser/parser';
68
- import { Tokenizer } from '../../../parser/tokenizer';
69
- import { PyrightFileSystem } from '../../../pyrightFileSystem';
70
- import { TestAccessHost } from '../testAccessHost';
71
- import * as host from '../testHost';
72
- import { stringify } from '../utils';
73
- import { createFromFileSystem, distlibFolder, libFolder, typeshedFolder } from '../vfs/factory';
74
- import * as vfs from '../vfs/filesystem';
75
- import { parseTestData } from './fourSlashParser';
76
- import {
77
- CompilerSettings,
78
- FourSlashData,
79
- FourSlashFile,
80
- GlobalMetadataOptionNames,
81
- Marker,
82
- MetadataOptionNames,
83
- MultiMap,
84
- Range,
85
- TestCancellationToken,
86
- } from './fourSlashTypes';
87
- import { TestFeatures, TestLanguageService } from './testLanguageService';
88
-
89
- export interface TextChange {
90
- span: TextRange;
91
- newText: string;
92
- }
93
-
94
- export interface HostSpecificFeatures {
95
- importResolverFactory: ImportResolverFactory;
96
-
97
- runIndexer(workspace: WorkspaceServiceInstance, noStdLib: boolean, options?: string): void;
98
- getCodeActionsForPosition(
99
- workspace: WorkspaceServiceInstance,
100
- filePath: string,
101
- range: PositionRange,
102
- token: CancellationToken
103
- ): Promise<CodeAction[]>;
104
-
105
- execute(ls: LanguageServerInterface, params: ExecuteCommandParams, token: CancellationToken): Promise<any>;
106
- }
107
-
108
- const testAccessHost = new TestAccessHost(vfs.MODULE_PATH, [libFolder, distlibFolder]);
109
-
110
- export class TestState {
111
- private readonly _cancellationToken: TestCancellationToken;
112
- private readonly _files: string[] = [];
113
- private readonly _hostSpecificFeatures: HostSpecificFeatures;
114
-
115
- readonly testFS: vfs.TestFileSystem;
116
- readonly fs: PyrightFileSystem;
117
- readonly workspace: WorkspaceServiceInstance;
118
- readonly console: ConsoleInterface;
119
- readonly rawConfigJson: any | undefined;
120
-
121
- // The current caret position in the active file
122
- currentCaretPosition = 0;
123
- // The position of the end of the current selection, or -1 if nothing is selected
124
- selectionEnd = -1;
125
-
126
- lastKnownMarker = '';
127
-
128
- // The file that's currently 'opened'
129
- activeFile!: FourSlashFile;
130
-
131
- constructor(
132
- basePath: string,
133
- public testData: FourSlashData,
134
- mountPaths?: Map<string, string>,
135
- hostSpecificFeatures?: HostSpecificFeatures
136
- ) {
137
- this._hostSpecificFeatures = hostSpecificFeatures ?? new TestFeatures();
138
-
139
- const nullConsole = new NullConsole();
140
- const ignoreCase = toBoolean(testData.globalOptions[GlobalMetadataOptionNames.ignoreCase]);
141
-
142
- this._cancellationToken = new TestCancellationToken();
143
-
144
- const sourceFiles = [];
145
- const files: vfs.FileSet = {};
146
- for (const file of testData.files) {
147
- // if one of file is configuration file, set config options from the given json
148
- if (this._isConfig(file, ignoreCase)) {
149
- try {
150
- this.rawConfigJson = JSONC.parse(file.content);
151
- } catch (e: any) {
152
- throw new Error(`Failed to parse test ${file.fileName}: ${e.message}`);
153
- }
154
- } else {
155
- files[file.fileName] = new vfs.File(file.content, { meta: file.fileOptions, encoding: 'utf8' });
156
-
157
- if (!toBoolean(file.fileOptions[MetadataOptionNames.library])) {
158
- sourceFiles.push(file.fileName);
159
- }
160
- }
161
- }
162
-
163
- this.console = nullConsole;
164
- this.testFS = createFromFileSystem(
165
- host.HOST,
166
- ignoreCase,
167
- { cwd: basePath, files, meta: testData.globalOptions },
168
- mountPaths
169
- );
170
-
171
- this.fs = new PyrightFileSystem(this.testFS);
172
- this._files = sourceFiles;
173
-
174
- const configOptions = this._convertGlobalOptionsToConfigOptions(this.testData.globalOptions, mountPaths);
175
- if (this.rawConfigJson) {
176
- configOptions.initializeFromJson(this.rawConfigJson, 'basic', nullConsole, this.fs, testAccessHost);
177
- this._applyTestConfigOptions(configOptions);
178
- }
179
-
180
- const service = this._createAnalysisService(
181
- nullConsole,
182
- this._hostSpecificFeatures.importResolverFactory,
183
- configOptions
184
- );
185
-
186
- this.workspace = {
187
- workspaceName: 'test workspace',
188
- rootPath: this.fs.getModulePath(),
189
- rootUri: convertPathToUri(this.fs, this.fs.getModulePath()),
190
- serviceInstance: service,
191
- disableLanguageServices: false,
192
- disableOrganizeImports: false,
193
- isInitialized: createDeferred<boolean>(),
194
- searchPathsToWatch: [],
195
- };
196
-
197
- const indexer = toBoolean(testData.globalOptions[GlobalMetadataOptionNames.indexer]);
198
- const indexerWithoutStdLib = toBoolean(testData.globalOptions[GlobalMetadataOptionNames.indexerWithoutStdLib]);
199
- if (indexer || indexerWithoutStdLib) {
200
- const indexerOptions = testData.globalOptions[GlobalMetadataOptionNames.indexerOptions];
201
- configOptions.indexing = true;
202
- this._hostSpecificFeatures.runIndexer(this.workspace, indexerWithoutStdLib, indexerOptions);
203
- }
204
-
205
- if (this._files.length > 0) {
206
- // Open the first file by default
207
- this.openFile(this._files[0]);
208
- }
209
-
210
- for (const filePath of this._files) {
211
- const file = files[filePath] as vfs.File;
212
- if (file.meta?.[MetadataOptionNames.ipythonMode]) {
213
- this.program.getSourceFile(filePath)?.test_enableIPythonMode(true);
214
- }
215
- }
216
- }
217
-
218
- get importResolver(): ImportResolver {
219
- return this.workspace.serviceInstance.getImportResolver();
220
- }
221
-
222
- get configOptions(): ConfigOptions {
223
- return this.workspace.serviceInstance.getConfigOptions();
224
- }
225
-
226
- get program(): Program {
227
- return this.workspace.serviceInstance.test_program;
228
- }
229
-
230
- cwd() {
231
- return this.testFS.cwd();
232
- }
233
-
234
- // Entry points from fourslash.ts
235
- goToMarker(nameOrMarker: string | Marker = '') {
236
- const marker = isString(nameOrMarker) ? this.getMarkerByName(nameOrMarker) : nameOrMarker;
237
- if (this.activeFile.fileName !== marker.fileName) {
238
- this.openFile(marker.fileName);
239
- }
240
-
241
- const content = this._getFileContent(marker.fileName);
242
- if (marker.position === -1 || marker.position > content.length) {
243
- throw new Error(`Marker "${nameOrMarker}" has been invalidated by unrecoverable edits to the file.`);
244
- }
245
-
246
- const mName = isString(nameOrMarker) ? nameOrMarker : this.getMarkerName(marker);
247
- this.lastKnownMarker = mName;
248
- this.goToPosition(marker.position);
249
- }
250
-
251
- goToEachMarker(markers: readonly Marker[], action: (marker: Marker, index: number) => void) {
252
- assert.ok(markers.length > 0);
253
- for (let i = 0; i < markers.length; i++) {
254
- this.goToMarker(markers[i]);
255
- action(markers[i], i);
256
- }
257
- }
258
-
259
- getMappedFilePath(path: string): string {
260
- this.importResolver.ensurePartialStubPackages(this.configOptions.findExecEnvironment(path));
261
- return this.fs.getMappedFilePath(path);
262
- }
263
-
264
- getMarkerName(m: Marker): string {
265
- let found: string | undefined;
266
- this.testData.markerPositions.forEach((marker, name) => {
267
- if (marker === m) {
268
- found = name;
269
- }
270
- });
271
-
272
- assert.ok(found);
273
- return found!;
274
- }
275
-
276
- getMarkerByName(markerName: string) {
277
- const markerPos = this.testData.markerPositions.get(markerName);
278
- if (markerPos === undefined) {
279
- throw new Error(
280
- `Unknown marker "${markerName}" Available markers: ${this.getMarkerNames()
281
- .map((m) => '"' + m + '"')
282
- .join(', ')}`
283
- );
284
- } else {
285
- return markerPos;
286
- }
287
- }
288
-
289
- getMarkers(): Marker[] {
290
- // Return a copy of the list
291
- return this.testData.markers.slice(0);
292
- }
293
-
294
- getMarkerNames(): string[] {
295
- return [...this.testData.markerPositions.keys()];
296
- }
297
-
298
- getPositionRange(markerString: string) {
299
- const marker = this.getMarkerByName(markerString);
300
- const ranges = this.getRanges().filter((r) => r.marker === marker);
301
- if (ranges.length !== 1) {
302
- this.raiseError(`no matching range for ${markerString}`);
303
- }
304
-
305
- const range = ranges[0];
306
- return this.convertPositionRange(range);
307
- }
308
-
309
- expandPositionRange(range: PositionRange, start: number, end: number) {
310
- return {
311
- start: { line: range.start.line, character: range.start.character - start },
312
- end: { line: range.end.line, character: range.end.character + end },
313
- };
314
- }
315
-
316
- convertPositionRange(range: Range) {
317
- return this.convertOffsetsToRange(range.fileName, range.pos, range.end);
318
- }
319
-
320
- convertPathToUri(path: string) {
321
- return convertPathToUri(this.fs, path);
322
- }
323
-
324
- getDirectoryPath(path: string) {
325
- return getDirectoryPath(path);
326
- }
327
-
328
- goToPosition(positionOrLineAndColumn: number | Position) {
329
- const pos = isNumber(positionOrLineAndColumn)
330
- ? positionOrLineAndColumn
331
- : this.convertPositionToOffset(this.activeFile.fileName, positionOrLineAndColumn);
332
- this.currentCaretPosition = pos;
333
- this.selectionEnd = -1;
334
- }
335
-
336
- select(startMarker: string, endMarker: string) {
337
- const start = this.getMarkerByName(startMarker);
338
- const end = this.getMarkerByName(endMarker);
339
-
340
- assert.ok(start.fileName === end.fileName);
341
- if (this.activeFile.fileName !== start.fileName) {
342
- this.openFile(start.fileName);
343
- }
344
- this.goToPosition(start.position);
345
- this.selectionEnd = end.position;
346
- }
347
-
348
- selectAllInFile(fileName: string) {
349
- this.openFile(fileName);
350
- this.goToPosition(0);
351
- this.selectionEnd = this.activeFile.content.length;
352
- }
353
-
354
- selectRange(range: Range): void {
355
- this.goToRangeStart(range);
356
- this.selectionEnd = range.end;
357
- }
358
-
359
- selectLine(index: number) {
360
- const lineStart = this.convertPositionToOffset(this.activeFile.fileName, { line: index, character: 0 });
361
- const lineEnd = lineStart + this._getLineContent(index).length;
362
- this.selectRange({ fileName: this.activeFile.fileName, pos: lineStart, end: lineEnd });
363
- }
364
-
365
- goToEachRange(action: (range: Range) => void) {
366
- const ranges = this.getRanges();
367
- assert.ok(ranges.length > 0);
368
- for (const range of ranges) {
369
- this.selectRange(range);
370
- action(range);
371
- }
372
- }
373
-
374
- goToRangeStart({ fileName, pos }: Range) {
375
- this.openFile(fileName);
376
- this.goToPosition(pos);
377
- }
378
-
379
- getRanges(): Range[] {
380
- return this.testData.ranges;
381
- }
382
-
383
- getRangesInFile(fileName = this.activeFile.fileName) {
384
- return this.getRanges().filter((r) => r.fileName === fileName);
385
- }
386
-
387
- getRangesByText(): Map<string, Range[]> {
388
- if (this.testData.rangesByText) {
389
- return this.testData.rangesByText;
390
- }
391
- const result = this.createMultiMap<Range>(this.getRanges(), (r) => this._rangeText(r));
392
- this.testData.rangesByText = result;
393
-
394
- return result;
395
- }
396
-
397
- getFilteredRanges<T extends {}>(
398
- predicate: (m: Marker | undefined, d: T | undefined, text: string) => boolean
399
- ): Range[] {
400
- return this.getRanges().filter((r) => predicate(r.marker, r.marker?.data as T | undefined, this._rangeText(r)));
401
- }
402
-
403
- getRangeByMarkerName(markerName: string): Range | undefined {
404
- const marker = this.getMarkerByName(markerName);
405
- return this.getRanges().find((r) => r.marker === marker);
406
- }
407
-
408
- goToBOF() {
409
- this.goToPosition(0);
410
- }
411
-
412
- goToEOF() {
413
- const len = this._getFileContent(this.activeFile.fileName).length;
414
- this.goToPosition(len);
415
- }
416
-
417
- moveCaretRight(count = 1) {
418
- this.currentCaretPosition += count;
419
- this.currentCaretPosition = Math.min(
420
- this.currentCaretPosition,
421
- this._getFileContent(this.activeFile.fileName).length
422
- );
423
- this.selectionEnd = -1;
424
- }
425
-
426
- // Opens a file given its 0-based index or fileName
427
- openFile(indexOrName: number | string): void {
428
- const fileToOpen: FourSlashFile = this._findFile(indexOrName);
429
- fileToOpen.fileName = normalizeSlashes(fileToOpen.fileName);
430
- this.activeFile = fileToOpen;
431
-
432
- this.program.setFileOpened(this.activeFile.fileName, 1, [{ text: fileToOpen.content }]);
433
- }
434
-
435
- openFiles(indexOrNames: (number | string)[]): void {
436
- for (const indexOrName of indexOrNames) {
437
- this.openFile(indexOrName);
438
- }
439
- }
440
-
441
- printCurrentFileState(showWhitespace: boolean, makeCaretVisible: boolean) {
442
- for (const file of this.testData.files) {
443
- const active = this.activeFile === file;
444
- host.HOST.log(`=== Script (${file.fileName}) ${active ? '(active, cursor at |)' : ''} ===`);
445
- let content = this._getFileContent(file.fileName);
446
- if (active) {
447
- content =
448
- content.substr(0, this.currentCaretPosition) +
449
- (makeCaretVisible ? '|' : '') +
450
- content.substr(this.currentCaretPosition);
451
- }
452
- if (showWhitespace) {
453
- content = this._makeWhitespaceVisible(content);
454
- }
455
- host.HOST.log(content);
456
- }
457
- }
458
-
459
- deleteChar(count = 1) {
460
- const offset = this.currentCaretPosition;
461
- const ch = '';
462
-
463
- const checkCadence = (count >> 2) + 1;
464
-
465
- for (let i = 0; i < count; i++) {
466
- this._editScriptAndUpdateMarkers(this.activeFile.fileName, offset, offset + 1, ch);
467
-
468
- if (i % checkCadence === 0) {
469
- this._checkPostEditInvariants();
470
- }
471
- }
472
-
473
- this._checkPostEditInvariants();
474
- }
475
-
476
- replace(start: number, length: number, text: string) {
477
- this._editScriptAndUpdateMarkers(this.activeFile.fileName, start, start + length, text);
478
- this._checkPostEditInvariants();
479
- }
480
-
481
- deleteLineRange(startIndex: number, endIndexInclusive: number) {
482
- const startPos = this.convertPositionToOffset(this.activeFile.fileName, { line: startIndex, character: 0 });
483
- const endPos = this.convertPositionToOffset(this.activeFile.fileName, {
484
- line: endIndexInclusive + 1,
485
- character: 0,
486
- });
487
- this.replace(startPos, endPos - startPos, '');
488
- }
489
-
490
- deleteCharBehindMarker(count = 1) {
491
- let offset = this.currentCaretPosition;
492
- const ch = '';
493
- const checkCadence = (count >> 2) + 1;
494
-
495
- for (let i = 0; i < count; i++) {
496
- this.currentCaretPosition--;
497
- offset--;
498
- this._editScriptAndUpdateMarkers(this.activeFile.fileName, offset, offset + 1, ch);
499
-
500
- if (i % checkCadence === 0) {
501
- this._checkPostEditInvariants();
502
- }
503
-
504
- // Don't need to examine formatting because there are no formatting changes on backspace.
505
- }
506
-
507
- this._checkPostEditInvariants();
508
- }
509
-
510
- // Enters lines of text at the current caret position
511
- type(text: string) {
512
- let offset = this.currentCaretPosition;
513
- const selection = this._getSelection();
514
- this.replace(selection.start, selection.length, '');
515
-
516
- for (let i = 0; i < text.length; i++) {
517
- const ch = text.charAt(i);
518
- this._editScriptAndUpdateMarkers(this.activeFile.fileName, offset, offset, ch);
519
-
520
- this.currentCaretPosition++;
521
- offset++;
522
- }
523
-
524
- this._checkPostEditInvariants();
525
- }
526
-
527
- // Enters text as if the user had pasted it
528
- paste(text: string) {
529
- this._editScriptAndUpdateMarkers(
530
- this.activeFile.fileName,
531
- this.currentCaretPosition,
532
- this.currentCaretPosition,
533
- text
534
- );
535
- this._checkPostEditInvariants();
536
- }
537
-
538
- verifyDiagnostics(map?: { [marker: string]: { category: string; message: string } }): void {
539
- this._analyze();
540
-
541
- // organize things per file
542
- const resultPerFile = this._getDiagnosticsPerFile();
543
- const rangePerFile = this.createMultiMap<Range>(this.getRanges(), (r) => r.fileName);
544
-
545
- if (!hasDiagnostics(resultPerFile) && rangePerFile.size === 0) {
546
- // no errors and no error is expected. we are done
547
- return;
548
- }
549
-
550
- for (const [file, ranges] of rangePerFile.entries()) {
551
- const rangesPerCategory = this.createMultiMap<Range>(ranges, (r) => {
552
- if (map) {
553
- const name = this.getMarkerName(r.marker!);
554
- return map[name].category;
555
- }
556
-
557
- return (r.marker!.data! as any).category as string;
558
- });
559
-
560
- if (!rangesPerCategory.has('error')) {
561
- rangesPerCategory.set('error', []);
562
- }
563
-
564
- if (!rangesPerCategory.has('warning')) {
565
- rangesPerCategory.set('warning', []);
566
- }
567
-
568
- if (!rangesPerCategory.has('information')) {
569
- rangesPerCategory.set('information', []);
570
- }
571
-
572
- const result = resultPerFile.get(file)!;
573
- resultPerFile.delete(file);
574
-
575
- for (const [category, expected] of rangesPerCategory.entries()) {
576
- const lines = result.parseResults!.tokenizerOutput.lines;
577
- const actual =
578
- category === 'error'
579
- ? result.errors
580
- : category === 'warning'
581
- ? result.warnings
582
- : category === 'information'
583
- ? result.information
584
- : this.raiseError(`unexpected category ${category}`);
585
-
586
- if (expected.length !== actual.length) {
587
- this.raiseError(
588
- `contains unexpected result - expected: ${stringify(expected)}, actual: ${stringify(actual)}`
589
- );
590
- }
591
-
592
- for (const range of expected) {
593
- const rangeSpan = TextRange.fromBounds(range.pos, range.end);
594
- const matches = actual.filter((d) => {
595
- const diagnosticSpan = TextRange.fromBounds(
596
- convertPositionToOffset(d.range.start, lines)!,
597
- convertPositionToOffset(d.range.end, lines)!
598
- );
599
- return this._deepEqual(diagnosticSpan, rangeSpan);
600
- });
601
-
602
- if (matches.length === 0) {
603
- this.raiseError(`doesn't contain expected range: ${stringify(range)}`);
604
- }
605
-
606
- // if map is provided, check message as well
607
- if (map) {
608
- const name = this.getMarkerName(range.marker!);
609
- const message = map[name].message;
610
-
611
- if (matches.filter((d) => message === d.message).length !== 1) {
612
- this.raiseError(
613
- `message doesn't match: ${message} of ${name} - ${stringify(
614
- range
615
- )}, actual: ${stringify(matches)}`
616
- );
617
- }
618
- }
619
- }
620
- }
621
- }
622
-
623
- if (hasDiagnostics(resultPerFile)) {
624
- this.raiseError(`these diagnostics were unexpected: ${stringify(resultPerFile)}`);
625
- }
626
-
627
- function hasDiagnostics(
628
- resultPerFile: Map<
629
- string,
630
- {
631
- filePath: string;
632
- parseResults: ParseResults | undefined;
633
- errors: Diagnostic[];
634
- warnings: Diagnostic[];
635
- }
636
- >
637
- ) {
638
- for (const entry of resultPerFile.values()) {
639
- if (entry.errors.length + entry.warnings.length > 0) {
640
- return true;
641
- }
642
- }
643
-
644
- return false;
645
- }
646
- }
647
-
648
- async verifyCodeActions(
649
- map: {
650
- [marker: string]: {
651
- codeActions: { title: string; kind: string; command?: Command; edit?: WorkspaceEdit[] }[];
652
- };
653
- },
654
- verifyCodeActionCount?: boolean
655
- ): Promise<any> {
656
- // make sure we don't use cache built from other tests
657
- this.workspace.serviceInstance.invalidateAndForceReanalysis();
658
- this._analyze();
659
-
660
- for (const range of this.getRanges()) {
661
- const name = this.getMarkerName(range.marker!);
662
- if (!map[name]) {
663
- continue;
664
- }
665
-
666
- const codeActions = await this._getCodeActions(range);
667
- if (verifyCodeActionCount) {
668
- if (codeActions.length !== map[name].codeActions.length) {
669
- this.raiseError(
670
- `doesn't contain expected result: ${stringify(map[name])}, actual: ${stringify(codeActions)}`
671
- );
672
- }
673
- }
674
-
675
- for (const expected of map[name].codeActions) {
676
- let expectedCommand: Command | undefined;
677
- if (expected.command) {
678
- expectedCommand = {
679
- title: expected.command.title,
680
- command: expected.command.command,
681
- arguments: convertToString(expected.command.arguments),
682
- };
683
- }
684
-
685
- const matches = codeActions.filter((a) => {
686
- const actualCommand = a.command
687
- ? {
688
- title: a.command.title,
689
- command: a.command.command,
690
- arguments: convertToString(a.command.arguments),
691
- }
692
- : undefined;
693
-
694
- const actualEdit = a.edit;
695
-
696
- return (
697
- a.title === expected.title &&
698
- a.kind! === expected.kind &&
699
- this._deepEqual(actualCommand, expectedCommand) &&
700
- this._deepEqual(actualEdit, expected.edit)
701
- );
702
- });
703
-
704
- if (matches.length !== 1) {
705
- this.raiseError(
706
- `doesn't contain expected result: ${stringify(expected)}, actual: ${stringify(codeActions)}`
707
- );
708
- }
709
- }
710
- }
711
-
712
- function convertToString(args: any[] | undefined): string[] | undefined {
713
- return args?.map((a) => {
714
- if (isString(a)) {
715
- return normalizeSlashes(a);
716
- }
717
-
718
- return JSON.stringify(a);
719
- });
720
- }
721
- }
722
-
723
- async verifyCommand(command: Command, files: { [filePath: string]: string }): Promise<any> {
724
- this._analyze();
725
-
726
- const commandResult = await this._hostSpecificFeatures.execute(
727
- new TestLanguageService(this.workspace, this.console, this.fs),
728
- { command: command.command, arguments: command.arguments || [] },
729
- CancellationToken.None
730
- );
731
-
732
- if (command.command === 'pyright.createtypestub') {
733
- await this._verifyFiles(files);
734
- } else if (command.command === 'pyright.organizeimports') {
735
- // Organize imports command can be used on only one file at a time,
736
- // so there is no looping over "commandResult" or "files".
737
- const workspaceEditResult = commandResult as WorkspaceEdit;
738
- const uri = Object.keys(workspaceEditResult.changes!)[0];
739
- const textEdit = workspaceEditResult.changes![uri][0];
740
- const actualText = textEdit.newText;
741
- const expectedText: string = Object.values(files)[0];
742
-
743
- if (actualText !== expectedText) {
744
- this.raiseError(
745
- `doesn't contain expected result: ${stringify(expectedText)}, actual: ${stringify(actualText)}`
746
- );
747
- }
748
- }
749
- return commandResult;
750
- }
751
-
752
- verifyWorkspaceEdit(expected: WorkspaceEdit, actual: WorkspaceEdit) {
753
- if (actual.changes) {
754
- this._verifyTextEditMap(expected.changes!, actual.changes);
755
- } else {
756
- assert(!expected.changes);
757
- }
758
-
759
- if (actual.documentChanges) {
760
- this._verifyDocumentEdits(expected.documentChanges!, actual.documentChanges);
761
- } else {
762
- assert(!expected.documentChanges);
763
- }
764
-
765
- if (actual.changeAnnotations) {
766
- this._verifyChangeAnnotations(expected.changeAnnotations!, actual.changeAnnotations);
767
- } else {
768
- assert(!expected.changeAnnotations);
769
- }
770
- }
771
-
772
- private _verifyChangeAnnotations(
773
- expected: { [id: string]: ChangeAnnotation },
774
- actual: { [id: string]: ChangeAnnotation }
775
- ) {
776
- assert.strictEqual(Object.entries(expected).length, Object.entries(actual).length);
777
-
778
- for (const key of Object.keys(expected)) {
779
- const expectedAnnotation = expected[key];
780
- const actualAnnotation = actual[key];
781
-
782
- // We need to improve it to test localized strings.
783
- assert.strictEqual(expectedAnnotation.label, actualAnnotation.label);
784
- assert.strictEqual(expectedAnnotation.description, actualAnnotation.description);
785
-
786
- assert.strictEqual(expectedAnnotation.needsConfirmation, actualAnnotation.needsConfirmation);
787
- }
788
- }
789
-
790
- private _textDocumentAreSame(
791
- expected: OptionalVersionedTextDocumentIdentifier,
792
- actual: OptionalVersionedTextDocumentIdentifier
793
- ) {
794
- return expected.version === actual.version && expected.uri === actual.uri;
795
- }
796
-
797
- private _verifyDocumentEdits(
798
- expected: (TextDocumentEdit | CreateFile | RenameFile | DeleteFile)[],
799
- actual: (TextDocumentEdit | CreateFile | RenameFile | DeleteFile)[]
800
- ) {
801
- assert.strictEqual(expected.length, actual.length);
802
-
803
- for (const op of expected) {
804
- assert(
805
- actual.some((a) => {
806
- const expectedKind = TextDocumentEdit.is(op) ? 'edit' : op.kind;
807
- const actualKind = TextDocumentEdit.is(a) ? 'edit' : a.kind;
808
- if (expectedKind !== actualKind) {
809
- return false;
810
- }
811
-
812
- switch (expectedKind) {
813
- case 'edit': {
814
- const expectedEdit = op as TextDocumentEdit;
815
- const actualEdit = a as TextDocumentEdit;
816
-
817
- if (!this._textDocumentAreSame(expectedEdit.textDocument, actualEdit.textDocument)) {
818
- return false;
819
- }
820
-
821
- return this._textEditsAreSame(expectedEdit.edits, actualEdit.edits);
822
- }
823
- case 'create': {
824
- const expectedOp = op as CreateFile;
825
- const actualOp = a as CreateFile;
826
- return (
827
- expectedOp.kind === actualOp.kind &&
828
- expectedOp.annotationId === actualOp.annotationId &&
829
- expectedOp.uri === actualOp.uri &&
830
- expectedOp.options?.ignoreIfExists === actualOp.options?.ignoreIfExists &&
831
- expectedOp.options?.overwrite === actualOp.options?.overwrite
832
- );
833
- }
834
- case 'rename': {
835
- const expectedOp = op as RenameFile;
836
- const actualOp = a as RenameFile;
837
- return (
838
- expectedOp.kind === actualOp.kind &&
839
- expectedOp.annotationId === actualOp.annotationId &&
840
- expectedOp.oldUri === actualOp.oldUri &&
841
- expectedOp.newUri === actualOp.newUri &&
842
- expectedOp.options?.ignoreIfExists === actualOp.options?.ignoreIfExists &&
843
- expectedOp.options?.overwrite === actualOp.options?.overwrite
844
- );
845
- }
846
- case 'delete': {
847
- const expectedOp = op as DeleteFile;
848
- const actualOp = a as DeleteFile;
849
- return (
850
- expectedOp.annotationId === actualOp.annotationId &&
851
- expectedOp.kind === actualOp.kind &&
852
- expectedOp.uri === actualOp.uri &&
853
- expectedOp.options?.ignoreIfNotExists === actualOp.options?.ignoreIfNotExists &&
854
- expectedOp.options?.recursive === actualOp.options?.recursive
855
- );
856
- }
857
- default:
858
- debug.assertNever(expectedKind);
859
- }
860
- })
861
- );
862
- }
863
- }
864
-
865
- private _verifyTextEditMap(expected: { [uri: string]: TextEdit[] }, actual: { [uri: string]: TextEdit[] }) {
866
- assert.strictEqual(Object.entries(expected).length, Object.entries(actual).length);
867
-
868
- for (const key of Object.keys(expected)) {
869
- assert(this._textEditsAreSame(expected[key], actual[key]));
870
- }
871
- }
872
-
873
- private _textEditsAreSame(
874
- expectedEdits: (TextEdit | AnnotatedTextEdit)[],
875
- actualEdits: (TextEdit | AnnotatedTextEdit)[]
876
- ) {
877
- if (expectedEdits.length !== actualEdits.length) {
878
- return false;
879
- }
880
-
881
- for (const edit of expectedEdits) {
882
- if (!actualEdits.some((a) => this._textEditAreSame(edit, a))) {
883
- return false;
884
- }
885
- }
886
-
887
- return true;
888
- }
889
-
890
- private _textEditAreSame(expected: TextEdit, actual: TextEdit) {
891
- if (!rangesAreEqual(expected.range, actual.range)) {
892
- return false;
893
- }
894
-
895
- if (expected.newText !== actual.newText) {
896
- return false;
897
- }
898
-
899
- const expectedAnnotation = AnnotatedTextEdit.is(expected) ? expected.annotationId : '';
900
- const actualAnnotation = AnnotatedTextEdit.is(actual) ? actual.annotationId : '';
901
- return expectedAnnotation === actualAnnotation;
902
- }
903
-
904
- async verifyInvokeCodeAction(
905
- map: {
906
- [marker: string]: { title: string; files?: { [filePath: string]: string }; edits?: TextEdit[] };
907
- },
908
- verifyCodeActionCount?: boolean
909
- ): Promise<any> {
910
- this._analyze();
911
-
912
- for (const range of this.getRanges()) {
913
- const name = this.getMarkerName(range.marker!);
914
- if (!map[name]) {
915
- continue;
916
- }
917
-
918
- const ls = new TestLanguageService(this.workspace, this.console, this.fs);
919
-
920
- const codeActions = await this._getCodeActions(range);
921
- if (verifyCodeActionCount) {
922
- if (codeActions.length !== Object.keys(map).length) {
923
- this.raiseError(
924
- `doesn't contain expected result: ${stringify(map[name])}, actual: ${stringify(codeActions)}`
925
- );
926
- }
927
- }
928
-
929
- const matches = codeActions.filter((c) => c.title === map[name].title);
930
- if (matches.length === 0) {
931
- this.raiseError(
932
- `doesn't contain expected result: ${stringify(map[name])}, actual: ${stringify(codeActions)}`
933
- );
934
- }
935
-
936
- for (const codeAction of matches) {
937
- const results = await this._hostSpecificFeatures.execute(
938
- ls,
939
- {
940
- command: codeAction.command!.command,
941
- arguments: codeAction.command?.arguments || [],
942
- },
943
- CancellationToken.None
944
- );
945
-
946
- if (map[name].edits) {
947
- const workspaceEdits = results as WorkspaceEdit;
948
- for (const edits of Object.values(workspaceEdits.changes!)) {
949
- for (const edit of edits) {
950
- if (map[name].edits!.filter((e) => this._editsAreEqual(e, edit)).length !== 1) {
951
- this.raiseError(
952
- `doesn't contain expected result: ${stringify(map[name])}, actual: ${stringify(
953
- edits
954
- )}`
955
- );
956
- }
957
- }
958
- }
959
- }
960
- }
961
-
962
- if (map[name].files) {
963
- await this._verifyFiles(map[name].files!);
964
- }
965
- }
966
- }
967
-
968
- verifyHover(kind: MarkupKind, map: { [marker: string]: string | null }): void {
969
- // Do not force analyze, it can lead to test passing while it doesn't work in product
970
- for (const range of this.getRanges()) {
971
- const name = this.getMarkerName(range.marker!);
972
- const expected = map[name];
973
- if (expected === undefined) {
974
- continue;
975
- }
976
-
977
- const rangePos = this.convertOffsetsToRange(range.fileName, range.pos, range.end);
978
-
979
- const actual = convertHoverResults(
980
- kind,
981
- this.program.getHoverForPosition(range.fileName, rangePos.start, kind, CancellationToken.None)
982
- );
983
-
984
- // if expected is null then there should be nothing shown on hover
985
- if (expected === null) {
986
- assert.equal(actual, undefined);
987
- continue;
988
- }
989
-
990
- assert.ok(actual);
991
-
992
- assert.deepEqual(actual!.range, rangePos);
993
-
994
- if (MarkupContent.is(actual!.contents)) {
995
- assert.equal(actual!.contents.value, expected);
996
- assert.equal(actual!.contents.kind, kind);
997
- } else {
998
- assert.fail(`Unexpected type of contents object "${actual!.contents}", should be MarkupContent.`);
999
- }
1000
- }
1001
- }
1002
-
1003
- verifyCaretAtMarker(markerName = '') {
1004
- const pos = this.getMarkerByName(markerName);
1005
- if (pos.fileName !== this.activeFile.fileName) {
1006
- throw new Error(
1007
- `verifyCaretAtMarker failed - expected to be in file "${pos.fileName}", but was in file "${this.activeFile.fileName}"`
1008
- );
1009
- }
1010
- if (pos.position !== this.currentCaretPosition) {
1011
- throw new Error(
1012
- `verifyCaretAtMarker failed - expected to be at marker "/*${markerName}*/, but was at position ${
1013
- this.currentCaretPosition
1014
- }(${this._getLineColStringAtPosition(this.currentCaretPosition)})`
1015
- );
1016
- }
1017
- }
1018
-
1019
- verifyCurrentLineContent(text: string) {
1020
- const actual = this._getCurrentLineContent();
1021
- if (actual !== text) {
1022
- throw new Error(
1023
- 'verifyCurrentLineContent\n' + this._displayExpectedAndActualString(text, actual, /* quoted */ true)
1024
- );
1025
- }
1026
- }
1027
-
1028
- verifyCurrentFileContent(text: string) {
1029
- this._verifyFileContent(this.activeFile.fileName, text);
1030
- }
1031
-
1032
- verifyTextAtCaretIs(text: string) {
1033
- const actual = this._getFileContent(this.activeFile.fileName).substring(
1034
- this.currentCaretPosition,
1035
- this.currentCaretPosition + text.length
1036
- );
1037
- if (actual !== text) {
1038
- throw new Error(
1039
- 'verifyTextAtCaretIs\n' + this._displayExpectedAndActualString(text, actual, /* quoted */ true)
1040
- );
1041
- }
1042
- }
1043
-
1044
- verifyRangeIs(expectedText: string, includeWhiteSpace?: boolean) {
1045
- this._verifyTextMatches(this._rangeText(this._getOnlyRange()), !!includeWhiteSpace, expectedText);
1046
- }
1047
-
1048
- async verifyCompletion(
1049
- verifyMode: _.FourSlashCompletionVerificationMode,
1050
- docFormat: MarkupKind,
1051
- map: {
1052
- [marker: string]: {
1053
- completions: _.FourSlashCompletionItem[];
1054
- memberAccessInfo?: {
1055
- lastKnownModule?: string;
1056
- lastKnownMemberName?: string;
1057
- unknownMemberName?: string;
1058
- };
1059
- };
1060
- },
1061
- abbrMap?: { [abbr: string]: AbbreviationInfo }
1062
- ): Promise<void> {
1063
- this._analyze();
1064
-
1065
- for (const marker of this.getMarkers()) {
1066
- const markerName = this.getMarkerName(marker);
1067
- if (!map[markerName]) {
1068
- continue;
1069
- }
1070
-
1071
- this.lastKnownMarker = markerName;
1072
-
1073
- const filePath = marker.fileName;
1074
- const expectedCompletions = map[markerName].completions;
1075
- const completionPosition = this.convertOffsetToPosition(filePath, marker.position);
1076
-
1077
- const options = { format: docFormat, snippet: true, lazyEdit: true, autoImport: true };
1078
- const nameMap = abbrMap ? new Map<string, AbbreviationInfo>(Object.entries(abbrMap)) : undefined;
1079
- const result = await this.workspace.serviceInstance.getCompletionsForPosition(
1080
- filePath,
1081
- completionPosition,
1082
- this.workspace.rootPath,
1083
- options,
1084
- nameMap,
1085
- CancellationToken.None
1086
- );
1087
-
1088
- if (result?.completionList) {
1089
- if (verifyMode === 'exact') {
1090
- if (result.completionList.items.length !== expectedCompletions.length) {
1091
- assert.fail(
1092
- `${markerName} - Expected ${expectedCompletions.length} items but received ${
1093
- result.completionList.items.length
1094
- }. Actual completions:\n${stringify(result.completionList.items.map((r) => r.label))}`
1095
- );
1096
- }
1097
- }
1098
-
1099
- for (let i = 0; i < expectedCompletions.length; i++) {
1100
- const expected = expectedCompletions[i];
1101
- const actualIndex = result.completionList.items.findIndex(
1102
- (a) =>
1103
- a.label === expected.label &&
1104
- (expected.kind ? a.kind === expected.kind : true) &&
1105
- (expected.detail ? a.detail === expected.detail : true) &&
1106
- (expected.documentation && MarkupContent.is(a.documentation)
1107
- ? a.documentation.value === expected.documentation
1108
- : true)
1109
- );
1110
- if (actualIndex >= 0) {
1111
- if (verifyMode === 'excluded') {
1112
- // we're not supposed to find the completions passed to the test
1113
- assert.fail(
1114
- `${markerName} - Completion item with label "${
1115
- expected.label
1116
- }" unexpected. Actual completions:\n${stringify(
1117
- result.completionList.items.map((r) => r.label)
1118
- )}`
1119
- );
1120
- }
1121
-
1122
- const actual: CompletionItem = result.completionList.items[actualIndex];
1123
-
1124
- if (expected.additionalTextEdits !== undefined) {
1125
- if (actual.additionalTextEdits === undefined) {
1126
- this.workspace.serviceInstance.resolveCompletionItem(
1127
- filePath,
1128
- actual,
1129
- options,
1130
- nameMap,
1131
- CancellationToken.None
1132
- );
1133
- }
1134
- }
1135
-
1136
- this.verifyCompletionItem(expected, actual);
1137
-
1138
- if (expected.documentation !== undefined) {
1139
- if (actual.documentation === undefined) {
1140
- this.workspace.serviceInstance.resolveCompletionItem(
1141
- filePath,
1142
- actual,
1143
- options,
1144
- nameMap,
1145
- CancellationToken.None
1146
- );
1147
- }
1148
-
1149
- if (MarkupContent.is(actual.documentation)) {
1150
- assert.strictEqual(actual.documentation.value, expected.documentation);
1151
- assert.strictEqual(actual.documentation.kind, docFormat);
1152
- } else {
1153
- assert.fail(
1154
- `${markerName} - Unexpected type of contents object "${actual.documentation}", should be MarkupContent.`
1155
- );
1156
- }
1157
- }
1158
-
1159
- result.completionList.items.splice(actualIndex, 1);
1160
- } else {
1161
- if (verifyMode === 'included' || verifyMode === 'exact') {
1162
- // we're supposed to find all items passed to the test
1163
- assert.fail(
1164
- `${markerName} - Completion item with label "${
1165
- expected.label
1166
- }" expected. Actual completions:\n${stringify(
1167
- result.completionList.items.map((r) => r.label)
1168
- )}`
1169
- );
1170
- }
1171
- }
1172
- }
1173
-
1174
- if (verifyMode === 'exact') {
1175
- if (result.completionList.items.length !== 0) {
1176
- // we removed every item we found, there should not be any remaining
1177
- assert.fail(
1178
- `${markerName} - Completion items unexpected: ${stringify(
1179
- result.completionList.items.map((r) => r.label)
1180
- )}`
1181
- );
1182
- }
1183
- }
1184
- } else {
1185
- if (verifyMode !== 'exact' || expectedCompletions.length > 0) {
1186
- assert.fail(`${markerName} - Failed to get completions`);
1187
- }
1188
- }
1189
-
1190
- if (map[markerName].memberAccessInfo !== undefined && result?.memberAccessInfo !== undefined) {
1191
- const expectedModule = map[markerName].memberAccessInfo?.lastKnownModule;
1192
- const expectedType = map[markerName].memberAccessInfo?.lastKnownMemberName;
1193
- const expectedName = map[markerName].memberAccessInfo?.unknownMemberName;
1194
- if (
1195
- result?.memberAccessInfo?.lastKnownModule !== expectedModule ||
1196
- result?.memberAccessInfo?.lastKnownMemberName !== expectedType ||
1197
- result?.memberAccessInfo?.unknownMemberName !== expectedName
1198
- ) {
1199
- assert.fail(
1200
- `${markerName} - Expected completion results memberAccessInfo with \n lastKnownModule: "${expectedModule}"\n lastKnownMemberName: "${expectedType}"\n unknownMemberName: "${expectedName}"\n Actual memberAccessInfo:\n lastKnownModule: "${
1201
- result.memberAccessInfo?.lastKnownModule ?? ''
1202
- }"\n lastKnownMemberName: "${
1203
- result.memberAccessInfo?.lastKnownMemberName ?? ''
1204
- }\n unknownMemberName: "${result.memberAccessInfo?.unknownMemberName ?? ''}" `
1205
- );
1206
- }
1207
- }
1208
- }
1209
- }
1210
-
1211
- verifySignature(
1212
- docFormat: MarkupKind,
1213
- map: {
1214
- [marker: string]: {
1215
- noSig?: boolean;
1216
- signatures?: {
1217
- label: string;
1218
- parameters: string[];
1219
- documentation?: string;
1220
- }[];
1221
- activeParameters?: (number | undefined)[];
1222
- callHasParameters?: boolean;
1223
- };
1224
- }
1225
- ): void {
1226
- this._analyze();
1227
-
1228
- for (const marker of this.getMarkers()) {
1229
- const fileName = marker.fileName;
1230
- const name = this.getMarkerName(marker);
1231
-
1232
- if (!(name in map)) {
1233
- continue;
1234
- }
1235
-
1236
- const expected = map[name];
1237
- const position = this.convertOffsetToPosition(fileName, marker.position);
1238
-
1239
- const actual = this.program.getSignatureHelpForPosition(
1240
- fileName,
1241
- position,
1242
- docFormat,
1243
- CancellationToken.None
1244
- );
1245
-
1246
- if (expected.noSig) {
1247
- assert.equal(actual, undefined);
1248
- continue;
1249
- }
1250
-
1251
- assert.ok(actual);
1252
- assert.ok(actual!.signatures);
1253
- assert.ok(expected.activeParameters);
1254
- assert.equal(actual!.signatures.length, expected.activeParameters.length);
1255
-
1256
- actual!.signatures.forEach((sig, index) => {
1257
- const expectedSig = expected.signatures![index];
1258
- assert.equal(sig.label, expectedSig.label);
1259
-
1260
- assert.ok(sig.parameters);
1261
- const actualParameters: string[] = [];
1262
-
1263
- sig.parameters!.forEach((p) => {
1264
- actualParameters.push(sig.label.substring(p.startOffset, p.endOffset));
1265
- });
1266
-
1267
- assert.deepEqual(actualParameters, expectedSig.parameters);
1268
-
1269
- if (expectedSig.documentation === undefined) {
1270
- assert.equal(sig.documentation, undefined);
1271
- } else {
1272
- assert.deepEqual(sig.documentation, {
1273
- kind: docFormat,
1274
- value: expectedSig.documentation,
1275
- });
1276
- }
1277
- });
1278
-
1279
- assert.deepEqual(
1280
- actual!.signatures.map((sig) => sig.activeParameter),
1281
- expected.activeParameters
1282
- );
1283
-
1284
- if (expected.callHasParameters !== undefined) {
1285
- assert.equal(actual.callHasParameters, expected.callHasParameters);
1286
- }
1287
- }
1288
- }
1289
-
1290
- verifyFindAllReferences(map: {
1291
- [marker: string]: {
1292
- references: DocumentRange[];
1293
- };
1294
- }) {
1295
- this._analyze();
1296
-
1297
- for (const marker of this.getMarkers()) {
1298
- const fileName = marker.fileName;
1299
- const name = this.getMarkerName(marker);
1300
-
1301
- if (!(name in map)) {
1302
- continue;
1303
- }
1304
-
1305
- const expected = map[name].references;
1306
-
1307
- const position = this.convertOffsetToPosition(fileName, marker.position);
1308
-
1309
- const actual: DocumentRange[] = [];
1310
- this.program.reportReferencesForPosition(
1311
- fileName,
1312
- position,
1313
- true,
1314
- (locs) => appendArray(actual, locs),
1315
- CancellationToken.None
1316
- );
1317
-
1318
- assert.strictEqual(actual?.length ?? 0, expected.length, `${name} has failed`);
1319
-
1320
- for (const r of expected) {
1321
- assert.equal(actual?.filter((d) => this._deepEqual(d, r)).length, 1);
1322
- }
1323
- }
1324
- }
1325
-
1326
- getDocumentHighlightKind(m?: Marker): DocumentHighlightKind | undefined {
1327
- const kind = m?.data ? ((m.data as any).kind as string) : undefined;
1328
- switch (kind) {
1329
- case 'text':
1330
- return DocumentHighlightKind.Text;
1331
- case 'read':
1332
- return DocumentHighlightKind.Read;
1333
- case 'write':
1334
- return DocumentHighlightKind.Write;
1335
- default:
1336
- return undefined;
1337
- }
1338
- }
1339
-
1340
- verifyHighlightReferences(map: {
1341
- [marker: string]: {
1342
- references: DocumentHighlight[];
1343
- };
1344
- }) {
1345
- this._analyze();
1346
-
1347
- for (const name of Object.keys(map)) {
1348
- const marker = this.getMarkerByName(name);
1349
- const fileName = marker.fileName;
1350
-
1351
- const expected = map[name].references;
1352
-
1353
- const position = this.convertOffsetToPosition(fileName, marker.position);
1354
- const actual = this.program.getDocumentHighlight(fileName, position, CancellationToken.None);
1355
-
1356
- assert.equal(actual?.length ?? 0, expected.length);
1357
-
1358
- for (const r of expected) {
1359
- const match = actual?.filter((h) => this._deepEqual(h.range, r.range));
1360
- assert.equal(match?.length, 1);
1361
-
1362
- if (r.kind) {
1363
- assert.equal(match![0].kind, r.kind);
1364
- }
1365
- }
1366
- }
1367
- }
1368
-
1369
- verifyFindDefinitions(
1370
- map: {
1371
- [marker: string]: {
1372
- definitions: DocumentRange[];
1373
- };
1374
- },
1375
- filter: DefinitionFilter = DefinitionFilter.All
1376
- ) {
1377
- this._analyze();
1378
-
1379
- for (const marker of this.getMarkers()) {
1380
- const fileName = marker.fileName;
1381
- const name = this.getMarkerName(marker);
1382
-
1383
- if (!(name in map)) {
1384
- continue;
1385
- }
1386
-
1387
- const expected = map[name].definitions;
1388
-
1389
- const position = this.convertOffsetToPosition(fileName, marker.position);
1390
- const actual = this.program.getDefinitionsForPosition(fileName, position, filter, CancellationToken.None);
1391
-
1392
- assert.equal(actual?.length ?? 0, expected.length);
1393
-
1394
- for (const r of expected) {
1395
- assert.equal(actual?.filter((d) => this._deepEqual(d, r)).length, 1);
1396
- }
1397
- }
1398
- }
1399
-
1400
- verifyFindTypeDefinitions(map: {
1401
- [marker: string]: {
1402
- definitions: DocumentRange[];
1403
- };
1404
- }) {
1405
- this._analyze();
1406
-
1407
- for (const marker of this.getMarkers()) {
1408
- const fileName = marker.fileName;
1409
- const name = this.getMarkerName(marker);
1410
-
1411
- if (!(name in map)) {
1412
- continue;
1413
- }
1414
-
1415
- const expected = map[name].definitions;
1416
-
1417
- const position = this.convertOffsetToPosition(fileName, marker.position);
1418
- const actual = this.program.getTypeDefinitionsForPosition(fileName, position, CancellationToken.None);
1419
-
1420
- assert.strictEqual(actual?.length ?? 0, expected.length, name);
1421
-
1422
- for (const r of expected) {
1423
- assert.strictEqual(actual?.filter((d) => this._deepEqual(d, r)).length, 1, name);
1424
- }
1425
- }
1426
- }
1427
-
1428
- verifyRename(map: {
1429
- [marker: string]: {
1430
- newName: string;
1431
- changes: FileEditAction[];
1432
- };
1433
- }) {
1434
- this._analyze();
1435
-
1436
- for (const marker of this.getMarkers()) {
1437
- const fileName = marker.fileName;
1438
- const name = this.getMarkerName(marker);
1439
-
1440
- if (!(name in map)) {
1441
- continue;
1442
- }
1443
-
1444
- const expected = map[name];
1445
-
1446
- const position = this.convertOffsetToPosition(fileName, marker.position);
1447
- const actual = this.program.renameSymbolAtPosition(
1448
- fileName,
1449
- position,
1450
- expected.newName,
1451
- /* isDefaultWorkspace */ false,
1452
- /* allowModuleRename */ false,
1453
- CancellationToken.None
1454
- );
1455
-
1456
- assert.equal(actual?.edits.length ?? 0, expected.changes.length);
1457
-
1458
- for (const c of expected.changes) {
1459
- assert.equal(actual?.edits.filter((e) => this._deepEqual(e, c)).length, 1);
1460
- }
1461
- }
1462
- }
1463
-
1464
- setCancelled(numberOfCalls: number): void {
1465
- this._cancellationToken.setCancelled(numberOfCalls);
1466
- }
1467
-
1468
- resetCancelled(): void {
1469
- this._cancellationToken.resetCancelled();
1470
- }
1471
-
1472
- private _isConfig(file: FourSlashFile, ignoreCase: boolean): boolean {
1473
- const comparer = getStringComparer(ignoreCase);
1474
- return configFileNames.some((f) => comparer(getBaseFileName(file.fileName), f) === Comparison.EqualTo);
1475
- }
1476
-
1477
- private _convertGlobalOptionsToConfigOptions(
1478
- globalOptions: CompilerSettings,
1479
- mountPaths?: Map<string, string>
1480
- ): ConfigOptions {
1481
- const srtRoot: string = GlobalMetadataOptionNames.projectRoot;
1482
- const projectRoot = normalizeSlashes(globalOptions[srtRoot] ?? vfs.MODULE_PATH);
1483
- const configOptions = new ConfigOptions(projectRoot);
1484
-
1485
- // add more global options as we need them
1486
- return this._applyTestConfigOptions(configOptions, mountPaths);
1487
- }
1488
-
1489
- private _applyTestConfigOptions(configOptions: ConfigOptions, mountPaths?: Map<string, string>) {
1490
- // Always enable "test mode".
1491
- configOptions.internalTestMode = true;
1492
-
1493
- // Always analyze all files
1494
- configOptions.checkOnlyOpenFiles = false;
1495
-
1496
- // make sure we set typing path
1497
- if (configOptions.stubPath === undefined) {
1498
- configOptions.stubPath = normalizePath(combinePaths(vfs.MODULE_PATH, 'typings'));
1499
- }
1500
-
1501
- configOptions.include.push(getFileSpec(this.fs, configOptions.projectRoot, '.'));
1502
- configOptions.exclude.push(getFileSpec(this.fs, configOptions.projectRoot, typeshedFolder));
1503
- configOptions.exclude.push(getFileSpec(this.fs, configOptions.projectRoot, distlibFolder));
1504
- configOptions.exclude.push(getFileSpec(this.fs, configOptions.projectRoot, libFolder));
1505
-
1506
- if (mountPaths) {
1507
- for (const mountPath of mountPaths.keys()) {
1508
- configOptions.exclude.push(getFileSpec(this.fs, configOptions.projectRoot, mountPath));
1509
- }
1510
- }
1511
-
1512
- return configOptions;
1513
- }
1514
-
1515
- private _getFileContent(fileName: string): string {
1516
- const files = this.testData.files.filter(
1517
- (f) => comparePaths(f.fileName, fileName, this.testFS.ignoreCase) === Comparison.EqualTo
1518
- );
1519
- return files[0].content;
1520
- }
1521
-
1522
- protected convertPositionToOffset(fileName: string, position: Position): number {
1523
- const lines = this._getTextRangeCollection(fileName);
1524
- return convertPositionToOffset(position, lines)!;
1525
- }
1526
-
1527
- protected convertOffsetToPosition(fileName: string, offset: number): Position {
1528
- const lines = this._getTextRangeCollection(fileName);
1529
-
1530
- return convertOffsetToPosition(offset, lines);
1531
- }
1532
-
1533
- protected convertOffsetsToRange(fileName: string, startOffset: number, endOffset: number): PositionRange {
1534
- const lines = this._getTextRangeCollection(fileName);
1535
-
1536
- return {
1537
- start: convertOffsetToPosition(startOffset, lines),
1538
- end: convertOffsetToPosition(endOffset, lines),
1539
- };
1540
- }
1541
-
1542
- private _getParseResult(fileName: string) {
1543
- const file = this.program.getBoundSourceFile(fileName)!;
1544
- return file.getParseResults()!;
1545
- }
1546
-
1547
- private _getTextRangeCollection(fileName: string): TextRangeCollection<TextRange> {
1548
- if (fileName in this._files) {
1549
- return this._getParseResult(fileName).tokenizerOutput.lines;
1550
- }
1551
-
1552
- // slow path
1553
- const fileContents = this.fs.readFileSync(fileName, 'utf8');
1554
- const tokenizer = new Tokenizer();
1555
- return tokenizer.tokenize(fileContents).lines;
1556
- }
1557
-
1558
- protected raiseError(message: string): never {
1559
- throw new Error(this._messageAtLastKnownMarker(message));
1560
- }
1561
-
1562
- private _messageAtLastKnownMarker(message: string) {
1563
- const locationDescription = this.lastKnownMarker
1564
- ? this.lastKnownMarker
1565
- : this._getLineColStringAtPosition(this.currentCaretPosition);
1566
- return `At ${locationDescription}: ${message}`;
1567
- }
1568
-
1569
- private _checkPostEditInvariants() {
1570
- // blank for now
1571
- }
1572
-
1573
- private _editScriptAndUpdateMarkers(fileName: string, editStart: number, editEnd: number, newText: string) {
1574
- // this.languageServiceAdapterHost.editScript(fileName, editStart, editEnd, newText);
1575
- for (const marker of this.testData.markers) {
1576
- if (marker.fileName === fileName) {
1577
- marker.position = this._updatePosition(marker.position, editStart, editEnd, newText);
1578
- }
1579
- }
1580
-
1581
- for (const range of this.testData.ranges) {
1582
- if (range.fileName === fileName) {
1583
- range.pos = this._updatePosition(range.pos, editStart, editEnd, newText);
1584
- range.end = this._updatePosition(range.end, editStart, editEnd, newText);
1585
- }
1586
- }
1587
- this.testData.rangesByText = undefined;
1588
- }
1589
-
1590
- private _removeWhitespace(text: string): string {
1591
- return text.replace(/\s/g, '');
1592
- }
1593
-
1594
- protected createMultiMap<T>(values?: T[], getKey?: (t: T) => string): MultiMap<T> {
1595
- const map = new Map<string, T[]>() as MultiMap<T>;
1596
- map.add = multiMapAdd;
1597
- map.remove = multiMapRemove;
1598
-
1599
- if (values && getKey) {
1600
- for (const value of values) {
1601
- map.add(getKey(value), value);
1602
- }
1603
- }
1604
-
1605
- return map;
1606
-
1607
- function multiMapAdd<T>(this: MultiMap<T>, key: string, value: T) {
1608
- let values = this.get(key);
1609
- if (values) {
1610
- values.push(value);
1611
- } else {
1612
- this.set(key, (values = [value]));
1613
- }
1614
- return values;
1615
- }
1616
-
1617
- function multiMapRemove<T>(this: MultiMap<T>, key: string, value: T) {
1618
- const values = this.get(key);
1619
- if (values) {
1620
- values.forEach((v, i, arr) => {
1621
- if (v === value) {
1622
- arr.splice(i, 1);
1623
- }
1624
- });
1625
- if (!values.length) {
1626
- this.delete(key);
1627
- }
1628
- }
1629
- }
1630
- }
1631
-
1632
- protected _rangeText({ fileName, pos, end }: Range): string {
1633
- return this._getFileContent(fileName).slice(pos, end);
1634
- }
1635
-
1636
- private _getOnlyRange() {
1637
- const ranges = this.getRanges();
1638
- if (ranges.length !== 1) {
1639
- this.raiseError('Exactly one range should be specified in the test file.');
1640
- }
1641
-
1642
- return ranges[0];
1643
- }
1644
-
1645
- private _verifyFileContent(fileName: string, text: string) {
1646
- const actual = this._getFileContent(fileName);
1647
- if (actual !== text) {
1648
- throw new Error(`verifyFileContent failed:\n${this._showTextDiff(text, actual)}`);
1649
- }
1650
- }
1651
-
1652
- private _verifyTextMatches(actualText: string, includeWhitespace: boolean, expectedText: string) {
1653
- const removeWhitespace = (s: string): string => (includeWhitespace ? s : this._removeWhitespace(s));
1654
- if (removeWhitespace(actualText) !== removeWhitespace(expectedText)) {
1655
- this.raiseError(
1656
- `Actual range text doesn't match expected text.\n${this._showTextDiff(expectedText, actualText)}`
1657
- );
1658
- }
1659
- }
1660
-
1661
- private _getSelection(): TextRange {
1662
- return TextRange.fromBounds(
1663
- this.currentCaretPosition,
1664
- this.selectionEnd === -1 ? this.currentCaretPosition : this.selectionEnd
1665
- );
1666
- }
1667
-
1668
- private _getLineContent(index: number) {
1669
- const text = this._getFileContent(this.activeFile.fileName);
1670
- const pos = this.convertPositionToOffset(this.activeFile.fileName, { line: index, character: 0 });
1671
- let startPos = pos;
1672
- let endPos = pos;
1673
-
1674
- while (startPos > 0) {
1675
- const ch = text.charCodeAt(startPos - 1);
1676
- if (ch === Char.CarriageReturn || ch === Char.LineFeed) {
1677
- break;
1678
- }
1679
-
1680
- startPos--;
1681
- }
1682
-
1683
- while (endPos < text.length) {
1684
- const ch = text.charCodeAt(endPos);
1685
-
1686
- if (ch === Char.CarriageReturn || ch === Char.LineFeed) {
1687
- break;
1688
- }
1689
-
1690
- endPos++;
1691
- }
1692
-
1693
- return text.substring(startPos, endPos);
1694
- }
1695
-
1696
- // Get the text of the entire line the caret is currently at
1697
- private _getCurrentLineContent() {
1698
- return this._getLineContent(
1699
- this.convertOffsetToPosition(this.activeFile.fileName, this.currentCaretPosition).line
1700
- );
1701
- }
1702
-
1703
- private _findFile(indexOrName: string | number): FourSlashFile {
1704
- if (typeof indexOrName === 'number') {
1705
- const index = indexOrName;
1706
- if (index >= this.testData.files.length) {
1707
- throw new Error(
1708
- `File index (${index}) in openFile was out of range. There are only ${this.testData.files.length} files in this test.`
1709
- );
1710
- } else {
1711
- return this.testData.files[index];
1712
- }
1713
- } else if (isString(indexOrName)) {
1714
- const { file, availableNames } = this._tryFindFileWorker(indexOrName);
1715
- if (!file) {
1716
- throw new Error(
1717
- `No test file named "${indexOrName}" exists. Available file names are: ${availableNames.join(', ')}`
1718
- );
1719
- }
1720
- return file;
1721
- } else {
1722
- return debug.assertNever(indexOrName);
1723
- }
1724
- }
1725
-
1726
- private _tryFindFileWorker(name: string): {
1727
- readonly file: FourSlashFile | undefined;
1728
- readonly availableNames: readonly string[];
1729
- } {
1730
- name = normalizePath(name);
1731
-
1732
- let file: FourSlashFile | undefined;
1733
- const availableNames: string[] = [];
1734
- this.testData.files.forEach((f) => {
1735
- const fn = normalizePath(f.fileName);
1736
- if (fn) {
1737
- if (fn === name) {
1738
- file = f;
1739
- }
1740
-
1741
- availableNames.push(fn);
1742
- }
1743
- });
1744
-
1745
- assert.ok(file);
1746
- return { file, availableNames };
1747
- }
1748
-
1749
- private _getLineColStringAtPosition(position: number, file: FourSlashFile = this.activeFile) {
1750
- const pos = this.convertOffsetToPosition(file.fileName, position);
1751
- return `line ${pos.line + 1}, col ${pos.character}`;
1752
- }
1753
-
1754
- private _showTextDiff(expected: string, actual: string): string {
1755
- // Only show whitespace if the difference is whitespace-only.
1756
- if (this._differOnlyByWhitespace(expected, actual)) {
1757
- expected = this._makeWhitespaceVisible(expected);
1758
- actual = this._makeWhitespaceVisible(actual);
1759
- }
1760
- return this._displayExpectedAndActualString(expected, actual);
1761
- }
1762
-
1763
- private _differOnlyByWhitespace(a: string, b: string) {
1764
- return this._removeWhitespace(a) === this._removeWhitespace(b);
1765
- }
1766
-
1767
- private _displayExpectedAndActualString(expected: string, actual: string, quoted = false) {
1768
- const expectMsg = '\x1b[1mExpected\x1b[0m\x1b[31m';
1769
- const actualMsg = '\x1b[1mActual\x1b[0m\x1b[31m';
1770
- const expectedString = quoted ? '"' + expected + '"' : expected;
1771
- const actualString = quoted ? '"' + actual + '"' : actual;
1772
- return `\n${expectMsg}:\n${expectedString}\n\n${actualMsg}:\n${actualString}`;
1773
- }
1774
-
1775
- private _makeWhitespaceVisible(text: string) {
1776
- return text
1777
- .replace(/ /g, '\u00B7')
1778
- .replace(/\r/g, '\u00B6')
1779
- .replace(/\n/g, '\u2193\n')
1780
- .replace(/\t/g, '\u2192 ');
1781
- }
1782
-
1783
- private _updatePosition(position: number, editStart: number, editEnd: number, { length }: string): number {
1784
- // If inside the edit, return -1 to mark as invalid
1785
- return position <= editStart ? position : position < editEnd ? -1 : position + length - +(editEnd - editStart);
1786
- }
1787
-
1788
- private _analyze() {
1789
- while (this.program.analyze()) {
1790
- // Continue to call analyze until it completes. Since we're not
1791
- // specifying a timeout, it should complete the first time.
1792
- }
1793
- }
1794
-
1795
- private _getDiagnosticsPerFile() {
1796
- const sourceFiles = this._files.map((f) => this.program.getSourceFile(f));
1797
- const results = sourceFiles.map((sourceFile, index) => {
1798
- if (sourceFile) {
1799
- const diagnostics = sourceFile.getDiagnostics(this.configOptions) || [];
1800
- const filePath = sourceFile.getFilePath();
1801
- const value = {
1802
- filePath,
1803
- parseResults: sourceFile.getParseResults(),
1804
- errors: diagnostics.filter((diag) => diag.category === DiagnosticCategory.Error),
1805
- warnings: diagnostics.filter((diag) => diag.category === DiagnosticCategory.Warning),
1806
- information: diagnostics.filter((diag) => diag.category === DiagnosticCategory.Information),
1807
- };
1808
- return [filePath, value] as [string, typeof value];
1809
- } else {
1810
- this.raiseError(`Source file not found for ${this._files[index]}`);
1811
- }
1812
- });
1813
-
1814
- return new Map<string, typeof results[0][1]>(results);
1815
- }
1816
-
1817
- private _createAnalysisService(
1818
- nullConsole: ConsoleInterface,
1819
- importResolverFactory: ImportResolverFactory,
1820
- configOptions: ConfigOptions
1821
- ) {
1822
- // we do not initiate automatic analysis or file watcher in test.
1823
- const service = new AnalyzerService(
1824
- 'test service',
1825
- this.fs,
1826
- nullConsole,
1827
- () => testAccessHost,
1828
- importResolverFactory,
1829
- configOptions
1830
- );
1831
-
1832
- // directly set files to track rather than using fileSpec from config
1833
- // to discover those files from file system
1834
- service.test_program.setTrackedFiles(
1835
- this._files
1836
- .filter((path) => {
1837
- const fileExtension = getFileExtension(path).toLowerCase();
1838
- return fileExtension === '.py' || fileExtension === '.pyi';
1839
- })
1840
- .filter((path) => service.isTracked(path))
1841
- );
1842
-
1843
- return service;
1844
- }
1845
-
1846
- private _deepEqual(a: any, e: any) {
1847
- try {
1848
- // NOTE: find better way.
1849
- assert.deepStrictEqual(a, e);
1850
- } catch {
1851
- return false;
1852
- }
1853
-
1854
- return true;
1855
- }
1856
-
1857
- private async _waitForFile(filePath: string) {
1858
- while (!this.fs.existsSync(filePath)) {
1859
- await new Promise<void>((res) =>
1860
- setTimeout(() => {
1861
- res();
1862
- }, 200)
1863
- );
1864
- }
1865
- }
1866
-
1867
- private _getCodeActions(range: Range) {
1868
- const file = range.fileName;
1869
- const textRange = {
1870
- start: this.convertOffsetToPosition(file, range.pos),
1871
- end: this.convertOffsetToPosition(file, range.end),
1872
- };
1873
-
1874
- return this._hostSpecificFeatures.getCodeActionsForPosition(
1875
- this.workspace,
1876
- file,
1877
- textRange,
1878
- CancellationToken.None
1879
- );
1880
- }
1881
-
1882
- private async _verifyFiles(files: { [filePath: string]: string }) {
1883
- for (const filePath of Object.keys(files)) {
1884
- const expected = files[filePath];
1885
- const normalizedFilePath = normalizeSlashes(filePath);
1886
-
1887
- // wait until the file exists
1888
- await this._waitForFile(normalizedFilePath);
1889
-
1890
- const actual = this.fs.readFileSync(normalizedFilePath, 'utf8');
1891
- if (actual !== expected) {
1892
- this.raiseError(
1893
- `doesn't contain expected result: ${stringify(expected)}, actual: ${stringify(actual)}`
1894
- );
1895
- }
1896
- }
1897
- }
1898
-
1899
- private _editsAreEqual(actual: TextEdit | undefined, expected: TextEdit | undefined) {
1900
- if (actual === expected) {
1901
- return true;
1902
- }
1903
-
1904
- if (actual === undefined || expected === undefined) {
1905
- return false;
1906
- }
1907
-
1908
- return rangesAreEqual(actual.range, expected.range) && actual.newText === expected.newText;
1909
- }
1910
-
1911
- private _verifyEdit(actual: TextEdit | undefined, expected: TextEdit | undefined) {
1912
- if (!this._editsAreEqual(actual, expected)) {
1913
- this.raiseError(`doesn't contain expected result: ${stringify(expected)}, actual: ${stringify(actual)}`);
1914
- }
1915
- }
1916
-
1917
- private _verifyEdits(actual: TextEdit[] | undefined, expected: TextEdit[] | undefined) {
1918
- actual = actual ?? [];
1919
- expected = expected ?? [];
1920
-
1921
- let extra = expected.slice(0);
1922
- let left = actual.slice(0);
1923
-
1924
- for (const item of actual) {
1925
- extra = extra.filter((e) => !this._editsAreEqual(e, item));
1926
- }
1927
-
1928
- for (const item of expected) {
1929
- left = left.filter((e) => !this._editsAreEqual(e, item));
1930
- }
1931
-
1932
- if (extra.length > 0 || left.length > 0) {
1933
- this.raiseError(`doesn't contain expected result: ${stringify(extra)}, actual: ${stringify(left)}`);
1934
- }
1935
- }
1936
-
1937
- protected verifyCompletionItem(expected: _.FourSlashCompletionItem, actual: CompletionItem) {
1938
- assert.strictEqual(actual.label, expected.label);
1939
- assert.strictEqual(actual.detail, expected.detail);
1940
- assert.strictEqual(actual.kind, expected.kind);
1941
-
1942
- assert.strictEqual(actual.insertText, expected.insertionText);
1943
- this._verifyEdit(actual.textEdit as TextEdit, expected.textEdit);
1944
- this._verifyEdits(actual.additionalTextEdits, expected.additionalTextEdits);
1945
-
1946
- if (expected.detailDescription !== undefined) {
1947
- assert.strictEqual(actual.labelDetails?.description, expected.detailDescription);
1948
- }
1949
- }
1950
- }
1951
-
1952
- export function parseAndGetTestState(code: string, projectRoot = '/', anonymousFileName = 'unnamedFile.py') {
1953
- const data = parseTestData(normalizeSlashes(projectRoot), code, anonymousFileName);
1954
- const state = new TestState(normalizeSlashes('/'), data);
1955
-
1956
- return { data, state };
1957
- }
1958
-
1959
- export function getNodeForRange(codeOrState: string | TestState, markerName = 'marker'): ParseNode {
1960
- const state = isString(codeOrState) ? parseAndGetTestState(codeOrState).state : codeOrState;
1961
- const range = state.getRangeByMarkerName(markerName);
1962
- assert(range);
1963
-
1964
- const textRange = TextRange.fromBounds(range.pos, range.end);
1965
-
1966
- const node = getNodeAtMarker(state, markerName);
1967
- let current: ParseNode | undefined = node;
1968
- while (current) {
1969
- if (TextRange.containsRange(current, textRange)) {
1970
- return current;
1971
- }
1972
-
1973
- current = current.parent;
1974
- }
1975
-
1976
- return node;
1977
- }
1978
-
1979
- export function getNodeAtMarker(codeOrState: string | TestState, markerName = 'marker'): ParseNode {
1980
- const state = isString(codeOrState) ? parseAndGetTestState(codeOrState).state : codeOrState;
1981
- const marker = state.getMarkerByName(markerName);
1982
-
1983
- const sourceFile = state.program.getBoundSourceFile(marker.fileName);
1984
- assert(sourceFile);
1985
-
1986
- const parserResults = sourceFile.getParseResults();
1987
- assert(parserResults);
1988
-
1989
- const node = findNodeByOffset(parserResults.parseTree, marker.position);
1990
- assert(node);
1991
-
1992
- return node;
1993
- }