@cloudant/couchbackup 2.9.15-SNAPSHOT.176 → 2.9.15

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 (424) hide show
  1. package/.scannerwork/report-task.txt +2 -2
  2. package/.scannerwork/scanner-report/analysis-cache2.pb +0 -0
  3. package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
  4. package/.scannerwork/scanner-report/analysis.log +1 -1
  5. package/.scannerwork/scanner-report/changesets-19.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-20.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-21.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-22.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-23.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-24.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-26.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-29.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-30.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-31.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-33.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-34.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-35.pb +1 -0
  18. package/.scannerwork/scanner-report/changesets-36.pb +1 -0
  19. package/.scannerwork/scanner-report/changesets-37.pb +1 -0
  20. package/.scannerwork/scanner-report/changesets-38.pb +1 -0
  21. package/.scannerwork/scanner-report/changesets-39.pb +1 -0
  22. package/.scannerwork/scanner-report/changesets-66.pb +1 -0
  23. package/.scannerwork/scanner-report/changesets-67.pb +1 -0
  24. package/.scannerwork/scanner-report/component-1.pb +2 -2
  25. package/.scannerwork/scanner-report/component-10.pb +1 -1
  26. package/.scannerwork/scanner-report/component-12.pb +1 -1
  27. package/.scannerwork/scanner-report/component-14.pb +1 -1
  28. package/.scannerwork/scanner-report/component-16.pb +1 -1
  29. package/.scannerwork/scanner-report/component-17.pb +1 -1
  30. package/.scannerwork/scanner-report/component-18.pb +1 -1
  31. package/.scannerwork/scanner-report/component-19.pb +1 -0
  32. package/.scannerwork/scanner-report/component-20.pb +1 -0
  33. package/.scannerwork/scanner-report/component-21.pb +1 -0
  34. package/.scannerwork/scanner-report/component-22.pb +1 -0
  35. package/.scannerwork/scanner-report/component-23.pb +1 -0
  36. package/.scannerwork/scanner-report/component-24.pb +1 -1
  37. package/.scannerwork/scanner-report/component-25.pb +1 -1
  38. package/.scannerwork/scanner-report/component-26.pb +1 -0
  39. package/.scannerwork/scanner-report/component-27.pb +1 -1
  40. package/.scannerwork/scanner-report/component-28.pb +1 -1
  41. package/.scannerwork/scanner-report/component-29.pb +1 -0
  42. package/.scannerwork/scanner-report/component-3.pb +1 -0
  43. package/.scannerwork/scanner-report/component-30.pb +1 -1
  44. package/.scannerwork/scanner-report/component-31.pb +1 -1
  45. package/.scannerwork/scanner-report/component-32.pb +1 -1
  46. package/.scannerwork/scanner-report/component-33.pb +1 -0
  47. package/.scannerwork/scanner-report/component-34.pb +1 -0
  48. package/.scannerwork/scanner-report/component-35.pb +1 -0
  49. package/.scannerwork/scanner-report/component-36.pb +1 -0
  50. package/.scannerwork/scanner-report/component-37.pb +1 -0
  51. package/.scannerwork/scanner-report/component-38.pb +1 -0
  52. package/.scannerwork/scanner-report/component-39.pb +1 -0
  53. package/.scannerwork/scanner-report/component-53.pb +1 -1
  54. package/.scannerwork/scanner-report/component-54.pb +1 -1
  55. package/.scannerwork/scanner-report/component-55.pb +1 -1
  56. package/.scannerwork/scanner-report/component-56.pb +1 -1
  57. package/.scannerwork/scanner-report/component-57.pb +1 -1
  58. package/.scannerwork/scanner-report/component-58.pb +1 -1
  59. package/.scannerwork/scanner-report/component-59.pb +1 -1
  60. package/.scannerwork/scanner-report/component-6.pb +1 -1
  61. package/.scannerwork/scanner-report/component-60.pb +1 -1
  62. package/.scannerwork/scanner-report/component-61.pb +1 -1
  63. package/.scannerwork/scanner-report/component-62.pb +1 -1
  64. package/.scannerwork/scanner-report/component-63.pb +1 -1
  65. package/.scannerwork/scanner-report/component-64.pb +1 -1
  66. package/.scannerwork/scanner-report/component-65.pb +1 -1
  67. package/.scannerwork/scanner-report/component-66.pb +1 -0
  68. package/.scannerwork/scanner-report/component-67.pb +1 -0
  69. package/.scannerwork/scanner-report/component-68.pb +1 -1
  70. package/.scannerwork/scanner-report/component-69.pb +1 -1
  71. package/.scannerwork/scanner-report/component-70.pb +1 -1
  72. package/.scannerwork/scanner-report/coverages-12.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-25.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-29.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-31.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-32.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-34.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  99. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  100. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  101. package/.scannerwork/scanner-report/coverages-63.pb +0 -0
  102. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  103. package/.scannerwork/scanner-report/coverages-65.pb +0 -0
  104. package/.scannerwork/scanner-report/coverages-67.pb +0 -0
  105. package/.scannerwork/scanner-report/coverages-68.pb +0 -0
  106. package/.scannerwork/scanner-report/coverages-69.pb +0 -0
  107. package/.scannerwork/scanner-report/duplications-12.pb +2 -0
  108. package/.scannerwork/scanner-report/duplications-14.pb +2 -0
  109. package/.scannerwork/scanner-report/duplications-25.pb +2 -0
  110. package/.scannerwork/scanner-report/duplications-54.pb +0 -0
  111. package/.scannerwork/scanner-report/duplications-56.pb +2 -0
  112. package/.scannerwork/scanner-report/duplications-66.pb +2 -0
  113. package/.scannerwork/scanner-report/duplications-67.pb +0 -0
  114. package/.scannerwork/scanner-report/duplications-68.pb +0 -2
  115. package/.scannerwork/scanner-report/duplications-69.pb +0 -2
  116. package/.scannerwork/scanner-report/issues-17.pb +3 -0
  117. package/.scannerwork/scanner-report/issues-32.pb +4 -1
  118. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-12.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-22.pb +16 -0
  127. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-25.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-29.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-3.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-31.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-32.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-61.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  150. package/.scannerwork/scanner-report/measures-63.pb +0 -0
  151. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-65.pb +0 -0
  153. package/.scannerwork/scanner-report/measures-66.pb +0 -0
  154. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  155. package/.scannerwork/scanner-report/measures-68.pb +0 -0
  156. package/.scannerwork/scanner-report/measures-69.pb +0 -0
  157. package/.scannerwork/scanner-report/metadata.pb +0 -0
  158. package/.scannerwork/scanner-report/source-10.txt +424 -92
  159. package/.scannerwork/scanner-report/source-12.txt +173 -14
  160. package/.scannerwork/scanner-report/source-14.txt +156 -145
  161. package/.scannerwork/scanner-report/source-16.txt +32 -99
  162. package/.scannerwork/scanner-report/source-17.txt +116 -115
  163. package/.scannerwork/scanner-report/source-18.txt +117 -29
  164. package/.scannerwork/scanner-report/source-19.txt +37 -0
  165. package/.scannerwork/scanner-report/source-21.txt +41 -0
  166. package/.scannerwork/scanner-report/source-22.txt +293 -0
  167. package/.scannerwork/scanner-report/source-24.txt +32 -424
  168. package/.scannerwork/scanner-report/source-25.txt +155 -386
  169. package/.scannerwork/scanner-report/source-27.txt +84 -65
  170. package/.scannerwork/scanner-report/source-28.txt +432 -43
  171. package/.scannerwork/scanner-report/source-29.txt +42 -0
  172. package/.scannerwork/scanner-report/source-3.txt +424 -0
  173. package/.scannerwork/scanner-report/source-30.txt +29 -424
  174. package/.scannerwork/scanner-report/source-31.txt +37 -102
  175. package/.scannerwork/scanner-report/source-32.txt +288 -89
  176. package/.scannerwork/scanner-report/source-34.txt +106 -0
  177. package/.scannerwork/scanner-report/source-35.txt +75 -0
  178. package/.scannerwork/scanner-report/source-37.txt +191 -0
  179. package/.scannerwork/scanner-report/source-53.txt +104 -61
  180. package/.scannerwork/scanner-report/source-54.txt +31 -14
  181. package/.scannerwork/scanner-report/source-55.txt +150 -23
  182. package/.scannerwork/scanner-report/source-56.txt +51 -167
  183. package/.scannerwork/scanner-report/source-57.txt +255 -80
  184. package/.scannerwork/scanner-report/source-58.txt +58 -427
  185. package/.scannerwork/scanner-report/source-59.txt +162 -118
  186. package/.scannerwork/scanner-report/source-6.txt +102 -41
  187. package/.scannerwork/scanner-report/source-60.txt +99 -27
  188. package/.scannerwork/scanner-report/source-61.txt +43 -16
  189. package/.scannerwork/scanner-report/source-62.txt +115 -315
  190. package/.scannerwork/scanner-report/source-63.txt +16 -27
  191. package/.scannerwork/scanner-report/source-64.txt +25 -21
  192. package/.scannerwork/scanner-report/source-65.txt +92 -274
  193. package/.scannerwork/scanner-report/{source-15.txt → source-66.txt} +29 -12
  194. package/.scannerwork/scanner-report/source-67.txt +414 -0
  195. package/.scannerwork/scanner-report/source-68.txt +42 -157
  196. package/.scannerwork/scanner-report/source-69.txt +57 -166
  197. package/.scannerwork/scanner-report/source-70.txt +155 -155
  198. package/.scannerwork/scanner-report/symbols-12.pb +180 -14
  199. package/.scannerwork/scanner-report/symbols-14.pb +147 -120
  200. package/.scannerwork/scanner-report/symbols-16.pb +7 -46
  201. package/.scannerwork/scanner-report/symbols-17.pb +86 -33
  202. package/.scannerwork/scanner-report/symbols-18.pb +71 -7
  203. package/.scannerwork/scanner-report/symbols-19.pb +9 -0
  204. package/.scannerwork/scanner-report/symbols-21.pb +31 -0
  205. package/.scannerwork/scanner-report/symbols-22.pb +428 -0
  206. package/.scannerwork/scanner-report/symbols-24.pb +9 -0
  207. package/.scannerwork/scanner-report/symbols-25.pb +179 -580
  208. package/.scannerwork/scanner-report/symbols-27.pb +69 -32
  209. package/.scannerwork/scanner-report/symbols-28.pb +790 -21
  210. package/.scannerwork/scanner-report/symbols-29.pb +19 -0
  211. package/.scannerwork/scanner-report/symbols-30.pb +8 -0
  212. package/.scannerwork/scanner-report/symbols-31.pb +13 -0
  213. package/.scannerwork/scanner-report/symbols-32.pb +353 -86
  214. package/.scannerwork/scanner-report/symbols-34.pb +59 -0
  215. package/.scannerwork/scanner-report/symbols-35.pb +39 -0
  216. package/.scannerwork/scanner-report/symbols-37.pb +209 -0
  217. package/.scannerwork/scanner-report/symbols-53.pb +30 -39
  218. package/.scannerwork/scanner-report/symbols-54.pb +20 -8
  219. package/.scannerwork/scanner-report/symbols-55.pb +126 -9
  220. package/.scannerwork/scanner-report/symbols-56.pb +41 -208
  221. package/.scannerwork/scanner-report/symbols-57.pb +354 -59
  222. package/.scannerwork/scanner-report/symbols-58.pb +43 -787
  223. package/.scannerwork/scanner-report/symbols-59.pb +143 -70
  224. package/.scannerwork/scanner-report/symbols-60.pb +46 -31
  225. package/.scannerwork/scanner-report/symbols-61.pb +19 -9
  226. package/.scannerwork/scanner-report/symbols-62.pb +33 -353
  227. package/.scannerwork/scanner-report/symbols-63.pb +14 -19
  228. package/.scannerwork/scanner-report/symbols-64.pb +18 -13
  229. package/.scannerwork/scanner-report/symbols-65.pb +57 -426
  230. package/.scannerwork/scanner-report/symbols-67.pb +604 -0
  231. package/.scannerwork/scanner-report/symbols-68.pb +21 -153
  232. package/.scannerwork/scanner-report/symbols-69.pb +32 -180
  233. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +3329 -82
  234. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +195 -15
  235. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +156 -155
  236. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +32 -96
  237. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +90 -94
  238. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +145 -26
  239. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +61 -0
  240. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +69 -0
  241. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +720 -0
  242. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +43 -3329
  243. package/.scannerwork/scanner-report/syntax-highlightings-25.pb +187 -548
  244. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +77 -70
  245. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +598 -53
  246. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +66 -0
  247. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +3342 -0
  248. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +32 -3323
  249. package/.scannerwork/scanner-report/syntax-highlightings-31.pb +44 -674
  250. package/.scannerwork/scanner-report/syntax-highlightings-32.pb +582 -87
  251. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +178 -0
  252. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +101 -0
  253. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +290 -0
  254. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +83 -71
  255. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +35 -20
  256. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +179 -27
  257. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +47 -256
  258. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +244 -137
  259. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +58 -590
  260. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +196 -134
  261. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +673 -34
  262. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +95 -38
  263. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +28 -23
  264. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +93 -584
  265. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +15 -36
  266. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +23 -33
  267. package/.scannerwork/scanner-report/syntax-highlightings-65.pb +96 -683
  268. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +93 -0
  269. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +641 -0
  270. package/.scannerwork/scanner-report/syntax-highlightings-68.pb +58 -190
  271. package/.scannerwork/scanner-report/syntax-highlightings-69.pb +75 -200
  272. package/.scannerwork/scanner-report/syntax-highlightings-70.pb +94 -96
  273. package/CHANGES.md +4 -0
  274. package/package.json +1 -1
  275. package/test-18-results.xml +157 -157
  276. package/test-20-results.xml +153 -153
  277. package/test-21-results.xml +145 -145
  278. package/test-iam-20-results.xml +50 -50
  279. package/.scannerwork/scanner-report/changesets-10.pb +0 -2
  280. package/.scannerwork/scanner-report/changesets-11.pb +0 -1
  281. package/.scannerwork/scanner-report/changesets-13.pb +0 -1
  282. package/.scannerwork/scanner-report/changesets-15.pb +0 -1
  283. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  284. package/.scannerwork/scanner-report/changesets-44.pb +0 -1
  285. package/.scannerwork/scanner-report/changesets-45.pb +0 -1
  286. package/.scannerwork/scanner-report/changesets-46.pb +0 -1
  287. package/.scannerwork/scanner-report/changesets-47.pb +0 -1
  288. package/.scannerwork/scanner-report/changesets-48.pb +0 -1
  289. package/.scannerwork/scanner-report/changesets-49.pb +0 -1
  290. package/.scannerwork/scanner-report/changesets-5.pb +0 -1
  291. package/.scannerwork/scanner-report/changesets-50.pb +0 -1
  292. package/.scannerwork/scanner-report/changesets-51.pb +0 -1
  293. package/.scannerwork/scanner-report/changesets-52.pb +0 -1
  294. package/.scannerwork/scanner-report/changesets-6.pb +0 -1
  295. package/.scannerwork/scanner-report/changesets-7.pb +0 -1
  296. package/.scannerwork/scanner-report/changesets-8.pb +0 -1
  297. package/.scannerwork/scanner-report/changesets-9.pb +0 -1
  298. package/.scannerwork/scanner-report/component-11.pb +0 -1
  299. package/.scannerwork/scanner-report/component-13.pb +0 -1
  300. package/.scannerwork/scanner-report/component-15.pb +0 -1
  301. package/.scannerwork/scanner-report/component-4.pb +0 -1
  302. package/.scannerwork/scanner-report/component-44.pb +0 -1
  303. package/.scannerwork/scanner-report/component-45.pb +0 -1
  304. package/.scannerwork/scanner-report/component-46.pb +0 -1
  305. package/.scannerwork/scanner-report/component-47.pb +0 -1
  306. package/.scannerwork/scanner-report/component-48.pb +0 -1
  307. package/.scannerwork/scanner-report/component-49.pb +0 -1
  308. package/.scannerwork/scanner-report/component-5.pb +0 -1
  309. package/.scannerwork/scanner-report/component-50.pb +0 -1
  310. package/.scannerwork/scanner-report/component-51.pb +0 -1
  311. package/.scannerwork/scanner-report/component-52.pb +0 -1
  312. package/.scannerwork/scanner-report/component-7.pb +0 -1
  313. package/.scannerwork/scanner-report/component-8.pb +0 -1
  314. package/.scannerwork/scanner-report/component-9.pb +0 -1
  315. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  316. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  317. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  318. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  319. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  320. package/.scannerwork/scanner-report/coverages-47.pb +0 -0
  321. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  322. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  323. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  324. package/.scannerwork/scanner-report/coverages-8.pb +0 -0
  325. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  326. package/.scannerwork/scanner-report/duplications-10.pb +0 -2
  327. package/.scannerwork/scanner-report/duplications-15.pb +0 -3
  328. package/.scannerwork/scanner-report/duplications-44.pb +0 -2
  329. package/.scannerwork/scanner-report/issues-62.pb +0 -6
  330. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  331. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  332. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  333. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  334. package/.scannerwork/scanner-report/measures-44.pb +0 -0
  335. package/.scannerwork/scanner-report/measures-47.pb +0 -0
  336. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  337. package/.scannerwork/scanner-report/measures-7.pb +0 -16
  338. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  339. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  340. package/.scannerwork/scanner-report/source-11.txt +0 -46
  341. package/.scannerwork/scanner-report/source-13.txt +0 -111
  342. package/.scannerwork/scanner-report/source-4.txt +0 -118
  343. package/.scannerwork/scanner-report/source-44.txt +0 -183
  344. package/.scannerwork/scanner-report/source-47.txt +0 -100
  345. package/.scannerwork/scanner-report/source-5.txt +0 -80
  346. package/.scannerwork/scanner-report/source-7.txt +0 -178
  347. package/.scannerwork/scanner-report/source-8.txt +0 -281
  348. package/.scannerwork/scanner-report/source-9.txt +0 -59
  349. package/.scannerwork/scanner-report/symbols-11.pb +0 -20
  350. package/.scannerwork/scanner-report/symbols-13.pb +0 -59
  351. package/.scannerwork/scanner-report/symbols-15.pb +0 -42
  352. package/.scannerwork/scanner-report/symbols-4.pb +0 -30
  353. package/.scannerwork/scanner-report/symbols-44.pb +0 -203
  354. package/.scannerwork/scanner-report/symbols-47.pb +0 -69
  355. package/.scannerwork/scanner-report/symbols-5.pb +0 -46
  356. package/.scannerwork/scanner-report/symbols-6.pb +0 -18
  357. package/.scannerwork/scanner-report/symbols-7.pb +0 -144
  358. package/.scannerwork/scanner-report/symbols-8.pb +0 -354
  359. package/.scannerwork/scanner-report/symbols-9.pb +0 -19
  360. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +0 -64
  361. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +0 -133
  362. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +0 -81
  363. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -113
  364. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +0 -280
  365. package/.scannerwork/scanner-report/syntax-highlightings-47.pb +0 -107
  366. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +0 -95
  367. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +0 -243
  368. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +0 -285
  369. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +0 -59
  370. /package/.scannerwork/scanner-report/{coverages-50.pb → coverages-20.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{coverages-48.pb → coverages-23.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{coverages-51.pb → coverages-26.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{coverages-45.pb → coverages-33.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{coverages-46.pb → coverages-36.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{coverages-52.pb → coverages-38.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{coverages-49.pb → coverages-39.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{coverages-10.pb → coverages-66.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{duplications-11.pb → duplications-19.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{duplications-13.pb → duplications-20.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-21.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{duplications-45.pb → duplications-22.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{duplications-46.pb → duplications-23.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{duplications-47.pb → duplications-24.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{duplications-51.pb → duplications-26.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{duplications-48.pb → duplications-29.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{duplications-5.pb → duplications-31.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-33.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{duplications-52.pb → duplications-34.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{duplications-6.pb → duplications-35.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{duplications-7.pb → duplications-36.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{duplications-8.pb → duplications-37.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{duplications-9.pb → duplications-38.pb} +0 -0
  393. /package/.scannerwork/scanner-report/{duplications-49.pb → duplications-39.pb} +0 -0
  394. /package/.scannerwork/scanner-report/{issues-51.pb → issues-26.pb} +0 -0
  395. /package/.scannerwork/scanner-report/{issues-63.pb → issues-29.pb} +0 -0
  396. /package/.scannerwork/scanner-report/{measures-50.pb → measures-20.pb} +0 -0
  397. /package/.scannerwork/scanner-report/{measures-48.pb → measures-23.pb} +0 -0
  398. /package/.scannerwork/scanner-report/{measures-51.pb → measures-26.pb} +0 -0
  399. /package/.scannerwork/scanner-report/{measures-45.pb → measures-33.pb} +0 -0
  400. /package/.scannerwork/scanner-report/{measures-46.pb → measures-36.pb} +0 -0
  401. /package/.scannerwork/scanner-report/{measures-52.pb → measures-38.pb} +0 -0
  402. /package/.scannerwork/scanner-report/{measures-49.pb → measures-39.pb} +0 -0
  403. /package/.scannerwork/scanner-report/{source-50.txt → source-20.txt} +0 -0
  404. /package/.scannerwork/scanner-report/{source-48.txt → source-23.txt} +0 -0
  405. /package/.scannerwork/scanner-report/{source-51.txt → source-26.txt} +0 -0
  406. /package/.scannerwork/scanner-report/{source-45.txt → source-33.txt} +0 -0
  407. /package/.scannerwork/scanner-report/{source-46.txt → source-36.txt} +0 -0
  408. /package/.scannerwork/scanner-report/{source-52.txt → source-38.txt} +0 -0
  409. /package/.scannerwork/scanner-report/{source-49.txt → source-39.txt} +0 -0
  410. /package/.scannerwork/scanner-report/{symbols-50.pb → symbols-20.pb} +0 -0
  411. /package/.scannerwork/scanner-report/{symbols-48.pb → symbols-23.pb} +0 -0
  412. /package/.scannerwork/scanner-report/{symbols-51.pb → symbols-26.pb} +0 -0
  413. /package/.scannerwork/scanner-report/{symbols-45.pb → symbols-33.pb} +0 -0
  414. /package/.scannerwork/scanner-report/{symbols-46.pb → symbols-36.pb} +0 -0
  415. /package/.scannerwork/scanner-report/{symbols-52.pb → symbols-38.pb} +0 -0
  416. /package/.scannerwork/scanner-report/{symbols-49.pb → symbols-39.pb} +0 -0
  417. /package/.scannerwork/scanner-report/{symbols-10.pb → symbols-66.pb} +0 -0
  418. /package/.scannerwork/scanner-report/{syntax-highlightings-50.pb → syntax-highlightings-20.pb} +0 -0
  419. /package/.scannerwork/scanner-report/{syntax-highlightings-48.pb → syntax-highlightings-23.pb} +0 -0
  420. /package/.scannerwork/scanner-report/{syntax-highlightings-51.pb → syntax-highlightings-26.pb} +0 -0
  421. /package/.scannerwork/scanner-report/{syntax-highlightings-45.pb → syntax-highlightings-33.pb} +0 -0
  422. /package/.scannerwork/scanner-report/{syntax-highlightings-46.pb → syntax-highlightings-36.pb} +0 -0
  423. /package/.scannerwork/scanner-report/{syntax-highlightings-52.pb → syntax-highlightings-38.pb} +0 -0
  424. /package/.scannerwork/scanner-report/{syntax-highlightings-49.pb → syntax-highlightings-39.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2023 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2022 IBM Corp. All rights reserved.
2
2
  //
3
3
  // Licensed under the Apache License, Version 2.0 (the "License");
4
4
  // you may not use this file except in compliance with the License.
@@ -11,283 +11,101 @@
11
11
  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
-
15
- /* global describe it before after beforeEach */
16
14
  'use strict';
17
15
 
18
- const assert = require('assert');
19
16
  const fs = require('fs');
20
- const u = require('./citestutils.js');
21
- const mockServerPort = +process.env.COUCHBACKUP_MOCK_SERVER_PORT || 7777;
22
- const { once } = require('node:events');
23
- const url = `http://localhost:${mockServerPort}`;
24
- const nock = require('nock');
25
- const httpProxy = require('http-proxy');
26
- const Readable = require('stream').Readable;
27
-
28
- // Create an infinite stream to read.
29
- // It just keeps sending a backup line, useful for testing cases of
30
- // termination while a stream has content remaining (the animaldb backup
31
- // is too small for that).
32
- class InfiniteBackupStream extends Readable {
33
- constructor(opt) {
34
- super(opt);
35
- this.contents = Buffer.from('[{"_id":"giraffe","_rev":"3-7665c3e66315ff40616cceef62886bd8","min_weight":830,"min_length":5,"max_weight":1600,"max_length":6,"wiki_page":"http://en.wikipedia.org/wiki/Giraffe","class":"mammal","diet":"herbivore","_revisions":{"start":3,"ids":["7665c3e66315ff40616cceef62886bd8","aaaf10d5a68cdf22d95a5482a0e95549","967a00dff5e02add41819138abb3284d"]}}]\n', 'utf8');
36
- }
37
-
38
- _read() {
39
- let proceed;
40
- do {
41
- proceed = this.push(this.contents);
42
- } while (proceed);
43
- }
44
- }
45
-
46
- function assertNock() {
47
- try {
48
- assert.ok(nock.isDone());
49
- } catch (err) {
50
- console.error('pending mocks: %j', nock.pendingMocks());
51
- throw err;
52
- }
53
- }
54
-
55
- function testPromiseWithAssertNock(testPromise) {
56
- return testPromise.finally(() => {
57
- assertNock();
58
- });
59
- }
60
-
61
- async function backupHttpError(opts, errorName, errorCode) {
62
- const p = u.p(opts, { expectedBackupError: { name: errorName, code: errorCode } });
63
-
64
- // Create a file and attempt a backup to it
65
- const output = fs.createWriteStream('/dev/null');
66
- return once(output, 'open')
67
- .then(() => {
68
- return testPromiseWithAssertNock(u.testBackup(p, 'fakenockdb', output));
69
- });
70
- }
71
-
72
- async function restoreHttpError(opts, errorName, errorCode) {
73
- const q = u.p(opts, { expectedRestoreError: { name: errorName, code: errorCode } });
74
- return testPromiseWithAssertNock(u.testRestoreFromFile(q, './test/fixtures/animaldb_expected.json', 'fakenockdb'));
75
- }
76
-
77
- [{ useApi: true }, { useApi: false }].forEach(function(params) {
78
- describe(u.scenario('#unit Fatal errors', params), function() {
79
- // These tests do real requests with mocks and if they run slowly
80
- // the 2 second default mocha timeout can be insufficient, use 10 s
81
- this.timeout(10000);
82
-
83
- let processEnvCopy;
84
- let proxy;
85
-
86
- before('Set process data for test', function() {
87
- const proxyPort = mockServerPort + 1000;
88
- // Copy env and argv so we can reset them after the tests
89
- processEnvCopy = JSON.parse(JSON.stringify(process.env));
90
-
91
- // Set up a proxy to point to our nock server because the nock override
92
- // isn't visible to the spawned CLI process
93
- if (!params.useApi) {
94
- proxy = httpProxy.createProxyServer({ target: url }).listen(proxyPort, 'localhost');
95
- proxy.on('error', (err, req, res) => {
96
- console.log(`Proxy received error ${err}`);
97
- res.writeHead(400, {
98
- 'Content-Type': 'application/json'
99
- });
100
- res.end(JSON.stringify(err));
101
- });
102
- }
103
-
104
- // setup environment variables
105
- process.env.COUCH_URL = (params.useApi) ? url : `http://localhost:${proxyPort}`;
106
-
107
- nock.emitter.on('no match', (req, opts) => {
108
- console.error(`Unmatched nock request ${opts.method} ${opts.protocol}${opts.host}${opts.path}`);
109
- });
110
- });
111
-
112
- after('Reset process data', function(done) {
113
- process.env = processEnvCopy;
114
- nock.emitter.removeAllListeners();
115
- if (!params.useApi) {
116
- proxy.close(done);
117
- } else {
118
- done();
17
+ const liner = require('./liner.js');
18
+ const change = require('./change.js');
19
+ const error = require('./error.js');
20
+ const debug = require('debug')('couchbackup:spoolchanges');
21
+
22
+ /**
23
+ * Write log file for all changes from a database, ready for downloading
24
+ * in batches.
25
+ *
26
+ * @param {string} dbUrl - URL of database
27
+ * @param {string} log - path to log file to use
28
+ * @param {number} bufferSize - the number of changes per batch/log line
29
+ * @param {function(err)} callback - a callback to run on completion
30
+ */
31
+ module.exports = function(db, log, bufferSize, ee, callback) {
32
+ // list of document ids to process
33
+ const buffer = [];
34
+ let batch = 0;
35
+ let lastSeq = null;
36
+ const logStream = fs.createWriteStream(log);
37
+ let pending = 0;
38
+ // The number of changes to fetch per request
39
+ const limit = 100000;
40
+
41
+ // send documents ids to the queue in batches of bufferSize + the last batch
42
+ const processBuffer = function(lastOne) {
43
+ if (buffer.length >= bufferSize || (lastOne && buffer.length > 0)) {
44
+ debug('writing', buffer.length, 'changes to the backup file');
45
+ const b = { docs: buffer.splice(0, bufferSize), batch: batch };
46
+ logStream.write(':t batch' + batch + ' ' + JSON.stringify(b.docs) + '\n');
47
+ ee.emit('changes', batch);
48
+ batch++;
49
+ }
50
+ };
51
+
52
+ // called once per received change
53
+ const onChange = function(c) {
54
+ if (c) {
55
+ if (c.error) {
56
+ ee.emit('error', new error.BackupError('InvalidChange', `Received invalid change: ${c}`));
57
+ } else if (c.changes) {
58
+ const obj = { id: c.id };
59
+ buffer.push(obj);
60
+ processBuffer(false);
61
+ } else if (c.last_seq) {
62
+ lastSeq = c.last_seq;
63
+ pending = c.pending;
119
64
  }
120
- });
121
-
122
- beforeEach('Reset nocks', function() {
123
- nock.cleanAll();
124
- });
125
-
126
- describe('for backup', function() {
127
- it('should terminate when DB does not exist', function() {
128
- // Simulate existence check
129
- nock(url).head('/fakenockdb').reply(404, { error: 'not_found', reason: 'missing' });
130
- return backupHttpError(params, 'DatabaseNotFound', 10);
131
- });
132
-
133
- it('should terminate on BulkGetError', function() {
134
- // Simulate existence check
135
- const n = nock(url).head('/fakenockdb').reply(200);
136
- // Simulate _bulk_get not available
137
- n.post('/fakenockdb/_bulk_get').reply(404, { error: 'not_found', reason: 'missing' });
138
- return backupHttpError(params, 'BulkGetError', 50);
139
- });
140
-
141
- it('should terminate on Unauthorized existence check', function() {
142
- // Simulate a 401
143
- nock(url).head('/fakenockdb').reply(401, { error: 'unauthorized', reason: '_reader access is required for this request' });
144
- return backupHttpError(params, 'Unauthorized', 11);
145
- });
146
-
147
- it('should terminate on Forbidden no _reader', function() {
148
- // Simulate a 403
149
- nock(url).head('/fakenockdb').reply(403, { error: 'forbidden', reason: '_reader access is required for this request' });
150
- return backupHttpError(params, 'Forbidden', 12);
151
- });
152
-
153
- it('should terminate on _bulk_get HTTPFatalError', function() {
154
- // Provide a mock complete changes log to allow a resume to skip ahead
155
- const p = u.p(params, { opts: { resume: true, log: './test/fixtures/test.log' } });
156
- // Allow the existence and _bulk_get checks to pass
157
- const n = nock(url).head('/fakenockdb').reply(200);
158
- n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
159
- // Simulate a fatal HTTP error when trying to fetch docs
160
- // Note: 2 outstanding batches, so 2 responses, 1 mock is optional because we can't guarantee timing
161
- n.post('/fakenockdb/_bulk_get').query(true).reply(400, { error: 'bad_request', reason: 'testing bad response' });
162
- n.post('/fakenockdb/_bulk_get').query(true).optionally().reply(400, { error: 'bad_request', reason: 'testing bad response' });
163
- return backupHttpError(p, 'HTTPFatalError', 40);
164
- });
165
-
166
- it('should terminate on NoLogFileName', function() {
167
- // Don't supply a log file name with resume
168
- const p = u.p(params, { opts: { resume: true } });
169
- return backupHttpError(p, 'NoLogFileName', 20);
170
- });
171
-
172
- it('should terminate on LogDoesNotExist', function() {
173
- // Use a non-existent log file
174
- const p = u.p(params, { opts: { resume: true, log: './test/fixtures/doesnotexist.log' } });
175
- return backupHttpError(p, 'LogDoesNotExist', 21);
176
- });
177
-
178
- it('should terminate on IncompleteChangesInLogFile', function() {
179
- // Use an incomplete changes log file
180
- const p = u.p(params, { opts: { resume: true, log: './test/fixtures/incomplete_changes.log' } });
181
- // Allow the existence and _bulk_get checks to pass
182
- const n = nock(url).head('/fakenockdb').reply(200);
183
- n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
184
- // Should fail when it reads the incomplete changes
185
- return backupHttpError(p, 'IncompleteChangesInLogFile', 22);
186
- });
187
-
188
- it('should terminate on _changes HTTPFatalError', function() {
189
- // Allow the existence and _bulk_get checks to pass
190
- const n = nock(url).head('/fakenockdb').reply(200);
191
- n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
192
- // Simulate a fatal HTTP error when trying to fetch docs (note 2 outstanding batches)
193
- n.post('/fakenockdb/_changes').query(true).reply(400, { error: 'bad_request', reason: 'testing bad response' });
194
- return backupHttpError(params, 'HTTPFatalError', 40);
195
- });
196
-
197
- it('should terminate on SpoolChangesError', function() {
198
- // Allow the existence and _bulk_get checks to pass
199
- const n = nock(url).head('/fakenockdb').reply(200);
200
- n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
201
- // Simulate a changes without a last_seq
202
- n.post('/fakenockdb/_changes').query(true).reply(200,
203
- {
204
- results: [{
205
- seq: '2-g1AAAAEbeJzLYWBgYMlgTmFQSElKzi9KdUhJstTLTS3KLElMT9VLzskvTUnMK9HLSy3JAapkSmRIsv___39WBnMiUy5QgN3MzDIxOdEMWb85dv0gSxThigyN8diS5AAkk-pBFiUyoOkzxKMvjwVIMjQAKaDW_Zh6TQnqPQDRC7I3CwDPDV1k',
206
- id: 'badger',
207
- changes: [{ rev: '4-51aa94e4b0ef37271082033bba52b850' }]
208
- }]
65
+ }
66
+ };
67
+
68
+ function getChanges(since = 0) {
69
+ debug('making changes request since ' + since);
70
+ return db.service.postChangesAsStream({ db: db.db, since: since, limit: limit, seqInterval: limit })
71
+ .then(response => {
72
+ response.result.pipe(liner())
73
+ .on('error', function(err) {
74
+ logStream.end();
75
+ callback(err);
76
+ })
77
+ .pipe(change(onChange))
78
+ .on('error', function(err) {
79
+ logStream.end();
80
+ callback(err);
81
+ })
82
+ .on('finish', function() {
83
+ processBuffer(true);
84
+ if (!lastSeq) {
85
+ logStream.end();
86
+ debug('changes request terminated before last_seq was sent');
87
+ callback(new error.BackupError('SpoolChangesError', 'Changes request terminated before last_seq was sent'));
88
+ } else {
89
+ debug(`changes request completed with last_seq: ${lastSeq} and ${pending} changes pending.`);
90
+ if (pending > 0) {
91
+ // Return the next promise
92
+ return getChanges(lastSeq);
93
+ } else {
94
+ debug('finished streaming database changes');
95
+ logStream.end(':changes_complete ' + lastSeq + '\n', 'utf8', callback);
96
+ }
97
+ }
209
98
  });
210
- return backupHttpError(params, 'SpoolChangesError', 30);
211
- });
212
- });
213
-
214
- describe('for restore', function() {
215
- it('should terminate on Unauthorized db existence check', function() {
216
- // Simulate a 401
217
- nock(url).get('/fakenockdb').reply(401, { error: 'unauthorized', reason: '_reader access is required for this request' });
218
- return restoreHttpError(params, 'Unauthorized', 11);
219
- });
220
-
221
- it('should terminate on Forbidden no _writer', function() {
222
- // Simulate the DB exists (i.e. you can read it)
223
- const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
224
- // Simulate a 403 trying to write
225
- n.post('/fakenockdb/_bulk_docs').reply(403, { error: 'forbidden', reason: '_writer access is required for this request' });
226
- return restoreHttpError(params, 'Forbidden', 12);
227
- });
228
-
229
- it('should terminate on RestoreDatabaseNotFound', function() {
230
- // Simulate the DB does not exist
231
- nock(url).get('/fakenockdb').reply(404, { error: 'not_found', reason: 'Database does not exist.' });
232
- return restoreHttpError(params, 'DatabaseNotFound', 10);
233
- });
234
-
235
- it('should terminate on notEmptyDBErr when database is not empty', function() {
236
- // Simulate the DB that does exist and not empty
237
- nock(url).get('/fakenockdb').reply(200, { doc_count: 10, doc_del_count: 0 });
238
- return restoreHttpError(params, 'DatabaseNotEmpty', 13);
239
- });
240
-
241
- it('should terminate on notEmptyDBErr when database is not new', function() {
242
- // Simulate the DB that does exist and not new
243
- nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 10 });
244
- return restoreHttpError(params, 'DatabaseNotEmpty', 13);
245
- });
246
-
247
- it('should terminate on _bulk_docs HTTPFatalError', function() {
248
- // Simulate the DB exists
249
- const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
250
- // Use a parallelism of one and mock one response
251
- const p = u.p(params, { opts: { parallelism: 1 } });
252
- // Simulate a 400 trying to write
253
- n.post('/fakenockdb/_bulk_docs').reply(400, { error: 'bad_request', reason: 'testing bad response' });
254
- return restoreHttpError(p, 'HTTPFatalError', 40);
255
- });
256
-
257
- it('should terminate on _bulk_docs HTTPFatalError from system database', function() {
258
- // Simulate that target database exists and is _not_ empty.
259
- // This should pass validator as we exclude system databases from the check.
260
- const n = nock(url).get('/_replicator').reply(200, { doc_count: 1, doc_del_count: 0 });
261
- // Simulate a 400 trying to write
262
- n.post('/_replicator/_bulk_docs').reply(400, { error: 'bad_request', reason: 'testing bad response' });
263
- // Use a parallelism of one and mock one response
264
- const q = u.p(params, { opts: { parallelism: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
265
- return testPromiseWithAssertNock(u.testRestore(q, new InfiniteBackupStream(), '_replicator'));
266
- });
267
-
268
- it('should terminate on _bulk_docs HTTPFatalError large stream', function() {
269
- // Simulate the DB exists
270
- const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
271
- // Simulate a 400 trying to write
272
- // Provide a body function to handle the stream, but allow any body
273
- n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).reply(400, { error: 'bad_request', reason: 'testing bad response' });
274
- // Use only parallelism 1 so we don't have to mock up loads of responses
275
- const q = u.p(params, { opts: { parallelism: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
276
- return testPromiseWithAssertNock(u.testRestore(q, new InfiniteBackupStream(), 'fakenockdb'));
99
+ })
100
+ .catch(err => {
101
+ logStream.end();
102
+ if (err.status && err.status >= 400) {
103
+ callback(error.convertResponseError(err));
104
+ } else if (err.name !== 'SpoolChangesError') {
105
+ callback(new error.BackupError('SpoolChangesError', `Failed changes request - ${err.message}`));
106
+ }
277
107
  });
108
+ }
278
109
 
279
- it('should terminate on multiple _bulk_docs HTTPFatalError', function() {
280
- // Simulate the DB exists
281
- const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
282
- // Simulate a 400 trying to write docs, 5 times because of default parallelism
283
- // Provide a body function to handle the stream, but allow any body
284
- // Four of the mocks are optional because of parallelism 5 we can't guarantee that the exit will happen
285
- // after all 5 requests, but we must get at least one of them
286
- n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).reply(400, { error: 'bad_request', reason: 'testing bad response' });
287
- n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).times(4).optionally().reply(400, { error: 'bad_request', reason: 'testing bad response' });
288
- const q = u.p(params, { opts: { bufferSize: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
289
- return restoreHttpError(q, 'HTTPFatalError', 40);
290
- });
291
- });
292
- });
293
- });
110
+ getChanges();
111
+ };
@@ -17,8 +17,9 @@ const fs = require('fs');
17
17
  const stream = require('stream');
18
18
  const liner = require('./liner.js');
19
19
 
20
- const onLine = function(onCommand, batches) {
20
+ const onLine = function(onCommand, getDocs) {
21
21
  const change = new stream.Transform({ objectMode: true });
22
+
22
23
  change._transform = function(line, encoding, done) {
23
24
  if (line && line[0] === ':') {
24
25
  const obj = {
@@ -41,35 +42,51 @@ const onLine = function(onCommand, batches) {
41
42
  obj.batch = parseInt(matches[1]);
42
43
  }
43
44
 
44
- // if this is one we want
45
- if (obj.command === 't' && batches.indexOf(obj.batch) > -1) {
45
+ // extract doc ids
46
+ if (getDocs && obj.command === 't') {
46
47
  const json = line.replace(/^.* batch[0-9]+ /, '').trim();
47
48
  obj.docs = JSON.parse(json);
48
- onCommand(obj);
49
49
  }
50
+ onCommand(obj);
50
51
  }
51
52
  done();
52
53
  };
53
54
  return change;
54
55
  };
55
56
 
56
- module.exports = function(log, batches, callback) {
57
+ /**
58
+ * Generate a list of remaining batches from a download file.
59
+ *
60
+ * @param {string} log - log file name
61
+ * @param {function} callback - callback with err, {changesComplete: N, batches: N}.
62
+ * changesComplete signifies whether the log file appeared to
63
+ * have completed reading the changes feed (contains :changes_complete).
64
+ * batches are remaining batch IDs for download.
65
+ */
66
+ module.exports = function(log, callback) {
57
67
  // our sense of state
58
- const retval = { };
68
+ const state = {
69
+
70
+ };
71
+ let changesComplete = false;
59
72
 
60
73
  // called with each line from the log file
61
74
  const onCommand = function(obj) {
62
- retval[obj.batch] = obj;
75
+ if (obj.command === 't') {
76
+ state[obj.batch] = true;
77
+ } else if (obj.command === 'd') {
78
+ delete state[obj.batch];
79
+ } else if (obj.command === 'changes_complete') {
80
+ changesComplete = true;
81
+ }
63
82
  };
64
83
 
65
84
  // stream through the previous log file
66
85
  fs.createReadStream(log)
67
86
  .pipe(liner())
68
- .pipe(onLine(onCommand, batches))
69
- .on('error', function(err) {
70
- callback(err);
71
- })
87
+ .pipe(onLine(onCommand, false))
72
88
  .on('finish', function() {
73
- callback(null, retval);
89
+ const obj = { changesComplete: changesComplete, batches: state };
90
+ callback(null, obj);
74
91
  });
75
92
  };