@goast/kotlin 0.4.1 → 0.4.2-beta1

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 (492) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +45 -45
  3. package/assets/client/okhttp3/ApiClient.kt +250 -250
  4. package/esm/src/assets.js +1 -1
  5. package/esm/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  6. package/package.json +2 -2
  7. package/script/src/assets.js +1 -1
  8. package/script/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  9. package/esm/_dnt.test_polyfills.d.ts +0 -29
  10. package/esm/_dnt.test_polyfills.d.ts.map +0 -1
  11. package/esm/_dnt.test_polyfills.js +0 -31
  12. package/esm/_dnt.test_shims.d.ts +0 -6
  13. package/esm/_dnt.test_shims.d.ts.map +0 -1
  14. package/esm/_dnt.test_shims.js +0 -61
  15. package/esm/deps/jsr.io/@std/assert/1.0.6/assertion_error.d.ts +0 -26
  16. package/esm/deps/jsr.io/@std/assert/1.0.6/assertion_error.d.ts.map +0 -1
  17. package/esm/deps/jsr.io/@std/assert/1.0.6/assertion_error.js +0 -30
  18. package/esm/deps/jsr.io/@std/assert/1.0.6/equal.d.ts +0 -17
  19. package/esm/deps/jsr.io/@std/assert/1.0.6/equal.d.ts.map +0 -1
  20. package/esm/deps/jsr.io/@std/assert/1.0.6/equal.js +0 -136
  21. package/esm/deps/jsr.io/@std/assert/1.0.6/equals.d.ts +0 -22
  22. package/esm/deps/jsr.io/@std/assert/1.0.6/equals.d.ts.map +0 -1
  23. package/esm/deps/jsr.io/@std/assert/1.0.6/equals.js +0 -45
  24. package/esm/deps/jsr.io/@std/assert/1.0.6/false.d.ts +0 -18
  25. package/esm/deps/jsr.io/@std/assert/1.0.6/false.d.ts.map +0 -1
  26. package/esm/deps/jsr.io/@std/assert/1.0.6/false.js +0 -22
  27. package/esm/deps/jsr.io/@std/assert/1.0.6/instance_of.d.ts +0 -23
  28. package/esm/deps/jsr.io/@std/assert/1.0.6/instance_of.d.ts.map +0 -1
  29. package/esm/deps/jsr.io/@std/assert/1.0.6/instance_of.js +0 -53
  30. package/esm/deps/jsr.io/@std/assert/1.0.6/is_error.d.ts +0 -25
  31. package/esm/deps/jsr.io/@std/assert/1.0.6/is_error.d.ts.map +0 -1
  32. package/esm/deps/jsr.io/@std/assert/1.0.6/is_error.js +0 -54
  33. package/esm/deps/jsr.io/@std/assert/1.0.6/match.d.ts +0 -18
  34. package/esm/deps/jsr.io/@std/assert/1.0.6/match.d.ts.map +0 -1
  35. package/esm/deps/jsr.io/@std/assert/1.0.6/match.js +0 -26
  36. package/esm/deps/jsr.io/@std/assert/1.0.6/not_instance_of.d.ts +0 -20
  37. package/esm/deps/jsr.io/@std/assert/1.0.6/not_instance_of.d.ts.map +0 -1
  38. package/esm/deps/jsr.io/@std/assert/1.0.6/not_instance_of.js +0 -29
  39. package/esm/deps/jsr.io/@std/assert/1.0.6/not_match.d.ts +0 -18
  40. package/esm/deps/jsr.io/@std/assert/1.0.6/not_match.d.ts.map +0 -1
  41. package/esm/deps/jsr.io/@std/assert/1.0.6/not_match.js +0 -26
  42. package/esm/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.d.ts +0 -23
  43. package/esm/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.d.ts.map +0 -1
  44. package/esm/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.js +0 -32
  45. package/esm/deps/jsr.io/@std/assert/1.0.6/object_match.d.ts +0 -28
  46. package/esm/deps/jsr.io/@std/assert/1.0.6/object_match.d.ts.map +0 -1
  47. package/esm/deps/jsr.io/@std/assert/1.0.6/object_match.js +0 -159
  48. package/esm/deps/jsr.io/@std/assert/1.0.6/rejects.d.ts +0 -42
  49. package/esm/deps/jsr.io/@std/assert/1.0.6/rejects.d.ts.map +0 -1
  50. package/esm/deps/jsr.io/@std/assert/1.0.6/rejects.js +0 -53
  51. package/esm/deps/jsr.io/@std/assert/1.0.6/strict_equals.d.ts +0 -24
  52. package/esm/deps/jsr.io/@std/assert/1.0.6/strict_equals.d.ts.map +0 -1
  53. package/esm/deps/jsr.io/@std/assert/1.0.6/strict_equals.js +0 -57
  54. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_equals.d.ts +0 -20
  55. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_equals.d.ts.map +0 -1
  56. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_equals.js +0 -29
  57. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.d.ts +0 -17
  58. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.d.ts.map +0 -1
  59. package/esm/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.js +0 -26
  60. package/esm/deps/jsr.io/@std/expect/1.0.6/_assertion.d.ts +0 -3
  61. package/esm/deps/jsr.io/@std/expect/1.0.6/_assertion.d.ts.map +0 -1
  62. package/esm/deps/jsr.io/@std/expect/1.0.6/_assertion.js +0 -9
  63. package/esm/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.d.ts +0 -41
  64. package/esm/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.d.ts.map +0 -1
  65. package/esm/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.js +0 -143
  66. package/esm/deps/jsr.io/@std/expect/1.0.6/_build_message.d.ts +0 -6
  67. package/esm/deps/jsr.io/@std/expect/1.0.6/_build_message.d.ts.map +0 -1
  68. package/esm/deps/jsr.io/@std/expect/1.0.6/_build_message.js +0 -29
  69. package/esm/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.d.ts +0 -4
  70. package/esm/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.d.ts.map +0 -1
  71. package/esm/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.js +0 -11
  72. package/esm/deps/jsr.io/@std/expect/1.0.6/_equal.d.ts +0 -9
  73. package/esm/deps/jsr.io/@std/expect/1.0.6/_equal.d.ts.map +0 -1
  74. package/esm/deps/jsr.io/@std/expect/1.0.6/_equal.js +0 -191
  75. package/esm/deps/jsr.io/@std/expect/1.0.6/_extend.d.ts +0 -4
  76. package/esm/deps/jsr.io/@std/expect/1.0.6/_extend.d.ts.map +0 -1
  77. package/esm/deps/jsr.io/@std/expect/1.0.6/_extend.js +0 -11
  78. package/esm/deps/jsr.io/@std/expect/1.0.6/_inspect_args.d.ts +0 -3
  79. package/esm/deps/jsr.io/@std/expect/1.0.6/_inspect_args.d.ts.map +0 -1
  80. package/esm/deps/jsr.io/@std/expect/1.0.6/_inspect_args.js +0 -12
  81. package/esm/deps/jsr.io/@std/expect/1.0.6/_matchers.d.ts +0 -34
  82. package/esm/deps/jsr.io/@std/expect/1.0.6/_matchers.d.ts.map +0 -1
  83. package/esm/deps/jsr.io/@std/expect/1.0.6/_matchers.js +0 -564
  84. package/esm/deps/jsr.io/@std/expect/1.0.6/_mock_util.d.ts +0 -11
  85. package/esm/deps/jsr.io/@std/expect/1.0.6/_mock_util.d.ts.map +0 -1
  86. package/esm/deps/jsr.io/@std/expect/1.0.6/_mock_util.js +0 -10
  87. package/esm/deps/jsr.io/@std/expect/1.0.6/_types.d.ts +0 -838
  88. package/esm/deps/jsr.io/@std/expect/1.0.6/_types.d.ts.map +0 -1
  89. package/esm/deps/jsr.io/@std/expect/1.0.6/_types.js +0 -3
  90. package/esm/deps/jsr.io/@std/expect/1.0.6/_utils.d.ts +0 -8
  91. package/esm/deps/jsr.io/@std/expect/1.0.6/_utils.d.ts.map +0 -1
  92. package/esm/deps/jsr.io/@std/expect/1.0.6/_utils.js +0 -159
  93. package/esm/deps/jsr.io/@std/expect/1.0.6/expect.d.ts +0 -52
  94. package/esm/deps/jsr.io/@std/expect/1.0.6/expect.d.ts.map +0 -1
  95. package/esm/deps/jsr.io/@std/expect/1.0.6/expect.js +0 -441
  96. package/esm/deps/jsr.io/@std/internal/1.0.4/assertion_state.d.ts +0 -75
  97. package/esm/deps/jsr.io/@std/internal/1.0.4/assertion_state.d.ts.map +0 -1
  98. package/esm/deps/jsr.io/@std/internal/1.0.4/assertion_state.js +0 -101
  99. package/esm/deps/jsr.io/@std/internal/1.0.4/build_message.d.ts +0 -82
  100. package/esm/deps/jsr.io/@std/internal/1.0.4/build_message.d.ts.map +0 -1
  101. package/esm/deps/jsr.io/@std/internal/1.0.4/build_message.js +0 -111
  102. package/esm/deps/jsr.io/@std/internal/1.0.4/diff.d.ts +0 -140
  103. package/esm/deps/jsr.io/@std/internal/1.0.4/diff.d.ts.map +0 -1
  104. package/esm/deps/jsr.io/@std/internal/1.0.4/diff.js +0 -277
  105. package/esm/deps/jsr.io/@std/internal/1.0.4/diff_str.d.ts +0 -99
  106. package/esm/deps/jsr.io/@std/internal/1.0.4/diff_str.d.ts.map +0 -1
  107. package/esm/deps/jsr.io/@std/internal/1.0.4/diff_str.js +0 -180
  108. package/esm/deps/jsr.io/@std/internal/1.0.4/format.d.ts +0 -2
  109. package/esm/deps/jsr.io/@std/internal/1.0.4/format.d.ts.map +0 -1
  110. package/esm/deps/jsr.io/@std/internal/1.0.4/format.js +0 -37
  111. package/esm/deps/jsr.io/@std/internal/1.0.4/styles.d.ts +0 -159
  112. package/esm/deps/jsr.io/@std/internal/1.0.4/styles.d.ts.map +0 -1
  113. package/esm/deps/jsr.io/@std/internal/1.0.4/styles.js +0 -207
  114. package/esm/deps/jsr.io/@std/internal/1.0.4/types.d.ts +0 -16
  115. package/esm/deps/jsr.io/@std/internal/1.0.4/types.d.ts.map +0 -1
  116. package/esm/deps/jsr.io/@std/internal/1.0.4/types.js +0 -2
  117. package/esm/deps/jsr.io/@std/testing/1.0.3/_test_suite.d.ts +0 -74
  118. package/esm/deps/jsr.io/@std/testing/1.0.3/_test_suite.d.ts.map +0 -1
  119. package/esm/deps/jsr.io/@std/testing/1.0.3/_test_suite.js +0 -340
  120. package/esm/deps/jsr.io/@std/testing/1.0.3/bdd.d.ts +0 -731
  121. package/esm/deps/jsr.io/@std/testing/1.0.3/bdd.d.ts.map +0 -1
  122. package/esm/deps/jsr.io/@std/testing/1.0.3/bdd.js +0 -576
  123. package/esm/deps/jsr.io/@std/testing/1.0.3/mock.d.ts +0 -674
  124. package/esm/deps/jsr.io/@std/testing/1.0.3/mock.d.ts.map +0 -1
  125. package/esm/deps/jsr.io/@std/testing/1.0.3/mock.js +0 -1117
  126. package/esm/src/ast/nodes/annotation.test.d.ts +0 -2
  127. package/esm/src/ast/nodes/annotation.test.d.ts.map +0 -1
  128. package/esm/src/ast/nodes/annotation.test.js +0 -56
  129. package/esm/src/ast/nodes/argument.test.d.ts +0 -2
  130. package/esm/src/ast/nodes/argument.test.d.ts.map +0 -1
  131. package/esm/src/ast/nodes/argument.test.js +0 -33
  132. package/esm/src/ast/nodes/call.test.d.ts +0 -2
  133. package/esm/src/ast/nodes/call.test.d.ts.map +0 -1
  134. package/esm/src/ast/nodes/call.test.js +0 -35
  135. package/esm/src/ast/nodes/class.test.d.ts +0 -2
  136. package/esm/src/ast/nodes/class.test.d.ts.map +0 -1
  137. package/esm/src/ast/nodes/class.test.js +0 -219
  138. package/esm/src/ast/nodes/constructor.test.d.ts +0 -2
  139. package/esm/src/ast/nodes/constructor.test.d.ts.map +0 -1
  140. package/esm/src/ast/nodes/constructor.test.js +0 -139
  141. package/esm/src/ast/nodes/doc-tag.test.d.ts +0 -2
  142. package/esm/src/ast/nodes/doc-tag.test.d.ts.map +0 -1
  143. package/esm/src/ast/nodes/doc-tag.test.js +0 -67
  144. package/esm/src/ast/nodes/doc.test.d.ts +0 -2
  145. package/esm/src/ast/nodes/doc.test.d.ts.map +0 -1
  146. package/esm/src/ast/nodes/doc.test.js +0 -33
  147. package/esm/src/ast/nodes/enum-value.test.d.ts +0 -2
  148. package/esm/src/ast/nodes/enum-value.test.d.ts.map +0 -1
  149. package/esm/src/ast/nodes/enum-value.test.js +0 -115
  150. package/esm/src/ast/nodes/enum.test.d.ts +0 -2
  151. package/esm/src/ast/nodes/enum.test.d.ts.map +0 -1
  152. package/esm/src/ast/nodes/enum.test.js +0 -129
  153. package/esm/src/ast/nodes/function.test.d.ts +0 -2
  154. package/esm/src/ast/nodes/function.test.d.ts.map +0 -1
  155. package/esm/src/ast/nodes/function.test.js +0 -160
  156. package/esm/src/ast/nodes/generic-parameter.test.d.ts +0 -2
  157. package/esm/src/ast/nodes/generic-parameter.test.d.ts.map +0 -1
  158. package/esm/src/ast/nodes/generic-parameter.test.js +0 -49
  159. package/esm/src/ast/nodes/init-block.test.d.ts +0 -2
  160. package/esm/src/ast/nodes/init-block.test.d.ts.map +0 -1
  161. package/esm/src/ast/nodes/init-block.test.js +0 -28
  162. package/esm/src/ast/nodes/interface.test.d.ts +0 -2
  163. package/esm/src/ast/nodes/interface.test.d.ts.map +0 -1
  164. package/esm/src/ast/nodes/interface.test.js +0 -121
  165. package/esm/src/ast/nodes/object.test.d.ts +0 -2
  166. package/esm/src/ast/nodes/object.test.d.ts.map +0 -1
  167. package/esm/src/ast/nodes/object.test.js +0 -78
  168. package/esm/src/ast/nodes/parameter.test.d.ts +0 -2
  169. package/esm/src/ast/nodes/parameter.test.d.ts.map +0 -1
  170. package/esm/src/ast/nodes/parameter.test.js +0 -152
  171. package/esm/src/ast/nodes/property.test.d.ts +0 -2
  172. package/esm/src/ast/nodes/property.test.d.ts.map +0 -1
  173. package/esm/src/ast/nodes/property.test.js +0 -206
  174. package/esm/src/ast/nodes/reference.test.d.ts +0 -2
  175. package/esm/src/ast/nodes/reference.test.d.ts.map +0 -1
  176. package/esm/src/ast/nodes/reference.test.js +0 -36
  177. package/esm/src/ast/nodes/string.test.d.ts +0 -2
  178. package/esm/src/ast/nodes/string.test.d.ts.map +0 -1
  179. package/esm/src/ast/nodes/string.test.js +0 -48
  180. package/esm/src/import-collection.test.d.ts +0 -2
  181. package/esm/src/import-collection.test.d.ts.map +0 -1
  182. package/esm/src/import-collection.test.js +0 -99
  183. package/esm/tests/openapi-models.test.d.ts +0 -2
  184. package/esm/tests/openapi-models.test.d.ts.map +0 -1
  185. package/esm/tests/openapi-models.test.js +0 -45
  186. package/script/_dnt.test_polyfills.d.ts +0 -29
  187. package/script/_dnt.test_polyfills.d.ts.map +0 -1
  188. package/script/_dnt.test_polyfills.js +0 -32
  189. package/script/_dnt.test_shims.d.ts +0 -6
  190. package/script/_dnt.test_shims.d.ts.map +0 -1
  191. package/script/_dnt.test_shims.js +0 -65
  192. package/script/deps/jsr.io/@std/assert/1.0.6/assertion_error.d.ts +0 -26
  193. package/script/deps/jsr.io/@std/assert/1.0.6/assertion_error.d.ts.map +0 -1
  194. package/script/deps/jsr.io/@std/assert/1.0.6/assertion_error.js +0 -34
  195. package/script/deps/jsr.io/@std/assert/1.0.6/equal.d.ts +0 -17
  196. package/script/deps/jsr.io/@std/assert/1.0.6/equal.d.ts.map +0 -1
  197. package/script/deps/jsr.io/@std/assert/1.0.6/equal.js +0 -139
  198. package/script/deps/jsr.io/@std/assert/1.0.6/equals.d.ts +0 -22
  199. package/script/deps/jsr.io/@std/assert/1.0.6/equals.d.ts.map +0 -1
  200. package/script/deps/jsr.io/@std/assert/1.0.6/equals.js +0 -48
  201. package/script/deps/jsr.io/@std/assert/1.0.6/false.d.ts +0 -18
  202. package/script/deps/jsr.io/@std/assert/1.0.6/false.d.ts.map +0 -1
  203. package/script/deps/jsr.io/@std/assert/1.0.6/false.js +0 -25
  204. package/script/deps/jsr.io/@std/assert/1.0.6/instance_of.d.ts +0 -23
  205. package/script/deps/jsr.io/@std/assert/1.0.6/instance_of.d.ts.map +0 -1
  206. package/script/deps/jsr.io/@std/assert/1.0.6/instance_of.js +0 -56
  207. package/script/deps/jsr.io/@std/assert/1.0.6/is_error.d.ts +0 -25
  208. package/script/deps/jsr.io/@std/assert/1.0.6/is_error.d.ts.map +0 -1
  209. package/script/deps/jsr.io/@std/assert/1.0.6/is_error.js +0 -57
  210. package/script/deps/jsr.io/@std/assert/1.0.6/match.d.ts +0 -18
  211. package/script/deps/jsr.io/@std/assert/1.0.6/match.d.ts.map +0 -1
  212. package/script/deps/jsr.io/@std/assert/1.0.6/match.js +0 -29
  213. package/script/deps/jsr.io/@std/assert/1.0.6/not_instance_of.d.ts +0 -20
  214. package/script/deps/jsr.io/@std/assert/1.0.6/not_instance_of.d.ts.map +0 -1
  215. package/script/deps/jsr.io/@std/assert/1.0.6/not_instance_of.js +0 -32
  216. package/script/deps/jsr.io/@std/assert/1.0.6/not_match.d.ts +0 -18
  217. package/script/deps/jsr.io/@std/assert/1.0.6/not_match.d.ts.map +0 -1
  218. package/script/deps/jsr.io/@std/assert/1.0.6/not_match.js +0 -29
  219. package/script/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.d.ts +0 -23
  220. package/script/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.d.ts.map +0 -1
  221. package/script/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.js +0 -35
  222. package/script/deps/jsr.io/@std/assert/1.0.6/object_match.d.ts +0 -28
  223. package/script/deps/jsr.io/@std/assert/1.0.6/object_match.d.ts.map +0 -1
  224. package/script/deps/jsr.io/@std/assert/1.0.6/object_match.js +0 -162
  225. package/script/deps/jsr.io/@std/assert/1.0.6/rejects.d.ts +0 -42
  226. package/script/deps/jsr.io/@std/assert/1.0.6/rejects.d.ts.map +0 -1
  227. package/script/deps/jsr.io/@std/assert/1.0.6/rejects.js +0 -56
  228. package/script/deps/jsr.io/@std/assert/1.0.6/strict_equals.d.ts +0 -24
  229. package/script/deps/jsr.io/@std/assert/1.0.6/strict_equals.d.ts.map +0 -1
  230. package/script/deps/jsr.io/@std/assert/1.0.6/strict_equals.js +0 -60
  231. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_equals.d.ts +0 -20
  232. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_equals.d.ts.map +0 -1
  233. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_equals.js +0 -32
  234. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.d.ts +0 -17
  235. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.d.ts.map +0 -1
  236. package/script/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.js +0 -29
  237. package/script/deps/jsr.io/@std/expect/1.0.6/_assertion.d.ts +0 -3
  238. package/script/deps/jsr.io/@std/expect/1.0.6/_assertion.d.ts.map +0 -1
  239. package/script/deps/jsr.io/@std/expect/1.0.6/_assertion.js +0 -13
  240. package/script/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.d.ts +0 -41
  241. package/script/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.d.ts.map +0 -1
  242. package/script/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.js +0 -161
  243. package/script/deps/jsr.io/@std/expect/1.0.6/_build_message.d.ts +0 -6
  244. package/script/deps/jsr.io/@std/expect/1.0.6/_build_message.d.ts.map +0 -1
  245. package/script/deps/jsr.io/@std/expect/1.0.6/_build_message.js +0 -33
  246. package/script/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.d.ts +0 -4
  247. package/script/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.d.ts.map +0 -1
  248. package/script/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.js +0 -15
  249. package/script/deps/jsr.io/@std/expect/1.0.6/_equal.d.ts +0 -9
  250. package/script/deps/jsr.io/@std/expect/1.0.6/_equal.d.ts.map +0 -1
  251. package/script/deps/jsr.io/@std/expect/1.0.6/_equal.js +0 -194
  252. package/script/deps/jsr.io/@std/expect/1.0.6/_extend.d.ts +0 -4
  253. package/script/deps/jsr.io/@std/expect/1.0.6/_extend.d.ts.map +0 -1
  254. package/script/deps/jsr.io/@std/expect/1.0.6/_extend.js +0 -15
  255. package/script/deps/jsr.io/@std/expect/1.0.6/_inspect_args.d.ts +0 -3
  256. package/script/deps/jsr.io/@std/expect/1.0.6/_inspect_args.d.ts.map +0 -1
  257. package/script/deps/jsr.io/@std/expect/1.0.6/_inspect_args.js +0 -17
  258. package/script/deps/jsr.io/@std/expect/1.0.6/_matchers.d.ts +0 -34
  259. package/script/deps/jsr.io/@std/expect/1.0.6/_matchers.d.ts.map +0 -1
  260. package/script/deps/jsr.io/@std/expect/1.0.6/_matchers.js +0 -598
  261. package/script/deps/jsr.io/@std/expect/1.0.6/_mock_util.d.ts +0 -11
  262. package/script/deps/jsr.io/@std/expect/1.0.6/_mock_util.d.ts.map +0 -1
  263. package/script/deps/jsr.io/@std/expect/1.0.6/_mock_util.js +0 -14
  264. package/script/deps/jsr.io/@std/expect/1.0.6/_types.d.ts +0 -838
  265. package/script/deps/jsr.io/@std/expect/1.0.6/_types.d.ts.map +0 -1
  266. package/script/deps/jsr.io/@std/expect/1.0.6/_types.js +0 -4
  267. package/script/deps/jsr.io/@std/expect/1.0.6/_utils.d.ts +0 -8
  268. package/script/deps/jsr.io/@std/expect/1.0.6/_utils.d.ts.map +0 -1
  269. package/script/deps/jsr.io/@std/expect/1.0.6/_utils.js +0 -166
  270. package/script/deps/jsr.io/@std/expect/1.0.6/expect.d.ts +0 -52
  271. package/script/deps/jsr.io/@std/expect/1.0.6/expect.d.ts.map +0 -1
  272. package/script/deps/jsr.io/@std/expect/1.0.6/expect.js +0 -445
  273. package/script/deps/jsr.io/@std/internal/1.0.4/assertion_state.d.ts +0 -75
  274. package/script/deps/jsr.io/@std/internal/1.0.4/assertion_state.d.ts.map +0 -1
  275. package/script/deps/jsr.io/@std/internal/1.0.4/assertion_state.js +0 -106
  276. package/script/deps/jsr.io/@std/internal/1.0.4/build_message.d.ts +0 -82
  277. package/script/deps/jsr.io/@std/internal/1.0.4/build_message.d.ts.map +0 -1
  278. package/script/deps/jsr.io/@std/internal/1.0.4/build_message.js +0 -116
  279. package/script/deps/jsr.io/@std/internal/1.0.4/diff.d.ts +0 -140
  280. package/script/deps/jsr.io/@std/internal/1.0.4/diff.d.ts.map +0 -1
  281. package/script/deps/jsr.io/@std/internal/1.0.4/diff.js +0 -284
  282. package/script/deps/jsr.io/@std/internal/1.0.4/diff_str.d.ts +0 -99
  283. package/script/deps/jsr.io/@std/internal/1.0.4/diff_str.d.ts.map +0 -1
  284. package/script/deps/jsr.io/@std/internal/1.0.4/diff_str.js +0 -186
  285. package/script/deps/jsr.io/@std/internal/1.0.4/format.d.ts +0 -2
  286. package/script/deps/jsr.io/@std/internal/1.0.4/format.d.ts.map +0 -1
  287. package/script/deps/jsr.io/@std/internal/1.0.4/format.js +0 -41
  288. package/script/deps/jsr.io/@std/internal/1.0.4/styles.d.ts +0 -159
  289. package/script/deps/jsr.io/@std/internal/1.0.4/styles.d.ts.map +0 -1
  290. package/script/deps/jsr.io/@std/internal/1.0.4/styles.js +0 -220
  291. package/script/deps/jsr.io/@std/internal/1.0.4/types.d.ts +0 -16
  292. package/script/deps/jsr.io/@std/internal/1.0.4/types.d.ts.map +0 -1
  293. package/script/deps/jsr.io/@std/internal/1.0.4/types.js +0 -3
  294. package/script/deps/jsr.io/@std/testing/1.0.3/_test_suite.d.ts +0 -74
  295. package/script/deps/jsr.io/@std/testing/1.0.3/_test_suite.d.ts.map +0 -1
  296. package/script/deps/jsr.io/@std/testing/1.0.3/_test_suite.js +0 -345
  297. package/script/deps/jsr.io/@std/testing/1.0.3/bdd.d.ts +0 -731
  298. package/script/deps/jsr.io/@std/testing/1.0.3/bdd.d.ts.map +0 -1
  299. package/script/deps/jsr.io/@std/testing/1.0.3/bdd.js +0 -587
  300. package/script/deps/jsr.io/@std/testing/1.0.3/mock.d.ts +0 -674
  301. package/script/deps/jsr.io/@std/testing/1.0.3/mock.d.ts.map +0 -1
  302. package/script/deps/jsr.io/@std/testing/1.0.3/mock.js +0 -1136
  303. package/script/src/ast/nodes/annotation.test.d.ts +0 -2
  304. package/script/src/ast/nodes/annotation.test.d.ts.map +0 -1
  305. package/script/src/ast/nodes/annotation.test.js +0 -58
  306. package/script/src/ast/nodes/argument.test.d.ts +0 -2
  307. package/script/src/ast/nodes/argument.test.d.ts.map +0 -1
  308. package/script/src/ast/nodes/argument.test.js +0 -35
  309. package/script/src/ast/nodes/call.test.d.ts +0 -2
  310. package/script/src/ast/nodes/call.test.d.ts.map +0 -1
  311. package/script/src/ast/nodes/call.test.js +0 -37
  312. package/script/src/ast/nodes/class.test.d.ts +0 -2
  313. package/script/src/ast/nodes/class.test.d.ts.map +0 -1
  314. package/script/src/ast/nodes/class.test.js +0 -221
  315. package/script/src/ast/nodes/constructor.test.d.ts +0 -2
  316. package/script/src/ast/nodes/constructor.test.d.ts.map +0 -1
  317. package/script/src/ast/nodes/constructor.test.js +0 -141
  318. package/script/src/ast/nodes/doc-tag.test.d.ts +0 -2
  319. package/script/src/ast/nodes/doc-tag.test.d.ts.map +0 -1
  320. package/script/src/ast/nodes/doc-tag.test.js +0 -69
  321. package/script/src/ast/nodes/doc.test.d.ts +0 -2
  322. package/script/src/ast/nodes/doc.test.d.ts.map +0 -1
  323. package/script/src/ast/nodes/doc.test.js +0 -35
  324. package/script/src/ast/nodes/enum-value.test.d.ts +0 -2
  325. package/script/src/ast/nodes/enum-value.test.d.ts.map +0 -1
  326. package/script/src/ast/nodes/enum-value.test.js +0 -117
  327. package/script/src/ast/nodes/enum.test.d.ts +0 -2
  328. package/script/src/ast/nodes/enum.test.d.ts.map +0 -1
  329. package/script/src/ast/nodes/enum.test.js +0 -131
  330. package/script/src/ast/nodes/function.test.d.ts +0 -2
  331. package/script/src/ast/nodes/function.test.d.ts.map +0 -1
  332. package/script/src/ast/nodes/function.test.js +0 -162
  333. package/script/src/ast/nodes/generic-parameter.test.d.ts +0 -2
  334. package/script/src/ast/nodes/generic-parameter.test.d.ts.map +0 -1
  335. package/script/src/ast/nodes/generic-parameter.test.js +0 -51
  336. package/script/src/ast/nodes/init-block.test.d.ts +0 -2
  337. package/script/src/ast/nodes/init-block.test.d.ts.map +0 -1
  338. package/script/src/ast/nodes/init-block.test.js +0 -30
  339. package/script/src/ast/nodes/interface.test.d.ts +0 -2
  340. package/script/src/ast/nodes/interface.test.d.ts.map +0 -1
  341. package/script/src/ast/nodes/interface.test.js +0 -123
  342. package/script/src/ast/nodes/object.test.d.ts +0 -2
  343. package/script/src/ast/nodes/object.test.d.ts.map +0 -1
  344. package/script/src/ast/nodes/object.test.js +0 -80
  345. package/script/src/ast/nodes/parameter.test.d.ts +0 -2
  346. package/script/src/ast/nodes/parameter.test.d.ts.map +0 -1
  347. package/script/src/ast/nodes/parameter.test.js +0 -154
  348. package/script/src/ast/nodes/property.test.d.ts +0 -2
  349. package/script/src/ast/nodes/property.test.d.ts.map +0 -1
  350. package/script/src/ast/nodes/property.test.js +0 -208
  351. package/script/src/ast/nodes/reference.test.d.ts +0 -2
  352. package/script/src/ast/nodes/reference.test.d.ts.map +0 -1
  353. package/script/src/ast/nodes/reference.test.js +0 -38
  354. package/script/src/ast/nodes/string.test.d.ts +0 -2
  355. package/script/src/ast/nodes/string.test.d.ts.map +0 -1
  356. package/script/src/ast/nodes/string.test.js +0 -50
  357. package/script/src/import-collection.test.d.ts +0 -2
  358. package/script/src/import-collection.test.d.ts.map +0 -1
  359. package/script/src/import-collection.test.js +0 -101
  360. package/script/tests/openapi-models.test.d.ts +0 -2
  361. package/script/tests/openapi-models.test.d.ts.map +0 -1
  362. package/script/tests/openapi-models.test.js +0 -48
  363. package/src/_dnt.test_polyfills.ts +0 -70
  364. package/src/_dnt.test_shims.ts +0 -64
  365. package/src/deps/jsr.io/@std/assert/1.0.6/assertion_error.ts +0 -31
  366. package/src/deps/jsr.io/@std/assert/1.0.6/equal.ts +0 -152
  367. package/src/deps/jsr.io/@std/assert/1.0.6/equals.ts +0 -52
  368. package/src/deps/jsr.io/@std/assert/1.0.6/false.ts +0 -26
  369. package/src/deps/jsr.io/@std/assert/1.0.6/instance_of.ts +0 -64
  370. package/src/deps/jsr.io/@std/assert/1.0.6/is_error.ts +0 -65
  371. package/src/deps/jsr.io/@std/assert/1.0.6/match.ts +0 -30
  372. package/src/deps/jsr.io/@std/assert/1.0.6/not_instance_of.ts +0 -33
  373. package/src/deps/jsr.io/@std/assert/1.0.6/not_match.ts +0 -30
  374. package/src/deps/jsr.io/@std/assert/1.0.6/not_strict_equals.ts +0 -42
  375. package/src/deps/jsr.io/@std/assert/1.0.6/object_match.ts +0 -202
  376. package/src/deps/jsr.io/@std/assert/1.0.6/rejects.ts +0 -123
  377. package/src/deps/jsr.io/@std/assert/1.0.6/strict_equals.ts +0 -67
  378. package/src/deps/jsr.io/@std/expect/1.0.6/_assert_equals.ts +0 -38
  379. package/src/deps/jsr.io/@std/expect/1.0.6/_assert_not_equals.ts +0 -35
  380. package/src/deps/jsr.io/@std/expect/1.0.6/_assertion.ts +0 -13
  381. package/src/deps/jsr.io/@std/expect/1.0.6/_asymmetric_matchers.ts +0 -177
  382. package/src/deps/jsr.io/@std/expect/1.0.6/_build_message.ts +0 -51
  383. package/src/deps/jsr.io/@std/expect/1.0.6/_custom_equality_tester.ts +0 -19
  384. package/src/deps/jsr.io/@std/expect/1.0.6/_equal.ts +0 -229
  385. package/src/deps/jsr.io/@std/expect/1.0.6/_extend.ts +0 -16
  386. package/src/deps/jsr.io/@std/expect/1.0.6/_inspect_args.ts +0 -15
  387. package/src/deps/jsr.io/@std/expect/1.0.6/_matchers.ts +0 -828
  388. package/src/deps/jsr.io/@std/expect/1.0.6/_mock_util.ts +0 -22
  389. package/src/deps/jsr.io/@std/expect/1.0.6/_types.ts +0 -917
  390. package/src/deps/jsr.io/@std/expect/1.0.6/_utils.ts +0 -201
  391. package/src/deps/jsr.io/@std/expect/1.0.6/expect.ts +0 -529
  392. package/src/deps/jsr.io/@std/internal/1.0.4/assertion_state.ts +0 -111
  393. package/src/deps/jsr.io/@std/internal/1.0.4/build_message.ts +0 -134
  394. package/src/deps/jsr.io/@std/internal/1.0.4/diff.ts +0 -317
  395. package/src/deps/jsr.io/@std/internal/1.0.4/diff_str.ts +0 -204
  396. package/src/deps/jsr.io/@std/internal/1.0.4/format.ts +0 -39
  397. package/src/deps/jsr.io/@std/internal/1.0.4/styles.ts +0 -233
  398. package/src/deps/jsr.io/@std/internal/1.0.4/types.ts +0 -18
  399. package/src/deps/jsr.io/@std/testing/1.0.3/_test_suite.ts +0 -389
  400. package/src/deps/jsr.io/@std/testing/1.0.3/bdd.ts +0 -1202
  401. package/src/deps/jsr.io/@std/testing/1.0.3/mock.ts +0 -1839
  402. package/src/mod.ts +0 -8
  403. package/src/src/assets.ts +0 -9
  404. package/src/src/ast/_index.ts +0 -66
  405. package/src/src/ast/common.ts +0 -1
  406. package/src/src/ast/index.ts +0 -1
  407. package/src/src/ast/node.ts +0 -10
  408. package/src/src/ast/nodes/annotation.test.ts +0 -69
  409. package/src/src/ast/nodes/annotation.ts +0 -79
  410. package/src/src/ast/nodes/argument.test.ts +0 -41
  411. package/src/src/ast/nodes/argument.ts +0 -62
  412. package/src/src/ast/nodes/call.test.ts +0 -44
  413. package/src/src/ast/nodes/call.ts +0 -66
  414. package/src/src/ast/nodes/class.test.ts +0 -274
  415. package/src/src/ast/nodes/class.ts +0 -178
  416. package/src/src/ast/nodes/collection-literal.ts +0 -49
  417. package/src/src/ast/nodes/constructor.test.ts +0 -178
  418. package/src/src/ast/nodes/constructor.ts +0 -126
  419. package/src/src/ast/nodes/doc-tag.test.ts +0 -84
  420. package/src/src/ast/nodes/doc-tag.ts +0 -138
  421. package/src/src/ast/nodes/doc.test.ts +0 -42
  422. package/src/src/ast/nodes/doc.ts +0 -111
  423. package/src/src/ast/nodes/enum-value.test.ts +0 -146
  424. package/src/src/ast/nodes/enum-value.ts +0 -100
  425. package/src/src/ast/nodes/enum.test.ts +0 -167
  426. package/src/src/ast/nodes/enum.ts +0 -163
  427. package/src/src/ast/nodes/function.test.ts +0 -194
  428. package/src/src/ast/nodes/function.ts +0 -176
  429. package/src/src/ast/nodes/generic-parameter.test.ts +0 -60
  430. package/src/src/ast/nodes/generic-parameter.ts +0 -54
  431. package/src/src/ast/nodes/init-block.test.ts +0 -36
  432. package/src/src/ast/nodes/init-block.ts +0 -38
  433. package/src/src/ast/nodes/interface.test.ts +0 -151
  434. package/src/src/ast/nodes/interface.ts +0 -133
  435. package/src/src/ast/nodes/lambda-type.ts +0 -68
  436. package/src/src/ast/nodes/lambda.ts +0 -68
  437. package/src/src/ast/nodes/object.test.ts +0 -101
  438. package/src/src/ast/nodes/object.ts +0 -102
  439. package/src/src/ast/nodes/parameter.test.ts +0 -191
  440. package/src/src/ast/nodes/parameter.ts +0 -118
  441. package/src/src/ast/nodes/property.test.ts +0 -253
  442. package/src/src/ast/nodes/property.ts +0 -225
  443. package/src/src/ast/nodes/reference.test.ts +0 -47
  444. package/src/src/ast/nodes/reference.ts +0 -178
  445. package/src/src/ast/nodes/string.test.ts +0 -61
  446. package/src/src/ast/nodes/string.ts +0 -114
  447. package/src/src/ast/nodes/types.ts +0 -23
  448. package/src/src/ast/references/index.ts +0 -8
  449. package/src/src/ast/references/jackson.ts +0 -16
  450. package/src/src/ast/references/jakarta.ts +0 -10
  451. package/src/src/ast/references/java.ts +0 -19
  452. package/src/src/ast/references/kotlin.ts +0 -40
  453. package/src/src/ast/references/okhttp3.ts +0 -5
  454. package/src/src/ast/references/reactor.ts +0 -5
  455. package/src/src/ast/references/spring.ts +0 -58
  456. package/src/src/ast/references/swagger.ts +0 -19
  457. package/src/src/ast/utils/get-kotlin-builder-options.ts +0 -19
  458. package/src/src/ast/utils/to-kt-node.ts +0 -31
  459. package/src/src/ast/utils/write-kt-annotations.ts +0 -15
  460. package/src/src/ast/utils/write-kt-arguments.ts +0 -45
  461. package/src/src/ast/utils/write-kt-enum-values.ts +0 -27
  462. package/src/src/ast/utils/write-kt-generic-parameters.ts +0 -12
  463. package/src/src/ast/utils/write-kt-members.ts +0 -25
  464. package/src/src/ast/utils/write-kt-node.ts +0 -37
  465. package/src/src/ast/utils/write-kt-parameters.ts +0 -25
  466. package/src/src/common-results.ts +0 -4
  467. package/src/src/config.ts +0 -39
  468. package/src/src/file-builder.ts +0 -108
  469. package/src/src/generators/file-generator.ts +0 -29
  470. package/src/src/generators/index.ts +0 -4
  471. package/src/src/generators/models/args.ts +0 -128
  472. package/src/src/generators/models/index.ts +0 -4
  473. package/src/src/generators/models/model-generator.ts +0 -602
  474. package/src/src/generators/models/models-generator.ts +0 -65
  475. package/src/src/generators/models/models.ts +0 -95
  476. package/src/src/generators/services/okhttp3-clients/args.ts +0 -78
  477. package/src/src/generators/services/okhttp3-clients/index.ts +0 -4
  478. package/src/src/generators/services/okhttp3-clients/models.ts +0 -60
  479. package/src/src/generators/services/okhttp3-clients/okhttp3-client-generator.ts +0 -557
  480. package/src/src/generators/services/okhttp3-clients/okhttp3-clients-generator.ts +0 -128
  481. package/src/src/generators/services/okhttp3-clients/refs.ts +0 -55
  482. package/src/src/generators/services/spring-controllers/args.ts +0 -71
  483. package/src/src/generators/services/spring-controllers/index.ts +0 -4
  484. package/src/src/generators/services/spring-controllers/models.ts +0 -58
  485. package/src/src/generators/services/spring-controllers/spring-controller-generator.ts +0 -605
  486. package/src/src/generators/services/spring-controllers/spring-controllers-generator.ts +0 -70
  487. package/src/src/import-collection.test.ts +0 -116
  488. package/src/src/import-collection.ts +0 -98
  489. package/src/src/types.ts +0 -3
  490. package/src/src/utils.ts +0 -39
  491. package/src/tests/openapi-models.test.ts +0 -63
  492. package/test_runner.js +0 -227
@@ -1,1202 +0,0 @@
1
- // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
-
3
- /**
4
- * A {@link https://en.wikipedia.org/wiki/Behavior-driven_development | BDD} interface
5
- * to `Deno.test()` API.
6
- *
7
- * With `@std/testing/bdd` module you can write your tests in a familiar format for
8
- * grouping tests and adding setup/teardown hooks used by other JavaScript testing
9
- * frameworks like Jasmine, Jest, and Mocha.
10
- *
11
- * The `describe` function creates a block that groups together several related
12
- * tests. The `it` function registers an individual test case.
13
- *
14
- * ## Hooks
15
- *
16
- * There are 4 types of hooks available for test suites. A test suite can have
17
- * multiples of each type of hook, they will be called in the order that they are
18
- * registered. The `afterEach` and `afterAll` hooks will be called whether or not
19
- * the test case passes. The *All hooks will be called once for the whole group
20
- * while the *Each hooks will be called for each individual test case.
21
- *
22
- * - `beforeAll`: Runs before all of the tests in the test suite.
23
- * - `afterAll`: Runs after all of the tests in the test suite finish.
24
- * - `beforeEach`: Runs before each of the individual test cases in the test suite.
25
- * - `afterEach`: Runs after each of the individual test cases in the test suite.
26
- *
27
- * If a hook is registered at the top level, a global test suite will be registered
28
- * and all tests will belong to it. Hooks registered at the top level must be
29
- * registered before any individual test cases or test suites.
30
- *
31
- * ## Focusing tests
32
- *
33
- * If you would like to run only specific test cases, you can do so by calling
34
- * `it.only` instead of `it`. If you would like to run only specific test suites,
35
- * you can do so by calling `describe.only` instead of `describe`.
36
- *
37
- * There is one limitation to this when using the flat test grouping style. When
38
- * `describe` is called without being nested, it registers the test with
39
- * `Deno.test`. If a child test case or suite is registered with `it.only` or
40
- * `describe.only`, it will be scoped to the top test suite instead of the file. To
41
- * make them the only tests that run in the file, you would need to register the
42
- * top test suite with `describe.only` too.
43
- *
44
- * ## Ignoring tests
45
- *
46
- * If you would like to not run specific individual test cases, you can do so by
47
- * calling `it.ignore` instead of `it`. If you would like to not run specific test
48
- * suites, you can do so by calling `describe.ignore` instead of `describe`.
49
- *
50
- * ## Sanitization options
51
- *
52
- * Like `Deno.TestDefinition`, the `DescribeDefinition` and `ItDefinition` have
53
- * sanitization options. They work in the same way.
54
- *
55
- * - `sanitizeExit`: Ensure the test case does not prematurely cause the process to
56
- * exit, for example via a call to Deno.exit. Defaults to true.
57
- * - `sanitizeOps`: Check that the number of async completed ops after the test is
58
- * the same as number of dispatched ops. Defaults to true.
59
- * - `sanitizeResources`: Ensure the test case does not "leak" resources - ie. the
60
- * resource table after the test has exactly the same contents as before the
61
- * test. Defaults to true.
62
- *
63
- * ## Permissions option
64
- *
65
- * Like `Deno.TestDefinition`, the `DescribeDefinition` and `ItDefinition` have a
66
- * `permissions` option. They specify the permissions that should be used to run an
67
- * individual test case or test suite. Set this to `"inherit"` to keep the calling
68
- * thread's permissions. Set this to `"none"` to revoke all permissions.
69
- *
70
- * This setting defaults to `"inherit"`.
71
- *
72
- * There is currently one limitation to this, you cannot use the permissions option
73
- * on an individual test case or test suite that belongs to another test suite.
74
- * That's because internally those tests are registered with `t.step` which does
75
- * not support the permissions option.
76
- *
77
- * ## Comparing to Deno\.test
78
- *
79
- * The default way of writing tests is using `Deno.test` and `t.step`. The
80
- * `describe` and `it` functions have similar call signatures to `Deno.test`,
81
- * making it easy to switch between the default style and the behavior-driven
82
- * development style of writing tests. Internally, `describe` and `it` are
83
- * registering tests with `Deno.test` and `t.step`.
84
- *
85
- * Below is an example of a test file using `Deno.test` and `t.step`. In the
86
- * following sections there are examples of how the same test could be written with
87
- * `describe` and `it` using nested test grouping, flat test grouping, or a mix of
88
- * both styles.
89
- *
90
- * ```ts
91
- * import {
92
- * assertEquals,
93
- * assertStrictEquals,
94
- * assertThrows,
95
- * } from "@std/assert";
96
- *
97
- * class User {
98
- * static users: Map<string, User> = new Map();
99
- * name: string;
100
- * age?: number;
101
- *
102
- * constructor(name: string) {
103
- * if (User.users.has(name)) {
104
- * throw new Deno.errors.AlreadyExists(`User ${name} already exists`);
105
- * }
106
- * this.name = name;
107
- * User.users.set(name, this);
108
- * }
109
- *
110
- * getAge(): number {
111
- * if (!this.age) {
112
- * throw new Error("Age unknown");
113
- * }
114
- * return this.age;
115
- * }
116
- *
117
- * setAge(age: number) {
118
- * this.age = age;
119
- * }
120
- * }
121
- *
122
- * Deno.test("User.users initially empty", () => {
123
- * assertEquals(User.users.size, 0);
124
- * });
125
- *
126
- * Deno.test("User constructor", () => {
127
- * try {
128
- * const user = new User("Kyle");
129
- * assertEquals(user.name, "Kyle");
130
- * assertStrictEquals(User.users.get("Kyle"), user);
131
- * } finally {
132
- * User.users.clear();
133
- * }
134
- * });
135
- *
136
- * Deno.test("User age", async (t) => {
137
- * const user = new User("Kyle");
138
- *
139
- * await t.step("getAge", () => {
140
- * assertThrows(() => user.getAge(), Error, "Age unknown");
141
- * user.age = 18;
142
- * assertEquals(user.getAge(), 18);
143
- * });
144
- *
145
- * await t.step("setAge", () => {
146
- * user.setAge(18);
147
- * assertEquals(user.getAge(), 18);
148
- * });
149
- * });
150
- * ```
151
- *
152
- * ### Nested test grouping
153
- *
154
- * Tests created within the callback of a `describe` function call will belong to
155
- * the new test suite it creates. The hooks can be created within it or be added to
156
- * the options argument for describe.
157
- *
158
- * ```ts
159
- * import {
160
- * assertEquals,
161
- * assertStrictEquals,
162
- * assertThrows,
163
- * } from "@std/assert";
164
- * import {
165
- * afterEach,
166
- * beforeEach,
167
- * describe,
168
- * it,
169
- * } from "@std/testing/bdd";
170
- *
171
- * class User {
172
- * static users: Map<string, User> = new Map();
173
- * name: string;
174
- * age?: number;
175
- *
176
- * constructor(name: string) {
177
- * if (User.users.has(name)) {
178
- * throw new Deno.errors.AlreadyExists(`User ${name} already exists`);
179
- * }
180
- * this.name = name;
181
- * User.users.set(name, this);
182
- * }
183
- *
184
- * getAge(): number {
185
- * if (!this.age) {
186
- * throw new Error("Age unknown");
187
- * }
188
- * return this.age;
189
- * }
190
- *
191
- * setAge(age: number) {
192
- * this.age = age;
193
- * }
194
- * }
195
- *
196
- * describe("User", () => {
197
- * it("users initially empty", () => {
198
- * assertEquals(User.users.size, 0);
199
- * });
200
- *
201
- * it("constructor", () => {
202
- * try {
203
- * const user = new User("Kyle");
204
- * assertEquals(user.name, "Kyle");
205
- * assertStrictEquals(User.users.get("Kyle"), user);
206
- * } finally {
207
- * User.users.clear();
208
- * }
209
- * });
210
- *
211
- * describe("age", () => {
212
- * let user: User;
213
- *
214
- * beforeEach(() => {
215
- * user = new User("Kyle");
216
- * });
217
- *
218
- * afterEach(() => {
219
- * User.users.clear();
220
- * });
221
- *
222
- * it("getAge", function () {
223
- * assertThrows(() => user.getAge(), Error, "Age unknown");
224
- * user.age = 18;
225
- * assertEquals(user.getAge(), 18);
226
- * });
227
- *
228
- * it("setAge", function () {
229
- * user.setAge(18);
230
- * assertEquals(user.getAge(), 18);
231
- * });
232
- * });
233
- * });
234
- * ```
235
- *
236
- * ### Flat test grouping
237
- *
238
- * The `describe` function returns a unique symbol that can be used to reference
239
- * the test suite for adding tests to it without having to create them within a
240
- * callback. The gives you the ability to have test grouping without any extra
241
- * indentation in front of the grouped tests.
242
- *
243
- * ```ts
244
- * import {
245
- * assertEquals,
246
- * assertStrictEquals,
247
- * assertThrows,
248
- * } from "@std/assert";
249
- * import {
250
- * describe,
251
- * it,
252
- * } from "@std/testing/bdd";
253
- *
254
- * class User {
255
- * static users: Map<string, User> = new Map();
256
- * name: string;
257
- * age?: number;
258
- *
259
- * constructor(name: string) {
260
- * if (User.users.has(name)) {
261
- * throw new Deno.errors.AlreadyExists(`User ${name} already exists`);
262
- * }
263
- * this.name = name;
264
- * User.users.set(name, this);
265
- * }
266
- *
267
- * getAge(): number {
268
- * if (!this.age) {
269
- * throw new Error("Age unknown");
270
- * }
271
- * return this.age;
272
- * }
273
- *
274
- * setAge(age: number) {
275
- * this.age = age;
276
- * }
277
- * }
278
- *
279
- * const userTests = describe("User");
280
- *
281
- * it(userTests, "users initially empty", () => {
282
- * assertEquals(User.users.size, 0);
283
- * });
284
- *
285
- * it(userTests, "constructor", () => {
286
- * try {
287
- * const user = new User("Kyle");
288
- * assertEquals(user.name, "Kyle");
289
- * assertStrictEquals(User.users.get("Kyle"), user);
290
- * } finally {
291
- * User.users.clear();
292
- * }
293
- * });
294
- *
295
- * const ageTests = describe({
296
- * name: "age",
297
- * suite: userTests,
298
- * beforeEach(this: { user: User }) {
299
- * this.user = new User("Kyle");
300
- * },
301
- * afterEach() {
302
- * User.users.clear();
303
- * },
304
- * });
305
- *
306
- * it(ageTests, "getAge", function () {
307
- * const { user } = this;
308
- * assertThrows(() => user.getAge(), Error, "Age unknown");
309
- * user.age = 18;
310
- * assertEquals(user.getAge(), 18);
311
- * });
312
- *
313
- * it(ageTests, "setAge", function () {
314
- * const { user } = this;
315
- * user.setAge(18);
316
- * assertEquals(user.getAge(), 18);
317
- * });
318
- * ```
319
- *
320
- * ### Mixed test grouping
321
- *
322
- * Both nested test grouping and flat test grouping can be used together. This can
323
- * be useful if you'd like to create deep groupings without all the extra
324
- * indentation in front of each line.
325
- *
326
- * ```ts
327
- * import {
328
- * assertEquals,
329
- * assertStrictEquals,
330
- * assertThrows,
331
- * } from "@std/assert";
332
- * import {
333
- * describe,
334
- * it,
335
- * } from "@std/testing/bdd";
336
- *
337
- * class User {
338
- * static users: Map<string, User> = new Map();
339
- * name: string;
340
- * age?: number;
341
- *
342
- * constructor(name: string) {
343
- * if (User.users.has(name)) {
344
- * throw new Deno.errors.AlreadyExists(`User ${name} already exists`);
345
- * }
346
- * this.name = name;
347
- * User.users.set(name, this);
348
- * }
349
- *
350
- * getAge(): number {
351
- * if (!this.age) {
352
- * throw new Error("Age unknown");
353
- * }
354
- * return this.age;
355
- * }
356
- *
357
- * setAge(age: number) {
358
- * this.age = age;
359
- * }
360
- * }
361
- *
362
- * describe("User", () => {
363
- * it("users initially empty", () => {
364
- * assertEquals(User.users.size, 0);
365
- * });
366
- *
367
- * it("constructor", () => {
368
- * try {
369
- * const user = new User("Kyle");
370
- * assertEquals(user.name, "Kyle");
371
- * assertStrictEquals(User.users.get("Kyle"), user);
372
- * } finally {
373
- * User.users.clear();
374
- * }
375
- * });
376
- *
377
- * const ageTests = describe({
378
- * name: "age",
379
- * beforeEach(this: { user: User }) {
380
- * this.user = new User("Kyle");
381
- * },
382
- * afterEach() {
383
- * User.users.clear();
384
- * },
385
- * });
386
- *
387
- * it(ageTests, "getAge", function () {
388
- * const { user } = this;
389
- * assertThrows(() => user.getAge(), Error, "Age unknown");
390
- * user.age = 18;
391
- * assertEquals(user.getAge(), 18);
392
- * });
393
- *
394
- * it(ageTests, "setAge", function () {
395
- * const { user } = this;
396
- * user.setAge(18);
397
- * assertEquals(user.getAge(), 18);
398
- * });
399
- * });
400
- * ```
401
- *
402
- * @module
403
- */
404
- import * as dntShim from "../../../../../_dnt.test_shims.js";
405
-
406
-
407
- import { getAssertionState } from "../../internal/1.0.4/assertion_state.js";
408
- import { AssertionError } from "../../assert/1.0.6/assertion_error.js";
409
- import {
410
- type DescribeDefinition,
411
- type HookNames,
412
- type ItDefinition,
413
- type TestSuite,
414
- TestSuiteInternal,
415
- } from "./_test_suite.js";
416
- export type { DescribeDefinition, ItDefinition, TestSuite };
417
-
418
- /** The arguments for an ItFunction. */
419
- export type ItArgs<T> =
420
- | [options: ItDefinition<T>]
421
- | [
422
- name: string,
423
- options: Omit<ItDefinition<T>, "name">,
424
- ]
425
- | [
426
- name: string,
427
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
428
- ]
429
- | [fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>]
430
- | [
431
- name: string,
432
- options: Omit<ItDefinition<T>, "fn" | "name">,
433
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
434
- ]
435
- | [
436
- options: Omit<ItDefinition<T>, "fn">,
437
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
438
- ]
439
- | [
440
- options: Omit<ItDefinition<T>, "fn" | "name">,
441
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
442
- ]
443
- | [
444
- suite: TestSuite<T>,
445
- name: string,
446
- options: Omit<ItDefinition<T>, "name" | "suite">,
447
- ]
448
- | [
449
- suite: TestSuite<T>,
450
- name: string,
451
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
452
- ]
453
- | [
454
- suite: TestSuite<T>,
455
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
456
- ]
457
- | [
458
- suite: TestSuite<T>,
459
- name: string,
460
- options: Omit<ItDefinition<T>, "fn" | "name" | "suite">,
461
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
462
- ]
463
- | [
464
- suite: TestSuite<T>,
465
- options: Omit<ItDefinition<T>, "fn" | "suite">,
466
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
467
- ]
468
- | [
469
- suite: TestSuite<T>,
470
- options: Omit<ItDefinition<T>, "fn" | "name" | "suite">,
471
- fn: (this: T, t: dntShim.Deno.TestContext) => void | Promise<void>,
472
- ];
473
-
474
- /** Generates an ItDefinition from ItArgs. */
475
- function itDefinition<T>(...args: ItArgs<T>): ItDefinition<T> {
476
- let [
477
- suiteOptionsOrNameOrFn,
478
- optionsOrNameOrFn,
479
- optionsOrFn,
480
- fn,
481
- ] = args;
482
- let suite: TestSuite<T> | undefined = undefined;
483
- let name: string;
484
- let options:
485
- | ItDefinition<T>
486
- | Omit<ItDefinition<T>, "fn">
487
- | Omit<ItDefinition<T>, "name">
488
- | Omit<ItDefinition<T>, "fn" | "name">;
489
- if (
490
- typeof suiteOptionsOrNameOrFn === "object" &&
491
- typeof (suiteOptionsOrNameOrFn as TestSuite<T>).symbol === "symbol"
492
- ) {
493
- suite = suiteOptionsOrNameOrFn as TestSuite<T>;
494
- } else {
495
- fn = optionsOrFn as typeof fn;
496
- optionsOrFn = optionsOrNameOrFn as typeof optionsOrFn;
497
- optionsOrNameOrFn = suiteOptionsOrNameOrFn as typeof optionsOrNameOrFn;
498
- }
499
- if (typeof optionsOrNameOrFn === "string") {
500
- name = optionsOrNameOrFn;
501
- if (typeof optionsOrFn === "function") {
502
- fn = optionsOrFn;
503
- options = {};
504
- } else {
505
- options = optionsOrFn!;
506
- if (!fn) fn = (options as Omit<ItDefinition<T>, "name">).fn;
507
- }
508
- } else if (typeof optionsOrNameOrFn === "function") {
509
- fn = optionsOrNameOrFn;
510
- name = fn.name;
511
- options = {};
512
- } else {
513
- options = optionsOrNameOrFn!;
514
- if (typeof optionsOrFn === "function") {
515
- fn = optionsOrFn;
516
- } else {
517
- fn = (options as ItDefinition<T>).fn;
518
- }
519
- name = (options as ItDefinition<T>).name ?? fn.name;
520
- }
521
-
522
- return {
523
- ...(suite !== undefined ? { suite } : {}),
524
- ...options,
525
- name,
526
- fn,
527
- };
528
- }
529
-
530
- /** Registers an individual test case. */
531
- export interface it {
532
- <T>(...args: ItArgs<T>): void;
533
-
534
- /** Registers an individual test case with only set to true. */
535
- only<T>(...args: ItArgs<T>): void;
536
-
537
- /** Registers an individual test case with ignore set to true. */
538
- ignore<T>(...args: ItArgs<T>): void;
539
-
540
- /**
541
- * Registers an individual test case with ignore set to true. Alias of
542
- * `.ignore()`.
543
- */
544
- skip<T>(...args: ItArgs<T>): void;
545
- }
546
-
547
- /**
548
- * Registers an individual test case.
549
- *
550
- * @example Usage
551
- * ```ts
552
- * import { describe, it } from "@std/testing/bdd";
553
- * import { assertEquals } from "@std/assert";
554
- *
555
- * describe("example", () => {
556
- * it("should pass", () => {
557
- * // test case
558
- * assertEquals(2 + 2, 4);
559
- * });
560
- * });
561
- * ```
562
- *
563
- * @typeParam T The self type of the function to implement the test case
564
- * @param args The test case
565
- */
566
- export function it<T>(...args: ItArgs<T>) {
567
- if (TestSuiteInternal.runningCount > 0) {
568
- throw new Error(
569
- "Cannot register new test cases after already registered test cases start running",
570
- );
571
- }
572
- const assertionState = getAssertionState();
573
- const options = itDefinition(...args);
574
- const { suite } = options;
575
- const testSuite = suite
576
- ? TestSuiteInternal.suites.get(suite.symbol)
577
- : TestSuiteInternal.current;
578
-
579
- if (!TestSuiteInternal.started) TestSuiteInternal.started = true;
580
- if (testSuite) {
581
- TestSuiteInternal.addStep(testSuite, options);
582
- } else {
583
- const {
584
- name,
585
- fn,
586
- ignore,
587
- only,
588
- permissions,
589
- sanitizeExit,
590
- sanitizeOps,
591
- sanitizeResources,
592
- } = options;
593
- const opts: dntShim.Deno.TestDefinition = {
594
- name,
595
- async fn(t) {
596
- TestSuiteInternal.runningCount++;
597
- try {
598
- await fn.call({} as T, t);
599
- } finally {
600
- TestSuiteInternal.runningCount--;
601
- }
602
-
603
- if (assertionState.checkAssertionErrorStateAndReset()) {
604
- throw new AssertionError(
605
- "Expected at least one assertion to be called but received none",
606
- );
607
- }
608
- },
609
- };
610
- if (ignore !== undefined) {
611
- opts.ignore = ignore;
612
- }
613
- if (only !== undefined) {
614
- opts.only = only;
615
- }
616
- if (permissions !== undefined) {
617
- opts.permissions = permissions;
618
- }
619
- if (sanitizeExit !== undefined) {
620
- opts.sanitizeExit = sanitizeExit;
621
- }
622
- if (sanitizeOps !== undefined) {
623
- opts.sanitizeOps = sanitizeOps;
624
- }
625
- if (sanitizeResources !== undefined) {
626
- opts.sanitizeResources = sanitizeResources;
627
- }
628
- TestSuiteInternal.registerTest(opts);
629
- }
630
- }
631
-
632
- /**
633
- * Only execute this test case.
634
- *
635
- * @example Usage
636
- * ```ts
637
- * import { describe, it } from "@std/testing/bdd";
638
- * import { assertEquals } from "@std/assert";
639
- *
640
- * describe("example", () => {
641
- * it("should pass", () => {
642
- * assertEquals(2 + 2, 4);
643
- * });
644
- *
645
- * it.only("should pass too", () => {
646
- * assertEquals(3 + 4, 7);
647
- * });
648
- * });
649
- * ```
650
- *
651
- * @param args The test case
652
- */
653
- it.only = function itOnly<T>(...args: ItArgs<T>): void {
654
- const options = itDefinition(...args);
655
- return it({
656
- ...options,
657
- only: true,
658
- });
659
- };
660
-
661
- /**
662
- * Ignore this test case.
663
- *
664
- * @example Usage
665
- * ```ts
666
- * import { describe, it } from "@std/testing/bdd";
667
- * import { assertEquals } from "@std/assert";
668
- *
669
- * describe("example", () => {
670
- * it("should pass", () => {
671
- * assertEquals(2 + 2, 4);
672
- * });
673
- *
674
- * it.ignore("should pass too", () => {
675
- * assertEquals(3 + 4, 7);
676
- * });
677
- * });
678
- * ```
679
- *
680
- * @param args The test case
681
- */
682
- it.ignore = function itIgnore<T>(...args: ItArgs<T>): void {
683
- const options = itDefinition(...args);
684
- return it({
685
- ...options,
686
- ignore: true,
687
- });
688
- };
689
-
690
- /** Skip this test case.
691
- *
692
- * @example Usage
693
- * ```ts
694
- * import { describe, it } from "@std/testing/bdd";
695
- * import { assertEquals } from "@std/assert";
696
- *
697
- * describe("example", () => {
698
- * it("should pass", () => {
699
- * assertEquals(2 + 2, 4);
700
- * });
701
- *
702
- * it.skip("should pass too", () => {
703
- * assertEquals(3 + 4, 7);
704
- * });
705
- * });
706
- * ```
707
- *
708
- * @param args The test case
709
- */
710
- it.skip = function itSkip<T>(...args: ItArgs<T>): void {
711
- it.ignore(...args);
712
- };
713
-
714
- /**
715
- * Alias of {@linkcode it}
716
- *
717
- * Registers an individual test case.
718
- *
719
- * @example Usage
720
- * ```ts
721
- * import { test } from "@std/testing/bdd";
722
- * import { assertEquals } from "@std/assert";
723
- *
724
- * test("a test case", () => {
725
- * // test case
726
- * assertEquals(2 + 2, 4);
727
- * });
728
- * ```
729
- *
730
- * @typeParam T The self type of the function to implement the test case
731
- * @param args The test case
732
- */
733
- export function test<T>(...args: ItArgs<T>) {
734
- it(...args);
735
- }
736
-
737
- function addHook<T>(
738
- name: HookNames,
739
- fn: (this: T) => void | Promise<void>,
740
- ) {
741
- if (!TestSuiteInternal.current) {
742
- if (TestSuiteInternal.started) {
743
- throw new Error(
744
- "Cannot add global hooks after a global test is registered",
745
- );
746
- }
747
- TestSuiteInternal.current = new TestSuiteInternal({
748
- name: "global",
749
- [name]: fn,
750
- });
751
- } else {
752
- TestSuiteInternal.setHook(TestSuiteInternal.current!, name, fn);
753
- }
754
- }
755
-
756
- /**
757
- * Run some shared setup before all of the tests in the suite.
758
- *
759
- * @example Usage
760
- * ```ts
761
- * import { describe, it, beforeAll } from "@std/testing/bdd";
762
- * import { assertEquals } from "@std/assert";
763
- *
764
- * beforeAll(() => {
765
- * console.log("beforeAll");
766
- * });
767
- *
768
- * describe("example", () => {
769
- * it("should pass", () => {
770
- * // test case
771
- * assertEquals(2 + 2, 4);
772
- * });
773
- * });
774
- * ```
775
- *
776
- * @typeParam T The self type of the function
777
- * @param fn The function to implement the setup behavior.
778
- */
779
- export function beforeAll<T>(
780
- fn: (this: T) => void | Promise<void>,
781
- ) {
782
- addHook("beforeAll", fn);
783
- }
784
-
785
- /**
786
- * Alias of {@linkcode beforeAll}
787
- *
788
- * Run some shared setup before all of the tests in the suite.
789
- *
790
- * @example Usage
791
- * ```ts
792
- * import { describe, it, before } from "@std/testing/bdd";
793
- * import { assertEquals } from "@std/assert";
794
- *
795
- * before(() => {
796
- * console.log("before");
797
- * });
798
- *
799
- * describe("example", () => {
800
- * it("should pass", () => {
801
- * // test case
802
- * assertEquals(2 + 2, 4);
803
- * });
804
- * });
805
- * ```
806
- *
807
- * @typeParam T The self type of the function
808
- * @param fn The function to implement the setup behavior.
809
- */
810
- export function before<T>(
811
- fn: (this: T) => void | Promise<void>,
812
- ) {
813
- beforeAll(fn);
814
- }
815
-
816
- /**
817
- * Run some shared teardown after all of the tests in the suite.
818
- *
819
- * @example Usage
820
- * ```ts
821
- * import { describe, it, afterAll } from "@std/testing/bdd";
822
- * import { assertEquals } from "@std/assert";
823
- *
824
- * afterAll(() => {
825
- * console.log("afterAll");
826
- * });
827
- *
828
- * describe("example", () => {
829
- * it("should pass", () => {
830
- * // test case
831
- * assertEquals(2 + 2, 4);
832
- * });
833
- * });
834
- * ```
835
- *
836
- * @typeParam T The self type of the function
837
- * @param fn The function to implement the teardown behavior.
838
- */
839
- export function afterAll<T>(
840
- fn: (this: T) => void | Promise<void>,
841
- ) {
842
- addHook("afterAll", fn);
843
- }
844
-
845
- /**
846
- * Alias of {@linkcode afterAll}.
847
- *
848
- * Run some shared teardown after all of the tests in the suite.
849
- *
850
- * @example Usage
851
- * ```ts
852
- * import { describe, it, after } from "@std/testing/bdd";
853
- * import { assertEquals } from "@std/assert";
854
- *
855
- * after(() => {
856
- * console.log("after");
857
- * });
858
- *
859
- * describe("example", () => {
860
- * it("should pass", () => {
861
- * // test case
862
- * assertEquals(2 + 2, 4);
863
- * });
864
- * });
865
- * ```
866
- *
867
- * @typeParam T The self type of the function
868
- * @param fn The function to implement the teardown behavior.
869
- */
870
- export function after<T>(
871
- fn: (this: T) => void | Promise<void>,
872
- ) {
873
- afterAll(fn);
874
- }
875
-
876
- /**
877
- * Run some shared setup before each test in the suite.
878
- *
879
- * @example Usage
880
- * ```ts
881
- * import { describe, it, beforeEach } from "@std/testing/bdd";
882
- * import { assertEquals } from "@std/assert";
883
- *
884
- * beforeEach(() => {
885
- * console.log("beforeEach");
886
- * });
887
- *
888
- * describe("example", () => {
889
- * it("should pass", () => {
890
- * // test case
891
- * assertEquals(2 + 2, 4);
892
- * });
893
- * });
894
- * ```
895
- *
896
- * @typeParam T The self type of the function
897
- * @param fn The function to implement the shared setup behavior
898
- */
899
- export function beforeEach<T>(
900
- fn: (this: T) => void | Promise<void>,
901
- ) {
902
- addHook("beforeEach", fn);
903
- }
904
-
905
- /**
906
- * Run some shared teardown after each test in the suite.
907
- *
908
- * @example Usage
909
- * ```ts
910
- * import { describe, it, afterEach } from "@std/testing/bdd";
911
- * import { assertEquals } from "@std/assert";
912
- *
913
- * afterEach(() => {
914
- * console.log("afterEach");
915
- * });
916
- *
917
- * describe("example", () => {
918
- * it("should pass", () => {
919
- * // test case
920
- * assertEquals(2 + 2, 4);
921
- * });
922
- * });
923
- * ```
924
- *
925
- * @typeParam T The self type of the function
926
- * @param fn The function to implement the shared teardown behavior
927
- */
928
- export function afterEach<T>(
929
- fn: (this: T) => void | Promise<void>,
930
- ) {
931
- addHook("afterEach", fn);
932
- }
933
-
934
- /** The arguments for a DescribeFunction. */
935
- export type DescribeArgs<T> =
936
- | [options: DescribeDefinition<T>]
937
- | [name: string]
938
- | [
939
- name: string,
940
- options: Omit<DescribeDefinition<T>, "name">,
941
- ]
942
- | [name: string, fn: () => void | undefined]
943
- | [fn: () => void | undefined]
944
- | [
945
- name: string,
946
- options: Omit<DescribeDefinition<T>, "fn" | "name">,
947
- fn: () => void | undefined,
948
- ]
949
- | [
950
- options: Omit<DescribeDefinition<T>, "fn">,
951
- fn: () => void | undefined,
952
- ]
953
- | [
954
- options: Omit<DescribeDefinition<T>, "fn" | "name">,
955
- fn: () => void | undefined,
956
- ]
957
- | [
958
- suite: TestSuite<T>,
959
- name: string,
960
- ]
961
- | [
962
- suite: TestSuite<T>,
963
- name: string,
964
- options: Omit<DescribeDefinition<T>, "name" | "suite">,
965
- ]
966
- | [
967
- suite: TestSuite<T>,
968
- name: string,
969
- fn: () => void | undefined,
970
- ]
971
- | [
972
- suite: TestSuite<T>,
973
- fn: () => void | undefined,
974
- ]
975
- | [
976
- suite: TestSuite<T>,
977
- name: string,
978
- options: Omit<DescribeDefinition<T>, "fn" | "name" | "suite">,
979
- fn: () => void | undefined,
980
- ]
981
- | [
982
- suite: TestSuite<T>,
983
- options: Omit<DescribeDefinition<T>, "fn" | "suite">,
984
- fn: () => void | undefined,
985
- ]
986
- | [
987
- suite: TestSuite<T>,
988
- options: Omit<DescribeDefinition<T>, "fn" | "name" | "suite">,
989
- fn: () => void | undefined,
990
- ];
991
-
992
- /** Generates a DescribeDefinition from DescribeArgs. */
993
- function describeDefinition<T>(
994
- ...args: DescribeArgs<T>
995
- ): DescribeDefinition<T> {
996
- let [
997
- suiteOptionsOrNameOrFn,
998
- optionsOrNameOrFn,
999
- optionsOrFn,
1000
- fn,
1001
- ] = args;
1002
- let suite: TestSuite<T> | undefined = undefined;
1003
- let name: string;
1004
- let options:
1005
- | DescribeDefinition<T>
1006
- | Omit<DescribeDefinition<T>, "fn">
1007
- | Omit<DescribeDefinition<T>, "name">
1008
- | Omit<DescribeDefinition<T>, "fn" | "name">;
1009
- if (
1010
- typeof suiteOptionsOrNameOrFn === "object" &&
1011
- typeof (suiteOptionsOrNameOrFn as TestSuite<T>).symbol === "symbol"
1012
- ) {
1013
- suite = suiteOptionsOrNameOrFn as TestSuite<T>;
1014
- } else {
1015
- fn = optionsOrFn as typeof fn;
1016
- optionsOrFn = optionsOrNameOrFn as typeof optionsOrFn;
1017
- optionsOrNameOrFn = suiteOptionsOrNameOrFn as typeof optionsOrNameOrFn;
1018
- }
1019
- if (typeof optionsOrNameOrFn === "string") {
1020
- name = optionsOrNameOrFn;
1021
- if (typeof optionsOrFn === "function") {
1022
- fn = optionsOrFn;
1023
- options = {};
1024
- } else {
1025
- options = optionsOrFn ?? {};
1026
- if (fn === undefined) {
1027
- fn = (options as Omit<DescribeDefinition<T>, "name">).fn;
1028
- }
1029
- }
1030
- } else if (typeof optionsOrNameOrFn === "function") {
1031
- fn = optionsOrNameOrFn;
1032
- name = fn.name;
1033
- options = {};
1034
- } else {
1035
- options = optionsOrNameOrFn ?? {};
1036
- if (typeof optionsOrFn === "function") {
1037
- fn = optionsOrFn;
1038
- } else {
1039
- fn = (options as DescribeDefinition<T>).fn;
1040
- }
1041
- name = (options as DescribeDefinition<T>).name ?? fn?.name ?? "";
1042
- }
1043
-
1044
- if (suite === undefined) {
1045
- suite = options.suite;
1046
- }
1047
- if (suite === undefined && TestSuiteInternal.current) {
1048
- const { symbol } = TestSuiteInternal.current;
1049
- suite = { symbol };
1050
- }
1051
-
1052
- return {
1053
- ...options,
1054
- suite: suite!,
1055
- name,
1056
- fn: fn!,
1057
- };
1058
- }
1059
-
1060
- /** Registers a test suite. */
1061
- export interface describe {
1062
- <T>(...args: DescribeArgs<T>): TestSuite<T>;
1063
-
1064
- /** Registers a test suite with only set to true. */
1065
- only<T>(...args: DescribeArgs<T>): TestSuite<T>;
1066
-
1067
- /** Registers a test suite with ignore set to true. */
1068
- ignore<T>(...args: DescribeArgs<T>): TestSuite<T>;
1069
-
1070
- /** Registers a test suite with ignore set to true. Alias of `.ignore()`. */
1071
- skip<T>(...args: ItArgs<T>): void;
1072
- }
1073
-
1074
- /**
1075
- * Registers a test suite.
1076
- *
1077
- * @example Usage
1078
- * ```ts
1079
- * import { describe, it } from "@std/testing/bdd";
1080
- * import { assertEquals } from "@std/assert";
1081
- *
1082
- * describe("example", () => {
1083
- * it("should pass", () => {
1084
- * // test case
1085
- * assertEquals(2 + 2, 4);
1086
- * });
1087
- * });
1088
- * ```
1089
- *
1090
- * @typeParam T The self type of the test suite body.
1091
- * @param args The test suite body.
1092
- * @returns The test suite
1093
- */
1094
- export function describe<T>(
1095
- ...args: DescribeArgs<T>
1096
- ): TestSuite<T> {
1097
- if (TestSuiteInternal.runningCount > 0) {
1098
- throw new Error(
1099
- "Cannot register new test suites after already registered test cases start running",
1100
- );
1101
- }
1102
- const options = describeDefinition(...args);
1103
- if (!TestSuiteInternal.started) TestSuiteInternal.started = true;
1104
- const { symbol } = new TestSuiteInternal(options);
1105
- return { symbol };
1106
- }
1107
-
1108
- /**
1109
- * Only execute this test suite.
1110
- *
1111
- * @example Usage
1112
- * ```ts
1113
- * import { describe, it, beforeAll } from "@std/testing/bdd";
1114
- * import { assertEquals } from "@std/assert";
1115
- *
1116
- * describe("example", () => {
1117
- * it("should pass", () => {
1118
- * assertEquals(2 + 2, 4);
1119
- * });
1120
- * });
1121
- *
1122
- * // Only this test suite will run
1123
- * describe.only("example 2", () => {
1124
- * it("should pass too", () => {
1125
- * assertEquals(3 + 4, 7);
1126
- * });
1127
- * });
1128
- * ```
1129
- *
1130
- * @param args The test suite body
1131
- */
1132
- describe.only = function describeOnly<T>(
1133
- ...args: DescribeArgs<T>
1134
- ): TestSuite<T> {
1135
- const options = describeDefinition(...args);
1136
- return describe({
1137
- ...options,
1138
- only: true,
1139
- });
1140
- };
1141
-
1142
- /**
1143
- * Ignore the test suite.
1144
- *
1145
- * @example Usage
1146
- * ```ts
1147
- * import { describe, it, beforeAll } from "@std/testing/bdd";
1148
- * import { assertEquals } from "@std/assert";
1149
- *
1150
- * describe("example", () => {
1151
- * it("should pass", () => {
1152
- * assertEquals(2 + 2, 4);
1153
- * });
1154
- * });
1155
- *
1156
- * describe.ignore("example 2", () => {
1157
- * it("should pass too", () => {
1158
- * assertEquals(3 + 4, 7);
1159
- * });
1160
- * });
1161
- * ```
1162
- *
1163
- * @param args The test suite body
1164
- */
1165
- describe.ignore = function describeIgnore<T>(
1166
- ...args: DescribeArgs<T>
1167
- ): TestSuite<T> {
1168
- const options = describeDefinition(...args);
1169
- return describe({
1170
- ...options,
1171
- ignore: true,
1172
- });
1173
- };
1174
-
1175
- /**
1176
- * Skip the test suite.
1177
- *
1178
- * @example Usage
1179
- * ```ts
1180
- * import { describe, it, beforeAll } from "@std/testing/bdd";
1181
- * import { assertEquals } from "@std/assert";
1182
- *
1183
- * describe("example", () => {
1184
- * it("should pass", () => {
1185
- * assertEquals(2 + 2, 4);
1186
- * });
1187
- * });
1188
- *
1189
- * describe.skip("example 2", () => {
1190
- * it("should pass too", () => {
1191
- * assertEquals(3 + 4, 7);
1192
- * });
1193
- * });
1194
- * ```
1195
- *
1196
- * @param args The test suite body
1197
- */
1198
- describe.skip = function describeSkip<T>(
1199
- ...args: DescribeArgs<T>
1200
- ): TestSuite<T> {
1201
- return describe.ignore(...args);
1202
- };