@cloudant/couchbackup 2.9.15 → 2.9.16-SNAPSHOT.179

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 (418) 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-10.pb +2 -0
  5. package/.scannerwork/scanner-report/changesets-11.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-13.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-15.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-3.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-4.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-40.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-41.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-42.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-43.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-44.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-5.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-6.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-7.pb +1 -0
  18. package/.scannerwork/scanner-report/changesets-70.pb +1 -0
  19. package/.scannerwork/scanner-report/changesets-8.pb +1 -0
  20. package/.scannerwork/scanner-report/changesets-9.pb +1 -0
  21. package/.scannerwork/scanner-report/component-1.pb +2 -2
  22. package/.scannerwork/scanner-report/component-10.pb +1 -1
  23. package/.scannerwork/scanner-report/component-11.pb +1 -0
  24. package/.scannerwork/scanner-report/component-12.pb +1 -1
  25. package/.scannerwork/scanner-report/component-13.pb +1 -0
  26. package/.scannerwork/scanner-report/component-14.pb +1 -1
  27. package/.scannerwork/scanner-report/component-15.pb +1 -0
  28. package/.scannerwork/scanner-report/component-16.pb +1 -1
  29. package/.scannerwork/scanner-report/component-18.pb +1 -1
  30. package/.scannerwork/scanner-report/component-19.pb +1 -1
  31. package/.scannerwork/scanner-report/component-2.pb +1 -0
  32. package/.scannerwork/scanner-report/component-24.pb +1 -1
  33. package/.scannerwork/scanner-report/component-27.pb +1 -1
  34. package/.scannerwork/scanner-report/component-29.pb +1 -1
  35. package/.scannerwork/scanner-report/component-3.pb +1 -1
  36. package/.scannerwork/scanner-report/component-30.pb +1 -1
  37. package/.scannerwork/scanner-report/component-31.pb +1 -1
  38. package/.scannerwork/scanner-report/component-34.pb +1 -1
  39. package/.scannerwork/scanner-report/component-36.pb +1 -1
  40. package/.scannerwork/scanner-report/component-37.pb +1 -1
  41. package/.scannerwork/scanner-report/component-38.pb +1 -1
  42. package/.scannerwork/scanner-report/component-39.pb +1 -1
  43. package/.scannerwork/scanner-report/component-4.pb +1 -0
  44. package/.scannerwork/scanner-report/component-40.pb +1 -0
  45. package/.scannerwork/scanner-report/component-41.pb +1 -0
  46. package/.scannerwork/scanner-report/component-42.pb +1 -0
  47. package/.scannerwork/scanner-report/component-43.pb +1 -0
  48. package/.scannerwork/scanner-report/component-44.pb +1 -0
  49. package/.scannerwork/scanner-report/component-5.pb +1 -0
  50. package/.scannerwork/scanner-report/component-56.pb +1 -1
  51. package/.scannerwork/scanner-report/component-57.pb +1 -1
  52. package/.scannerwork/scanner-report/component-58.pb +1 -1
  53. package/.scannerwork/scanner-report/component-59.pb +1 -1
  54. package/.scannerwork/scanner-report/component-6.pb +1 -1
  55. package/.scannerwork/scanner-report/component-60.pb +1 -1
  56. package/.scannerwork/scanner-report/component-61.pb +1 -1
  57. package/.scannerwork/scanner-report/component-62.pb +1 -1
  58. package/.scannerwork/scanner-report/component-63.pb +1 -1
  59. package/.scannerwork/scanner-report/component-64.pb +1 -1
  60. package/.scannerwork/scanner-report/component-65.pb +1 -1
  61. package/.scannerwork/scanner-report/component-66.pb +1 -1
  62. package/.scannerwork/scanner-report/component-67.pb +1 -1
  63. package/.scannerwork/scanner-report/component-68.pb +1 -1
  64. package/.scannerwork/scanner-report/component-69.pb +1 -1
  65. package/.scannerwork/scanner-report/component-7.pb +1 -0
  66. package/.scannerwork/scanner-report/component-70.pb +1 -1
  67. package/.scannerwork/scanner-report/component-8.pb +1 -0
  68. package/.scannerwork/scanner-report/component-9.pb +1 -0
  69. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-12.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-31.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-38.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-39.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-40.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-63.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-65.pb +0 -0
  99. package/.scannerwork/scanner-report/coverages-66.pb +0 -0
  100. package/.scannerwork/scanner-report/coverages-67.pb +0 -0
  101. package/.scannerwork/scanner-report/coverages-68.pb +0 -0
  102. package/.scannerwork/scanner-report/coverages-69.pb +0 -0
  103. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  104. package/.scannerwork/scanner-report/coverages-70.pb +0 -0
  105. package/.scannerwork/scanner-report/coverages-8.pb +0 -0
  106. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  107. package/.scannerwork/scanner-report/duplications-10.pb +2 -0
  108. package/.scannerwork/scanner-report/duplications-12.pb +0 -2
  109. package/.scannerwork/scanner-report/duplications-13.pb +3 -0
  110. package/.scannerwork/scanner-report/duplications-14.pb +0 -2
  111. package/.scannerwork/scanner-report/duplications-18.pb +2 -0
  112. package/.scannerwork/scanner-report/duplications-19.pb +2 -0
  113. package/.scannerwork/scanner-report/duplications-39.pb +0 -2
  114. package/.scannerwork/scanner-report/duplications-43.pb +2 -0
  115. package/.scannerwork/scanner-report/duplications-56.pb +0 -2
  116. package/.scannerwork/scanner-report/duplications-60.pb +3 -0
  117. package/.scannerwork/scanner-report/duplications-66.pb +0 -2
  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-13.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-29.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-3.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-31.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-44.pb +15 -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/measures-7.pb +0 -0
  158. package/.scannerwork/scanner-report/measures-70.pb +0 -0
  159. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  160. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  161. package/.scannerwork/scanner-report/metadata.pb +0 -0
  162. package/.scannerwork/scanner-report/source-10.txt +92 -424
  163. package/.scannerwork/scanner-report/source-12.txt +150 -162
  164. package/.scannerwork/scanner-report/source-13.txt +75 -0
  165. package/.scannerwork/scanner-report/source-14.txt +88 -150
  166. package/.scannerwork/scanner-report/source-15.txt +281 -0
  167. package/.scannerwork/scanner-report/source-16.txt +21 -26
  168. package/.scannerwork/scanner-report/source-18.txt +154 -113
  169. package/.scannerwork/scanner-report/source-19.txt +170 -17
  170. package/.scannerwork/scanner-report/source-2.txt +424 -0
  171. package/.scannerwork/scanner-report/source-24.txt +397 -15
  172. package/.scannerwork/scanner-report/source-27.txt +102 -100
  173. package/.scannerwork/scanner-report/source-29.txt +424 -42
  174. package/.scannerwork/scanner-report/source-3.txt +46 -424
  175. package/.scannerwork/scanner-report/source-30.txt +65 -13
  176. package/.scannerwork/scanner-report/source-31.txt +43 -20
  177. package/.scannerwork/scanner-report/source-34.txt +424 -106
  178. package/.scannerwork/scanner-report/source-36.txt +40 -129
  179. package/.scannerwork/scanner-report/source-37.txt +101 -158
  180. package/.scannerwork/scanner-report/source-38.txt +161 -10
  181. package/.scannerwork/scanner-report/source-39.txt +18 -168
  182. package/.scannerwork/scanner-report/source-4.txt +31 -0
  183. package/.scannerwork/scanner-report/source-40.txt +29 -0
  184. package/.scannerwork/scanner-report/source-43.txt +187 -0
  185. package/.scannerwork/scanner-report/source-44.txt +151 -0
  186. package/.scannerwork/scanner-report/source-56.txt +15 -58
  187. package/.scannerwork/scanner-report/source-57.txt +22 -263
  188. package/.scannerwork/scanner-report/source-58.txt +116 -66
  189. package/.scannerwork/scanner-report/source-59.txt +47 -150
  190. package/.scannerwork/scanner-report/source-6.txt +111 -102
  191. package/.scannerwork/scanner-report/source-60.txt +199 -99
  192. package/.scannerwork/scanner-report/source-61.txt +430 -40
  193. package/.scannerwork/scanner-report/source-62.txt +92 -115
  194. package/.scannerwork/scanner-report/source-63.txt +87 -17
  195. package/.scannerwork/scanner-report/source-64.txt +79 -20
  196. package/.scannerwork/scanner-report/source-65.txt +26 -95
  197. package/.scannerwork/scanner-report/source-66.txt +26 -77
  198. package/.scannerwork/scanner-report/source-67.txt +41 -390
  199. package/.scannerwork/scanner-report/source-68.txt +20 -43
  200. package/.scannerwork/scanner-report/source-69.txt +274 -62
  201. package/.scannerwork/scanner-report/source-7.txt +59 -0
  202. package/.scannerwork/scanner-report/source-70.txt +46 -424
  203. package/.scannerwork/scanner-report/source-8.txt +80 -0
  204. package/.scannerwork/scanner-report/source-9.txt +129 -0
  205. package/.scannerwork/scanner-report/symbols-10.pb +44 -0
  206. package/.scannerwork/scanner-report/symbols-12.pb +143 -179
  207. package/.scannerwork/scanner-report/symbols-13.pb +42 -0
  208. package/.scannerwork/scanner-report/symbols-14.pb +45 -152
  209. package/.scannerwork/scanner-report/symbols-15.pb +354 -0
  210. package/.scannerwork/scanner-report/symbols-16.pb +18 -7
  211. package/.scannerwork/scanner-report/symbols-18.pb +153 -71
  212. package/.scannerwork/scanner-report/symbols-19.pb +180 -9
  213. package/.scannerwork/scanner-report/symbols-24.pb +604 -9
  214. package/.scannerwork/scanner-report/symbols-30.pb +32 -8
  215. package/.scannerwork/scanner-report/symbols-31.pb +21 -13
  216. package/.scannerwork/scanner-report/symbols-36.pb +22 -91
  217. package/.scannerwork/scanner-report/symbols-37.pb +71 -209
  218. package/.scannerwork/scanner-report/symbols-38.pb +207 -21
  219. package/.scannerwork/scanner-report/symbols-39.pb +9 -227
  220. package/.scannerwork/scanner-report/symbols-4.pb +14 -0
  221. package/.scannerwork/scanner-report/symbols-40.pb +8 -0
  222. package/.scannerwork/scanner-report/symbols-43.pb +227 -0
  223. package/.scannerwork/scanner-report/symbols-44.pb +93 -0
  224. package/.scannerwork/scanner-report/symbols-56.pb +9 -42
  225. package/.scannerwork/scanner-report/symbols-57.pb +23 -354
  226. package/.scannerwork/scanner-report/symbols-58.pb +86 -46
  227. package/.scannerwork/scanner-report/symbols-59.pb +39 -144
  228. package/.scannerwork/scanner-report/symbols-6.pb +59 -0
  229. package/.scannerwork/scanner-report/symbols-60.pb +264 -46
  230. package/.scannerwork/scanner-report/symbols-61.pb +789 -18
  231. package/.scannerwork/scanner-report/symbols-62.pb +59 -33
  232. package/.scannerwork/scanner-report/symbols-63.pb +57 -13
  233. package/.scannerwork/scanner-report/symbols-64.pb +68 -17
  234. package/.scannerwork/scanner-report/symbols-65.pb +19 -59
  235. package/.scannerwork/scanner-report/symbols-66.pb +30 -43
  236. package/.scannerwork/scanner-report/symbols-67.pb +33 -604
  237. package/.scannerwork/scanner-report/symbols-68.pb +13 -21
  238. package/.scannerwork/scanner-report/symbols-69.pb +428 -32
  239. package/.scannerwork/scanner-report/symbols-7.pb +19 -0
  240. package/.scannerwork/scanner-report/symbols-70.pb +7 -0
  241. package/.scannerwork/scanner-report/symbols-8.pb +46 -0
  242. package/.scannerwork/scanner-report/symbols-9.pb +33 -0
  243. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +82 -3329
  244. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +171 -153
  245. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +81 -0
  246. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +90 -178
  247. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +285 -0
  248. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +22 -32
  249. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +168 -135
  250. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +195 -31
  251. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +3341 -0
  252. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +611 -24
  253. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +690 -105
  254. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +3331 -55
  255. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +53 -3331
  256. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +81 -30
  257. package/.scannerwork/scanner-report/syntax-highlightings-31.pb +63 -43
  258. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +3331 -167
  259. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +59 -199
  260. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +127 -236
  261. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +250 -16
  262. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +25 -332
  263. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +45 -0
  264. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +49 -0
  265. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +368 -0
  266. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +237 -0
  267. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +22 -49
  268. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +20 -249
  269. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +92 -62
  270. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +59 -201
  271. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +131 -689
  272. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +261 -90
  273. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +591 -23
  274. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +141 -92
  275. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +124 -15
  276. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +75 -20
  277. package/.scannerwork/scanner-report/syntax-highlightings-65.pb +28 -95
  278. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +36 -60
  279. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +69 -600
  280. package/.scannerwork/scanner-report/syntax-highlightings-68.pb +43 -63
  281. package/.scannerwork/scanner-report/syntax-highlightings-69.pb +689 -69
  282. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +59 -0
  283. package/.scannerwork/scanner-report/syntax-highlightings-70.pb +51 -3328
  284. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +95 -0
  285. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +129 -0
  286. package/package.json +1 -1
  287. package/test-18-results.xml +160 -160
  288. package/test-20-results.xml +163 -163
  289. package/test-21-results.xml +161 -161
  290. package/test-iam-20-results.xml +50 -50
  291. package/.scannerwork/scanner-report/changesets-17.pb +0 -1
  292. package/.scannerwork/scanner-report/changesets-20.pb +0 -1
  293. package/.scannerwork/scanner-report/changesets-21.pb +0 -1
  294. package/.scannerwork/scanner-report/changesets-22.pb +0 -1
  295. package/.scannerwork/scanner-report/changesets-23.pb +0 -1
  296. package/.scannerwork/scanner-report/changesets-25.pb +0 -1
  297. package/.scannerwork/scanner-report/changesets-26.pb +0 -1
  298. package/.scannerwork/scanner-report/changesets-27.pb +0 -1
  299. package/.scannerwork/scanner-report/changesets-28.pb +0 -1
  300. package/.scannerwork/scanner-report/changesets-29.pb +0 -1
  301. package/.scannerwork/scanner-report/changesets-32.pb +0 -1
  302. package/.scannerwork/scanner-report/changesets-33.pb +0 -1
  303. package/.scannerwork/scanner-report/changesets-34.pb +0 -1
  304. package/.scannerwork/scanner-report/changesets-35.pb +0 -1
  305. package/.scannerwork/scanner-report/changesets-53.pb +0 -1
  306. package/.scannerwork/scanner-report/changesets-54.pb +0 -1
  307. package/.scannerwork/scanner-report/changesets-55.pb +0 -1
  308. package/.scannerwork/scanner-report/component-17.pb +0 -1
  309. package/.scannerwork/scanner-report/component-20.pb +0 -1
  310. package/.scannerwork/scanner-report/component-21.pb +0 -1
  311. package/.scannerwork/scanner-report/component-22.pb +0 -1
  312. package/.scannerwork/scanner-report/component-23.pb +0 -1
  313. package/.scannerwork/scanner-report/component-25.pb +0 -1
  314. package/.scannerwork/scanner-report/component-26.pb +0 -1
  315. package/.scannerwork/scanner-report/component-28.pb +0 -1
  316. package/.scannerwork/scanner-report/component-32.pb +0 -1
  317. package/.scannerwork/scanner-report/component-33.pb +0 -1
  318. package/.scannerwork/scanner-report/component-35.pb +0 -1
  319. package/.scannerwork/scanner-report/component-53.pb +0 -1
  320. package/.scannerwork/scanner-report/component-54.pb +0 -1
  321. package/.scannerwork/scanner-report/component-55.pb +0 -1
  322. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  323. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  324. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  325. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  326. package/.scannerwork/scanner-report/coverages-23.pb +0 -0
  327. package/.scannerwork/scanner-report/coverages-26.pb +0 -0
  328. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  329. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  330. package/.scannerwork/scanner-report/coverages-29.pb +0 -0
  331. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  332. package/.scannerwork/scanner-report/coverages-34.pb +0 -0
  333. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  334. package/.scannerwork/scanner-report/duplications-26.pb +0 -3
  335. package/.scannerwork/scanner-report/duplications-54.pb +0 -0
  336. package/.scannerwork/scanner-report/duplications-55.pb +0 -0
  337. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  338. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  339. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  340. package/.scannerwork/scanner-report/measures-22.pb +0 -16
  341. package/.scannerwork/scanner-report/measures-23.pb +0 -0
  342. package/.scannerwork/scanner-report/measures-26.pb +0 -0
  343. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  344. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  345. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  346. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  347. package/.scannerwork/scanner-report/source-17.txt +0 -130
  348. package/.scannerwork/scanner-report/source-20.txt +0 -62
  349. package/.scannerwork/scanner-report/source-21.txt +0 -41
  350. package/.scannerwork/scanner-report/source-22.txt +0 -293
  351. package/.scannerwork/scanner-report/source-23.txt +0 -101
  352. package/.scannerwork/scanner-report/source-26.txt +0 -213
  353. package/.scannerwork/scanner-report/source-28.txt +0 -449
  354. package/.scannerwork/scanner-report/source-33.txt +0 -65
  355. package/.scannerwork/scanner-report/source-35.txt +0 -75
  356. package/.scannerwork/scanner-report/source-54.txt +0 -46
  357. package/.scannerwork/scanner-report/symbols-17.pb +0 -86
  358. package/.scannerwork/scanner-report/symbols-20.pb +0 -24
  359. package/.scannerwork/scanner-report/symbols-21.pb +0 -31
  360. package/.scannerwork/scanner-report/symbols-22.pb +0 -428
  361. package/.scannerwork/scanner-report/symbols-23.pb +0 -58
  362. package/.scannerwork/scanner-report/symbols-26.pb +0 -264
  363. package/.scannerwork/scanner-report/symbols-27.pb +0 -69
  364. package/.scannerwork/scanner-report/symbols-28.pb +0 -790
  365. package/.scannerwork/scanner-report/symbols-29.pb +0 -19
  366. package/.scannerwork/scanner-report/symbols-33.pb +0 -33
  367. package/.scannerwork/scanner-report/symbols-34.pb +0 -59
  368. package/.scannerwork/scanner-report/symbols-35.pb +0 -39
  369. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +0 -125
  370. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -97
  371. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -69
  372. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +0 -720
  373. package/.scannerwork/scanner-report/syntax-highlightings-23.pb +0 -154
  374. package/.scannerwork/scanner-report/syntax-highlightings-26.pb +0 -297
  375. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +0 -627
  376. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +0 -110
  377. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +0 -101
  378. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +0 -64
  379. /package/.scannerwork/scanner-report/{coverages-53.pb → coverages-11.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{coverages-54.pb → coverages-3.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{coverages-25.pb → coverages-41.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{coverages-32.pb → coverages-42.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{coverages-55.pb → coverages-5.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{duplications-17.pb → duplications-11.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-15.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{duplications-21.pb → duplications-3.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{duplications-22.pb → duplications-30.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{duplications-23.pb → duplications-4.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-41.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{duplications-27.pb → duplications-42.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{duplications-28.pb → duplications-44.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{duplications-29.pb → duplications-5.pb} +0 -0
  393. /package/.scannerwork/scanner-report/{duplications-32.pb → duplications-6.pb} +0 -0
  394. /package/.scannerwork/scanner-report/{duplications-33.pb → duplications-7.pb} +0 -0
  395. /package/.scannerwork/scanner-report/{duplications-34.pb → duplications-70.pb} +0 -0
  396. /package/.scannerwork/scanner-report/{duplications-35.pb → duplications-8.pb} +0 -0
  397. /package/.scannerwork/scanner-report/{duplications-53.pb → duplications-9.pb} +0 -0
  398. /package/.scannerwork/scanner-report/{issues-32.pb → issues-42.pb} +0 -0
  399. /package/.scannerwork/scanner-report/{issues-17.pb → issues-58.pb} +0 -0
  400. /package/.scannerwork/scanner-report/{issues-26.pb → issues-60.pb} +0 -0
  401. /package/.scannerwork/scanner-report/{issues-29.pb → issues-65.pb} +0 -0
  402. /package/.scannerwork/scanner-report/{measures-53.pb → measures-11.pb} +0 -0
  403. /package/.scannerwork/scanner-report/{measures-25.pb → measures-41.pb} +0 -0
  404. /package/.scannerwork/scanner-report/{measures-32.pb → measures-42.pb} +0 -0
  405. /package/.scannerwork/scanner-report/{measures-55.pb → measures-5.pb} +0 -0
  406. /package/.scannerwork/scanner-report/{source-53.txt → source-11.txt} +0 -0
  407. /package/.scannerwork/scanner-report/{source-25.txt → source-41.txt} +0 -0
  408. /package/.scannerwork/scanner-report/{source-32.txt → source-42.txt} +0 -0
  409. /package/.scannerwork/scanner-report/{source-55.txt → source-5.txt} +0 -0
  410. /package/.scannerwork/scanner-report/{symbols-53.pb → symbols-11.pb} +0 -0
  411. /package/.scannerwork/scanner-report/{symbols-54.pb → symbols-3.pb} +0 -0
  412. /package/.scannerwork/scanner-report/{symbols-25.pb → symbols-41.pb} +0 -0
  413. /package/.scannerwork/scanner-report/{symbols-32.pb → symbols-42.pb} +0 -0
  414. /package/.scannerwork/scanner-report/{symbols-55.pb → symbols-5.pb} +0 -0
  415. /package/.scannerwork/scanner-report/{syntax-highlightings-53.pb → syntax-highlightings-11.pb} +0 -0
  416. /package/.scannerwork/scanner-report/{syntax-highlightings-25.pb → syntax-highlightings-41.pb} +0 -0
  417. /package/.scannerwork/scanner-report/{syntax-highlightings-32.pb → syntax-highlightings-42.pb} +0 -0
  418. /package/.scannerwork/scanner-report/{syntax-highlightings-55.pb → syntax-highlightings-5.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2023 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2023 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.
@@ -12,140 +12,51 @@
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
14
 
15
- /* global */
15
+ /* global describe it */
16
16
  'use strict';
17
17
 
18
- const { fork, spawn } = require('node:child_process');
18
+ const fs = require('fs');
19
19
  const { once } = require('node:events');
20
- const { Duplex } = require('node:stream');
21
- const debug = require('debug');
22
- const logProcess = debug('couchbackup:test:process');
20
+ const u = require('./citestutils.js');
23
21
 
24
- class TestProcess {
25
- constructor(cmd, args, mode) {
26
- this.cmd = cmd;
27
- // Child process stdio [stdin, stdout, stderr, ...extra channels]
28
- const childProcessOptions = { stdio: [] };
29
- switch (mode) {
30
- case 'readable':
31
- // Readable only, no writing to stdin so ignore it
32
- childProcessOptions.stdio = ['ignore', 'pipe', 'inherit'];
33
- break;
34
- case 'writable':
35
- // Writable only, no reading from stdout so ignore it
36
- childProcessOptions.stdio = ['pipe', 'ignore', 'inherit'];
37
- break;
38
- default:
39
- // Default Duplex mode pipe both stdin and stdout
40
- childProcessOptions.stdio = ['pipe', 'pipe', 'inherit'];
41
- break;
42
- }
43
- if (cmd.endsWith('.js')) {
44
- // Add Node fork ipc channel
45
- childProcessOptions.stdio.push('ipc');
46
- logProcess(`Forking Node process for ${cmd} with stdio:[${childProcessOptions.stdio}]`);
47
- this.childProcess = fork(cmd, args, childProcessOptions);
48
- } else {
49
- logProcess(`Spawning process for ${cmd} with stdio:[${childProcessOptions.stdio}]`);
50
- this.childProcess = spawn(cmd, args, childProcessOptions);
51
- }
22
+ [{ useApi: true }, { useApi: false }].forEach(function(params) {
23
+ describe(u.scenario('Compression tests', params), function() {
24
+ const p = u.p(params, { compression: true });
52
25
 
53
- this.childProcessPromise = once(this.childProcess, 'close').then(() => {
54
- const code = this.childProcess.exitCode;
55
- const signal = this.childProcess.signalCode;
56
- logProcess(`Test process ${cmd} closed with code ${code} and signal ${signal}`);
57
- if (code === 0) {
58
- logProcess(`Resolving process promise for ${cmd}`);
59
- return Promise.resolve(code);
60
- } else {
61
- const e = new Error(`Test child process ${cmd} exited with code ${code} and ${signal}. This may be normal for error case testing.`);
62
- e.code = code;
63
- e.signal = signal;
64
- logProcess(`Will reject process promise for ${cmd} with ${e}`);
65
- return Promise.reject(e);
66
- }
26
+ it('should backup animaldb to a compressed file', async function() {
27
+ // Allow up to 60 s for backup of animaldb
28
+ u.setTimeout(this, 60);
29
+ const compressedBackup = `./${this.fileName}`;
30
+ const output = fs.createWriteStream(compressedBackup);
31
+ return once(output, 'open')
32
+ .then(() => {
33
+ return u.testBackup(p, 'animaldb', output);
34
+ }).then(() => {
35
+ return u.assertGzipFile(compressedBackup);
36
+ });
67
37
  });
68
38
 
69
- switch (mode) {
70
- case 'readable':
71
- this.duplexFrom = this.childProcess.stdout;
72
- break;
73
- case 'writable':
74
- this.duplexFrom = this.childProcess.stdin;
75
- break;
76
- default:
77
- // Default is duplex
78
- this.duplexFrom = { writable: this.childProcess.stdin, readable: this.childProcess.stdout };
79
- }
39
+ it('should backup and restore animaldb via a compressed file', async function() {
40
+ // Allow up to 60 s for backup and restore of animaldb
41
+ u.setTimeout(this, 60);
42
+ const compressedBackup = `./${this.fileName}`;
43
+ return u.testBackupAndRestoreViaFile(p, 'animaldb', compressedBackup, this.dbName).then(() => {
44
+ return u.assertGzipFile(compressedBackup);
45
+ });
46
+ });
80
47
 
81
- this.stream = Duplex.from(this.duplexFrom);
82
- }
83
- }
48
+ it('should backup and restore animaldb via a compressed stream', async function() {
49
+ // Allow up to 60 s for backup and restore of animaldb
50
+ u.setTimeout(this, 60);
51
+ return u.testDirectBackupAndRestore(p, 'animaldb', this.dbName);
52
+ });
84
53
 
85
- module.exports = {
86
- TestProcess,
87
- cliBackup: function(databaseName, params = {}) {
88
- const args = ['--db', databaseName];
89
- if (params.opts) {
90
- if (params.opts.mode) {
91
- args.push('--mode');
92
- args.push(params.opts.mode);
93
- }
94
- if (params.opts.output) {
95
- args.push('--output');
96
- args.push(params.opts.output);
97
- }
98
- if (params.opts.log) {
99
- args.push('--log');
100
- args.push(params.opts.log);
101
- }
102
- if (params.opts.resume) {
103
- args.push('--resume');
104
- args.push(params.opts.resume);
105
- }
106
- if (params.opts.bufferSize) {
107
- args.push('--buffer-size');
108
- args.push(params.opts.bufferSize);
109
- }
110
- if (params.opts.iamApiKey) {
111
- args.push('--iam-api-key');
112
- args.push(params.opts.iamApiKey);
113
- }
114
- }
115
- return new TestProcess('./bin/couchbackup.bin.js', args, 'readable');
116
- },
117
- cliRestore: function(databaseName, params) {
118
- const args = ['--db', databaseName];
119
- if (params.opts) {
120
- if (params.opts.bufferSize) {
121
- args.push('--buffer-size');
122
- args.push(params.opts.bufferSize);
123
- }
124
- if (params.opts.parallelism) {
125
- args.push('--parallelism');
126
- args.push(params.opts.parallelism);
127
- }
128
- if (params.opts.requestTimeout) {
129
- args.push('--request-timeout');
130
- args.push(params.opts.requestTimeout);
131
- }
132
- if (params.opts.iamApiKey) {
133
- args.push('--iam-api-key');
134
- args.push(params.opts.iamApiKey);
135
- }
136
- }
137
- return new TestProcess('./bin/couchrestore.bin.js', args, 'writable');
138
- },
139
- cliGzip: function() {
140
- return new TestProcess('gzip', []);
141
- },
142
- cliGunzip: function() {
143
- return new TestProcess('gunzip', []);
144
- },
145
- cliEncrypt: function() {
146
- return new TestProcess('openssl', ['aes-128-cbc', '-pass', 'pass:12345']);
147
- },
148
- cliDecrypt: function() {
149
- return new TestProcess('openssl', ['aes-128-cbc', '-d', '-pass', 'pass:12345']);
150
- }
151
- };
54
+ it('should backup and restore largedb2g via a compressed file #slower', async function() {
55
+ // Takes ~ 25 min using CLI, but sometimes over an hour with API
56
+ u.setTimeout(this, 180 * 60);
57
+ const compressedBackup = `./${this.fileName}`;
58
+ params.compression = true;
59
+ return u.testBackupAndRestoreViaFile(p, 'largedb2g', compressedBackup, this.dbName);
60
+ });
61
+ });
62
+ });
@@ -12,180 +12,123 @@
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
14
 
15
- /* global describe it */
15
+ /* global describe it beforeEach */
16
16
  'use strict';
17
17
 
18
18
  const assert = require('assert');
19
+ const fs = require('fs');
19
20
  const nock = require('nock');
20
21
  const request = require('../includes/request.js');
21
- const changes = require('../includes/spoolchanges.js');
22
-
23
- const url = 'http://localhost:7777';
24
- const dbName = 'fakenockdb';
22
+ const writer = require('../includes/writer.js');
23
+ const noopEmitter = new (require('events')).EventEmitter();
24
+ const liner = require('../includes/liner.js');
25
+ const { once } = require('node:events');
26
+ const { pipeline } = require('node:stream/promises');
25
27
  const longTestTimeout = 3000;
26
28
 
27
- const db = request.client(`${url}/${dbName}`, { parallelism: 1 });
29
+ describe('#unit Check database restore writer', function() {
30
+ const dbUrl = 'http://localhost:5984/animaldb';
31
+ const db = request.client(dbUrl, { parallelism: 1 });
28
32
 
29
- const seqSuffix = Buffer.alloc(124, 'abc123').toString('base64');
30
- function provideChanges(batchSize, totalChanges, fullResponse = false) {
31
- let pending = totalChanges;
32
- const sparseResultsArray = Array(batchSize).fill({
33
- seq: null,
34
- id: 'doc',
35
- changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
33
+ beforeEach('Reset nocks', function() {
34
+ nock.cleanAll();
36
35
  });
37
- nock(url)
38
- .post(`/${dbName}/_changes`)
39
- .query(true)
40
- .times(totalChanges / batchSize + (totalChanges % batchSize > 0 ? 1 : 0))
41
- .reply(200, (uri, requestBody) => {
42
- pending -= batchSize;
43
- const lastSeq = (totalChanges - pending);
44
- const seq = lastSeq - batchSize;
45
- return {
46
- results: fullResponse
47
- ? Array.from(Array(batchSize), (_, i) => {
48
- return {
49
- seq: `${seq + i}-${seqSuffix}`,
50
- id: `doc${seq + i}`,
51
- changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
52
- };
53
- })
54
- : sparseResultsArray,
55
- pending: pending,
56
- last_seq: `${lastSeq}-abc`
57
- };
58
- });
59
- }
60
-
61
- describe('#unit Check spool changes', function() {
62
- it('should terminate on request error', async function() {
63
- nock(url)
64
- .post(`/${dbName}/_changes`)
65
- .query(true)
66
- .times(3)
67
- .replyWithError({ code: 'ECONNRESET', message: 'socket hang up' });
68
-
69
- return new Promise((resolve, reject) => {
70
- changes(db, '/dev/null', 500, null, function(err) {
71
- try {
72
- assert.strictEqual(err.name, 'SpoolChangesError');
73
- assert.strictEqual(err.message, `Failed changes request - socket hang up: post ${url}/${dbName}/_changes`);
74
- assert.ok(nock.isDone());
75
- resolve();
76
- } catch (err) {
77
- reject(err);
78
- }
79
- });
80
- });
81
- }).timeout(longTestTimeout);
82
36
 
83
- it('should terminate on bad HTTP status code response', async function() {
84
- nock(url)
85
- .post(`/${dbName}/_changes`)
86
- .query(true)
87
- .times(3)
88
- .reply(500, function(uri, requestBody) {
89
- this.req.response.statusMessage = 'Internal Server Error';
90
- return { error: 'foo', reason: 'bar' };
91
- });
92
- return new Promise((resolve, reject) => {
93
- changes(db, '/dev/null', 500, null, function(err) {
94
- try {
95
- assert.strictEqual(err.name, 'HTTPFatalError');
96
- assert.strictEqual(err.message, `500 Internal Server Error: post ${url}/${dbName}/_changes - Error: foo, Reason: bar`);
97
- assert.ok(nock.isDone());
98
- resolve();
99
- } catch (err) {
100
- reject(err);
101
- }
102
- });
103
- });
104
- }).timeout(longTestTimeout);
37
+ it('should complete successfully', async function() {
38
+ nock(dbUrl)
39
+ .post('/_bulk_docs')
40
+ .reply(200, []); // success
105
41
 
106
- it('should keep collecting changes', async function() {
107
- // This test validates that spooling will correctly
108
- // continue across multiple requests
109
- // (4 batches of 100000 to be precise).
110
- // This test might take up to 10 seconds
111
- this.timeout(10 * 1000);
112
-
113
- // Use full changes for this test
114
- provideChanges(100000, 400000, true);
115
- return new Promise((resolve, reject) => {
116
- changes(db, '/dev/null', 500, null, function(err) {
117
- try {
118
- assert.ok(!err);
119
- assert.ok(nock.isDone());
120
- resolve();
121
- } catch (err) {
122
- reject(err);
123
- }
124
- });
125
- });
42
+ const w = writer(db, 500, 1, noopEmitter);
43
+ return Promise.all([pipeline(fs.createReadStream('./test/fixtures/animaldb_expected.json'), liner(), w),
44
+ once(w, 'finished').then((data) => {
45
+ assert.strictEqual(data[0].total, 15);
46
+ assert.ok(nock.isDone());
47
+ })]);
126
48
  });
127
49
 
128
- it('should keep collecting sparse changes', async function() {
129
- // This test checks that making thousands of requests doesn't
130
- // make anything bad happen.
131
- // This test might take up to 25 seconds
132
- this.timeout(25 * 1000);
133
- // Use sparse changes for this test and a batch size of 1
134
- provideChanges(1, 2500);
135
- return new Promise((resolve, reject) => {
136
- changes(db, '/dev/null', 500, null, function(err) {
137
- try {
138
- assert.ok(!err);
139
- assert.ok(nock.isDone());
140
- resolve();
141
- } catch (err) {
142
- reject(err);
143
- }
144
- });
145
- });
50
+ it('should terminate on a fatal error', async function() {
51
+ nock(dbUrl)
52
+ .post('/_bulk_docs')
53
+ .reply(401, { error: 'Unauthorized' }); // fatal error
54
+
55
+ const w = writer(db, 500, 1, noopEmitter);
56
+ return assert.rejects(
57
+ pipeline(fs.createReadStream('./test/fixtures/animaldb_expected.json'), liner(), w),
58
+ (err) => {
59
+ assert.strictEqual(err.name, 'Unauthorized');
60
+ assert.strictEqual(err.message, 'Access is denied due to invalid credentials.');
61
+ assert.ok(nock.isDone());
62
+ return true;
63
+ }
64
+ );
146
65
  });
147
- });
148
66
 
149
- describe('Longer spool changes checks', function() {
150
- it('#slow should keep collecting changes (25M)', async function() {
151
- // This test might take up to 5 minutes
152
- this.timeout(5 * 60 * 1000);
153
- // Note changes spooling uses a constant batch size, we are setting
154
- // a test value here and setting the buffer to match
155
- const batch = 100000;
156
- // Use sparse changes for this test
157
- provideChanges(batch, 25000000);
158
- return new Promise((resolve, reject) => {
159
- changes(db, '/dev/null', batch, null, function(err) {
160
- try {
161
- assert.ok(!err);
162
- assert.ok(nock.isDone());
163
- resolve();
164
- } catch (err) {
165
- reject(err);
166
- }
167
- });
168
- });
67
+ it('should retry on transient errors', async function() {
68
+ nock(dbUrl)
69
+ .post('/_bulk_docs')
70
+ .reply(429, { error: 'Too Many Requests' }) // transient error
71
+ .post('/_bulk_docs')
72
+ .reply(500, { error: 'Internal Server Error' }) // transient error
73
+ .post('/_bulk_docs')
74
+ .reply(200, { ok: true }); // third time lucky success
75
+
76
+ const w = writer(db, 500, 1, noopEmitter);
77
+ return Promise.all([pipeline(fs.createReadStream('./test/fixtures/animaldb_expected.json'), liner(), w),
78
+ once(w, 'finished').then((data) => {
79
+ assert.strictEqual(data[0].total, 15);
80
+ assert.ok(nock.isDone());
81
+ })]);
82
+ }).timeout(longTestTimeout);
83
+
84
+ it('should fail after 3 transient errors', async function() {
85
+ nock(dbUrl)
86
+ .post('/_bulk_docs')
87
+ .reply(429, { error: 'Too Many Requests' }) // transient error
88
+ .post('/_bulk_docs')
89
+ .reply(500, { error: 'Internal Server Error' }) // transient error
90
+ .post('/_bulk_docs')
91
+ .reply(503, { error: 'Service Unavailable' }); // Final transient error
92
+
93
+ const w = writer(db, 500, 1, noopEmitter);
94
+ return assert.rejects(
95
+ pipeline(fs.createReadStream('./test/fixtures/animaldb_expected.json'), liner(), w),
96
+ (err) => {
97
+ assert.strictEqual(err.name, 'HTTPFatalError');
98
+ assert.strictEqual(err.message, `503 : post ${dbUrl}/_bulk_docs - Error: Service Unavailable`);
99
+ assert.ok(nock.isDone());
100
+ return true;
101
+ }
102
+ );
103
+ }).timeout(longTestTimeout);
104
+
105
+ it('should restore shallow backups without rev info successfully', async function() {
106
+ nock(dbUrl)
107
+ .post('/_bulk_docs')
108
+ .reply(200, [{ ok: true, id: 'foo', rev: '1-abc' }]); // success
109
+
110
+ const w = writer(db, 500, 1, noopEmitter);
111
+ return Promise.all([pipeline(fs.createReadStream('./test/fixtures/animaldb_old_shallow.json'), liner(), w),
112
+ once(w, 'finished').then((data) => {
113
+ assert.strictEqual(data[0].total, 11);
114
+ assert.ok(nock.isDone());
115
+ })]);
169
116
  });
170
117
 
171
- it('#slower should keep collecting changes (500M)', async function() {
172
- // This test might take up to 90 minutes
173
- this.timeout(90 * 60 * 1000);
174
- // Note changes spooling uses a constant batch size, we are setting
175
- // a test value here and setting the buffer to match
176
- const batch = 1000000;
177
- // Use full changes for this test to exercise load
178
- provideChanges(batch, 500000000, true);
179
- return new Promise((resolve, reject) => {
180
- changes(db, '/dev/null', batch, null, function(err) {
181
- try {
182
- assert.ok(!err);
183
- assert.ok(nock.isDone());
184
- resolve();
185
- } catch (err) {
186
- reject(err);
187
- }
188
- });
189
- });
118
+ it('should get a batch error for non-empty array response with new_edits false', async function() {
119
+ nock(dbUrl)
120
+ .post('/_bulk_docs')
121
+ .reply(200, [{ id: 'foo', error: 'foo', reason: 'bar' }]);
122
+
123
+ const w = writer(db, 500, 1, noopEmitter);
124
+ return assert.rejects(
125
+ pipeline(fs.createReadStream('./test/fixtures/animaldb_expected.json'), liner(), w),
126
+ (err) => {
127
+ assert.strictEqual(err.name, 'Error');
128
+ assert.strictEqual(err.message, 'Error writing batch with new_edits:false and 1 items');
129
+ assert.ok(nock.isDone());
130
+ return true;
131
+ }
132
+ );
190
133
  });
191
134
  });
@@ -16,20 +16,171 @@
16
16
  'use strict';
17
17
 
18
18
  const assert = require('assert');
19
- const logfilesummary = require('../includes/logfilesummary.js');
19
+ const nock = require('nock');
20
+ const request = require('../includes/request.js');
21
+ const changes = require('../includes/spoolchanges.js');
20
22
 
21
- describe('#unit Fetching summary from the log file', function() {
22
- it('should fetch a summary correctly', function() {
23
+ const url = 'http://localhost:7777';
24
+ const dbName = 'fakenockdb';
25
+ const longTestTimeout = 3000;
26
+
27
+ const db = request.client(`${url}/${dbName}`, { parallelism: 1 });
28
+
29
+ const seqSuffix = Buffer.alloc(124, 'abc123').toString('base64');
30
+ function provideChanges(batchSize, totalChanges, fullResponse = false) {
31
+ let pending = totalChanges;
32
+ const sparseResultsArray = Array(batchSize).fill({
33
+ seq: null,
34
+ id: 'doc',
35
+ changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
36
+ });
37
+ nock(url)
38
+ .post(`/${dbName}/_changes`)
39
+ .query(true)
40
+ .times(totalChanges / batchSize + (totalChanges % batchSize > 0 ? 1 : 0))
41
+ .reply(200, (uri, requestBody) => {
42
+ pending -= batchSize;
43
+ const lastSeq = (totalChanges - pending);
44
+ const seq = lastSeq - batchSize;
45
+ return {
46
+ results: fullResponse
47
+ ? Array.from(Array(batchSize), (_, i) => {
48
+ return {
49
+ seq: `${seq + i}-${seqSuffix}`,
50
+ id: `doc${seq + i}`,
51
+ changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
52
+ };
53
+ })
54
+ : sparseResultsArray,
55
+ pending: pending,
56
+ last_seq: `${lastSeq}-abc`
57
+ };
58
+ });
59
+ }
60
+
61
+ describe('#unit Check spool changes', function() {
62
+ it('should terminate on request error', async function() {
63
+ nock(url)
64
+ .post(`/${dbName}/_changes`)
65
+ .query(true)
66
+ .times(3)
67
+ .replyWithError({ code: 'ECONNRESET', message: 'socket hang up' });
68
+
69
+ return new Promise((resolve, reject) => {
70
+ changes(db, '/dev/null', 500, null, function(err) {
71
+ try {
72
+ assert.strictEqual(err.name, 'SpoolChangesError');
73
+ assert.strictEqual(err.message, `Failed changes request - socket hang up: post ${url}/${dbName}/_changes`);
74
+ assert.ok(nock.isDone());
75
+ resolve();
76
+ } catch (err) {
77
+ reject(err);
78
+ }
79
+ });
80
+ });
81
+ }).timeout(longTestTimeout);
82
+
83
+ it('should terminate on bad HTTP status code response', async function() {
84
+ nock(url)
85
+ .post(`/${dbName}/_changes`)
86
+ .query(true)
87
+ .times(3)
88
+ .reply(500, function(uri, requestBody) {
89
+ this.req.response.statusMessage = 'Internal Server Error';
90
+ return { error: 'foo', reason: 'bar' };
91
+ });
92
+ return new Promise((resolve, reject) => {
93
+ changes(db, '/dev/null', 500, null, function(err) {
94
+ try {
95
+ assert.strictEqual(err.name, 'HTTPFatalError');
96
+ assert.strictEqual(err.message, `500 Internal Server Error: post ${url}/${dbName}/_changes - Error: foo, Reason: bar`);
97
+ assert.ok(nock.isDone());
98
+ resolve();
99
+ } catch (err) {
100
+ reject(err);
101
+ }
102
+ });
103
+ });
104
+ }).timeout(longTestTimeout);
105
+
106
+ it('should keep collecting changes', async function() {
107
+ // This test validates that spooling will correctly
108
+ // continue across multiple requests
109
+ // (4 batches of 100000 to be precise).
110
+ // This test might take up to 10 seconds
111
+ this.timeout(10 * 1000);
112
+
113
+ // Use full changes for this test
114
+ provideChanges(100000, 400000, true);
115
+ return new Promise((resolve, reject) => {
116
+ changes(db, '/dev/null', 500, null, function(err) {
117
+ try {
118
+ assert.ok(!err);
119
+ assert.ok(nock.isDone());
120
+ resolve();
121
+ } catch (err) {
122
+ reject(err);
123
+ }
124
+ });
125
+ });
126
+ });
127
+
128
+ it('should keep collecting sparse changes', async function() {
129
+ // This test checks that making thousands of requests doesn't
130
+ // make anything bad happen.
131
+ // This test might take up to 25 seconds
132
+ this.timeout(25 * 1000);
133
+ // Use sparse changes for this test and a batch size of 1
134
+ provideChanges(1, 2500);
135
+ return new Promise((resolve, reject) => {
136
+ changes(db, '/dev/null', 500, null, function(err) {
137
+ try {
138
+ assert.ok(!err);
139
+ assert.ok(nock.isDone());
140
+ resolve();
141
+ } catch (err) {
142
+ reject(err);
143
+ }
144
+ });
145
+ });
146
+ });
147
+ });
148
+
149
+ describe('Longer spool changes checks', function() {
150
+ it('#slow should keep collecting changes (25M)', async function() {
151
+ // This test might take up to 5 minutes
152
+ this.timeout(5 * 60 * 1000);
153
+ // Note changes spooling uses a constant batch size, we are setting
154
+ // a test value here and setting the buffer to match
155
+ const batch = 100000;
156
+ // Use sparse changes for this test
157
+ provideChanges(batch, 25000000);
158
+ return new Promise((resolve, reject) => {
159
+ changes(db, '/dev/null', batch, null, function(err) {
160
+ try {
161
+ assert.ok(!err);
162
+ assert.ok(nock.isDone());
163
+ resolve();
164
+ } catch (err) {
165
+ reject(err);
166
+ }
167
+ });
168
+ });
169
+ });
170
+
171
+ it('#slower should keep collecting changes (500M)', async function() {
172
+ // This test might take up to 90 minutes
173
+ this.timeout(90 * 60 * 1000);
174
+ // Note changes spooling uses a constant batch size, we are setting
175
+ // a test value here and setting the buffer to match
176
+ const batch = 1000000;
177
+ // Use full changes for this test to exercise load
178
+ provideChanges(batch, 500000000, true);
23
179
  return new Promise((resolve, reject) => {
24
- logfilesummary('./test/fixtures/test.log', function(err, data) {
180
+ changes(db, '/dev/null', batch, null, function(err) {
25
181
  try {
26
182
  assert.ok(!err);
27
- assert.ok(data);
28
- assert.strictEqual(data.changesComplete, true);
29
- assert.strictEqual(typeof data.batches, 'object');
30
- assert.strictEqual(Object.keys(data.batches).length, 2);
31
- assert.deepStrictEqual(data.batches['1'], true);
32
- assert.deepStrictEqual(data.batches['4'], true);
183
+ assert.ok(nock.isDone());
33
184
  resolve();
34
185
  } catch (err) {
35
186
  reject(err);