mcp-server-azure-devops 1.1.0

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 (929) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +265 -0
  3. package/dist/clients/azure-devops.d.ts +105 -0
  4. package/dist/clients/azure-devops.js +492 -0
  5. package/dist/clients/azure-devops.js.map +1 -0
  6. package/dist/clients/azure-devops.spec.unit.d.ts +1 -0
  7. package/dist/clients/azure-devops.spec.unit.js +37 -0
  8. package/dist/clients/azure-devops.spec.unit.js.map +1 -0
  9. package/dist/extension.d.ts +3 -0
  10. package/dist/extension.js +93 -0
  11. package/dist/extension.js.map +1 -0
  12. package/dist/features/organizations/__test__/test-helpers.d.ts +13 -0
  13. package/dist/features/organizations/__test__/test-helpers.js +34 -0
  14. package/dist/features/organizations/__test__/test-helpers.js.map +1 -0
  15. package/dist/features/organizations/index.d.ts +13 -0
  16. package/dist/features/organizations/index.js +44 -0
  17. package/dist/features/organizations/index.js.map +1 -0
  18. package/dist/features/organizations/index.spec.unit.d.ts +1 -0
  19. package/dist/features/organizations/index.spec.unit.js +71 -0
  20. package/dist/features/organizations/index.spec.unit.js.map +1 -0
  21. package/dist/features/organizations/list-organizations/feature.d.ts +13 -0
  22. package/dist/features/organizations/list-organizations/feature.js +95 -0
  23. package/dist/features/organizations/list-organizations/feature.js.map +1 -0
  24. package/dist/features/organizations/list-organizations/feature.spec.int.d.ts +1 -0
  25. package/dist/features/organizations/list-organizations/feature.spec.int.js +32 -0
  26. package/dist/features/organizations/list-organizations/feature.spec.int.js.map +1 -0
  27. package/dist/features/organizations/list-organizations/feature.spec.unit.d.ts +1 -0
  28. package/dist/features/organizations/list-organizations/feature.spec.unit.js +110 -0
  29. package/dist/features/organizations/list-organizations/feature.spec.unit.js.map +1 -0
  30. package/dist/features/organizations/list-organizations/index.d.ts +2 -0
  31. package/dist/features/organizations/list-organizations/index.js +3 -0
  32. package/dist/features/organizations/list-organizations/index.js.map +1 -0
  33. package/dist/features/organizations/list-organizations/schema.d.ts +2 -0
  34. package/dist/features/organizations/list-organizations/schema.js +3 -0
  35. package/dist/features/organizations/list-organizations/schema.js.map +1 -0
  36. package/dist/features/organizations/schemas.d.ts +6 -0
  37. package/dist/features/organizations/schemas.js +7 -0
  38. package/dist/features/organizations/schemas.js.map +1 -0
  39. package/dist/features/organizations/tool-definitions.d.ts +5 -0
  40. package/dist/features/organizations/tool-definitions.js +13 -0
  41. package/dist/features/organizations/tool-definitions.js.map +1 -0
  42. package/dist/features/organizations/types.d.ts +21 -0
  43. package/dist/features/organizations/types.js +5 -0
  44. package/dist/features/organizations/types.js.map +1 -0
  45. package/dist/features/pipelines/artifacts.d.ts +11 -0
  46. package/dist/features/pipelines/artifacts.js +280 -0
  47. package/dist/features/pipelines/artifacts.js.map +1 -0
  48. package/dist/features/pipelines/artifacts.spec.unit.d.ts +1 -0
  49. package/dist/features/pipelines/artifacts.spec.unit.js +98 -0
  50. package/dist/features/pipelines/artifacts.spec.unit.js.map +1 -0
  51. package/dist/features/pipelines/download-pipeline-artifact/feature.d.ts +3 -0
  52. package/dist/features/pipelines/download-pipeline-artifact/feature.js +216 -0
  53. package/dist/features/pipelines/download-pipeline-artifact/feature.js.map +1 -0
  54. package/dist/features/pipelines/download-pipeline-artifact/feature.spec.unit.d.ts +1 -0
  55. package/dist/features/pipelines/download-pipeline-artifact/feature.spec.unit.js +63 -0
  56. package/dist/features/pipelines/download-pipeline-artifact/feature.spec.unit.js.map +1 -0
  57. package/dist/features/pipelines/download-pipeline-artifact/index.d.ts +2 -0
  58. package/dist/features/pipelines/download-pipeline-artifact/index.js +3 -0
  59. package/dist/features/pipelines/download-pipeline-artifact/index.js.map +1 -0
  60. package/dist/features/pipelines/download-pipeline-artifact/schema.d.ts +17 -0
  61. package/dist/features/pipelines/download-pipeline-artifact/schema.js +20 -0
  62. package/dist/features/pipelines/download-pipeline-artifact/schema.js.map +1 -0
  63. package/dist/features/pipelines/get-pipeline/feature.d.ts +10 -0
  64. package/dist/features/pipelines/get-pipeline/feature.js +43 -0
  65. package/dist/features/pipelines/get-pipeline/feature.js.map +1 -0
  66. package/dist/features/pipelines/get-pipeline/feature.spec.int.d.ts +1 -0
  67. package/dist/features/pipelines/get-pipeline/feature.spec.int.js +52 -0
  68. package/dist/features/pipelines/get-pipeline/feature.spec.int.js.map +1 -0
  69. package/dist/features/pipelines/get-pipeline/feature.spec.unit.d.ts +1 -0
  70. package/dist/features/pipelines/get-pipeline/feature.spec.unit.js +87 -0
  71. package/dist/features/pipelines/get-pipeline/feature.spec.unit.js.map +1 -0
  72. package/dist/features/pipelines/get-pipeline/index.d.ts +2 -0
  73. package/dist/features/pipelines/get-pipeline/index.js +3 -0
  74. package/dist/features/pipelines/get-pipeline/index.js.map +1 -0
  75. package/dist/features/pipelines/get-pipeline/schema.d.ts +17 -0
  76. package/dist/features/pipelines/get-pipeline/schema.js +26 -0
  77. package/dist/features/pipelines/get-pipeline/schema.js.map +1 -0
  78. package/dist/features/pipelines/get-pipeline-log/feature.d.ts +3 -0
  79. package/dist/features/pipelines/get-pipeline-log/feature.js +54 -0
  80. package/dist/features/pipelines/get-pipeline-log/feature.js.map +1 -0
  81. package/dist/features/pipelines/get-pipeline-log/feature.spec.unit.d.ts +1 -0
  82. package/dist/features/pipelines/get-pipeline-log/feature.spec.unit.js +79 -0
  83. package/dist/features/pipelines/get-pipeline-log/feature.spec.unit.js.map +1 -0
  84. package/dist/features/pipelines/get-pipeline-log/index.d.ts +2 -0
  85. package/dist/features/pipelines/get-pipeline-log/index.js +3 -0
  86. package/dist/features/pipelines/get-pipeline-log/index.js.map +1 -0
  87. package/dist/features/pipelines/get-pipeline-log/schema.d.ts +26 -0
  88. package/dist/features/pipelines/get-pipeline-log/schema.js +37 -0
  89. package/dist/features/pipelines/get-pipeline-log/schema.js.map +1 -0
  90. package/dist/features/pipelines/get-pipeline-run/feature.d.ts +3 -0
  91. package/dist/features/pipelines/get-pipeline-run/feature.js +73 -0
  92. package/dist/features/pipelines/get-pipeline-run/feature.js.map +1 -0
  93. package/dist/features/pipelines/get-pipeline-run/feature.spec.unit.d.ts +1 -0
  94. package/dist/features/pipelines/get-pipeline-run/feature.spec.unit.js +154 -0
  95. package/dist/features/pipelines/get-pipeline-run/feature.spec.unit.js.map +1 -0
  96. package/dist/features/pipelines/get-pipeline-run/index.d.ts +2 -0
  97. package/dist/features/pipelines/get-pipeline-run/index.js +3 -0
  98. package/dist/features/pipelines/get-pipeline-run/index.js.map +1 -0
  99. package/dist/features/pipelines/get-pipeline-run/schema.d.ts +14 -0
  100. package/dist/features/pipelines/get-pipeline-run/schema.js +16 -0
  101. package/dist/features/pipelines/get-pipeline-run/schema.js.map +1 -0
  102. package/dist/features/pipelines/helpers.d.ts +3 -0
  103. package/dist/features/pipelines/helpers.js +25 -0
  104. package/dist/features/pipelines/helpers.js.map +1 -0
  105. package/dist/features/pipelines/index.d.ts +19 -0
  106. package/dist/features/pipelines/index.js +137 -0
  107. package/dist/features/pipelines/index.js.map +1 -0
  108. package/dist/features/pipelines/index.spec.unit.d.ts +1 -0
  109. package/dist/features/pipelines/index.spec.unit.js +221 -0
  110. package/dist/features/pipelines/index.spec.unit.js.map +1 -0
  111. package/dist/features/pipelines/list-pipeline-runs/feature.d.ts +3 -0
  112. package/dist/features/pipelines/list-pipeline-runs/feature.js +95 -0
  113. package/dist/features/pipelines/list-pipeline-runs/feature.js.map +1 -0
  114. package/dist/features/pipelines/list-pipeline-runs/feature.spec.unit.d.ts +1 -0
  115. package/dist/features/pipelines/list-pipeline-runs/feature.spec.unit.js +146 -0
  116. package/dist/features/pipelines/list-pipeline-runs/feature.spec.unit.js.map +1 -0
  117. package/dist/features/pipelines/list-pipeline-runs/index.d.ts +2 -0
  118. package/dist/features/pipelines/list-pipeline-runs/index.js +3 -0
  119. package/dist/features/pipelines/list-pipeline-runs/index.js.map +1 -0
  120. package/dist/features/pipelines/list-pipeline-runs/schema.d.ts +35 -0
  121. package/dist/features/pipelines/list-pipeline-runs/schema.js +47 -0
  122. package/dist/features/pipelines/list-pipeline-runs/schema.js.map +1 -0
  123. package/dist/features/pipelines/list-pipelines/feature.d.ts +10 -0
  124. package/dist/features/pipelines/list-pipelines/feature.js +39 -0
  125. package/dist/features/pipelines/list-pipelines/feature.js.map +1 -0
  126. package/dist/features/pipelines/list-pipelines/feature.spec.int.d.ts +1 -0
  127. package/dist/features/pipelines/list-pipelines/feature.spec.int.js +34 -0
  128. package/dist/features/pipelines/list-pipelines/feature.spec.int.js.map +1 -0
  129. package/dist/features/pipelines/list-pipelines/feature.spec.unit.d.ts +1 -0
  130. package/dist/features/pipelines/list-pipelines/feature.spec.unit.js +89 -0
  131. package/dist/features/pipelines/list-pipelines/feature.spec.unit.js.map +1 -0
  132. package/dist/features/pipelines/list-pipelines/index.d.ts +2 -0
  133. package/dist/features/pipelines/list-pipelines/index.js +3 -0
  134. package/dist/features/pipelines/list-pipelines/index.js.map +1 -0
  135. package/dist/features/pipelines/list-pipelines/schema.d.ts +17 -0
  136. package/dist/features/pipelines/list-pipelines/schema.js +20 -0
  137. package/dist/features/pipelines/list-pipelines/schema.js.map +1 -0
  138. package/dist/features/pipelines/pipeline-timeline/feature.d.ts +3 -0
  139. package/dist/features/pipelines/pipeline-timeline/feature.js +92 -0
  140. package/dist/features/pipelines/pipeline-timeline/feature.js.map +1 -0
  141. package/dist/features/pipelines/pipeline-timeline/feature.spec.unit.d.ts +1 -0
  142. package/dist/features/pipelines/pipeline-timeline/feature.spec.unit.js +98 -0
  143. package/dist/features/pipelines/pipeline-timeline/feature.spec.unit.js.map +1 -0
  144. package/dist/features/pipelines/pipeline-timeline/index.d.ts +2 -0
  145. package/dist/features/pipelines/pipeline-timeline/index.js +3 -0
  146. package/dist/features/pipelines/pipeline-timeline/index.js.map +1 -0
  147. package/dist/features/pipelines/pipeline-timeline/schema.d.ts +23 -0
  148. package/dist/features/pipelines/pipeline-timeline/schema.js +48 -0
  149. package/dist/features/pipelines/pipeline-timeline/schema.js.map +1 -0
  150. package/dist/features/pipelines/tool-definitions.d.ts +5 -0
  151. package/dist/features/pipelines/tool-definitions.js +63 -0
  152. package/dist/features/pipelines/tool-definitions.js.map +1 -0
  153. package/dist/features/pipelines/trigger-pipeline/feature.d.ts +10 -0
  154. package/dist/features/pipelines/trigger-pipeline/feature.js +62 -0
  155. package/dist/features/pipelines/trigger-pipeline/feature.js.map +1 -0
  156. package/dist/features/pipelines/trigger-pipeline/feature.spec.int.d.ts +1 -0
  157. package/dist/features/pipelines/trigger-pipeline/feature.spec.int.js +83 -0
  158. package/dist/features/pipelines/trigger-pipeline/feature.spec.int.js.map +1 -0
  159. package/dist/features/pipelines/trigger-pipeline/feature.spec.unit.d.ts +1 -0
  160. package/dist/features/pipelines/trigger-pipeline/feature.spec.unit.js +110 -0
  161. package/dist/features/pipelines/trigger-pipeline/feature.spec.unit.js.map +1 -0
  162. package/dist/features/pipelines/trigger-pipeline/index.d.ts +2 -0
  163. package/dist/features/pipelines/trigger-pipeline/index.js +3 -0
  164. package/dist/features/pipelines/trigger-pipeline/index.js.map +1 -0
  165. package/dist/features/pipelines/trigger-pipeline/schema.d.ts +41 -0
  166. package/dist/features/pipelines/trigger-pipeline/schema.js +42 -0
  167. package/dist/features/pipelines/trigger-pipeline/schema.js.map +1 -0
  168. package/dist/features/pipelines/types.d.ts +122 -0
  169. package/dist/features/pipelines/types.js +2 -0
  170. package/dist/features/pipelines/types.js.map +1 -0
  171. package/dist/features/projects/__test__/test-helpers.d.ts +13 -0
  172. package/dist/features/projects/__test__/test-helpers.js +31 -0
  173. package/dist/features/projects/__test__/test-helpers.js.map +1 -0
  174. package/dist/features/projects/get-project/feature.d.ts +11 -0
  175. package/dist/features/projects/get-project/feature.js +26 -0
  176. package/dist/features/projects/get-project/feature.js.map +1 -0
  177. package/dist/features/projects/get-project/feature.spec.int.d.ts +1 -0
  178. package/dist/features/projects/get-project/feature.spec.int.js +37 -0
  179. package/dist/features/projects/get-project/feature.spec.int.js.map +1 -0
  180. package/dist/features/projects/get-project/feature.spec.unit.d.ts +1 -0
  181. package/dist/features/projects/get-project/feature.spec.unit.js +39 -0
  182. package/dist/features/projects/get-project/feature.spec.unit.js.map +1 -0
  183. package/dist/features/projects/get-project/index.d.ts +2 -0
  184. package/dist/features/projects/get-project/index.js +3 -0
  185. package/dist/features/projects/get-project/index.js.map +1 -0
  186. package/dist/features/projects/get-project/schema.d.ts +2 -0
  187. package/dist/features/projects/get-project/schema.js +3 -0
  188. package/dist/features/projects/get-project/schema.js.map +1 -0
  189. package/dist/features/projects/get-project-details/feature.d.ts +78 -0
  190. package/dist/features/projects/get-project-details/feature.js +182 -0
  191. package/dist/features/projects/get-project-details/feature.js.map +1 -0
  192. package/dist/features/projects/get-project-details/feature.spec.int.d.ts +1 -0
  193. package/dist/features/projects/get-project-details/feature.spec.int.js +118 -0
  194. package/dist/features/projects/get-project-details/feature.spec.int.js.map +1 -0
  195. package/dist/features/projects/get-project-details/feature.spec.unit.d.ts +1 -0
  196. package/dist/features/projects/get-project-details/feature.spec.unit.js +377 -0
  197. package/dist/features/projects/get-project-details/feature.spec.unit.js.map +1 -0
  198. package/dist/features/projects/get-project-details/index.d.ts +2 -0
  199. package/dist/features/projects/get-project-details/index.js +3 -0
  200. package/dist/features/projects/get-project-details/index.js.map +1 -0
  201. package/dist/features/projects/get-project-details/schema.d.ts +2 -0
  202. package/dist/features/projects/get-project-details/schema.js +3 -0
  203. package/dist/features/projects/get-project-details/schema.js.map +1 -0
  204. package/dist/features/projects/index.d.ts +15 -0
  205. package/dist/features/projects/index.js +61 -0
  206. package/dist/features/projects/index.js.map +1 -0
  207. package/dist/features/projects/index.spec.unit.d.ts +1 -0
  208. package/dist/features/projects/index.spec.unit.js +129 -0
  209. package/dist/features/projects/index.spec.unit.js.map +1 -0
  210. package/dist/features/projects/list-projects/feature.d.ts +10 -0
  211. package/dist/features/projects/list-projects/feature.js +22 -0
  212. package/dist/features/projects/list-projects/feature.js.map +1 -0
  213. package/dist/features/projects/list-projects/feature.spec.int.d.ts +1 -0
  214. package/dist/features/projects/list-projects/feature.spec.int.js +52 -0
  215. package/dist/features/projects/list-projects/feature.spec.int.js.map +1 -0
  216. package/dist/features/projects/list-projects/index.d.ts +2 -0
  217. package/dist/features/projects/list-projects/index.js +3 -0
  218. package/dist/features/projects/list-projects/index.js.map +1 -0
  219. package/dist/features/projects/list-projects/schema.d.ts +2 -0
  220. package/dist/features/projects/list-projects/schema.js +3 -0
  221. package/dist/features/projects/list-projects/schema.js.map +1 -0
  222. package/dist/features/projects/schemas.d.ts +64 -0
  223. package/dist/features/projects/schemas.js +73 -0
  224. package/dist/features/projects/schemas.js.map +1 -0
  225. package/dist/features/projects/tool-definitions.d.ts +5 -0
  226. package/dist/features/projects/tool-definitions.js +23 -0
  227. package/dist/features/projects/tool-definitions.js.map +1 -0
  228. package/dist/features/projects/types.d.ts +11 -0
  229. package/dist/features/projects/types.js +2 -0
  230. package/dist/features/projects/types.js.map +1 -0
  231. package/dist/features/pull-requests/add-pull-request-comment/feature.d.ts +13 -0
  232. package/dist/features/pull-requests/add-pull-request-comment/feature.js +127 -0
  233. package/dist/features/pull-requests/add-pull-request-comment/feature.js.map +1 -0
  234. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.int.d.ts +1 -0
  235. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.int.js +184 -0
  236. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.int.js.map +1 -0
  237. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.unit.d.ts +1 -0
  238. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.unit.js +257 -0
  239. package/dist/features/pull-requests/add-pull-request-comment/feature.spec.unit.js.map +1 -0
  240. package/dist/features/pull-requests/add-pull-request-comment/index.d.ts +1 -0
  241. package/dist/features/pull-requests/add-pull-request-comment/index.js +2 -0
  242. package/dist/features/pull-requests/add-pull-request-comment/index.js.map +1 -0
  243. package/dist/features/pull-requests/create-pull-request/feature.d.ts +12 -0
  244. package/dist/features/pull-requests/create-pull-request/feature.js +96 -0
  245. package/dist/features/pull-requests/create-pull-request/feature.js.map +1 -0
  246. package/dist/features/pull-requests/create-pull-request/feature.spec.int.d.ts +1 -0
  247. package/dist/features/pull-requests/create-pull-request/feature.spec.int.js +109 -0
  248. package/dist/features/pull-requests/create-pull-request/feature.spec.int.js.map +1 -0
  249. package/dist/features/pull-requests/create-pull-request/feature.spec.unit.d.ts +1 -0
  250. package/dist/features/pull-requests/create-pull-request/feature.spec.unit.js +110 -0
  251. package/dist/features/pull-requests/create-pull-request/feature.spec.unit.js.map +1 -0
  252. package/dist/features/pull-requests/create-pull-request/index.d.ts +2 -0
  253. package/dist/features/pull-requests/create-pull-request/index.js +3 -0
  254. package/dist/features/pull-requests/create-pull-request/index.js.map +1 -0
  255. package/dist/features/pull-requests/create-pull-request/schema.d.ts +2 -0
  256. package/dist/features/pull-requests/create-pull-request/schema.js +3 -0
  257. package/dist/features/pull-requests/create-pull-request/schema.js.map +1 -0
  258. package/dist/features/pull-requests/get-pull-request/feature.d.ts +6 -0
  259. package/dist/features/pull-requests/get-pull-request/feature.js +19 -0
  260. package/dist/features/pull-requests/get-pull-request/feature.js.map +1 -0
  261. package/dist/features/pull-requests/get-pull-request/feature.spec.int.d.ts +1 -0
  262. package/dist/features/pull-requests/get-pull-request/feature.spec.int.js +107 -0
  263. package/dist/features/pull-requests/get-pull-request/feature.spec.int.js.map +1 -0
  264. package/dist/features/pull-requests/get-pull-request/feature.spec.unit.d.ts +1 -0
  265. package/dist/features/pull-requests/get-pull-request/feature.spec.unit.js +35 -0
  266. package/dist/features/pull-requests/get-pull-request/feature.spec.unit.js.map +1 -0
  267. package/dist/features/pull-requests/get-pull-request/index.d.ts +2 -0
  268. package/dist/features/pull-requests/get-pull-request/index.js +3 -0
  269. package/dist/features/pull-requests/get-pull-request/index.js.map +1 -0
  270. package/dist/features/pull-requests/get-pull-request/schema.d.ts +1 -0
  271. package/dist/features/pull-requests/get-pull-request/schema.js +2 -0
  272. package/dist/features/pull-requests/get-pull-request/schema.js.map +1 -0
  273. package/dist/features/pull-requests/get-pull-request-changes/feature.d.ts +22 -0
  274. package/dist/features/pull-requests/get-pull-request-changes/feature.js +57 -0
  275. package/dist/features/pull-requests/get-pull-request-changes/feature.js.map +1 -0
  276. package/dist/features/pull-requests/get-pull-request-changes/feature.spec.unit.d.ts +1 -0
  277. package/dist/features/pull-requests/get-pull-request-changes/feature.spec.unit.js +75 -0
  278. package/dist/features/pull-requests/get-pull-request-changes/feature.spec.unit.js.map +1 -0
  279. package/dist/features/pull-requests/get-pull-request-changes/index.d.ts +1 -0
  280. package/dist/features/pull-requests/get-pull-request-changes/index.js +2 -0
  281. package/dist/features/pull-requests/get-pull-request-changes/index.js.map +1 -0
  282. package/dist/features/pull-requests/get-pull-request-checks/feature.d.ts +51 -0
  283. package/dist/features/pull-requests/get-pull-request-checks/feature.js +256 -0
  284. package/dist/features/pull-requests/get-pull-request-checks/feature.js.map +1 -0
  285. package/dist/features/pull-requests/get-pull-request-checks/feature.spec.unit.d.ts +1 -0
  286. package/dist/features/pull-requests/get-pull-request-checks/feature.spec.unit.js +136 -0
  287. package/dist/features/pull-requests/get-pull-request-checks/feature.spec.unit.js.map +1 -0
  288. package/dist/features/pull-requests/get-pull-request-checks/index.d.ts +1 -0
  289. package/dist/features/pull-requests/get-pull-request-checks/index.js +2 -0
  290. package/dist/features/pull-requests/get-pull-request-checks/index.js.map +1 -0
  291. package/dist/features/pull-requests/get-pull-request-comments/feature.d.ts +13 -0
  292. package/dist/features/pull-requests/get-pull-request-comments/feature.js +85 -0
  293. package/dist/features/pull-requests/get-pull-request-comments/feature.js.map +1 -0
  294. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.int.d.ts +1 -0
  295. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.int.js +214 -0
  296. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.int.js.map +1 -0
  297. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.unit.d.ts +1 -0
  298. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.unit.js +338 -0
  299. package/dist/features/pull-requests/get-pull-request-comments/feature.spec.unit.js.map +1 -0
  300. package/dist/features/pull-requests/get-pull-request-comments/index.d.ts +1 -0
  301. package/dist/features/pull-requests/get-pull-request-comments/index.js +2 -0
  302. package/dist/features/pull-requests/get-pull-request-comments/index.js.map +1 -0
  303. package/dist/features/pull-requests/index.d.ts +20 -0
  304. package/dist/features/pull-requests/index.js +138 -0
  305. package/dist/features/pull-requests/index.js.map +1 -0
  306. package/dist/features/pull-requests/index.spec.unit.d.ts +1 -0
  307. package/dist/features/pull-requests/index.spec.unit.js +259 -0
  308. package/dist/features/pull-requests/index.spec.unit.js.map +1 -0
  309. package/dist/features/pull-requests/list-pull-requests/feature.d.ts +17 -0
  310. package/dist/features/pull-requests/list-pull-requests/feature.js +78 -0
  311. package/dist/features/pull-requests/list-pull-requests/feature.js.map +1 -0
  312. package/dist/features/pull-requests/list-pull-requests/feature.spec.int.d.ts +1 -0
  313. package/dist/features/pull-requests/list-pull-requests/feature.spec.int.js +122 -0
  314. package/dist/features/pull-requests/list-pull-requests/feature.spec.int.js.map +1 -0
  315. package/dist/features/pull-requests/list-pull-requests/feature.spec.unit.d.ts +1 -0
  316. package/dist/features/pull-requests/list-pull-requests/feature.spec.unit.js +178 -0
  317. package/dist/features/pull-requests/list-pull-requests/feature.spec.unit.js.map +1 -0
  318. package/dist/features/pull-requests/list-pull-requests/index.d.ts +2 -0
  319. package/dist/features/pull-requests/list-pull-requests/index.js +3 -0
  320. package/dist/features/pull-requests/list-pull-requests/index.js.map +1 -0
  321. package/dist/features/pull-requests/list-pull-requests/schema.d.ts +1 -0
  322. package/dist/features/pull-requests/list-pull-requests/schema.js +2 -0
  323. package/dist/features/pull-requests/list-pull-requests/schema.js.map +1 -0
  324. package/dist/features/pull-requests/schemas.d.ts +318 -0
  325. package/dist/features/pull-requests/schemas.js +280 -0
  326. package/dist/features/pull-requests/schemas.js.map +1 -0
  327. package/dist/features/pull-requests/tool-definitions.d.ts +5 -0
  328. package/dist/features/pull-requests/tool-definitions.js +52 -0
  329. package/dist/features/pull-requests/tool-definitions.js.map +1 -0
  330. package/dist/features/pull-requests/types.d.ts +100 -0
  331. package/dist/features/pull-requests/types.js +2 -0
  332. package/dist/features/pull-requests/types.js.map +1 -0
  333. package/dist/features/pull-requests/update-pull-request/feature.d.ts +9 -0
  334. package/dist/features/pull-requests/update-pull-request/feature.js +246 -0
  335. package/dist/features/pull-requests/update-pull-request/feature.js.map +1 -0
  336. package/dist/features/pull-requests/update-pull-request/feature.spec.int.d.ts +1 -0
  337. package/dist/features/pull-requests/update-pull-request/feature.spec.int.js +160 -0
  338. package/dist/features/pull-requests/update-pull-request/feature.spec.int.js.map +1 -0
  339. package/dist/features/pull-requests/update-pull-request/feature.spec.unit.d.ts +1 -0
  340. package/dist/features/pull-requests/update-pull-request/feature.spec.unit.js +278 -0
  341. package/dist/features/pull-requests/update-pull-request/feature.spec.unit.js.map +1 -0
  342. package/dist/features/pull-requests/update-pull-request/index.d.ts +1 -0
  343. package/dist/features/pull-requests/update-pull-request/index.js +2 -0
  344. package/dist/features/pull-requests/update-pull-request/index.js.map +1 -0
  345. package/dist/features/releases/create-release/feature.d.ts +3 -0
  346. package/dist/features/releases/create-release/feature.js +48 -0
  347. package/dist/features/releases/create-release/feature.js.map +1 -0
  348. package/dist/features/releases/create-release/index.d.ts +2 -0
  349. package/dist/features/releases/create-release/index.js +3 -0
  350. package/dist/features/releases/create-release/index.js.map +1 -0
  351. package/dist/features/releases/create-release/schema.d.ts +20 -0
  352. package/dist/features/releases/create-release/schema.js +21 -0
  353. package/dist/features/releases/create-release/schema.js.map +1 -0
  354. package/dist/features/releases/deploy-release-stage/feature.d.ts +9 -0
  355. package/dist/features/releases/deploy-release-stage/feature.js +35 -0
  356. package/dist/features/releases/deploy-release-stage/feature.js.map +1 -0
  357. package/dist/features/releases/deploy-release-stage/index.d.ts +2 -0
  358. package/dist/features/releases/deploy-release-stage/index.js +3 -0
  359. package/dist/features/releases/deploy-release-stage/index.js.map +1 -0
  360. package/dist/features/releases/deploy-release-stage/schema.d.ts +17 -0
  361. package/dist/features/releases/deploy-release-stage/schema.js +17 -0
  362. package/dist/features/releases/deploy-release-stage/schema.js.map +1 -0
  363. package/dist/features/releases/get-release/feature.d.ts +3 -0
  364. package/dist/features/releases/get-release/feature.js +31 -0
  365. package/dist/features/releases/get-release/feature.js.map +1 -0
  366. package/dist/features/releases/get-release/index.d.ts +2 -0
  367. package/dist/features/releases/get-release/index.js +3 -0
  368. package/dist/features/releases/get-release/index.js.map +1 -0
  369. package/dist/features/releases/get-release/schema.d.ts +11 -0
  370. package/dist/features/releases/get-release/schema.js +10 -0
  371. package/dist/features/releases/get-release/schema.js.map +1 -0
  372. package/dist/features/releases/get-release-definition/feature.d.ts +3 -0
  373. package/dist/features/releases/get-release-definition/feature.js +31 -0
  374. package/dist/features/releases/get-release-definition/feature.js.map +1 -0
  375. package/dist/features/releases/get-release-definition/index.d.ts +2 -0
  376. package/dist/features/releases/get-release-definition/index.js +3 -0
  377. package/dist/features/releases/get-release-definition/index.js.map +1 -0
  378. package/dist/features/releases/get-release-definition/schema.d.ts +11 -0
  379. package/dist/features/releases/get-release-definition/schema.js +10 -0
  380. package/dist/features/releases/get-release-definition/schema.js.map +1 -0
  381. package/dist/features/releases/index.d.ts +11 -0
  382. package/dist/features/releases/index.js +102 -0
  383. package/dist/features/releases/index.js.map +1 -0
  384. package/dist/features/releases/list-release-definitions/feature.d.ts +3 -0
  385. package/dist/features/releases/list-release-definitions/feature.js +28 -0
  386. package/dist/features/releases/list-release-definitions/feature.js.map +1 -0
  387. package/dist/features/releases/list-release-definitions/index.d.ts +2 -0
  388. package/dist/features/releases/list-release-definitions/index.js +3 -0
  389. package/dist/features/releases/list-release-definitions/index.js.map +1 -0
  390. package/dist/features/releases/list-release-definitions/schema.d.ts +17 -0
  391. package/dist/features/releases/list-release-definitions/schema.js +21 -0
  392. package/dist/features/releases/list-release-definitions/schema.js.map +1 -0
  393. package/dist/features/releases/list-releases/feature.d.ts +3 -0
  394. package/dist/features/releases/list-releases/feature.js +28 -0
  395. package/dist/features/releases/list-releases/feature.js.map +1 -0
  396. package/dist/features/releases/list-releases/index.d.ts +2 -0
  397. package/dist/features/releases/list-releases/index.js +3 -0
  398. package/dist/features/releases/list-releases/index.js.map +1 -0
  399. package/dist/features/releases/list-releases/schema.d.ts +26 -0
  400. package/dist/features/releases/list-releases/schema.js +27 -0
  401. package/dist/features/releases/list-releases/schema.js.map +1 -0
  402. package/dist/features/releases/tool-definitions.d.ts +2 -0
  403. package/dist/features/releases/tool-definitions.js +46 -0
  404. package/dist/features/releases/tool-definitions.js.map +1 -0
  405. package/dist/features/releases/types.d.ts +32 -0
  406. package/dist/features/releases/types.js +2 -0
  407. package/dist/features/releases/types.js.map +1 -0
  408. package/dist/features/repositories/__test__/test-helpers.d.ts +13 -0
  409. package/dist/features/repositories/__test__/test-helpers.js +31 -0
  410. package/dist/features/repositories/__test__/test-helpers.js.map +1 -0
  411. package/dist/features/repositories/create-branch/feature.d.ts +6 -0
  412. package/dist/features/repositories/create-branch/feature.js +30 -0
  413. package/dist/features/repositories/create-branch/feature.js.map +1 -0
  414. package/dist/features/repositories/create-branch/feature.spec.unit.d.ts +1 -0
  415. package/dist/features/repositories/create-branch/feature.spec.unit.js +34 -0
  416. package/dist/features/repositories/create-branch/feature.spec.unit.js.map +1 -0
  417. package/dist/features/repositories/create-branch/index.d.ts +1 -0
  418. package/dist/features/repositories/create-branch/index.js +2 -0
  419. package/dist/features/repositories/create-branch/index.js.map +1 -0
  420. package/dist/features/repositories/create-commit/feature.d.ts +6 -0
  421. package/dist/features/repositories/create-commit/feature.js +119 -0
  422. package/dist/features/repositories/create-commit/feature.js.map +1 -0
  423. package/dist/features/repositories/create-commit/feature.spec.unit.d.ts +1 -0
  424. package/dist/features/repositories/create-commit/feature.spec.unit.js +155 -0
  425. package/dist/features/repositories/create-commit/feature.spec.unit.js.map +1 -0
  426. package/dist/features/repositories/create-commit/index.d.ts +1 -0
  427. package/dist/features/repositories/create-commit/index.js +2 -0
  428. package/dist/features/repositories/create-commit/index.js.map +1 -0
  429. package/dist/features/repositories/get-all-repositories-tree/feature.d.ts +22 -0
  430. package/dist/features/repositories/get-all-repositories-tree/feature.js +299 -0
  431. package/dist/features/repositories/get-all-repositories-tree/feature.js.map +1 -0
  432. package/dist/features/repositories/get-all-repositories-tree/feature.spec.int.d.ts +1 -0
  433. package/dist/features/repositories/get-all-repositories-tree/feature.spec.int.js +87 -0
  434. package/dist/features/repositories/get-all-repositories-tree/feature.spec.int.js.map +1 -0
  435. package/dist/features/repositories/get-all-repositories-tree/feature.spec.unit.d.ts +1 -0
  436. package/dist/features/repositories/get-all-repositories-tree/feature.spec.unit.js +389 -0
  437. package/dist/features/repositories/get-all-repositories-tree/feature.spec.unit.js.map +1 -0
  438. package/dist/features/repositories/get-all-repositories-tree/index.d.ts +2 -0
  439. package/dist/features/repositories/get-all-repositories-tree/index.js +3 -0
  440. package/dist/features/repositories/get-all-repositories-tree/index.js.map +1 -0
  441. package/dist/features/repositories/get-all-repositories-tree/schema.d.ts +2 -0
  442. package/dist/features/repositories/get-all-repositories-tree/schema.js +4 -0
  443. package/dist/features/repositories/get-all-repositories-tree/schema.js.map +1 -0
  444. package/dist/features/repositories/get-file-content/feature.d.ts +23 -0
  445. package/dist/features/repositories/get-file-content/feature.js +93 -0
  446. package/dist/features/repositories/get-file-content/feature.js.map +1 -0
  447. package/dist/features/repositories/get-file-content/feature.spec.int.d.ts +1 -0
  448. package/dist/features/repositories/get-file-content/feature.spec.int.js +84 -0
  449. package/dist/features/repositories/get-file-content/feature.spec.int.js.map +1 -0
  450. package/dist/features/repositories/get-file-content/feature.spec.unit.d.ts +1 -0
  451. package/dist/features/repositories/get-file-content/feature.spec.unit.js +126 -0
  452. package/dist/features/repositories/get-file-content/feature.spec.unit.js.map +1 -0
  453. package/dist/features/repositories/get-file-content/index.d.ts +2 -0
  454. package/dist/features/repositories/get-file-content/index.js +3 -0
  455. package/dist/features/repositories/get-file-content/index.js.map +1 -0
  456. package/dist/features/repositories/get-file-content/schema.d.ts +2 -0
  457. package/dist/features/repositories/get-file-content/schema.js +4 -0
  458. package/dist/features/repositories/get-file-content/schema.js.map +1 -0
  459. package/dist/features/repositories/get-repository/feature.d.ts +12 -0
  460. package/dist/features/repositories/get-repository/feature.js +27 -0
  461. package/dist/features/repositories/get-repository/feature.js.map +1 -0
  462. package/dist/features/repositories/get-repository/feature.spec.int.d.ts +1 -0
  463. package/dist/features/repositories/get-repository/feature.spec.int.js +42 -0
  464. package/dist/features/repositories/get-repository/feature.spec.int.js.map +1 -0
  465. package/dist/features/repositories/get-repository/feature.spec.unit.d.ts +1 -0
  466. package/dist/features/repositories/get-repository/feature.spec.unit.js +39 -0
  467. package/dist/features/repositories/get-repository/feature.spec.unit.js.map +1 -0
  468. package/dist/features/repositories/get-repository/index.d.ts +2 -0
  469. package/dist/features/repositories/get-repository/index.js +3 -0
  470. package/dist/features/repositories/get-repository/index.js.map +1 -0
  471. package/dist/features/repositories/get-repository/schema.d.ts +2 -0
  472. package/dist/features/repositories/get-repository/schema.js +3 -0
  473. package/dist/features/repositories/get-repository/schema.js.map +1 -0
  474. package/dist/features/repositories/get-repository-details/feature.d.ts +11 -0
  475. package/dist/features/repositories/get-repository-details/feature.js +64 -0
  476. package/dist/features/repositories/get-repository-details/feature.js.map +1 -0
  477. package/dist/features/repositories/get-repository-details/feature.spec.int.d.ts +1 -0
  478. package/dist/features/repositories/get-repository-details/feature.spec.int.js +117 -0
  479. package/dist/features/repositories/get-repository-details/feature.spec.int.js.map +1 -0
  480. package/dist/features/repositories/get-repository-details/feature.spec.unit.d.ts +1 -0
  481. package/dist/features/repositories/get-repository-details/feature.spec.unit.js +253 -0
  482. package/dist/features/repositories/get-repository-details/feature.spec.unit.js.map +1 -0
  483. package/dist/features/repositories/get-repository-details/index.d.ts +2 -0
  484. package/dist/features/repositories/get-repository-details/index.js +3 -0
  485. package/dist/features/repositories/get-repository-details/index.js.map +1 -0
  486. package/dist/features/repositories/get-repository-details/schema.d.ts +2 -0
  487. package/dist/features/repositories/get-repository-details/schema.js +3 -0
  488. package/dist/features/repositories/get-repository-details/schema.js.map +1 -0
  489. package/dist/features/repositories/get-repository-tree/feature.d.ts +6 -0
  490. package/dist/features/repositories/get-repository-tree/feature.js +62 -0
  491. package/dist/features/repositories/get-repository-tree/feature.js.map +1 -0
  492. package/dist/features/repositories/get-repository-tree/feature.spec.unit.d.ts +1 -0
  493. package/dist/features/repositories/get-repository-tree/feature.spec.unit.js +67 -0
  494. package/dist/features/repositories/get-repository-tree/feature.spec.unit.js.map +1 -0
  495. package/dist/features/repositories/get-repository-tree/index.d.ts +1 -0
  496. package/dist/features/repositories/get-repository-tree/index.js +2 -0
  497. package/dist/features/repositories/get-repository-tree/index.js.map +1 -0
  498. package/dist/features/repositories/index.d.ts +21 -0
  499. package/dist/features/repositories/index.js +160 -0
  500. package/dist/features/repositories/index.js.map +1 -0
  501. package/dist/features/repositories/index.spec.unit.d.ts +1 -0
  502. package/dist/features/repositories/index.spec.unit.js +289 -0
  503. package/dist/features/repositories/index.spec.unit.js.map +1 -0
  504. package/dist/features/repositories/list-commits/feature.d.ts +6 -0
  505. package/dist/features/repositories/list-commits/feature.js +72 -0
  506. package/dist/features/repositories/list-commits/feature.js.map +1 -0
  507. package/dist/features/repositories/list-commits/feature.spec.unit.d.ts +1 -0
  508. package/dist/features/repositories/list-commits/feature.spec.unit.js +56 -0
  509. package/dist/features/repositories/list-commits/feature.spec.unit.js.map +1 -0
  510. package/dist/features/repositories/list-commits/index.d.ts +1 -0
  511. package/dist/features/repositories/list-commits/index.js +2 -0
  512. package/dist/features/repositories/list-commits/index.js.map +1 -0
  513. package/dist/features/repositories/list-repositories/feature.d.ts +10 -0
  514. package/dist/features/repositories/list-repositories/feature.js +22 -0
  515. package/dist/features/repositories/list-repositories/feature.js.map +1 -0
  516. package/dist/features/repositories/list-repositories/feature.spec.int.d.ts +1 -0
  517. package/dist/features/repositories/list-repositories/feature.spec.int.js +54 -0
  518. package/dist/features/repositories/list-repositories/feature.spec.int.js.map +1 -0
  519. package/dist/features/repositories/list-repositories/feature.spec.unit.d.ts +1 -0
  520. package/dist/features/repositories/list-repositories/feature.spec.unit.js +57 -0
  521. package/dist/features/repositories/list-repositories/feature.spec.unit.js.map +1 -0
  522. package/dist/features/repositories/list-repositories/index.d.ts +2 -0
  523. package/dist/features/repositories/list-repositories/index.js +3 -0
  524. package/dist/features/repositories/list-repositories/index.js.map +1 -0
  525. package/dist/features/repositories/list-repositories/schema.d.ts +2 -0
  526. package/dist/features/repositories/list-repositories/schema.js +3 -0
  527. package/dist/features/repositories/list-repositories/schema.js.map +1 -0
  528. package/dist/features/repositories/schemas.d.ts +237 -0
  529. package/dist/features/repositories/schemas.js +303 -0
  530. package/dist/features/repositories/schemas.js.map +1 -0
  531. package/dist/features/repositories/tool-definitions.d.ts +5 -0
  532. package/dist/features/repositories/tool-definitions.js +91 -0
  533. package/dist/features/repositories/tool-definitions.js.map +1 -0
  534. package/dist/features/repositories/types.d.ts +167 -0
  535. package/dist/features/repositories/types.js +2 -0
  536. package/dist/features/repositories/types.js.map +1 -0
  537. package/dist/features/search/index.d.ts +15 -0
  538. package/dist/features/search/index.js +46 -0
  539. package/dist/features/search/index.js.map +1 -0
  540. package/dist/features/search/index.spec.unit.d.ts +1 -0
  541. package/dist/features/search/index.spec.unit.js +141 -0
  542. package/dist/features/search/index.spec.unit.js.map +1 -0
  543. package/dist/features/search/schemas.d.ts +171 -0
  544. package/dist/features/search/schemas.js +156 -0
  545. package/dist/features/search/schemas.js.map +1 -0
  546. package/dist/features/search/schemas.spec.unit.d.ts +0 -0
  547. package/dist/features/search/schemas.spec.unit.js +38 -0
  548. package/dist/features/search/schemas.spec.unit.js.map +1 -0
  549. package/dist/features/search/search-code/feature.d.ts +10 -0
  550. package/dist/features/search/search-code/feature.js +171 -0
  551. package/dist/features/search/search-code/feature.js.map +1 -0
  552. package/dist/features/search/search-code/feature.spec.int.d.ts +1 -0
  553. package/dist/features/search/search-code/feature.spec.int.js +190 -0
  554. package/dist/features/search/search-code/feature.spec.int.js.map +1 -0
  555. package/dist/features/search/search-code/feature.spec.unit.d.ts +1 -0
  556. package/dist/features/search/search-code/feature.spec.unit.js +963 -0
  557. package/dist/features/search/search-code/feature.spec.unit.js.map +1 -0
  558. package/dist/features/search/search-code/index.d.ts +2 -0
  559. package/dist/features/search/search-code/index.js +3 -0
  560. package/dist/features/search/search-code/index.js.map +1 -0
  561. package/dist/features/search/search-wiki/feature.d.ts +10 -0
  562. package/dist/features/search/search-wiki/feature.js +126 -0
  563. package/dist/features/search/search-wiki/feature.js.map +1 -0
  564. package/dist/features/search/search-wiki/feature.spec.int.d.ts +1 -0
  565. package/dist/features/search/search-wiki/feature.spec.int.js +65 -0
  566. package/dist/features/search/search-wiki/feature.spec.int.js.map +1 -0
  567. package/dist/features/search/search-wiki/feature.spec.unit.d.ts +1 -0
  568. package/dist/features/search/search-wiki/feature.spec.unit.js +171 -0
  569. package/dist/features/search/search-wiki/feature.spec.unit.js.map +1 -0
  570. package/dist/features/search/search-wiki/index.d.ts +1 -0
  571. package/dist/features/search/search-wiki/index.js +2 -0
  572. package/dist/features/search/search-wiki/index.js.map +1 -0
  573. package/dist/features/search/search-work-items/feature.d.ts +10 -0
  574. package/dist/features/search/search-work-items/feature.js +112 -0
  575. package/dist/features/search/search-work-items/feature.js.map +1 -0
  576. package/dist/features/search/search-work-items/feature.spec.int.d.ts +1 -0
  577. package/dist/features/search/search-work-items/feature.spec.int.js +148 -0
  578. package/dist/features/search/search-work-items/feature.spec.int.js.map +1 -0
  579. package/dist/features/search/search-work-items/feature.spec.unit.d.ts +1 -0
  580. package/dist/features/search/search-work-items/feature.spec.unit.js +337 -0
  581. package/dist/features/search/search-work-items/feature.spec.unit.js.map +1 -0
  582. package/dist/features/search/search-work-items/index.d.ts +1 -0
  583. package/dist/features/search/search-work-items/index.js +2 -0
  584. package/dist/features/search/search-work-items/index.js.map +1 -0
  585. package/dist/features/search/tool-definitions.d.ts +5 -0
  586. package/dist/features/search/tool-definitions.js +23 -0
  587. package/dist/features/search/tool-definitions.js.map +1 -0
  588. package/dist/features/search/types.d.ts +537 -0
  589. package/dist/features/search/types.js +2 -0
  590. package/dist/features/search/types.js.map +1 -0
  591. package/dist/features/users/get-me/feature.d.ts +12 -0
  592. package/dist/features/users/get-me/feature.js +90 -0
  593. package/dist/features/users/get-me/feature.js.map +1 -0
  594. package/dist/features/users/get-me/feature.spec.int.d.ts +1 -0
  595. package/dist/features/users/get-me/feature.spec.int.js +31 -0
  596. package/dist/features/users/get-me/feature.spec.int.js.map +1 -0
  597. package/dist/features/users/get-me/feature.spec.unit.d.ts +1 -0
  598. package/dist/features/users/get-me/feature.spec.unit.js +159 -0
  599. package/dist/features/users/get-me/feature.spec.unit.js.map +1 -0
  600. package/dist/features/users/get-me/index.d.ts +2 -0
  601. package/dist/features/users/get-me/index.js +3 -0
  602. package/dist/features/users/get-me/index.js.map +1 -0
  603. package/dist/features/users/get-me/schema.d.ts +2 -0
  604. package/dist/features/users/get-me/schema.js +3 -0
  605. package/dist/features/users/get-me/schema.js.map +1 -0
  606. package/dist/features/users/index.d.ts +17 -0
  607. package/dist/features/users/index.js +33 -0
  608. package/dist/features/users/index.js.map +1 -0
  609. package/dist/features/users/index.spec.unit.d.ts +1 -0
  610. package/dist/features/users/index.spec.unit.js +69 -0
  611. package/dist/features/users/index.spec.unit.js.map +1 -0
  612. package/dist/features/users/schemas.d.ts +5 -0
  613. package/dist/features/users/schemas.js +6 -0
  614. package/dist/features/users/schemas.js.map +1 -0
  615. package/dist/features/users/tool-definitions.d.ts +5 -0
  616. package/dist/features/users/tool-definitions.js +13 -0
  617. package/dist/features/users/tool-definitions.js.map +1 -0
  618. package/dist/features/users/types.d.ts +17 -0
  619. package/dist/features/users/types.js +2 -0
  620. package/dist/features/users/types.js.map +1 -0
  621. package/dist/features/wikis/create-wiki/feature.d.ts +49 -0
  622. package/dist/features/wikis/create-wiki/feature.js +53 -0
  623. package/dist/features/wikis/create-wiki/feature.js.map +1 -0
  624. package/dist/features/wikis/create-wiki/feature.spec.int.d.ts +1 -0
  625. package/dist/features/wikis/create-wiki/feature.spec.int.js +42 -0
  626. package/dist/features/wikis/create-wiki/feature.spec.int.js.map +1 -0
  627. package/dist/features/wikis/create-wiki/feature.spec.unit.d.ts +1 -0
  628. package/dist/features/wikis/create-wiki/feature.spec.unit.js +166 -0
  629. package/dist/features/wikis/create-wiki/feature.spec.unit.js.map +1 -0
  630. package/dist/features/wikis/create-wiki/index.d.ts +2 -0
  631. package/dist/features/wikis/create-wiki/index.js +3 -0
  632. package/dist/features/wikis/create-wiki/index.js.map +1 -0
  633. package/dist/features/wikis/create-wiki/schema.d.ts +53 -0
  634. package/dist/features/wikis/create-wiki/schema.js +57 -0
  635. package/dist/features/wikis/create-wiki/schema.js.map +1 -0
  636. package/dist/features/wikis/create-wiki-page/feature.d.ts +18 -0
  637. package/dist/features/wikis/create-wiki-page/feature.js +58 -0
  638. package/dist/features/wikis/create-wiki-page/feature.js.map +1 -0
  639. package/dist/features/wikis/create-wiki-page/feature.spec.int.d.ts +1 -0
  640. package/dist/features/wikis/create-wiki-page/feature.spec.int.js +272 -0
  641. package/dist/features/wikis/create-wiki-page/feature.spec.int.js.map +1 -0
  642. package/dist/features/wikis/create-wiki-page/feature.spec.unit.d.ts +1 -0
  643. package/dist/features/wikis/create-wiki-page/feature.spec.unit.js +139 -0
  644. package/dist/features/wikis/create-wiki-page/feature.spec.unit.js.map +1 -0
  645. package/dist/features/wikis/create-wiki-page/index.d.ts +2 -0
  646. package/dist/features/wikis/create-wiki-page/index.js +3 -0
  647. package/dist/features/wikis/create-wiki-page/index.js.map +1 -0
  648. package/dist/features/wikis/create-wiki-page/schema.d.ts +26 -0
  649. package/dist/features/wikis/create-wiki-page/schema.js +33 -0
  650. package/dist/features/wikis/create-wiki-page/schema.js.map +1 -0
  651. package/dist/features/wikis/get-wiki-page/feature.d.ts +33 -0
  652. package/dist/features/wikis/get-wiki-page/feature.js +32 -0
  653. package/dist/features/wikis/get-wiki-page/feature.js.map +1 -0
  654. package/dist/features/wikis/get-wiki-page/feature.spec.int.d.ts +1 -0
  655. package/dist/features/wikis/get-wiki-page/feature.spec.int.js +56 -0
  656. package/dist/features/wikis/get-wiki-page/feature.spec.int.js.map +1 -0
  657. package/dist/features/wikis/get-wiki-page/feature.spec.unit.d.ts +1 -0
  658. package/dist/features/wikis/get-wiki-page/feature.spec.unit.js +86 -0
  659. package/dist/features/wikis/get-wiki-page/feature.spec.unit.js.map +1 -0
  660. package/dist/features/wikis/get-wiki-page/index.d.ts +2 -0
  661. package/dist/features/wikis/get-wiki-page/index.js +3 -0
  662. package/dist/features/wikis/get-wiki-page/index.js.map +1 -0
  663. package/dist/features/wikis/get-wiki-page/schema.d.ts +20 -0
  664. package/dist/features/wikis/get-wiki-page/schema.js +20 -0
  665. package/dist/features/wikis/get-wiki-page/schema.js.map +1 -0
  666. package/dist/features/wikis/get-wikis/feature.d.ts +25 -0
  667. package/dist/features/wikis/get-wikis/feature.js +34 -0
  668. package/dist/features/wikis/get-wikis/feature.js.map +1 -0
  669. package/dist/features/wikis/get-wikis/feature.spec.int.d.ts +1 -0
  670. package/dist/features/wikis/get-wikis/feature.spec.int.js +32 -0
  671. package/dist/features/wikis/get-wikis/feature.spec.int.js.map +1 -0
  672. package/dist/features/wikis/get-wikis/feature.spec.unit.d.ts +1 -0
  673. package/dist/features/wikis/get-wikis/feature.spec.unit.js +81 -0
  674. package/dist/features/wikis/get-wikis/feature.spec.unit.js.map +1 -0
  675. package/dist/features/wikis/get-wikis/index.d.ts +2 -0
  676. package/dist/features/wikis/get-wikis/index.js +3 -0
  677. package/dist/features/wikis/get-wikis/index.js.map +1 -0
  678. package/dist/features/wikis/get-wikis/schema.d.ts +14 -0
  679. package/dist/features/wikis/get-wikis/schema.js +18 -0
  680. package/dist/features/wikis/get-wikis/schema.js.map +1 -0
  681. package/dist/features/wikis/index.d.ts +16 -0
  682. package/dist/features/wikis/index.js +109 -0
  683. package/dist/features/wikis/index.js.map +1 -0
  684. package/dist/features/wikis/index.spec.unit.d.ts +1 -0
  685. package/dist/features/wikis/index.spec.unit.js +212 -0
  686. package/dist/features/wikis/index.spec.unit.js.map +1 -0
  687. package/dist/features/wikis/list-wiki-pages/feature.d.ts +20 -0
  688. package/dist/features/wikis/list-wiki-pages/feature.js +43 -0
  689. package/dist/features/wikis/list-wiki-pages/feature.js.map +1 -0
  690. package/dist/features/wikis/list-wiki-pages/feature.spec.int.d.ts +1 -0
  691. package/dist/features/wikis/list-wiki-pages/feature.spec.int.js +228 -0
  692. package/dist/features/wikis/list-wiki-pages/feature.spec.int.js.map +1 -0
  693. package/dist/features/wikis/list-wiki-pages/feature.spec.unit.d.ts +1 -0
  694. package/dist/features/wikis/list-wiki-pages/feature.spec.unit.js +392 -0
  695. package/dist/features/wikis/list-wiki-pages/feature.spec.unit.js.map +1 -0
  696. package/dist/features/wikis/list-wiki-pages/index.d.ts +2 -0
  697. package/dist/features/wikis/list-wiki-pages/index.js +3 -0
  698. package/dist/features/wikis/list-wiki-pages/index.js.map +1 -0
  699. package/dist/features/wikis/list-wiki-pages/schema.d.ts +18 -0
  700. package/dist/features/wikis/list-wiki-pages/schema.js +19 -0
  701. package/dist/features/wikis/list-wiki-pages/schema.js.map +1 -0
  702. package/dist/features/wikis/tool-definitions.d.ts +5 -0
  703. package/dist/features/wikis/tool-definitions.js +43 -0
  704. package/dist/features/wikis/tool-definitions.js.map +1 -0
  705. package/dist/features/wikis/update-wiki-page/feature.d.ts +12 -0
  706. package/dist/features/wikis/update-wiki-page/feature.js +27 -0
  707. package/dist/features/wikis/update-wiki-page/feature.js.map +1 -0
  708. package/dist/features/wikis/update-wiki-page/feature.spec.int.d.ts +1 -0
  709. package/dist/features/wikis/update-wiki-page/feature.spec.int.js +37 -0
  710. package/dist/features/wikis/update-wiki-page/feature.spec.int.js.map +1 -0
  711. package/dist/features/wikis/update-wiki-page/index.d.ts +2 -0
  712. package/dist/features/wikis/update-wiki-page/index.js +3 -0
  713. package/dist/features/wikis/update-wiki-page/index.js.map +1 -0
  714. package/dist/features/wikis/update-wiki-page/schema.d.ts +26 -0
  715. package/dist/features/wikis/update-wiki-page/schema.js +29 -0
  716. package/dist/features/wikis/update-wiki-page/schema.js.map +1 -0
  717. package/dist/features/work-items/__test__/fixtures.d.ts +9 -0
  718. package/dist/features/work-items/__test__/fixtures.js +23 -0
  719. package/dist/features/work-items/__test__/fixtures.js.map +1 -0
  720. package/dist/features/work-items/__test__/test-helpers.d.ts +13 -0
  721. package/dist/features/work-items/__test__/test-helpers.js +31 -0
  722. package/dist/features/work-items/__test__/test-helpers.js.map +1 -0
  723. package/dist/features/work-items/__test__/test-utils.d.ts +17 -0
  724. package/dist/features/work-items/__test__/test-utils.js +35 -0
  725. package/dist/features/work-items/__test__/test-utils.js.map +1 -0
  726. package/dist/features/work-items/create-work-item/feature.d.ts +12 -0
  727. package/dist/features/work-items/create-work-item/feature.js +96 -0
  728. package/dist/features/work-items/create-work-item/feature.js.map +1 -0
  729. package/dist/features/work-items/create-work-item/feature.spec.int.d.ts +1 -0
  730. package/dist/features/work-items/create-work-item/feature.spec.int.js +103 -0
  731. package/dist/features/work-items/create-work-item/feature.spec.int.js.map +1 -0
  732. package/dist/features/work-items/create-work-item/feature.spec.unit.d.ts +1 -0
  733. package/dist/features/work-items/create-work-item/feature.spec.unit.js +44 -0
  734. package/dist/features/work-items/create-work-item/feature.spec.unit.js.map +1 -0
  735. package/dist/features/work-items/create-work-item/index.d.ts +2 -0
  736. package/dist/features/work-items/create-work-item/index.js +3 -0
  737. package/dist/features/work-items/create-work-item/index.js.map +1 -0
  738. package/dist/features/work-items/create-work-item/schema.d.ts +2 -0
  739. package/dist/features/work-items/create-work-item/schema.js +3 -0
  740. package/dist/features/work-items/create-work-item/schema.js.map +1 -0
  741. package/dist/features/work-items/get-work-item/feature.d.ts +12 -0
  742. package/dist/features/work-items/get-work-item/feature.js +66 -0
  743. package/dist/features/work-items/get-work-item/feature.js.map +1 -0
  744. package/dist/features/work-items/get-work-item/feature.spec.int.d.ts +1 -0
  745. package/dist/features/work-items/get-work-item/feature.spec.int.js +136 -0
  746. package/dist/features/work-items/get-work-item/feature.spec.int.js.map +1 -0
  747. package/dist/features/work-items/get-work-item/feature.spec.unit.d.ts +1 -0
  748. package/dist/features/work-items/get-work-item/feature.spec.unit.js +29 -0
  749. package/dist/features/work-items/get-work-item/feature.spec.unit.js.map +1 -0
  750. package/dist/features/work-items/get-work-item/index.d.ts +2 -0
  751. package/dist/features/work-items/get-work-item/index.js +3 -0
  752. package/dist/features/work-items/get-work-item/index.js.map +1 -0
  753. package/dist/features/work-items/get-work-item/schema.d.ts +2 -0
  754. package/dist/features/work-items/get-work-item/schema.js +3 -0
  755. package/dist/features/work-items/get-work-item/schema.js.map +1 -0
  756. package/dist/features/work-items/index.d.ts +17 -0
  757. package/dist/features/work-items/index.js +103 -0
  758. package/dist/features/work-items/index.js.map +1 -0
  759. package/dist/features/work-items/index.spec.unit.d.ts +1 -0
  760. package/dist/features/work-items/index.spec.unit.js +197 -0
  761. package/dist/features/work-items/index.spec.unit.js.map +1 -0
  762. package/dist/features/work-items/list-work-items/feature.d.ts +10 -0
  763. package/dist/features/work-items/list-work-items/feature.js +86 -0
  764. package/dist/features/work-items/list-work-items/feature.js.map +1 -0
  765. package/dist/features/work-items/list-work-items/feature.spec.int.d.ts +1 -0
  766. package/dist/features/work-items/list-work-items/feature.spec.int.js +101 -0
  767. package/dist/features/work-items/list-work-items/feature.spec.int.js.map +1 -0
  768. package/dist/features/work-items/list-work-items/feature.spec.unit.d.ts +1 -0
  769. package/dist/features/work-items/list-work-items/feature.spec.unit.js +93 -0
  770. package/dist/features/work-items/list-work-items/feature.spec.unit.js.map +1 -0
  771. package/dist/features/work-items/list-work-items/index.d.ts +2 -0
  772. package/dist/features/work-items/list-work-items/index.js +3 -0
  773. package/dist/features/work-items/list-work-items/index.js.map +1 -0
  774. package/dist/features/work-items/list-work-items/schema.d.ts +2 -0
  775. package/dist/features/work-items/list-work-items/schema.js +3 -0
  776. package/dist/features/work-items/list-work-items/schema.js.map +1 -0
  777. package/dist/features/work-items/manage-work-item-link/feature.d.ts +24 -0
  778. package/dist/features/work-items/manage-work-item-link/feature.js +73 -0
  779. package/dist/features/work-items/manage-work-item-link/feature.js.map +1 -0
  780. package/dist/features/work-items/manage-work-item-link/feature.spec.int.d.ts +1 -0
  781. package/dist/features/work-items/manage-work-item-link/feature.spec.int.js +73 -0
  782. package/dist/features/work-items/manage-work-item-link/feature.spec.int.js.map +1 -0
  783. package/dist/features/work-items/manage-work-item-link/feature.spec.unit.d.ts +1 -0
  784. package/dist/features/work-items/manage-work-item-link/feature.spec.unit.js +135 -0
  785. package/dist/features/work-items/manage-work-item-link/feature.spec.unit.js.map +1 -0
  786. package/dist/features/work-items/manage-work-item-link/index.d.ts +2 -0
  787. package/dist/features/work-items/manage-work-item-link/index.js +3 -0
  788. package/dist/features/work-items/manage-work-item-link/index.js.map +1 -0
  789. package/dist/features/work-items/manage-work-item-link/schema.d.ts +2 -0
  790. package/dist/features/work-items/manage-work-item-link/schema.js +3 -0
  791. package/dist/features/work-items/manage-work-item-link/schema.js.map +1 -0
  792. package/dist/features/work-items/schemas.d.ts +147 -0
  793. package/dist/features/work-items/schemas.js +131 -0
  794. package/dist/features/work-items/schemas.js.map +1 -0
  795. package/dist/features/work-items/tool-definitions.d.ts +5 -0
  796. package/dist/features/work-items/tool-definitions.js +33 -0
  797. package/dist/features/work-items/tool-definitions.js.map +1 -0
  798. package/dist/features/work-items/types.d.ts +39 -0
  799. package/dist/features/work-items/types.js +2 -0
  800. package/dist/features/work-items/types.js.map +1 -0
  801. package/dist/features/work-items/update-work-item/feature.d.ts +12 -0
  802. package/dist/features/work-items/update-work-item/feature.js +100 -0
  803. package/dist/features/work-items/update-work-item/feature.js.map +1 -0
  804. package/dist/features/work-items/update-work-item/feature.spec.int.d.ts +1 -0
  805. package/dist/features/work-items/update-work-item/feature.spec.int.js +82 -0
  806. package/dist/features/work-items/update-work-item/feature.spec.int.js.map +1 -0
  807. package/dist/features/work-items/update-work-item/feature.spec.unit.d.ts +1 -0
  808. package/dist/features/work-items/update-work-item/feature.spec.unit.js +36 -0
  809. package/dist/features/work-items/update-work-item/feature.spec.unit.js.map +1 -0
  810. package/dist/features/work-items/update-work-item/index.d.ts +2 -0
  811. package/dist/features/work-items/update-work-item/index.js +3 -0
  812. package/dist/features/work-items/update-work-item/index.js.map +1 -0
  813. package/dist/features/work-items/update-work-item/schema.d.ts +2 -0
  814. package/dist/features/work-items/update-work-item/schema.js +3 -0
  815. package/dist/features/work-items/update-work-item/schema.js.map +1 -0
  816. package/dist/index.d.ts +14 -0
  817. package/dist/index.js +127931 -0
  818. package/dist/index.js.map +1 -0
  819. package/dist/index.spec.unit.d.ts +1 -0
  820. package/dist/index.spec.unit.js +81 -0
  821. package/dist/index.spec.unit.js.map +1 -0
  822. package/dist/server.d.ts +21 -0
  823. package/dist/server.js +378 -0
  824. package/dist/server.js.map +1 -0
  825. package/dist/server.spec.e2e.d.ts +1 -0
  826. package/dist/server.spec.e2e.js +224 -0
  827. package/dist/server.spec.e2e.js.map +1 -0
  828. package/dist/setup-env.spec.unit.d.ts +1 -0
  829. package/dist/setup-env.spec.unit.js +144 -0
  830. package/dist/setup-env.spec.unit.js.map +1 -0
  831. package/dist/setup.d.ts +6 -0
  832. package/dist/setup.js +124 -0
  833. package/dist/setup.js.map +1 -0
  834. package/dist/shared/api/client.d.ts +91 -0
  835. package/dist/shared/api/client.js +238 -0
  836. package/dist/shared/api/client.js.map +1 -0
  837. package/dist/shared/api/index.d.ts +1 -0
  838. package/dist/shared/api/index.js +2 -0
  839. package/dist/shared/api/index.js.map +1 -0
  840. package/dist/shared/auth/auth-factory.d.ts +43 -0
  841. package/dist/shared/auth/auth-factory.js +136 -0
  842. package/dist/shared/auth/auth-factory.js.map +1 -0
  843. package/dist/shared/auth/auth-factory.spec.unit.d.ts +1 -0
  844. package/dist/shared/auth/auth-factory.spec.unit.js +36 -0
  845. package/dist/shared/auth/auth-factory.spec.unit.js.map +1 -0
  846. package/dist/shared/auth/client-factory.d.ts +109 -0
  847. package/dist/shared/auth/client-factory.js +268 -0
  848. package/dist/shared/auth/client-factory.js.map +1 -0
  849. package/dist/shared/auth/index.d.ts +11 -0
  850. package/dist/shared/auth/index.js +12 -0
  851. package/dist/shared/auth/index.js.map +1 -0
  852. package/dist/shared/azure-devops-url.d.ts +17 -0
  853. package/dist/shared/azure-devops-url.js +116 -0
  854. package/dist/shared/azure-devops-url.js.map +1 -0
  855. package/dist/shared/azure-devops-url.spec.unit.d.ts +1 -0
  856. package/dist/shared/azure-devops-url.spec.unit.js +101 -0
  857. package/dist/shared/azure-devops-url.spec.unit.js.map +1 -0
  858. package/dist/shared/config/index.d.ts +1 -0
  859. package/dist/shared/config/index.js +2 -0
  860. package/dist/shared/config/index.js.map +1 -0
  861. package/dist/shared/config/version.d.ts +4 -0
  862. package/dist/shared/config/version.js +5 -0
  863. package/dist/shared/config/version.js.map +1 -0
  864. package/dist/shared/enums/index.d.ts +40 -0
  865. package/dist/shared/enums/index.js +81 -0
  866. package/dist/shared/enums/index.js.map +1 -0
  867. package/dist/shared/enums/index.spec.unit.d.ts +1 -0
  868. package/dist/shared/enums/index.spec.unit.js +73 -0
  869. package/dist/shared/enums/index.spec.unit.js.map +1 -0
  870. package/dist/shared/errors/azure-devops-errors.d.ts +107 -0
  871. package/dist/shared/errors/azure-devops-errors.js +150 -0
  872. package/dist/shared/errors/azure-devops-errors.js.map +1 -0
  873. package/dist/shared/errors/handle-request-error.d.ts +31 -0
  874. package/dist/shared/errors/handle-request-error.js +91 -0
  875. package/dist/shared/errors/handle-request-error.js.map +1 -0
  876. package/dist/shared/errors/index.d.ts +1 -0
  877. package/dist/shared/errors/index.js +2 -0
  878. package/dist/shared/errors/index.js.map +1 -0
  879. package/dist/shared/test/test-helpers.d.ts +20 -0
  880. package/dist/shared/test/test-helpers.js +52 -0
  881. package/dist/shared/test/test-helpers.js.map +1 -0
  882. package/dist/shared/types/config.d.ts +27 -0
  883. package/dist/shared/types/config.js +2 -0
  884. package/dist/shared/types/config.js.map +1 -0
  885. package/dist/shared/types/index.d.ts +1 -0
  886. package/dist/shared/types/index.js +2 -0
  887. package/dist/shared/types/index.js.map +1 -0
  888. package/dist/shared/types/request-handler.d.ts +21 -0
  889. package/dist/shared/types/request-handler.js +2 -0
  890. package/dist/shared/types/request-handler.js.map +1 -0
  891. package/dist/shared/types/tool-definition.d.ts +10 -0
  892. package/dist/shared/types/tool-definition.js +2 -0
  893. package/dist/shared/types/tool-definition.js.map +1 -0
  894. package/dist/shared/utils/serialize.d.ts +7 -0
  895. package/dist/shared/utils/serialize.js +21 -0
  896. package/dist/shared/utils/serialize.js.map +1 -0
  897. package/dist/utils/environment.d.ts +15 -0
  898. package/dist/utils/environment.js +45 -0
  899. package/dist/utils/environment.js.map +1 -0
  900. package/dist/utils/environment.spec.unit.d.ts +1 -0
  901. package/dist/utils/environment.spec.unit.js +62 -0
  902. package/dist/utils/environment.spec.unit.js.map +1 -0
  903. package/docs/SOLUTION_SUMMARY.md +145 -0
  904. package/docs/authentication.md +267 -0
  905. package/docs/azure-identity-authentication.md +187 -0
  906. package/docs/ci-setup.md +61 -0
  907. package/docs/examples/README.md +33 -0
  908. package/docs/examples/azure-cli-authentication.env +25 -0
  909. package/docs/examples/azure-identity-authentication.env +33 -0
  910. package/docs/examples/pat-authentication.env +24 -0
  911. package/docs/important-knowledge/azure-devops-rest-api-research.md +88 -0
  912. package/docs/important-knowledge/llm-tldr-cli.md +37 -0
  913. package/docs/npm-trusted-publishers-migration.md +142 -0
  914. package/docs/release-troubleshooting.md +153 -0
  915. package/docs/testing/README.md +140 -0
  916. package/docs/testing/setup.md +72 -0
  917. package/docs/tools/README.md +73 -0
  918. package/docs/tools/core-navigation.md +114 -0
  919. package/docs/tools/organizations.md +73 -0
  920. package/docs/tools/pipelines.md +532 -0
  921. package/docs/tools/projects.md +114 -0
  922. package/docs/tools/pull-requests.md +1108 -0
  923. package/docs/tools/repositories.md +610 -0
  924. package/docs/tools/resources.md +133 -0
  925. package/docs/tools/search.md +165 -0
  926. package/docs/tools/user-tools.md +39 -0
  927. package/docs/tools/wiki.md +192 -0
  928. package/docs/tools/work-items.md +182 -0
  929. package/package.json +129 -0
@@ -0,0 +1,63 @@
1
+ import { Readable } from 'stream';
2
+ import { downloadPipelineArtifact } from './feature';
3
+ import { AzureDevOpsResourceNotFoundError } from '../../../shared/errors';
4
+ describe('downloadPipelineArtifact', () => {
5
+ const projectId = 'GHQ_B2B_Delta';
6
+ const runId = 13590799;
7
+ const getArtifacts = jest.fn();
8
+ const getItem = jest.fn();
9
+ const getBuildApi = jest.fn().mockResolvedValue({ getArtifacts });
10
+ const getFileContainerApi = jest.fn().mockResolvedValue({ getItem });
11
+ const getPipelinesApi = jest.fn();
12
+ const connection = {
13
+ getBuildApi,
14
+ getFileContainerApi,
15
+ getPipelinesApi,
16
+ };
17
+ const containerArtifact = {
18
+ name: 'embedding-metrics',
19
+ source: 'source',
20
+ resource: {
21
+ type: 'Container',
22
+ data: '#/39106000/embedding-metrics',
23
+ downloadUrl: 'https://example.com/container.zip',
24
+ },
25
+ };
26
+ beforeEach(() => {
27
+ jest.resetAllMocks();
28
+ getBuildApi.mockResolvedValue({ getArtifacts });
29
+ getFileContainerApi.mockResolvedValue({ getItem });
30
+ getArtifacts.mockResolvedValue([containerArtifact]);
31
+ });
32
+ it('downloads content from container artifacts using fallback paths', async () => {
33
+ const streamContent = Readable.from(['{"status":"ok"}']);
34
+ getItem.mockImplementation(async (_containerId, _scope, itemPath) => {
35
+ if (itemPath === 'embedding-metrics/embedding_metrics.json') {
36
+ return { statusCode: 200, result: streamContent };
37
+ }
38
+ return { statusCode: 404, result: undefined };
39
+ });
40
+ const result = await downloadPipelineArtifact(connection, {
41
+ projectId,
42
+ runId,
43
+ artifactPath: 'embedding-metrics/embedding_metrics.json',
44
+ });
45
+ expect(result).toEqual({
46
+ artifact: 'embedding-metrics',
47
+ path: 'embedding-metrics/embedding_metrics.json',
48
+ content: '{"status":"ok"}',
49
+ });
50
+ const attemptedPaths = getItem.mock.calls.map(([, , path]) => path);
51
+ expect(attemptedPaths).toContain('embedding_metrics.json');
52
+ expect(attemptedPaths).toContain('embedding-metrics/embedding_metrics.json');
53
+ });
54
+ it('throws when the requested file is missing', async () => {
55
+ getItem.mockResolvedValue({ statusCode: 404, result: undefined });
56
+ await expect(downloadPipelineArtifact(connection, {
57
+ projectId,
58
+ runId,
59
+ artifactPath: 'embedding-metrics/missing.json',
60
+ })).rejects.toBeInstanceOf(AzureDevOpsResourceNotFoundError);
61
+ });
62
+ });
63
+ //# sourceMappingURL=feature.spec.unit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.spec.unit.js","sourceRoot":"","sources":["../../../../src/features/pipelines/download-pipeline-artifact/feature.spec.unit.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './feature';
2
+ export * from './schema';
@@ -0,0 +1,3 @@
1
+ export * from './feature';
2
+ export * from './schema';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/features/pipelines/download-pipeline-artifact/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { z } from 'zod';
2
+ export declare const DownloadPipelineArtifactSchema: z.ZodObject<{
3
+ projectId: z.ZodOptional<z.ZodString>;
4
+ runId: z.ZodNumber;
5
+ artifactPath: z.ZodString;
6
+ pipelineId: z.ZodOptional<z.ZodNumber>;
7
+ }, "strip", z.ZodTypeAny, {
8
+ runId: number;
9
+ artifactPath: string;
10
+ projectId?: string | undefined;
11
+ pipelineId?: number | undefined;
12
+ }, {
13
+ runId: number;
14
+ artifactPath: string;
15
+ projectId?: string | undefined;
16
+ pipelineId?: number | undefined;
17
+ }>;
@@ -0,0 +1,20 @@
1
+ import { z } from 'zod';
2
+ import { defaultProject } from '../../../utils/environment';
3
+ export const DownloadPipelineArtifactSchema = z.object({
4
+ projectId: z
5
+ .string()
6
+ .optional()
7
+ .describe(`The ID or name of the project (Default: ${defaultProject})`),
8
+ runId: z.number().int().min(1).describe('Pipeline run identifier'),
9
+ artifactPath: z
10
+ .string()
11
+ .min(1)
12
+ .describe('Path to the desired file inside the artifact (format: <artifactName>/<path/to/file>)'),
13
+ pipelineId: z
14
+ .number()
15
+ .int()
16
+ .min(1)
17
+ .optional()
18
+ .describe('Optional guard; validates the run belongs to this pipeline'),
19
+ });
20
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/features/pipelines/download-pipeline-artifact/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAAC,CAAC,MAAM,CAAC;IACrD,SAAS,EAAE,CAAC;SACT,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,2CAA2C,cAAc,GAAG,CAAC;IACzE,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,yBAAyB,CAAC;IAClE,YAAY,EAAE,CAAC;SACZ,MAAM,EAAE;SACR,GAAG,CAAC,CAAC,CAAC;SACN,QAAQ,CACP,sFAAsF,CACvF;IACH,UAAU,EAAE,CAAC;SACV,MAAM,EAAE;SACR,GAAG,EAAE;SACL,GAAG,CAAC,CAAC,CAAC;SACN,QAAQ,EAAE;SACV,QAAQ,CAAC,4DAA4D,CAAC;CAC1E,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { WebApi } from 'azure-devops-node-api';
2
+ import { GetPipelineOptions, Pipeline } from '../types';
3
+ /**
4
+ * Get a specific pipeline by ID
5
+ *
6
+ * @param connection The Azure DevOps WebApi connection
7
+ * @param options Options for getting a pipeline
8
+ * @returns Pipeline details
9
+ */
10
+ export declare function getPipeline(connection: WebApi, options: GetPipelineOptions): Promise<Pipeline>;
@@ -0,0 +1,43 @@
1
+ import { AzureDevOpsError, AzureDevOpsAuthenticationError, AzureDevOpsResourceNotFoundError, } from '../../../shared/errors';
2
+ /**
3
+ * Get a specific pipeline by ID
4
+ *
5
+ * @param connection The Azure DevOps WebApi connection
6
+ * @param options Options for getting a pipeline
7
+ * @returns Pipeline details
8
+ */
9
+ export async function getPipeline(connection, options) {
10
+ try {
11
+ const pipelinesApi = await connection.getPipelinesApi();
12
+ const { projectId, pipelineId, pipelineVersion } = options;
13
+ // Call the pipelines API to get the pipeline
14
+ const pipeline = await pipelinesApi.getPipeline(projectId, pipelineId, pipelineVersion);
15
+ // If pipeline not found, API returns null instead of throwing error
16
+ if (pipeline === null) {
17
+ throw new AzureDevOpsResourceNotFoundError(`Pipeline not found with ID: ${pipelineId}`);
18
+ }
19
+ return pipeline;
20
+ }
21
+ catch (error) {
22
+ // Handle specific error types
23
+ if (error instanceof AzureDevOpsError) {
24
+ throw error;
25
+ }
26
+ // Check for specific error types and convert to appropriate Azure DevOps errors
27
+ if (error instanceof Error) {
28
+ if (error.message.includes('Authentication') ||
29
+ error.message.includes('Unauthorized') ||
30
+ error.message.includes('401')) {
31
+ throw new AzureDevOpsAuthenticationError(`Failed to authenticate: ${error.message}`);
32
+ }
33
+ if (error.message.includes('not found') ||
34
+ error.message.includes('does not exist') ||
35
+ error.message.includes('404')) {
36
+ throw new AzureDevOpsResourceNotFoundError(`Pipeline or project not found: ${error.message}`);
37
+ }
38
+ }
39
+ // Otherwise, wrap it in a generic error
40
+ throw new AzureDevOpsError(`Failed to get pipeline: ${error instanceof Error ? error.message : String(error)}`);
41
+ }
42
+ }
43
+ //# sourceMappingURL=feature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline/feature.ts"],"names":[],"mappings":"AACA,OAAO,EACL,gBAAgB,EAChB,8BAA8B,EAC9B,gCAAgC,GACjC,MAAM,wBAAwB,CAAC;AAGhC;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,UAAkB,EAClB,OAA2B;IAE3B,IAAI,CAAC;QACH,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,eAAe,EAAE,CAAC;QACxD,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC;QAE3D,6CAA6C;QAC7C,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,WAAW,CAC7C,SAAS,EACT,UAAU,EACV,eAAe,CAChB,CAAC;QAEF,oEAAoE;QACpE,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;YACtB,MAAM,IAAI,gCAAgC,CACxC,+BAA+B,UAAU,EAAE,CAC5C,CAAC;QACJ,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,8BAA8B;QAC9B,IAAI,KAAK,YAAY,gBAAgB,EAAE,CAAC;YACtC,MAAM,KAAK,CAAC;QACd,CAAC;QAED,gFAAgF;QAChF,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,IACE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;gBACxC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC;gBACtC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC7B,CAAC;gBACD,MAAM,IAAI,8BAA8B,CACtC,2BAA2B,KAAK,CAAC,OAAO,EAAE,CAC3C,CAAC;YACJ,CAAC;YAED,IACE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;gBACnC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;gBACxC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC7B,CAAC;gBACD,MAAM,IAAI,gCAAgC,CACxC,kCAAkC,KAAK,CAAC,OAAO,EAAE,CAClD,CAAC;YACJ,CAAC;QACH,CAAC;QAED,wCAAwC;QACxC,MAAM,IAAI,gBAAgB,CACxB,2BAA2B,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CACpF,CAAC;IACJ,CAAC;AACH,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { getPipeline } from './feature';
2
+ import { listPipelines } from '../list-pipelines/feature';
3
+ import { getTestConnection, shouldSkipIntegrationTest, } from '../../../shared/test/test-helpers';
4
+ const shouldSkip = shouldSkipIntegrationTest();
5
+ const projectId = process.env.AZURE_DEVOPS_DEFAULT_PROJECT || '';
6
+ const hasProjectId = Boolean(projectId);
7
+ const describeOrSkip = !shouldSkip && hasProjectId ? describe : describe.skip;
8
+ describeOrSkip('getPipeline integration', () => {
9
+ let connection;
10
+ let existingPipelineId;
11
+ beforeAll(async () => {
12
+ // Get a real connection using environment variables
13
+ const testConnection = await getTestConnection();
14
+ if (!testConnection) {
15
+ throw new Error('Connection should be available when integration tests are enabled');
16
+ }
17
+ connection = testConnection;
18
+ // Try to get an existing pipeline ID for testing
19
+ const pipelines = await listPipelines(connection, { projectId });
20
+ const pipelineId = pipelines[0]?.id;
21
+ if (!pipelineId) {
22
+ throw new Error('No pipelines found for getPipeline tests');
23
+ }
24
+ existingPipelineId = pipelineId;
25
+ });
26
+ test('should get a pipeline by ID', async () => {
27
+ // Act - make an API call to Azure DevOps
28
+ const pipeline = await getPipeline(connection, {
29
+ projectId,
30
+ pipelineId: existingPipelineId,
31
+ });
32
+ // Assert
33
+ expect(pipeline).toBeDefined();
34
+ expect(pipeline.id).toBe(existingPipelineId);
35
+ expect(pipeline.name).toBeDefined();
36
+ expect(typeof pipeline.name).toBe('string');
37
+ expect(pipeline.folder).toBeDefined();
38
+ expect(pipeline.revision).toBeDefined();
39
+ expect(pipeline.url).toBeDefined();
40
+ expect(pipeline.url).toContain('_apis/pipelines');
41
+ });
42
+ test('should throw ResourceNotFoundError for non-existent pipeline', async () => {
43
+ // Use a very high ID that is unlikely to exist
44
+ const nonExistentPipelineId = 999999;
45
+ // Act & Assert - should throw a not found error
46
+ await expect(getPipeline(connection, {
47
+ projectId,
48
+ pipelineId: nonExistentPipelineId,
49
+ })).rejects.toThrow(/not found/);
50
+ });
51
+ });
52
+ //# sourceMappingURL=feature.spec.int.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.spec.int.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline/feature.spec.int.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EACL,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,mCAAmC,CAAC;AAE3C,MAAM,UAAU,GAAG,yBAAyB,EAAE,CAAC;AAC/C,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,4BAA4B,IAAI,EAAE,CAAC;AACjE,MAAM,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;AACxC,MAAM,cAAc,GAAG,CAAC,UAAU,IAAI,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;AAE9E,cAAc,CAAC,yBAAyB,EAAE,GAAG,EAAE;IAC7C,IAAI,UAAkB,CAAC;IACvB,IAAI,kBAA0B,CAAC;IAE/B,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,oDAAoD;QACpD,MAAM,cAAc,GAAG,MAAM,iBAAiB,EAAE,CAAC;QACjD,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CACb,mEAAmE,CACpE,CAAC;QACJ,CAAC;QACD,UAAU,GAAG,cAAc,CAAC;QAE5B,iDAAiD;QACjD,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;QACjE,MAAM,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;QACpC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;QAC9D,CAAC;QACD,kBAAkB,GAAG,UAAU,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;QAC7C,yCAAyC;QACzC,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,UAAU,EAAE;YAC7C,SAAS;YACT,UAAU,EAAE,kBAAkB;SAC/B,CAAC,CAAC;QAEH,SAAS;QACT,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/B,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAC7C,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,CAAC,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;QACtC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QACxC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;QACnC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC9E,+CAA+C;QAC/C,MAAM,qBAAqB,GAAG,MAAM,CAAC;QAErC,gDAAgD;QAChD,MAAM,MAAM,CACV,WAAW,CAAC,UAAU,EAAE;YACtB,SAAS;YACT,UAAU,EAAE,qBAAqB;SAClC,CAAC,CACH,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,87 @@
1
+ import { getPipeline } from './feature';
2
+ import { AzureDevOpsError, AzureDevOpsAuthenticationError, AzureDevOpsResourceNotFoundError, } from '../../../shared/errors';
3
+ // Unit tests should only focus on isolated logic
4
+ describe('getPipeline unit', () => {
5
+ let mockConnection;
6
+ let mockPipelinesApi;
7
+ beforeEach(() => {
8
+ // Reset mocks
9
+ jest.resetAllMocks();
10
+ // Setup mock Pipelines API
11
+ mockPipelinesApi = {
12
+ getPipeline: jest.fn(),
13
+ };
14
+ // Mock WebApi with a getPipelinesApi method
15
+ mockConnection = {
16
+ serverUrl: 'https://dev.azure.com/testorg',
17
+ getPipelinesApi: jest.fn().mockResolvedValue(mockPipelinesApi),
18
+ };
19
+ });
20
+ test('should return a pipeline', async () => {
21
+ // Arrange
22
+ const mockPipeline = {
23
+ id: 1,
24
+ name: 'Pipeline 1',
25
+ folder: 'Folder 1',
26
+ revision: 1,
27
+ url: 'https://dev.azure.com/testorg/testproject/_apis/pipelines/1',
28
+ };
29
+ // Mock the Pipelines API to return data
30
+ mockPipelinesApi.getPipeline.mockResolvedValue(mockPipeline);
31
+ // Act
32
+ const result = await getPipeline(mockConnection, {
33
+ projectId: 'testproject',
34
+ pipelineId: 1,
35
+ });
36
+ // Assert
37
+ expect(mockConnection.getPipelinesApi).toHaveBeenCalled();
38
+ expect(mockPipelinesApi.getPipeline).toHaveBeenCalledWith('testproject', 1, undefined);
39
+ expect(result).toEqual(mockPipeline);
40
+ });
41
+ test('should handle pipeline version parameter', async () => {
42
+ // Arrange
43
+ const mockPipeline = {
44
+ id: 1,
45
+ name: 'Pipeline 1',
46
+ folder: 'Folder 1',
47
+ revision: 2,
48
+ url: 'https://dev.azure.com/testorg/testproject/_apis/pipelines/1',
49
+ };
50
+ mockPipelinesApi.getPipeline.mockResolvedValue(mockPipeline);
51
+ // Act
52
+ await getPipeline(mockConnection, {
53
+ projectId: 'testproject',
54
+ pipelineId: 1,
55
+ pipelineVersion: 2,
56
+ });
57
+ // Assert
58
+ expect(mockPipelinesApi.getPipeline).toHaveBeenCalledWith('testproject', 1, 2);
59
+ });
60
+ test('should handle authentication errors', async () => {
61
+ // Arrange
62
+ const authError = new Error('Authentication failed');
63
+ authError.message = 'Authentication failed: Unauthorized';
64
+ mockPipelinesApi.getPipeline.mockRejectedValue(authError);
65
+ // Act & Assert
66
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(AzureDevOpsAuthenticationError);
67
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(/Failed to authenticate/);
68
+ });
69
+ test('should handle resource not found errors', async () => {
70
+ // Arrange
71
+ const notFoundError = new Error('Not found');
72
+ notFoundError.message = 'Pipeline does not exist';
73
+ mockPipelinesApi.getPipeline.mockRejectedValue(notFoundError);
74
+ // Act & Assert
75
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(AzureDevOpsResourceNotFoundError);
76
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(/Pipeline or project not found/);
77
+ });
78
+ test('should wrap general errors in AzureDevOpsError', async () => {
79
+ // Arrange
80
+ const testError = new Error('Test API error');
81
+ mockPipelinesApi.getPipeline.mockRejectedValue(testError);
82
+ // Act & Assert
83
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(AzureDevOpsError);
84
+ await expect(getPipeline(mockConnection, { projectId: 'testproject', pipelineId: 1 })).rejects.toThrow(/Failed to get pipeline/);
85
+ });
86
+ });
87
+ //# sourceMappingURL=feature.spec.unit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.spec.unit.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline/feature.spec.unit.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './feature';
2
+ export * from './schema';
@@ -0,0 +1,3 @@
1
+ export * from './feature';
2
+ export * from './schema';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Schema for the getPipeline function
4
+ */
5
+ export declare const GetPipelineSchema: z.ZodObject<{
6
+ projectId: z.ZodOptional<z.ZodString>;
7
+ pipelineId: z.ZodNumber;
8
+ pipelineVersion: z.ZodOptional<z.ZodNumber>;
9
+ }, "strip", z.ZodTypeAny, {
10
+ pipelineId: number;
11
+ projectId?: string | undefined;
12
+ pipelineVersion?: number | undefined;
13
+ }, {
14
+ pipelineId: number;
15
+ projectId?: string | undefined;
16
+ pipelineVersion?: number | undefined;
17
+ }>;
@@ -0,0 +1,26 @@
1
+ import { z } from 'zod';
2
+ import { defaultProject } from '../../../utils/environment';
3
+ /**
4
+ * Schema for the getPipeline function
5
+ */
6
+ export const GetPipelineSchema = z.object({
7
+ // The project containing the pipeline
8
+ projectId: z
9
+ .string()
10
+ .optional()
11
+ .describe(`The ID or name of the project (Default: ${defaultProject})`),
12
+ // The ID of the pipeline to retrieve
13
+ pipelineId: z
14
+ .number()
15
+ .int()
16
+ .positive()
17
+ .describe('The numeric ID of the pipeline to retrieve'),
18
+ // The version of the pipeline to retrieve
19
+ pipelineVersion: z
20
+ .number()
21
+ .int()
22
+ .positive()
23
+ .optional()
24
+ .describe('The version of the pipeline to retrieve (latest if not specified)'),
25
+ });
26
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D;;GAEG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IACxC,sCAAsC;IACtC,SAAS,EAAE,CAAC;SACT,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,2CAA2C,cAAc,GAAG,CAAC;IACzE,qCAAqC;IACrC,UAAU,EAAE,CAAC;SACV,MAAM,EAAE;SACR,GAAG,EAAE;SACL,QAAQ,EAAE;SACV,QAAQ,CAAC,4CAA4C,CAAC;IACzD,0CAA0C;IAC1C,eAAe,EAAE,CAAC;SACf,MAAM,EAAE;SACR,GAAG,EAAE;SACL,QAAQ,EAAE;SACV,QAAQ,EAAE;SACV,QAAQ,CACP,mEAAmE,CACpE;CACJ,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { WebApi } from 'azure-devops-node-api';
2
+ import { GetPipelineLogOptions, PipelineLogContent } from '../types';
3
+ export declare function getPipelineLog(connection: WebApi, options: GetPipelineLogOptions): Promise<PipelineLogContent>;
@@ -0,0 +1,54 @@
1
+ import { AzureDevOpsAuthenticationError, AzureDevOpsError, AzureDevOpsResourceNotFoundError, } from '../../../shared/errors';
2
+ import { defaultProject } from '../../../utils/environment';
3
+ const API_VERSION = '7.1';
4
+ export async function getPipelineLog(connection, options) {
5
+ try {
6
+ const buildApi = await connection.getBuildApi();
7
+ const projectId = options.projectId ?? defaultProject;
8
+ const { runId, logId, format, startLine, endLine } = options;
9
+ if (format === 'json') {
10
+ const route = `${encodeURIComponent(projectId)}/_apis/build/builds/${runId}/logs/${logId}`;
11
+ const baseUrl = connection.serverUrl.replace(/\/+$/, '');
12
+ const url = new URL(`${route}`, `${baseUrl}/`);
13
+ url.searchParams.set('api-version', API_VERSION);
14
+ url.searchParams.set('format', 'json');
15
+ if (typeof startLine === 'number') {
16
+ url.searchParams.set('startLine', startLine.toString());
17
+ }
18
+ if (typeof endLine === 'number') {
19
+ url.searchParams.set('endLine', endLine.toString());
20
+ }
21
+ const requestOptions = buildApi.createRequestOptions('application/json', API_VERSION);
22
+ const response = await buildApi.rest.get(url.toString(), requestOptions);
23
+ if (response.statusCode === 404 || response.result === null) {
24
+ throw new AzureDevOpsResourceNotFoundError(`Log ${logId} not found for run ${runId} in project ${projectId}`);
25
+ }
26
+ return response.result;
27
+ }
28
+ const lines = await buildApi.getBuildLogLines(projectId, runId, logId, startLine, endLine);
29
+ if (!lines) {
30
+ throw new AzureDevOpsResourceNotFoundError(`Log ${logId} not found for run ${runId} in project ${projectId}`);
31
+ }
32
+ return lines.join('\n');
33
+ }
34
+ catch (error) {
35
+ if (error instanceof AzureDevOpsError) {
36
+ throw error;
37
+ }
38
+ if (error instanceof Error) {
39
+ const message = error.message.toLowerCase();
40
+ if (message.includes('authentication') ||
41
+ message.includes('unauthorized') ||
42
+ message.includes('401')) {
43
+ throw new AzureDevOpsAuthenticationError(`Failed to authenticate: ${error.message}`);
44
+ }
45
+ if (message.includes('not found') ||
46
+ message.includes('does not exist') ||
47
+ message.includes('404')) {
48
+ throw new AzureDevOpsResourceNotFoundError(`Pipeline log or project not found: ${error.message}`);
49
+ }
50
+ }
51
+ throw new AzureDevOpsError(`Failed to retrieve pipeline log: ${error instanceof Error ? error.message : String(error)}`);
52
+ }
53
+ }
54
+ //# sourceMappingURL=feature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline-log/feature.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,79 @@
1
+ import { getPipelineLog } from './feature';
2
+ import { AzureDevOpsAuthenticationError, AzureDevOpsError, AzureDevOpsResourceNotFoundError, } from '../../../shared/errors';
3
+ describe('getPipelineLog unit', () => {
4
+ let mockConnection;
5
+ let mockBuildApi;
6
+ let mockRestGet;
7
+ beforeEach(() => {
8
+ jest.resetAllMocks();
9
+ mockRestGet = jest.fn();
10
+ mockBuildApi = {
11
+ rest: { get: mockRestGet },
12
+ createRequestOptions: jest
13
+ .fn()
14
+ .mockReturnValue({ acceptHeader: 'application/json' }),
15
+ getBuildLogLines: jest.fn(),
16
+ };
17
+ mockConnection = {
18
+ serverUrl: 'https://dev.azure.com/testorg',
19
+ getBuildApi: jest.fn().mockResolvedValue(mockBuildApi),
20
+ };
21
+ });
22
+ it('retrieves the pipeline log with query parameters', async () => {
23
+ mockRestGet.mockResolvedValue({
24
+ statusCode: 200,
25
+ result: 'log content',
26
+ headers: {},
27
+ });
28
+ const result = await getPipelineLog(mockConnection, {
29
+ projectId: 'test-project',
30
+ runId: 101,
31
+ logId: 7,
32
+ format: 'json',
33
+ startLine: 10,
34
+ endLine: 20,
35
+ });
36
+ expect(result).toEqual('log content');
37
+ expect(mockBuildApi.createRequestOptions).toHaveBeenCalledWith('application/json', '7.1');
38
+ const [requestUrl] = mockRestGet.mock.calls[0];
39
+ const url = new URL(requestUrl);
40
+ expect(url.pathname).toContain('/build/builds/101/logs/7');
41
+ expect(url.searchParams.get('format')).toBe('json');
42
+ expect(url.searchParams.get('startLine')).toBe('10');
43
+ expect(url.searchParams.get('endLine')).toBe('20');
44
+ });
45
+ it('defaults to plain text when format not provided', async () => {
46
+ mockBuildApi.getBuildLogLines.mockResolvedValue(['line1', 'line2']);
47
+ await getPipelineLog(mockConnection, {
48
+ projectId: 'test-project',
49
+ runId: 101,
50
+ logId: 7,
51
+ });
52
+ expect(mockBuildApi.getBuildLogLines).toHaveBeenCalledWith('test-project', 101, 7, undefined, undefined);
53
+ });
54
+ it('throws resource not found when API returns 404', async () => {
55
+ mockBuildApi.getBuildLogLines.mockResolvedValue(undefined);
56
+ await expect(getPipelineLog(mockConnection, {
57
+ projectId: 'test-project',
58
+ runId: 101,
59
+ logId: 7,
60
+ })).rejects.toBeInstanceOf(AzureDevOpsResourceNotFoundError);
61
+ });
62
+ it('maps authentication errors', async () => {
63
+ mockBuildApi.getBuildLogLines.mockRejectedValue(new Error('401 Unauthorized'));
64
+ await expect(getPipelineLog(mockConnection, {
65
+ projectId: 'test-project',
66
+ runId: 101,
67
+ logId: 7,
68
+ })).rejects.toBeInstanceOf(AzureDevOpsAuthenticationError);
69
+ });
70
+ it('wraps unexpected errors', async () => {
71
+ mockBuildApi.getBuildLogLines.mockRejectedValue(new Error('Boom'));
72
+ await expect(getPipelineLog(mockConnection, {
73
+ projectId: 'test-project',
74
+ runId: 101,
75
+ logId: 7,
76
+ })).rejects.toBeInstanceOf(AzureDevOpsError);
77
+ });
78
+ });
79
+ //# sourceMappingURL=feature.spec.unit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feature.spec.unit.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline-log/feature.spec.unit.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './feature';
2
+ export * from './schema';
@@ -0,0 +1,3 @@
1
+ export * from './feature';
2
+ export * from './schema';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/features/pipelines/get-pipeline-log/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { z } from 'zod';
2
+ export declare const GetPipelineLogSchema: z.ZodObject<{
3
+ projectId: z.ZodOptional<z.ZodString>;
4
+ runId: z.ZodNumber;
5
+ logId: z.ZodNumber;
6
+ format: z.ZodOptional<z.ZodEnum<["plain", "json"]>>;
7
+ startLine: z.ZodOptional<z.ZodNumber>;
8
+ endLine: z.ZodOptional<z.ZodNumber>;
9
+ pipelineId: z.ZodOptional<z.ZodNumber>;
10
+ }, "strip", z.ZodTypeAny, {
11
+ runId: number;
12
+ logId: number;
13
+ projectId?: string | undefined;
14
+ pipelineId?: number | undefined;
15
+ format?: "json" | "plain" | undefined;
16
+ startLine?: number | undefined;
17
+ endLine?: number | undefined;
18
+ }, {
19
+ runId: number;
20
+ logId: number;
21
+ projectId?: string | undefined;
22
+ pipelineId?: number | undefined;
23
+ format?: "json" | "plain" | undefined;
24
+ startLine?: number | undefined;
25
+ endLine?: number | undefined;
26
+ }>;