@cloudant/couchbackup 2.9.16 → 2.9.17-SNAPSHOT.185

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 (392) 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/changesets-23.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-24.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-26.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-27.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-28.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-29.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-53.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-55.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-56.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-57.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-58.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-59.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-62.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-63.pb +1 -0
  18. package/.scannerwork/scanner-report/changesets-67.pb +1 -0
  19. package/.scannerwork/scanner-report/changesets-69.pb +1 -0
  20. package/.scannerwork/scanner-report/component-1.pb +1 -2
  21. package/.scannerwork/scanner-report/component-11.pb +1 -1
  22. package/.scannerwork/scanner-report/component-12.pb +1 -1
  23. package/.scannerwork/scanner-report/component-13.pb +1 -1
  24. package/.scannerwork/scanner-report/component-14.pb +1 -1
  25. package/.scannerwork/scanner-report/component-15.pb +1 -1
  26. package/.scannerwork/scanner-report/component-16.pb +1 -1
  27. package/.scannerwork/scanner-report/component-17.pb +1 -1
  28. package/.scannerwork/scanner-report/component-18.pb +1 -1
  29. package/.scannerwork/scanner-report/component-19.pb +1 -1
  30. package/.scannerwork/scanner-report/component-20.pb +1 -1
  31. package/.scannerwork/scanner-report/component-21.pb +1 -1
  32. package/.scannerwork/scanner-report/component-22.pb +1 -1
  33. package/.scannerwork/scanner-report/component-23.pb +1 -0
  34. package/.scannerwork/scanner-report/component-24.pb +1 -0
  35. package/.scannerwork/scanner-report/component-25.pb +1 -0
  36. package/.scannerwork/scanner-report/component-26.pb +1 -0
  37. package/.scannerwork/scanner-report/component-27.pb +1 -0
  38. package/.scannerwork/scanner-report/component-28.pb +1 -0
  39. package/.scannerwork/scanner-report/component-29.pb +1 -0
  40. package/.scannerwork/scanner-report/component-3.pb +1 -1
  41. package/.scannerwork/scanner-report/component-41.pb +1 -1
  42. package/.scannerwork/scanner-report/component-42.pb +1 -1
  43. package/.scannerwork/scanner-report/component-43.pb +1 -1
  44. package/.scannerwork/scanner-report/component-44.pb +1 -1
  45. package/.scannerwork/scanner-report/component-45.pb +1 -1
  46. package/.scannerwork/scanner-report/component-46.pb +1 -1
  47. package/.scannerwork/scanner-report/component-47.pb +1 -1
  48. package/.scannerwork/scanner-report/component-48.pb +1 -1
  49. package/.scannerwork/scanner-report/component-49.pb +1 -1
  50. package/.scannerwork/scanner-report/component-50.pb +1 -1
  51. package/.scannerwork/scanner-report/component-51.pb +1 -1
  52. package/.scannerwork/scanner-report/component-52.pb +1 -1
  53. package/.scannerwork/scanner-report/component-53.pb +1 -0
  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 -0
  57. package/.scannerwork/scanner-report/component-57.pb +1 -0
  58. package/.scannerwork/scanner-report/component-58.pb +1 -0
  59. package/.scannerwork/scanner-report/component-59.pb +1 -0
  60. package/.scannerwork/scanner-report/component-60.pb +1 -1
  61. package/.scannerwork/scanner-report/component-62.pb +1 -0
  62. package/.scannerwork/scanner-report/component-63.pb +1 -0
  63. package/.scannerwork/scanner-report/component-67.pb +1 -0
  64. package/.scannerwork/scanner-report/component-69.pb +1 -0
  65. package/.scannerwork/scanner-report/component-70.pb +1 -0
  66. package/.scannerwork/scanner-report/component-9.pb +1 -1
  67. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-12.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-41.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-47.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-49.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-51.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-56.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-62.pb +0 -0
  100. package/.scannerwork/scanner-report/coverages-69.pb +0 -0
  101. package/.scannerwork/scanner-report/duplications-12.pb +0 -3
  102. package/.scannerwork/scanner-report/duplications-15.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-24.pb +2 -0
  104. package/.scannerwork/scanner-report/duplications-43.pb +2 -0
  105. package/.scannerwork/scanner-report/duplications-50.pb +0 -2
  106. package/.scannerwork/scanner-report/duplications-51.pb +3 -2
  107. package/.scannerwork/scanner-report/duplications-66.pb +1 -1
  108. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  109. package/.scannerwork/scanner-report/measures-12.pb +0 -0
  110. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  111. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  112. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  113. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  114. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  115. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-41.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-44.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-47.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-69.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  144. package/.scannerwork/scanner-report/metadata.pb +0 -0
  145. package/.scannerwork/scanner-report/source-11.txt +25 -16
  146. package/.scannerwork/scanner-report/source-12.txt +32 -199
  147. package/.scannerwork/scanner-report/source-13.txt +17 -87
  148. package/.scannerwork/scanner-report/source-14.txt +115 -116
  149. package/.scannerwork/scanner-report/source-15.txt +66 -423
  150. package/.scannerwork/scanner-report/source-16.txt +64 -277
  151. package/.scannerwork/scanner-report/source-17.txt +247 -66
  152. package/.scannerwork/scanner-report/source-18.txt +104 -92
  153. package/.scannerwork/scanner-report/source-19.txt +45 -120
  154. package/.scannerwork/scanner-report/source-20.txt +89 -41
  155. package/.scannerwork/scanner-report/source-21.txt +148 -24
  156. package/.scannerwork/scanner-report/source-22.txt +162 -25
  157. package/.scannerwork/scanner-report/source-24.txt +75 -0
  158. package/.scannerwork/scanner-report/{source-38.txt → source-25.txt} +143 -143
  159. package/.scannerwork/scanner-report/source-27.txt +65 -0
  160. package/.scannerwork/scanner-report/source-28.txt +100 -0
  161. package/.scannerwork/scanner-report/source-3.txt +152 -152
  162. package/.scannerwork/scanner-report/source-41.txt +315 -32
  163. package/.scannerwork/scanner-report/source-42.txt +23 -63
  164. package/.scannerwork/scanner-report/source-43.txt +169 -45
  165. package/.scannerwork/scanner-report/source-44.txt +23 -164
  166. package/.scannerwork/scanner-report/source-45.txt +116 -104
  167. package/.scannerwork/scanner-report/source-46.txt +14 -26
  168. package/.scannerwork/scanner-report/source-47.txt +48 -99
  169. package/.scannerwork/scanner-report/source-48.txt +52 -141
  170. package/.scannerwork/scanner-report/source-49.txt +254 -242
  171. package/.scannerwork/scanner-report/source-50.txt +114 -72
  172. package/.scannerwork/scanner-report/source-51.txt +198 -60
  173. package/.scannerwork/scanner-report/source-52.txt +134 -14
  174. package/.scannerwork/scanner-report/source-54.txt +80 -25
  175. package/.scannerwork/scanner-report/source-55.txt +187 -424
  176. package/.scannerwork/scanner-report/{source-5.txt → source-56.txt} +10 -7
  177. package/.scannerwork/scanner-report/source-58.txt +106 -0
  178. package/.scannerwork/scanner-report/source-59.txt +449 -0
  179. package/.scannerwork/scanner-report/source-60.txt +25 -44
  180. package/.scannerwork/scanner-report/source-62.txt +60 -0
  181. package/.scannerwork/scanner-report/source-69.txt +46 -0
  182. package/.scannerwork/scanner-report/{source-68.txt → source-70.txt} +49 -49
  183. package/.scannerwork/scanner-report/source-9.txt +424 -183
  184. package/.scannerwork/scanner-report/symbols-11.pb +18 -9
  185. package/.scannerwork/scanner-report/symbols-12.pb +20 -264
  186. package/.scannerwork/scanner-report/symbols-13.pb +13 -57
  187. package/.scannerwork/scanner-report/symbols-14.pb +33 -86
  188. package/.scannerwork/scanner-report/symbols-15.pb +43 -789
  189. package/.scannerwork/scanner-report/symbols-16.pb +44 -426
  190. package/.scannerwork/scanner-report/symbols-17.pb +354 -69
  191. package/.scannerwork/scanner-report/symbols-18.pb +30 -59
  192. package/.scannerwork/scanner-report/symbols-19.pb +19 -71
  193. package/.scannerwork/scanner-report/symbols-20.pb +45 -32
  194. package/.scannerwork/scanner-report/symbols-21.pb +126 -23
  195. package/.scannerwork/scanner-report/symbols-22.pb +143 -30
  196. package/.scannerwork/scanner-report/symbols-24.pb +42 -0
  197. package/.scannerwork/scanner-report/symbols-27.pb +33 -0
  198. package/.scannerwork/scanner-report/symbols-28.pb +69 -0
  199. package/.scannerwork/scanner-report/symbols-41.pb +353 -20
  200. package/.scannerwork/scanner-report/symbols-42.pb +23 -46
  201. package/.scannerwork/scanner-report/symbols-43.pb +203 -19
  202. package/.scannerwork/scanner-report/symbols-44.pb +9 -144
  203. package/.scannerwork/scanner-report/symbols-45.pb +86 -30
  204. package/.scannerwork/scanner-report/symbols-46.pb +8 -18
  205. package/.scannerwork/scanner-report/symbols-47.pb +23 -45
  206. package/.scannerwork/scanner-report/symbols-48.pb +39 -126
  207. package/.scannerwork/scanner-report/symbols-49.pb +402 -328
  208. package/.scannerwork/scanner-report/symbols-50.pb +71 -44
  209. package/.scannerwork/scanner-report/symbols-51.pb +264 -42
  210. package/.scannerwork/scanner-report/symbols-52.pb +92 -13
  211. package/.scannerwork/scanner-report/symbols-54.pb +58 -7
  212. package/.scannerwork/scanner-report/symbols-56.pb +9 -0
  213. package/.scannerwork/scanner-report/symbols-58.pb +59 -0
  214. package/.scannerwork/scanner-report/symbols-59.pb +790 -0
  215. package/.scannerwork/scanner-report/symbols-60.pb +31 -21
  216. package/.scannerwork/scanner-report/symbols-62.pb +21 -0
  217. package/.scannerwork/scanner-report/symbols-69.pb +7 -0
  218. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +23 -25
  219. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +33 -266
  220. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +15 -124
  221. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +94 -90
  222. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +57 -591
  223. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +62 -687
  224. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +245 -67
  225. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +83 -148
  226. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +23 -145
  227. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +93 -77
  228. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +177 -20
  229. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +207 -33
  230. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +81 -0
  231. package/.scannerwork/scanner-report/{syntax-highlightings-38.pb → syntax-highlightings-25.pb} +103 -100
  232. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +110 -0
  233. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +107 -0
  234. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +107 -108
  235. package/.scannerwork/scanner-report/syntax-highlightings-41.pb +590 -34
  236. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +22 -61
  237. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +246 -25
  238. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +27 -209
  239. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +95 -83
  240. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +20 -23
  241. package/.scannerwork/scanner-report/syntax-highlightings-47.pb +67 -96
  242. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +64 -176
  243. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +606 -171
  244. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +145 -57
  245. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +263 -47
  246. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +208 -16
  247. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +119 -27
  248. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +289 -3261
  249. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +54 -0
  250. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +178 -0
  251. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +627 -0
  252. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +48 -61
  253. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +82 -0
  254. package/.scannerwork/scanner-report/syntax-highlightings-69.pb +62 -0
  255. package/.scannerwork/scanner-report/{syntax-highlightings-68.pb → syntax-highlightings-70.pb} +14 -13
  256. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +3286 -226
  257. package/package.json +1 -1
  258. package/test-18-results.xml +147 -147
  259. package/test-20-results.xml +141 -141
  260. package/test-21-results.xml +143 -143
  261. package/test-iam-20-results.xml +49 -49
  262. package/.scannerwork/scanner-report/changesets-10.pb +0 -2
  263. package/.scannerwork/scanner-report/changesets-2.pb +0 -1
  264. package/.scannerwork/scanner-report/changesets-34.pb +0 -1
  265. package/.scannerwork/scanner-report/changesets-35.pb +0 -1
  266. package/.scannerwork/scanner-report/changesets-36.pb +0 -1
  267. package/.scannerwork/scanner-report/changesets-37.pb +0 -1
  268. package/.scannerwork/scanner-report/changesets-39.pb +0 -1
  269. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  270. package/.scannerwork/scanner-report/changesets-40.pb +0 -1
  271. package/.scannerwork/scanner-report/changesets-5.pb +0 -1
  272. package/.scannerwork/scanner-report/changesets-6.pb +0 -1
  273. package/.scannerwork/scanner-report/changesets-61.pb +0 -1
  274. package/.scannerwork/scanner-report/changesets-64.pb +0 -1
  275. package/.scannerwork/scanner-report/changesets-7.pb +0 -1
  276. package/.scannerwork/scanner-report/changesets-8.pb +0 -1
  277. package/.scannerwork/scanner-report/changesets-9.pb +0 -1
  278. package/.scannerwork/scanner-report/component-10.pb +0 -2
  279. package/.scannerwork/scanner-report/component-2.pb +0 -1
  280. package/.scannerwork/scanner-report/component-34.pb +0 -1
  281. package/.scannerwork/scanner-report/component-35.pb +0 -1
  282. package/.scannerwork/scanner-report/component-36.pb +0 -1
  283. package/.scannerwork/scanner-report/component-37.pb +0 -1
  284. package/.scannerwork/scanner-report/component-38.pb +0 -1
  285. package/.scannerwork/scanner-report/component-39.pb +0 -1
  286. package/.scannerwork/scanner-report/component-4.pb +0 -1
  287. package/.scannerwork/scanner-report/component-40.pb +0 -1
  288. package/.scannerwork/scanner-report/component-5.pb +0 -1
  289. package/.scannerwork/scanner-report/component-6.pb +0 -1
  290. package/.scannerwork/scanner-report/component-61.pb +0 -1
  291. package/.scannerwork/scanner-report/component-64.pb +0 -1
  292. package/.scannerwork/scanner-report/component-68.pb +0 -1
  293. package/.scannerwork/scanner-report/component-7.pb +0 -1
  294. package/.scannerwork/scanner-report/component-8.pb +0 -1
  295. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  296. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  297. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  298. package/.scannerwork/scanner-report/coverages-39.pb +0 -0
  299. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  300. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  301. package/.scannerwork/scanner-report/coverages-8.pb +0 -0
  302. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  303. package/.scannerwork/scanner-report/duplications-9.pb +0 -2
  304. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  305. package/.scannerwork/scanner-report/measures-36.pb +0 -15
  306. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  307. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  308. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  309. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  310. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  311. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  312. package/.scannerwork/scanner-report/source-10.txt +0 -37
  313. package/.scannerwork/scanner-report/source-36.txt +0 -151
  314. package/.scannerwork/scanner-report/source-37.txt +0 -75
  315. package/.scannerwork/scanner-report/source-39.txt +0 -129
  316. package/.scannerwork/scanner-report/source-4.txt +0 -187
  317. package/.scannerwork/scanner-report/source-6.txt +0 -329
  318. package/.scannerwork/scanner-report/source-8.txt +0 -62
  319. package/.scannerwork/scanner-report/symbols-10.pb +0 -9
  320. package/.scannerwork/scanner-report/symbols-36.pb +0 -93
  321. package/.scannerwork/scanner-report/symbols-37.pb +0 -39
  322. package/.scannerwork/scanner-report/symbols-39.pb +0 -33
  323. package/.scannerwork/scanner-report/symbols-5.pb +0 -8
  324. package/.scannerwork/scanner-report/symbols-6.pb +0 -353
  325. package/.scannerwork/scanner-report/symbols-8.pb +0 -24
  326. package/.scannerwork/scanner-report/symbols-9.pb +0 -203
  327. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +0 -61
  328. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +0 -237
  329. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +0 -101
  330. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +0 -129
  331. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -368
  332. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +0 -49
  333. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +0 -620
  334. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +0 -97
  335. /package/.scannerwork/scanner-report/{coverages-40.pb → coverages-23.pb} +0 -0
  336. /package/.scannerwork/scanner-report/{coverages-2.pb → coverages-26.pb} +0 -0
  337. /package/.scannerwork/scanner-report/{coverages-34.pb → coverages-29.pb} +0 -0
  338. /package/.scannerwork/scanner-report/{coverages-7.pb → coverages-53.pb} +0 -0
  339. /package/.scannerwork/scanner-report/{coverages-4.pb → coverages-55.pb} +0 -0
  340. /package/.scannerwork/scanner-report/{coverages-35.pb → coverages-57.pb} +0 -0
  341. /package/.scannerwork/scanner-report/{coverages-61.pb → coverages-63.pb} +0 -0
  342. /package/.scannerwork/scanner-report/{coverages-64.pb → coverages-67.pb} +0 -0
  343. /package/.scannerwork/scanner-report/{duplications-10.pb → duplications-23.pb} +0 -0
  344. /package/.scannerwork/scanner-report/{duplications-2.pb → duplications-26.pb} +0 -0
  345. /package/.scannerwork/scanner-report/{duplications-34.pb → duplications-27.pb} +0 -0
  346. /package/.scannerwork/scanner-report/{duplications-35.pb → duplications-28.pb} +0 -0
  347. /package/.scannerwork/scanner-report/{duplications-36.pb → duplications-29.pb} +0 -0
  348. /package/.scannerwork/scanner-report/{duplications-37.pb → duplications-53.pb} +0 -0
  349. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-55.pb} +0 -0
  350. /package/.scannerwork/scanner-report/{duplications-39.pb → duplications-56.pb} +0 -0
  351. /package/.scannerwork/scanner-report/{duplications-40.pb → duplications-57.pb} +0 -0
  352. /package/.scannerwork/scanner-report/{duplications-46.pb → duplications-58.pb} +0 -0
  353. /package/.scannerwork/scanner-report/{duplications-6.pb → duplications-59.pb} +0 -0
  354. /package/.scannerwork/scanner-report/{duplications-61.pb → duplications-62.pb} +0 -0
  355. /package/.scannerwork/scanner-report/{duplications-7.pb → duplications-63.pb} +0 -0
  356. /package/.scannerwork/scanner-report/{duplications-64.pb → duplications-67.pb} +0 -0
  357. /package/.scannerwork/scanner-report/{duplications-8.pb → duplications-69.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{issues-6.pb → issues-41.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{issues-14.pb → issues-45.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{issues-12.pb → issues-51.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{issues-35.pb → issues-57.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{measures-40.pb → measures-23.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{measures-38.pb → measures-25.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{measures-2.pb → measures-26.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{measures-34.pb → measures-29.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{measures-7.pb → measures-53.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{measures-35.pb → measures-57.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{measures-61.pb → measures-63.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{measures-64.pb → measures-67.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{measures-68.pb → measures-70.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{source-40.txt → source-23.txt} +0 -0
  372. /package/.scannerwork/scanner-report/{source-2.txt → source-26.txt} +0 -0
  373. /package/.scannerwork/scanner-report/{source-34.txt → source-29.txt} +0 -0
  374. /package/.scannerwork/scanner-report/{source-7.txt → source-53.txt} +0 -0
  375. /package/.scannerwork/scanner-report/{source-35.txt → source-57.txt} +0 -0
  376. /package/.scannerwork/scanner-report/{source-61.txt → source-63.txt} +0 -0
  377. /package/.scannerwork/scanner-report/{source-64.txt → source-67.txt} +0 -0
  378. /package/.scannerwork/scanner-report/{symbols-40.pb → symbols-23.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{symbols-2.pb → symbols-26.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{symbols-34.pb → symbols-29.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{symbols-7.pb → symbols-53.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{symbols-4.pb → symbols-55.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{symbols-35.pb → symbols-57.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{symbols-61.pb → symbols-63.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{symbols-64.pb → symbols-67.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{syntax-highlightings-40.pb → syntax-highlightings-23.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{syntax-highlightings-2.pb → syntax-highlightings-26.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{syntax-highlightings-34.pb → syntax-highlightings-29.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{syntax-highlightings-7.pb → syntax-highlightings-53.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{syntax-highlightings-35.pb → syntax-highlightings-57.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{syntax-highlightings-61.pb → syntax-highlightings-63.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{syntax-highlightings-64.pb → syntax-highlightings-67.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2023 IBM Corp. All rights reserved.
1
+ // Copyright © 2017 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,439 +11,82 @@
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 */
16
14
  'use strict';
17
15
 
18
- const assert = require('node:assert');
19
- const { once } = require('node:events');
20
- const fs = require('node:fs');
21
- const { PassThrough } = require('node:stream');
22
- const { pipeline } = require('node:stream/promises');
23
- const { createGzip, createGunzip } = require('node:zlib');
24
- const debug = require('debug');
25
- const { Tail } = require('tail');
26
- const app = require('../app.js');
27
- const dbUrl = require('../includes/cliutils.js').databaseUrl;
28
- const compare = require('./compare.js');
29
- const request = require('../includes/request.js');
30
- const { cliBackup, cliDecrypt, cliEncrypt, cliGzip, cliGunzip, cliRestore } = require('./test_process.js');
31
- const testLogger = debug('couchbackup:test:utils');
32
-
33
- function scenario(test, params) {
34
- return `${test} ${(params.useApi) ? 'using API' : 'using CLI'}`;
35
- }
16
+ const fs = require('fs');
17
+ const stream = require('stream');
18
+ const liner = require('./liner.js');
36
19
 
37
- function params() {
38
- const p = {};
39
- for (let i = 0; i < arguments.length; i++) {
40
- Object.assign(p, arguments[i]);
41
- }
42
- return p;
43
- }
20
+ const onLine = function(onCommand, getDocs) {
21
+ const change = new stream.Transform({ objectMode: true });
44
22
 
45
- // Returns the event emitter for API calls, or the child process for CLI calls
46
- async function testBackup(params, databaseName, outputStream) {
47
- const pipelineStreams = [];
48
- const promises = [];
23
+ change._transform = function(line, encoding, done) {
24
+ if (line && line[0] === ':') {
25
+ const obj = {
26
+ command: null,
27
+ batch: null,
28
+ docs: []
29
+ };
49
30
 
50
- // Configure API key if needed
51
- augmentParamsWithApiKey(params);
52
-
53
- let backup;
54
- let backupStream;
55
- let backupPromise;
56
- let tail;
57
- if (params.useApi) {
58
- if (params.useStdOut) {
59
- backupStream = outputStream;
60
- } else {
61
- backupStream = new PassThrough();
62
- }
63
- const backupCallbackPromise = new Promise((resolve, reject) => {
64
- backup = app.backup(
65
- dbUrl(process.env.COUCH_URL, databaseName),
66
- backupStream,
67
- params.opts,
68
- (err, data) => {
69
- if (err) {
70
- testLogger(`API backup callback with ${JSON.stringify(err)}, will reject.`);
71
- reject(err);
72
- } else {
73
- testLogger(`API backup callback with ${JSON.stringify(data)}, will resolve.`);
74
- resolve(data);
75
- }
76
- });
77
- });
78
- const backupFinshedPromise = once(backup, 'finished')
79
- .then((summary) => {
80
- testLogger(`Resolving API backup event promise with ${JSON.stringify(summary)}`);
81
- if (params.resume) {
82
- assertWrittenFewerThan(summary.total, params.exclusiveMaxExpected);
83
- }
84
- })
85
- .catch((err) => {
86
- testLogger(`Rejecting API backup event promise with error ${JSON.stringify(err)}`);
87
- throw err;
88
- });
89
- backupPromise = Promise.all([backupCallbackPromise, backupFinshedPromise])
90
- .then(() => {
91
- testLogger('Both API backup promises resolved.');
92
- });
93
- } else {
94
- backup = cliBackup(databaseName, params);
95
- backupStream = backup.stream;
96
- backupPromise = backup.childProcessPromise;
97
- if (params.abort) {
98
- // Create the log file for abort tests so we can tail it, other tests assert
99
- // the log file is usually created normally by the backup process.
100
- const f = fs.openSync(params.opts.log, 'w');
101
- fs.closeSync(f);
102
-
103
- // Use tail to watch the log file for a batch to be completed then abort
104
- tail = new Tail(params.opts.log, { useWatchFile: true, fsWatchOptions: { interval: 500 }, follow: false });
105
- tail.on('line', function(data) {
106
- const matches = data.match(/:d batch\d+/);
107
- if (matches !== null) {
108
- // Turn off the tail.
109
- tail.unwatch();
110
- // Abort the backup
111
- backup.childProcess.kill();
112
- }
113
- });
114
- }
115
- if (params.resume) {
116
- const listenerPromise = new Promise((resolve, reject) => {
117
- const listener = function(data) {
118
- const matches = data.toString().match(/.*Finished - Total document revisions written: (\d+).*/);
119
- if (matches !== null) {
120
- try {
121
- assertWrittenFewerThan(matches[1], params.exclusiveMaxExpected);
122
- resolve();
123
- } catch (err) {
124
- reject(err);
125
- }
126
- process.stderr.removeListener('data', listener);
127
- }
128
- };
129
- backup.childProcess.stderr.on('data', listener);
130
- });
131
- promises.push(listenerPromise);
132
- }
133
- }
134
-
135
- promises.push(backupPromise);
136
- if (!params.useStdOut) {
137
- pipelineStreams.push(backupStream);
138
- }
139
-
140
- if (params.compression) {
141
- if (params.useApi) {
142
- pipelineStreams.push(createGzip());
143
- } else {
144
- const gzipProcess = cliGzip();
145
- pipelineStreams.push(gzipProcess.stream);
146
- promises.push(gzipProcess.childProcessPromise);
147
- }
148
- }
149
-
150
- // Pipe via encryption if requested
151
- if (params.encryption) {
152
- if (params.useApi) {
153
- // Currently only CLI support for testing encryption
154
- return Promise.reject(new Error('Not implemented: cannot test encrypted API backups at this time.'));
155
- } else {
156
- const encryptProcess = cliEncrypt();
157
- pipelineStreams.push(encryptProcess.stream);
158
- promises.push(encryptProcess.childProcessPromise);
159
- }
160
- }
31
+ let matches;
161
32
 
162
- if (!params.useStdOut) {
163
- // Finally add the outputStream to the list we want to pipeline
164
- pipelineStreams.push(outputStream);
165
-
166
- // Create the promisified pipeline and add it to the array of promises we'll wait for
167
- promises.unshift(pipeline(pipelineStreams));
168
- }
169
-
170
- // Wait for the promises and then assert
171
- return Promise.all(promises)
172
- .then(() => testLogger('All backup promises resolved.'))
173
- .then(() => {
174
- if (params.expectedBackupError) {
175
- return Promise.reject(new Error('Backup passed when it should have failed.'));
176
- }
177
- })
178
- .catch((err) => {
179
- if (params.expectedBackupError || params.abort) {
180
- if (params.useApi) {
181
- assert.strictEqual(err.name, params.expectedBackupError.name, 'The backup should receive the expected error.');
182
- } else {
183
- if (params.abort) {
184
- // The tail should be stopped when we match a line and abort, but if
185
- // something didn't work we need to make sure the tail is stopped
186
- tail.unwatch();
187
- // Assert that the process was aborted as expected
188
- assert.strictEqual(err.signal, 'SIGTERM', `The backup should have terminated with SIGTERM, but was ${err.signal}.`);
189
- } else if (params.expectedBackupError) {
190
- assert.strictEqual(err.code, params.expectedBackupError.code, `The backup exited with unexpected code ${err.code} and signal ${err.signal}.`);
191
- }
192
- }
193
- } else {
194
- return Promise.reject(err);
33
+ // extract command
34
+ matches = line.match(/^:([a-z_]+) ?/);
35
+ if (matches) {
36
+ obj.command = matches[1];
195
37
  }
196
- });
197
- }
198
-
199
- async function testRestore(params, inputStream, databaseName) {
200
- const pipelineStreams = [inputStream];
201
- const promises = [];
202
-
203
- // Configure API key if needed
204
- augmentParamsWithApiKey(params);
205
-
206
- let restore;
207
- let restoreStream;
208
- let restorePromise;
209
-
210
- if (params.useApi) {
211
- restoreStream = new PassThrough();
212
- const restoreCallbackPromise = new Promise((resolve, reject) => {
213
- restore = app.restore(
214
- restoreStream,
215
- dbUrl(process.env.COUCH_URL, databaseName),
216
- params.opts,
217
- (err, data) => {
218
- if (err) {
219
- testLogger(`API restore callback with ${err}, will reject.`);
220
- reject(err);
221
- } else {
222
- resolve(data);
223
- }
224
- });
225
- });
226
- const restoreFinshedPromise = once(restore, 'finished')
227
- .then((summary) => {
228
- testLogger(`Resolving API restore promise with ${summary}`);
229
- })
230
- .catch((err) => {
231
- testLogger(`Handling API restore error event ${JSON.stringify(err)}`);
232
- if (params.expectedRestoreErrorRecoverable) {
233
- testLogger(`Expecting restore error ${params.expectedRestoreErrorRecoverable.name}`);
234
- assert.strictEqual(err.name, params.expectedRestoreErrorRecoverable.name, 'The restore should receive the expected recoverable error.');
235
- } else {
236
- testLogger(`API restore will reject by throwing error event ${JSON.stringify(err)}`);
237
- return Promise.reject(err);
238
- }
239
- });
240
- restorePromise = Promise.all([restoreCallbackPromise, restoreFinshedPromise]);
241
- } else {
242
- restore = cliRestore(databaseName, params);
243
- restoreStream = restore.stream;
244
- restorePromise = restore.childProcessPromise;
245
- }
246
- promises.push(restorePromise);
247
-
248
- // Pipe via decompression if requested
249
- if (params.compression) {
250
- if (params.useApi) {
251
- pipelineStreams.push(createGunzip());
252
- } else {
253
- const gunzipProcess = cliGunzip();
254
- pipelineStreams.push(gunzipProcess.stream);
255
- promises.push(gunzipProcess.childProcessPromise);
256
- }
257
- }
258
-
259
- // Pipe via decryption if requested
260
- if (params.encryption) {
261
- if (params.useApi) {
262
- // Currently only CLI support for testing encryption
263
- return Promise.reject(new Error('Not implemented: cannot test encrypted API backups at this time.'));
264
- } else {
265
- const decryptProcess = cliDecrypt();
266
- pipelineStreams.push(decryptProcess.stream);
267
- promises.push(decryptProcess.childProcessPromise);
268
- }
269
- }
270
-
271
- // pipeline everything into the restoreStream
272
- pipelineStreams.push(restoreStream);
273
38
 
274
- // Create the promisified pipeline and add it to the array of promises we'll wait for
275
- promises.unshift(pipeline(pipelineStreams));
276
-
277
- // Wait for the all the promises to settle and then assert based on the process promise
278
- return Promise.allSettled(promises)
279
- .then(() => { return restorePromise; })
280
- .then((summary) => {
281
- testLogger(`Restore promise resolved with ${summary}.`);
282
- if (params.expectedRestoreError) {
283
- return Promise.reject(new Error('Restore passed when it should have failed.'));
284
- }
285
- })
286
- .catch((err) => {
287
- testLogger(`Restore promise rejected with ${err}.`);
288
- if (params.expectedRestoreError) {
289
- if (params.useApi) {
290
- assert.strictEqual(err.name, params.expectedRestoreError.name, 'The restore should receive the expected error.');
291
- } else {
292
- assert.strictEqual(err.code, params.expectedRestoreError.code, `The restore exited with unexpected code ${err.code} and signal ${err.signal}.`);
293
- }
294
- } else {
295
- return Promise.reject(err);
39
+ // extract batch
40
+ matches = line.match(/ batch([0-9]+)/);
41
+ if (matches) {
42
+ obj.batch = parseInt(matches[1]);
296
43
  }
297
- });
298
- }
299
-
300
- // Serial backup and restore via a file on disk
301
- async function testBackupAndRestoreViaFile(params, srcDb, backupFile, targetDb) {
302
- return testBackupToFile(params, srcDb, backupFile).then(() => {
303
- return testRestoreFromFile(params, backupFile, targetDb);
304
- });
305
- }
306
44
 
307
- async function testBackupToFile(params, srcDb, backupFile) {
308
- // Open the file for appending if this is a resume
309
- const output = fs.createWriteStream(backupFile, { flags: (params.opts && params.opts.resume) ? 'a' : 'w' });
310
- return once(output, 'open')
311
- .then(() => {
312
- return testBackup(params, srcDb, output);
313
- });
314
- }
315
-
316
- async function testRestoreFromFile(params, backupFile, targetDb) {
317
- const input = fs.createReadStream(backupFile);
318
- return once(input, 'open')
319
- .then(() => {
320
- return testRestore(params, input, targetDb);
321
- });
322
- }
323
-
324
- async function testDirectBackupAndRestore(params, srcDb, targetDb) {
325
- // Allow a 64 MB highWaterMark for the passthrough during testing
326
- const passthrough = new PassThrough({ highWaterMark: 67108864 });
327
- const backup = testBackup(params, srcDb, passthrough);
328
- const restore = testRestore(params, passthrough, targetDb);
329
- return Promise.all([backup, restore]).then(() => {
330
- return dbCompare(srcDb, targetDb);
331
- });
332
- }
333
-
334
- async function testBackupAbortResumeRestore(params, srcDb, backupFile, targetDb) {
335
- return Promise.resolve()
336
- .then(() => {
337
- // First backup with an abort
338
- if (params.opts && params.opts.output) {
339
- return testBackup(params, srcDb, new PassThrough());
340
- } else {
341
- return testBackupToFile(params, srcDb, backupFile);
342
- }
343
- }).then(() => {
344
- // Remove the abort parameter and add the resume parameter
345
- delete params.abort;
346
- params.opts.resume = true;
347
- // Resume the backup
348
- if (params.opts && params.opts.output) {
349
- return testBackup(params, srcDb, new PassThrough());
350
- } else {
351
- return testBackupToFile(params, srcDb, backupFile);
45
+ // extract doc ids
46
+ if (getDocs && obj.command === 't') {
47
+ const json = line.replace(/^.* batch[0-9]+ /, '').trim();
48
+ obj.docs = JSON.parse(json);
352
49
  }
353
- }).then(() => {
354
- // Restore the backup
355
- return testRestoreFromFile(params, backupFile, targetDb);
356
- }).then(() => {
357
- // Now compare the restored to the original for validation
358
- return dbCompare(srcDb, targetDb);
359
- });
360
- }
361
-
362
- async function dbCompare(db1Name, db2Name) {
363
- const client = request.client(process.env.COUCH_BACKEND_URL, {});
364
- return compare.compare(db1Name, db2Name, client.service)
365
- .then(result => {
366
- return assert.strictEqual(result, true, 'The database comparison should succeed, but failed');
367
- });
368
- }
369
-
370
- function sortByIdThenRev(o1, o2) {
371
- if (o1._id < o2._id) return -1;
372
- if (o1._id > o2._id) return 1;
373
- if (o1._rev < o2._rev) return -1;
374
- if (o1._rev > o2._rev) return 1;
375
- return 0;
376
- }
377
-
378
- function readSortAndDeepEqual(actualContentPath, expectedContentPath) {
379
- const backupContent = JSON.parse(fs.readFileSync(actualContentPath, 'utf8'));
380
- const expectedContent = JSON.parse(fs.readFileSync(expectedContentPath, 'utf8'));
381
- // Array order of the docs is important for equality, but not for backup
382
- backupContent.sort(sortByIdThenRev);
383
- expectedContent.sort(sortByIdThenRev);
384
- // Assert that the backup matches the expected
385
- assert.deepStrictEqual(backupContent, expectedContent);
386
- }
387
-
388
- function setTimeout(context, timeout) {
389
- // Increase timeout using TEST_TIMEOUT_MULTIPLIER
390
- const multiplier = (typeof process.env.TEST_TIMEOUT_MULTIPLIER !== 'undefined') ? parseInt(process.env.TEST_TIMEOUT_MULTIPLIER) : 1;
391
- timeout *= multiplier;
392
- // Set the mocha timeout
393
- context.timeout(timeout * 1000);
394
- }
395
-
396
- function assertGzipFile(path) {
397
- // 1f 8b is the gzip magic number
398
- const expectedBytes = Buffer.from([0x1f, 0x8b]);
399
- const buffer = Buffer.alloc(2);
400
- const fd = fs.openSync(path, 'r');
401
- // Read the first two bytes
402
- fs.readSync(fd, buffer, 0, 2, 0);
403
- fs.closeSync(fd);
404
- // Assert the magic number corresponds to gz extension
405
- assert.deepStrictEqual(buffer, expectedBytes, 'The backup file should be gz compressed.');
406
- }
407
-
408
- function assertEncryptedFile(path) {
409
- // Openssl encrypted files start with Salted
410
- const expectedBytes = Buffer.from('Salted');
411
- const buffer = Buffer.alloc(6);
412
- const fd = fs.openSync(path, 'r');
413
- // Read the first six bytes
414
- fs.readSync(fd, buffer, 0, 6, 0);
415
- fs.closeSync(fd);
416
- // Assert first 6 characters of the file are "Salted"
417
- assert.deepStrictEqual(buffer, expectedBytes, 'The backup file should be encrypted.');
418
- }
419
-
420
- function assertWrittenFewerThan(total, number) {
421
- assert(total < number && total > 0, `Saw ${total} but expected between 1 and ${number - 1} documents for the resumed backup.`);
422
- }
423
-
424
- function augmentParamsWithApiKey(params) {
425
- if (process.env.COUCHBACKUP_TEST_IAM_API_KEY) {
426
- if (!params.opts) {
427
- params.opts = {};
50
+ onCommand(obj);
428
51
  }
429
- params.opts.iamApiKey = process.env.COUCHBACKUP_TEST_IAM_API_KEY;
430
- params.opts.iamTokenUrl = process.env.CLOUDANT_IAM_TOKEN_URL;
431
- }
432
- }
52
+ done();
53
+ };
54
+ return change;
55
+ };
433
56
 
434
- module.exports = {
435
- scenario,
436
- p: params,
437
- setTimeout,
438
- dbCompare,
439
- readSortAndDeepEqual,
440
- assertGzipFile,
441
- assertEncryptedFile,
442
- testBackup,
443
- testRestore,
444
- testDirectBackupAndRestore,
445
- testBackupToFile,
446
- testRestoreFromFile,
447
- testBackupAndRestoreViaFile,
448
- testBackupAbortResumeRestore
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) {
67
+ // our sense of state
68
+ const state = {
69
+
70
+ };
71
+ let changesComplete = false;
72
+
73
+ // called with each line from the log file
74
+ const onCommand = function(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
+ }
82
+ };
83
+
84
+ // stream through the previous log file
85
+ fs.createReadStream(log)
86
+ .pipe(liner())
87
+ .pipe(onLine(onCommand, false))
88
+ .on('finish', function() {
89
+ const obj = { changesComplete: changesComplete, batches: state };
90
+ callback(null, obj);
91
+ });
449
92
  };