@cloudant/couchbackup 2.9.13-SNAPSHOT.144 → 2.9.13

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 (414) hide show
  1. package/.scannerwork/report-task.txt +2 -2
  2. package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
  3. package/.scannerwork/scanner-report/changesets-11.pb +1 -0
  4. package/.scannerwork/scanner-report/changesets-12.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-14.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-15.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-16.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-17.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-18.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-19.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-2.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-20.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-37.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-38.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-39.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-55.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-56.pb +1 -0
  18. package/.scannerwork/scanner-report/changesets-57.pb +1 -0
  19. package/.scannerwork/scanner-report/changesets-60.pb +1 -0
  20. package/.scannerwork/scanner-report/changesets-61.pb +1 -0
  21. package/.scannerwork/scanner-report/changesets-63.pb +1 -0
  22. package/.scannerwork/scanner-report/changesets-64.pb +1 -0
  23. package/.scannerwork/scanner-report/component-1.pb +1 -1
  24. package/.scannerwork/scanner-report/component-11.pb +1 -0
  25. package/.scannerwork/scanner-report/component-12.pb +1 -0
  26. package/.scannerwork/scanner-report/component-14.pb +1 -0
  27. package/.scannerwork/scanner-report/component-15.pb +1 -0
  28. package/.scannerwork/scanner-report/component-16.pb +1 -0
  29. package/.scannerwork/scanner-report/component-17.pb +1 -0
  30. package/.scannerwork/scanner-report/component-18.pb +1 -0
  31. package/.scannerwork/scanner-report/component-19.pb +1 -0
  32. package/.scannerwork/scanner-report/component-2.pb +1 -0
  33. package/.scannerwork/scanner-report/component-20.pb +1 -0
  34. package/.scannerwork/scanner-report/component-21.pb +1 -1
  35. package/.scannerwork/scanner-report/component-22.pb +1 -1
  36. package/.scannerwork/scanner-report/component-23.pb +1 -1
  37. package/.scannerwork/scanner-report/component-35.pb +1 -1
  38. package/.scannerwork/scanner-report/component-36.pb +1 -1
  39. package/.scannerwork/scanner-report/component-37.pb +1 -0
  40. package/.scannerwork/scanner-report/component-38.pb +1 -0
  41. package/.scannerwork/scanner-report/component-39.pb +1 -0
  42. package/.scannerwork/scanner-report/component-40.pb +1 -1
  43. package/.scannerwork/scanner-report/component-41.pb +1 -1
  44. package/.scannerwork/scanner-report/component-42.pb +1 -1
  45. package/.scannerwork/scanner-report/component-43.pb +1 -1
  46. package/.scannerwork/scanner-report/component-44.pb +1 -1
  47. package/.scannerwork/scanner-report/component-45.pb +1 -1
  48. package/.scannerwork/scanner-report/component-46.pb +1 -1
  49. package/.scannerwork/scanner-report/component-47.pb +1 -1
  50. package/.scannerwork/scanner-report/component-48.pb +1 -1
  51. package/.scannerwork/scanner-report/component-5.pb +1 -1
  52. package/.scannerwork/scanner-report/component-50.pb +1 -1
  53. package/.scannerwork/scanner-report/component-52.pb +1 -1
  54. package/.scannerwork/scanner-report/component-53.pb +1 -1
  55. package/.scannerwork/scanner-report/component-54.pb +1 -1
  56. package/.scannerwork/scanner-report/component-55.pb +1 -0
  57. package/.scannerwork/scanner-report/component-56.pb +1 -0
  58. package/.scannerwork/scanner-report/component-57.pb +1 -0
  59. package/.scannerwork/scanner-report/component-58.pb +1 -1
  60. package/.scannerwork/scanner-report/component-59.pb +1 -1
  61. package/.scannerwork/scanner-report/component-60.pb +1 -1
  62. package/.scannerwork/scanner-report/component-61.pb +1 -0
  63. package/.scannerwork/scanner-report/component-62.pb +1 -1
  64. package/.scannerwork/scanner-report/component-63.pb +1 -0
  65. package/.scannerwork/scanner-report/component-64.pb +1 -0
  66. package/.scannerwork/scanner-report/component-8.pb +1 -1
  67. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-23.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-40.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-41.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-47.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  99. package/.scannerwork/scanner-report/duplications-11.pb +2 -0
  100. package/.scannerwork/scanner-report/duplications-12.pb +2 -0
  101. package/.scannerwork/scanner-report/duplications-21.pb +3 -0
  102. package/.scannerwork/scanner-report/duplications-22.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-23.pb +3 -0
  104. package/.scannerwork/scanner-report/duplications-42.pb +3 -0
  105. package/.scannerwork/scanner-report/duplications-44.pb +0 -2
  106. package/.scannerwork/scanner-report/duplications-45.pb +2 -0
  107. package/.scannerwork/scanner-report/duplications-54.pb +0 -2
  108. package/.scannerwork/scanner-report/duplications-60.pb +2 -0
  109. package/.scannerwork/scanner-report/duplications-61.pb +2 -0
  110. package/.scannerwork/scanner-report/duplications-62.pb +0 -2
  111. package/.scannerwork/scanner-report/duplications-63.pb +0 -0
  112. package/.scannerwork/scanner-report/duplications-64.pb +0 -0
  113. package/.scannerwork/scanner-report/issues-23.pb +3 -2
  114. package/.scannerwork/scanner-report/issues-36.pb +3 -0
  115. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-23.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-41.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-44.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-47.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-53.pb +12 -11
  139. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-61.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  150. package/.scannerwork/scanner-report/metadata.pb +0 -0
  151. package/.scannerwork/scanner-report/source-11.txt +175 -0
  152. package/.scannerwork/scanner-report/source-14.txt +68 -0
  153. package/.scannerwork/scanner-report/source-15.txt +100 -0
  154. package/.scannerwork/scanner-report/{source-28.txt → source-16.txt} +14 -7
  155. package/.scannerwork/scanner-report/source-17.txt +63 -0
  156. package/.scannerwork/scanner-report/source-20.txt +625 -0
  157. package/.scannerwork/scanner-report/source-21.txt +97 -14
  158. package/.scannerwork/scanner-report/source-22.txt +203 -46
  159. package/.scannerwork/scanner-report/source-23.txt +213 -111
  160. package/.scannerwork/scanner-report/source-35.txt +346 -14
  161. package/.scannerwork/scanner-report/source-36.txt +125 -46
  162. package/.scannerwork/scanner-report/source-40.txt +19 -403
  163. package/.scannerwork/scanner-report/source-41.txt +15 -115
  164. package/.scannerwork/scanner-report/source-42.txt +113 -36
  165. package/.scannerwork/scanner-report/source-43.txt +64 -253
  166. package/.scannerwork/scanner-report/source-44.txt +132 -51
  167. package/.scannerwork/scanner-report/source-45.txt +267 -138
  168. package/.scannerwork/scanner-report/source-46.txt +130 -101
  169. package/.scannerwork/scanner-report/source-47.txt +37 -61
  170. package/.scannerwork/scanner-report/source-48.txt +62 -16
  171. package/.scannerwork/scanner-report/source-5.txt +382 -64
  172. package/.scannerwork/scanner-report/source-50.txt +509 -46
  173. package/.scannerwork/scanner-report/source-52.txt +16 -163
  174. package/.scannerwork/scanner-report/source-53.txt +148 -74
  175. package/.scannerwork/scanner-report/source-54.txt +18 -64
  176. package/.scannerwork/scanner-report/source-55.txt +129 -0
  177. package/.scannerwork/scanner-report/source-56.txt +281 -0
  178. package/.scannerwork/scanner-report/source-57.txt +118 -0
  179. package/.scannerwork/scanner-report/source-58.txt +84 -36
  180. package/.scannerwork/scanner-report/source-59.txt +60 -57
  181. package/.scannerwork/scanner-report/source-60.txt +75 -509
  182. package/.scannerwork/scanner-report/source-61.txt +92 -0
  183. package/.scannerwork/scanner-report/source-62.txt +35 -156
  184. package/.scannerwork/scanner-report/source-64.txt +164 -0
  185. package/.scannerwork/scanner-report/source-8.txt +167 -625
  186. package/.scannerwork/scanner-report/symbols-11.pb +153 -0
  187. package/.scannerwork/scanner-report/symbols-14.pb +45 -0
  188. package/.scannerwork/scanner-report/symbols-15.pb +69 -0
  189. package/.scannerwork/scanner-report/symbols-16.pb +14 -0
  190. package/.scannerwork/scanner-report/symbols-17.pb +43 -0
  191. package/.scannerwork/scanner-report/symbols-21.pb +77 -14
  192. package/.scannerwork/scanner-report/symbols-22.pb +417 -44
  193. package/.scannerwork/scanner-report/symbols-23.pb +387 -109
  194. package/.scannerwork/scanner-report/symbols-35.pb +494 -10
  195. package/.scannerwork/scanner-report/symbols-36.pb +115 -42
  196. package/.scannerwork/scanner-report/symbols-40.pb +10 -610
  197. package/.scannerwork/scanner-report/symbols-41.pb +9 -33
  198. package/.scannerwork/scanner-report/symbols-42.pb +97 -15
  199. package/.scannerwork/scanner-report/symbols-43.pb +60 -354
  200. package/.scannerwork/scanner-report/symbols-44.pb +111 -41
  201. package/.scannerwork/scanner-report/symbols-45.pb +482 -122
  202. package/.scannerwork/scanner-report/symbols-46.pb +85 -30
  203. package/.scannerwork/scanner-report/symbols-47.pb +18 -45
  204. package/.scannerwork/scanner-report/symbols-48.pb +29 -13
  205. package/.scannerwork/scanner-report/symbols-5.pb +610 -69
  206. package/.scannerwork/scanner-report/symbols-52.pb +13 -143
  207. package/.scannerwork/scanner-report/symbols-53.pb +143 -41
  208. package/.scannerwork/scanner-report/symbols-54.pb +18 -42
  209. package/.scannerwork/scanner-report/symbols-55.pb +33 -0
  210. package/.scannerwork/scanner-report/symbols-56.pb +354 -0
  211. package/.scannerwork/scanner-report/symbols-57.pb +30 -0
  212. package/.scannerwork/scanner-report/symbols-58.pb +41 -18
  213. package/.scannerwork/scanner-report/symbols-59.pb +45 -29
  214. package/.scannerwork/scanner-report/symbols-60.pb +42 -0
  215. package/.scannerwork/scanner-report/symbols-61.pb +44 -0
  216. package/.scannerwork/scanner-report/symbols-62.pb +14 -152
  217. package/.scannerwork/scanner-report/symbols-64.pb +126 -0
  218. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +214 -0
  219. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +110 -0
  220. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +105 -0
  221. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +54 -0
  222. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +82 -0
  223. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +887 -0
  224. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +123 -19
  225. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +281 -60
  226. package/.scannerwork/scanner-report/syntax-highlightings-23.pb +292 -97
  227. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +594 -14
  228. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +98 -46
  229. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +21 -619
  230. package/.scannerwork/scanner-report/syntax-highlightings-41.pb +16 -97
  231. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +153 -25
  232. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +65 -240
  233. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +189 -44
  234. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +593 -147
  235. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +154 -76
  236. package/.scannerwork/scanner-report/syntax-highlightings-47.pb +61 -74
  237. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +91 -33
  238. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +613 -70
  239. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +3736 -53
  240. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +15 -213
  241. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +205 -78
  242. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +27 -53
  243. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +129 -0
  244. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +285 -0
  245. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +113 -0
  246. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +97 -63
  247. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +74 -82
  248. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +67 -3736
  249. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +90 -0
  250. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +23 -183
  251. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +213 -0
  252. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +809 -747
  253. package/CHANGES.md +5 -0
  254. package/package.json +1 -1
  255. package/test-18-results.xml +163 -163
  256. package/test-iam-18-results.xml +49 -49
  257. package/.scannerwork/scanner-report/changesets-24.pb +0 -1
  258. package/.scannerwork/scanner-report/changesets-25.pb +0 -1
  259. package/.scannerwork/scanner-report/changesets-26.pb +0 -1
  260. package/.scannerwork/scanner-report/changesets-27.pb +0 -1
  261. package/.scannerwork/scanner-report/changesets-28.pb +0 -1
  262. package/.scannerwork/scanner-report/changesets-29.pb +0 -1
  263. package/.scannerwork/scanner-report/changesets-3.pb +0 -1
  264. package/.scannerwork/scanner-report/changesets-30.pb +0 -1
  265. package/.scannerwork/scanner-report/changesets-31.pb +0 -1
  266. package/.scannerwork/scanner-report/changesets-32.pb +0 -1
  267. package/.scannerwork/scanner-report/changesets-33.pb +0 -1
  268. package/.scannerwork/scanner-report/changesets-34.pb +0 -1
  269. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  270. package/.scannerwork/scanner-report/changesets-49.pb +0 -1
  271. package/.scannerwork/scanner-report/changesets-50.pb +0 -1
  272. package/.scannerwork/scanner-report/changesets-6.pb +0 -1
  273. package/.scannerwork/scanner-report/changesets-65.pb +0 -1
  274. package/.scannerwork/scanner-report/changesets-7.pb +0 -1
  275. package/.scannerwork/scanner-report/changesets-8.pb +0 -1
  276. package/.scannerwork/scanner-report/changesets-9.pb +0 -1
  277. package/.scannerwork/scanner-report/component-24.pb +0 -1
  278. package/.scannerwork/scanner-report/component-25.pb +0 -1
  279. package/.scannerwork/scanner-report/component-26.pb +0 -1
  280. package/.scannerwork/scanner-report/component-27.pb +0 -1
  281. package/.scannerwork/scanner-report/component-28.pb +0 -1
  282. package/.scannerwork/scanner-report/component-29.pb +0 -1
  283. package/.scannerwork/scanner-report/component-3.pb +0 -1
  284. package/.scannerwork/scanner-report/component-30.pb +0 -1
  285. package/.scannerwork/scanner-report/component-31.pb +0 -1
  286. package/.scannerwork/scanner-report/component-32.pb +0 -1
  287. package/.scannerwork/scanner-report/component-33.pb +0 -1
  288. package/.scannerwork/scanner-report/component-34.pb +0 -1
  289. package/.scannerwork/scanner-report/component-4.pb +0 -1
  290. package/.scannerwork/scanner-report/component-49.pb +0 -1
  291. package/.scannerwork/scanner-report/component-6.pb +0 -1
  292. package/.scannerwork/scanner-report/component-65.pb +0 -1
  293. package/.scannerwork/scanner-report/component-67.pb +0 -1
  294. package/.scannerwork/scanner-report/component-7.pb +0 -1
  295. package/.scannerwork/scanner-report/component-9.pb +0 -1
  296. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  297. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  298. package/.scannerwork/scanner-report/coverages-29.pb +0 -0
  299. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  300. package/.scannerwork/scanner-report/coverages-32.pb +0 -0
  301. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  302. package/.scannerwork/scanner-report/coverages-34.pb +0 -0
  303. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  304. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  305. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  306. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  307. package/.scannerwork/scanner-report/duplications-27.pb +0 -2
  308. package/.scannerwork/scanner-report/duplications-30.pb +0 -3
  309. package/.scannerwork/scanner-report/duplications-33.pb +0 -3
  310. package/.scannerwork/scanner-report/duplications-34.pb +0 -2
  311. package/.scannerwork/scanner-report/duplications-6.pb +0 -3
  312. package/.scannerwork/scanner-report/duplications-65.pb +0 -2
  313. package/.scannerwork/scanner-report/issues-33.pb +0 -4
  314. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  315. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  316. package/.scannerwork/scanner-report/measures-29.pb +0 -0
  317. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  318. package/.scannerwork/scanner-report/measures-32.pb +0 -0
  319. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  320. package/.scannerwork/scanner-report/measures-34.pb +0 -15
  321. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  322. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  323. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  324. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  325. package/.scannerwork/scanner-report/source-27.txt +0 -225
  326. package/.scannerwork/scanner-report/source-29.txt +0 -156
  327. package/.scannerwork/scanner-report/source-30.txt +0 -131
  328. package/.scannerwork/scanner-report/source-32.txt +0 -92
  329. package/.scannerwork/scanner-report/source-33.txt +0 -244
  330. package/.scannerwork/scanner-report/source-34.txt +0 -293
  331. package/.scannerwork/scanner-report/source-4.txt +0 -366
  332. package/.scannerwork/scanner-report/source-6.txt +0 -119
  333. package/.scannerwork/scanner-report/source-67.txt +0 -167
  334. package/.scannerwork/scanner-report/source-9.txt +0 -147
  335. package/.scannerwork/scanner-report/symbols-27.pb +0 -418
  336. package/.scannerwork/scanner-report/symbols-28.pb +0 -9
  337. package/.scannerwork/scanner-report/symbols-29.pb +0 -112
  338. package/.scannerwork/scanner-report/symbols-30.pb +0 -97
  339. package/.scannerwork/scanner-report/symbols-32.pb +0 -60
  340. package/.scannerwork/scanner-report/symbols-33.pb +0 -394
  341. package/.scannerwork/scanner-report/symbols-34.pb +0 -486
  342. package/.scannerwork/scanner-report/symbols-4.pb +0 -494
  343. package/.scannerwork/scanner-report/symbols-50.pb +0 -20
  344. package/.scannerwork/scanner-report/symbols-6.pb +0 -77
  345. package/.scannerwork/scanner-report/symbols-9.pb +0 -85
  346. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +0 -331
  347. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +0 -48
  348. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +0 -223
  349. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +0 -182
  350. package/.scannerwork/scanner-report/syntax-highlightings-32.pb +0 -110
  351. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +0 -329
  352. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +0 -659
  353. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -630
  354. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +0 -158
  355. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +0 -949
  356. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +0 -191
  357. /package/.scannerwork/scanner-report/{coverages-65.pb → coverages-12.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{coverages-24.pb → coverages-18.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{coverages-31.pb → coverages-19.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{coverages-3.pb → coverages-2.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{coverages-8.pb → coverages-20.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{coverages-26.pb → coverages-37.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{coverages-7.pb → coverages-38.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{coverages-25.pb → coverages-39.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{coverages-49.pb → coverages-63.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{duplications-24.pb → duplications-14.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-15.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{duplications-29.pb → duplications-16.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{duplications-3.pb → duplications-17.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{duplications-31.pb → duplications-18.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{duplications-32.pb → duplications-19.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-2.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{duplications-41.pb → duplications-20.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{duplications-26.pb → duplications-37.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{duplications-49.pb → duplications-38.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-39.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{duplications-7.pb → duplications-55.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{duplications-8.pb → duplications-56.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{duplications-9.pb → duplications-57.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{issues-4.pb → issues-35.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{issues-25.pb → issues-39.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{measures-65.pb → measures-12.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{measures-24.pb → measures-18.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{measures-31.pb → measures-19.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{measures-3.pb → measures-2.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{measures-26.pb → measures-37.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{measures-7.pb → measures-38.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{measures-25.pb → measures-39.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{measures-49.pb → measures-63.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{source-65.txt → source-12.txt} +0 -0
  391. /package/.scannerwork/scanner-report/{source-24.txt → source-18.txt} +0 -0
  392. /package/.scannerwork/scanner-report/{source-31.txt → source-19.txt} +0 -0
  393. /package/.scannerwork/scanner-report/{source-3.txt → source-2.txt} +0 -0
  394. /package/.scannerwork/scanner-report/{source-26.txt → source-37.txt} +0 -0
  395. /package/.scannerwork/scanner-report/{source-7.txt → source-38.txt} +0 -0
  396. /package/.scannerwork/scanner-report/{source-25.txt → source-39.txt} +0 -0
  397. /package/.scannerwork/scanner-report/{source-49.txt → source-63.txt} +0 -0
  398. /package/.scannerwork/scanner-report/{symbols-65.pb → symbols-12.pb} +0 -0
  399. /package/.scannerwork/scanner-report/{symbols-24.pb → symbols-18.pb} +0 -0
  400. /package/.scannerwork/scanner-report/{symbols-31.pb → symbols-19.pb} +0 -0
  401. /package/.scannerwork/scanner-report/{symbols-3.pb → symbols-2.pb} +0 -0
  402. /package/.scannerwork/scanner-report/{symbols-8.pb → symbols-20.pb} +0 -0
  403. /package/.scannerwork/scanner-report/{symbols-26.pb → symbols-37.pb} +0 -0
  404. /package/.scannerwork/scanner-report/{symbols-7.pb → symbols-38.pb} +0 -0
  405. /package/.scannerwork/scanner-report/{symbols-25.pb → symbols-39.pb} +0 -0
  406. /package/.scannerwork/scanner-report/{symbols-49.pb → symbols-63.pb} +0 -0
  407. /package/.scannerwork/scanner-report/{syntax-highlightings-65.pb → syntax-highlightings-12.pb} +0 -0
  408. /package/.scannerwork/scanner-report/{syntax-highlightings-24.pb → syntax-highlightings-18.pb} +0 -0
  409. /package/.scannerwork/scanner-report/{syntax-highlightings-31.pb → syntax-highlightings-19.pb} +0 -0
  410. /package/.scannerwork/scanner-report/{syntax-highlightings-3.pb → syntax-highlightings-2.pb} +0 -0
  411. /package/.scannerwork/scanner-report/{syntax-highlightings-26.pb → syntax-highlightings-37.pb} +0 -0
  412. /package/.scannerwork/scanner-report/{syntax-highlightings-7.pb → syntax-highlightings-38.pb} +0 -0
  413. /package/.scannerwork/scanner-report/{syntax-highlightings-25.pb → syntax-highlightings-39.pb} +0 -0
  414. /package/.scannerwork/scanner-report/{syntax-highlightings-49.pb → syntax-highlightings-63.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2021 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,65 +11,146 @@
11
11
  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
+
15
+ /* global describe it */
14
16
  'use strict';
15
17
 
16
- const fs = require('fs');
17
- const stream = require('stream');
18
- const liner = require('./liner.js');
18
+ const assert = require('assert');
19
+ const nock = require('nock');
20
+ const request = require('../includes/request.js');
21
+ const changes = require('../includes/spoolchanges.js');
22
+
23
+ const url = 'http://localhost:7777';
24
+ const dbName = 'fakenockdb';
25
+ const longTestTimeout = 3000;
26
+
27
+ const db = request.client(`${url}/${dbName}`, { parallelism: 1 });
19
28
 
20
- const onLine = function(onCommand, batches) {
21
- const change = new stream.Transform({ objectMode: true });
22
- change._transform = function(line, encoding, done) {
23
- if (line && line[0] === ':') {
24
- const obj = {
25
- command: null,
26
- batch: null,
27
- docs: []
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`
28
57
  };
58
+ });
59
+ }
29
60
 
30
- let matches;
61
+ describe('#unit Check spool changes', function() {
62
+ it('should terminate on request error', function(done) {
63
+ nock(url)
64
+ .post(`/${dbName}/_changes`)
65
+ .query(true)
66
+ .times(3)
67
+ .replyWithError({ code: 'ECONNRESET', message: 'socket hang up' });
31
68
 
32
- // extract command
33
- matches = line.match(/^:([a-z_]+) ?/);
34
- if (matches) {
35
- obj.command = matches[1];
36
- }
69
+ changes(db, '/dev/null', 500, null, function(err) {
70
+ assert.strictEqual(err.name, 'SpoolChangesError');
71
+ assert.strictEqual(err.message, `Failed changes request - socket hang up: post ${url}/${dbName}/_changes`);
72
+ assert.ok(nock.isDone());
73
+ done();
74
+ });
75
+ }).timeout(longTestTimeout);
37
76
 
38
- // extract batch
39
- matches = line.match(/ batch([0-9]+)/);
40
- if (matches) {
41
- obj.batch = parseInt(matches[1]);
42
- }
77
+ it('should terminate on bad HTTP status code response', function(done) {
78
+ nock(url)
79
+ .post(`/${dbName}/_changes`)
80
+ .query(true)
81
+ .times(3)
82
+ .reply(500, function(uri, requestBody) {
83
+ this.req.response.statusMessage = 'Internal Server Error';
84
+ return { error: 'foo', reason: 'bar' };
85
+ });
43
86
 
44
- // if this is one we want
45
- if (obj.command === 't' && batches.indexOf(obj.batch) > -1) {
46
- const json = line.replace(/^.* batch[0-9]+ /, '').trim();
47
- obj.docs = JSON.parse(json);
48
- onCommand(obj);
49
- }
50
- }
51
- done();
52
- };
53
- return change;
54
- };
87
+ changes(db, '/dev/null', 500, null, function(err) {
88
+ assert.strictEqual(err.name, 'HTTPFatalError');
89
+ assert.strictEqual(err.message, `500 Internal Server Error: post ${url}/${dbName}/_changes - Error: foo, Reason: bar`);
90
+ assert.ok(nock.isDone());
91
+ done();
92
+ });
93
+ }).timeout(longTestTimeout);
55
94
 
56
- module.exports = function(log, batches, callback) {
57
- // our sense of state
58
- const retval = { };
95
+ it('should keep collecting changes', function(done) {
96
+ // This test validates that spooling will correctly
97
+ // continue across multiple requests
98
+ // (4 batches of 100000 to be precise).
99
+ // This test might take up to 10 seconds
100
+ this.timeout(10 * 1000);
59
101
 
60
- // called with each line from the log file
61
- const onCommand = function(obj) {
62
- retval[obj.batch] = obj;
63
- };
102
+ // Use full changes for this test
103
+ provideChanges(100000, 400000, true);
104
+ changes(db, '/dev/null', 500, null, function(err) {
105
+ assert.ok(!err);
106
+ assert.ok(nock.isDone());
107
+ done();
108
+ });
109
+ });
110
+
111
+ it('should keep collecting sparse changes', function(done) {
112
+ // This test checks that making thousands of requests doesn't
113
+ // make anything bad happen.
114
+ // This test might take up to 25 seconds
115
+ this.timeout(25 * 1000);
116
+ // Use sparse changes for this test and a batch size of 1
117
+ provideChanges(1, 2500);
118
+ changes(db, '/dev/null', 500, null, function(err) {
119
+ assert.ok(!err);
120
+ assert.ok(nock.isDone());
121
+ done();
122
+ });
123
+ });
124
+ });
125
+
126
+ describe('Longer spool changes checks', function() {
127
+ it('#slow should keep collecting changes (25M)', function(done) {
128
+ // This test might take up to 5 minutes
129
+ this.timeout(5 * 60 * 1000);
130
+ // Note changes spooling uses a constant batch size, we are setting
131
+ // a test value here and setting the buffer to match
132
+ const batch = 100000;
133
+ // Use sparse changes for this test
134
+ provideChanges(batch, 25000000);
135
+ changes(db, '/dev/null', batch, null, function(err) {
136
+ assert.ok(!err);
137
+ assert.ok(nock.isDone());
138
+ done();
139
+ });
140
+ });
64
141
 
65
- // stream through the previous log file
66
- fs.createReadStream(log)
67
- .pipe(liner())
68
- .pipe(onLine(onCommand, batches))
69
- .on('error', function(err) {
70
- callback(err);
71
- })
72
- .on('finish', function() {
73
- callback(null, retval);
142
+ it('#slower should keep collecting changes (500M)', function(done) {
143
+ // This test might take up to 90 minutes
144
+ this.timeout(90 * 60 * 1000);
145
+ // Note changes spooling uses a constant batch size, we are setting
146
+ // a test value here and setting the buffer to match
147
+ const batch = 1000000;
148
+ // Use full changes for this test to exercise load
149
+ provideChanges(batch, 500000000, true);
150
+ changes(db, '/dev/null', batch, null, function(err) {
151
+ assert.ok(!err);
152
+ assert.ok(nock.isDone());
153
+ done();
74
154
  });
75
- };
155
+ });
156
+ });
@@ -11,154 +11,283 @@
11
11
  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
+
15
+ /* global describe it before after beforeEach */
14
16
  'use strict';
15
17
 
16
- const async = require('async');
17
- const stream = require('stream');
18
- const error = require('./error.js');
19
- const debug = require('debug')('couchbackup:writer');
20
-
21
- module.exports = function(db, bufferSize, parallelism, ee) {
22
- const writer = new stream.Transform({ objectMode: true });
23
- let buffer = [];
24
- let written = 0;
25
- let linenumber = 0;
26
-
27
- // this is the queue of chunks that are written to the database
28
- // the queue's payload will be an array of documents to be written,
29
- // the size of the array will be bufferSize. The variable parallelism
30
- // determines how many HTTP requests will occur at any one time.
31
- const q = async.queue(function(payload, cb) {
32
- // if we are restoring known revisions, we need to supply new_edits=false
33
- if (payload.docs && payload.docs[0] && payload.docs[0]._rev) {
34
- payload.new_edits = false;
35
- debug('Using new_edits false mode.');
36
- }
18
+ const assert = require('assert');
19
+ const fs = require('fs');
20
+ const u = require('./citestutils.js');
21
+ const mockServerPort = +process.env.COUCHBACKUP_MOCK_SERVER_PORT || 7777;
22
+ const url = `http://localhost:${mockServerPort}`;
23
+ const nock = require('nock');
24
+ const httpProxy = require('http-proxy');
25
+ const Readable = require('stream').Readable;
37
26
 
38
- if (!didError) {
39
- db.service.postBulkDocs({
40
- db: db.db,
41
- bulkDocs: payload
42
- }).then(response => {
43
- if (!response.result || (payload.new_edits === false && response.result.length > 0)) {
44
- throw new Error(`Error writing batch with new_edits:${payload.new_edits !== false}` +
45
- ` and ${response.result ? response.result.length : 'unavailable'} items`);
46
- }
47
- written += payload.docs.length;
48
- writer.emit('restored', { documents: payload.docs.length, total: written });
49
- cb();
50
- }).catch(err => {
51
- err = error.convertResponseError(err);
52
- debug(`Error writing docs ${err.name} ${err.message}`);
53
- cb(err, payload);
54
- });
55
- }
56
- }, parallelism);
57
-
58
- let didError = false;
59
-
60
- // write the contents of the buffer to CouchDB in blocks of bufferSize
61
- function processBuffer(flush, callback) {
62
- function taskCallback(err, payload) {
63
- if (err && !didError) {
64
- debug(`Queue task failed with error ${err.name}`);
65
- didError = true;
66
- q.kill();
67
- writer.emit('error', err);
27
+ // Create an infinite stream to read.
28
+ // It just keeps sending a backup line, useful for testing cases of
29
+ // termination while a stream has content remaining (the animaldb backup
30
+ // is too small for that).
31
+ class InfiniteBackupStream extends Readable {
32
+ constructor(opt) {
33
+ super(opt);
34
+ this.contents = Buffer.from('[{"_id":"giraffe","_rev":"3-7665c3e66315ff40616cceef62886bd8","min_weight":830,"min_length":5,"max_weight":1600,"max_length":6,"wiki_page":"http://en.wikipedia.org/wiki/Giraffe","class":"mammal","diet":"herbivore","_revisions":{"start":3,"ids":["7665c3e66315ff40616cceef62886bd8","aaaf10d5a68cdf22d95a5482a0e95549","967a00dff5e02add41819138abb3284d"]}}]\n', 'utf8');
35
+ }
36
+
37
+ _read() {
38
+ let proceed;
39
+ do {
40
+ proceed = this.push(this.contents);
41
+ } while (proceed);
42
+ }
43
+ }
44
+
45
+ function assertNock(done) {
46
+ try {
47
+ assert.ok(nock.isDone());
48
+ done();
49
+ } catch (err) {
50
+ console.error('pending mocks: %j', nock.pendingMocks());
51
+ done(err);
52
+ }
53
+ }
54
+
55
+ function backupHttpError(opts, errorName, errorCode, done) {
56
+ const p = u.p(opts, { expectedBackupError: { name: errorName, code: errorCode } });
57
+
58
+ // Create a file and attempt a backup to it
59
+ const output = fs.createWriteStream('/dev/null');
60
+ output.on('open', function() {
61
+ u.testBackup(p, 'fakenockdb', output, function(err) {
62
+ if (err) {
63
+ done(err);
64
+ } else {
65
+ assertNock(done);
68
66
  }
67
+ });
68
+ });
69
+ }
70
+
71
+ function restoreHttpError(opts, errorName, errorCode, done) {
72
+ const q = u.p(opts, { expectedRestoreError: { name: errorName, code: errorCode } });
73
+ u.testRestoreFromFile(q, './test/fixtures/animaldb_expected.json', 'fakenockdb', function(err) {
74
+ if (err) {
75
+ done(err);
76
+ } else {
77
+ assertNock(done);
69
78
  }
79
+ });
80
+ }
70
81
 
71
- if (flush || buffer.length >= bufferSize) {
72
- // work through the buffer to break off bufferSize chunks
73
- // and feed the chunks to the queue
74
- do {
75
- // split the buffer into bufferSize chunks
76
- const toSend = buffer.splice(0, bufferSize);
77
-
78
- // and add the chunk to the queue
79
- debug(`Adding ${toSend.length} to the write queue.`);
80
- q.push({ docs: toSend }, taskCallback);
81
- } while (buffer.length >= bufferSize);
82
-
83
- // send any leftover documents to the queue
84
- if (flush && buffer.length > 0) {
85
- debug(`Adding remaining ${buffer.length} to the write queue.`);
86
- q.push({ docs: buffer }, taskCallback);
82
+ [{ useApi: true }, { useApi: false }].forEach(function(params) {
83
+ describe(u.scenario('#unit Fatal errors', params), function() {
84
+ let processEnvCopy;
85
+ let proxy;
86
+
87
+ before('Set process data for test', function() {
88
+ // Copy env and argv so we can reset them after the tests
89
+ processEnvCopy = JSON.parse(JSON.stringify(process.env));
90
+
91
+ // Set up a proxy to point to our nock server because the nock override
92
+ // isn't visible to the spawned CLI process
93
+ if (!params.useApi) {
94
+ proxy = httpProxy.createProxyServer({ target: url }).listen(mockServerPort + 1000, 'localhost');
87
95
  }
88
96
 
89
- // wait until the queue size falls to a reasonable level
90
- async.until(
91
- // wait until the queue length drops to twice the paralellism
92
- // or until empty on the last write
93
- function(callback) {
94
- // if we encountered an error, stop this until loop
95
- if (didError) {
96
- return callback(null, true);
97
- }
98
- if (flush) {
99
- callback(null, q.idle() && q.length() === 0);
97
+ // setup environment variables
98
+ process.env.COUCH_URL = (params.useApi) ? url : `http://localhost:${mockServerPort + 1000}`;
99
+ });
100
+
101
+ after('Reset process data', function(done) {
102
+ process.env = processEnvCopy;
103
+ if (!params.useApi) {
104
+ proxy.close(done);
105
+ } else {
106
+ done();
107
+ }
108
+ });
109
+
110
+ beforeEach('Reset nocks', function() {
111
+ nock.cleanAll();
112
+ });
113
+
114
+ describe('for backup', function() {
115
+ it('should terminate when DB does not exist', function(done) {
116
+ // Simulate existence check
117
+ nock(url).head('/fakenockdb').reply(404, { error: 'not_found', reason: 'missing' });
118
+ backupHttpError(params, 'DatabaseNotFound', 10, done);
119
+ });
120
+
121
+ it('should terminate on BulkGetError', function(done) {
122
+ // Simulate existence check
123
+ const n = nock(url).head('/fakenockdb').reply(200);
124
+ // Simulate _bulk_get not available
125
+ n.post('/fakenockdb/_bulk_get').reply(404, { error: 'not_found', reason: 'missing' });
126
+ backupHttpError(params, 'BulkGetError', 50, done);
127
+ });
128
+
129
+ it('should terminate on Unauthorized existence check', function(done) {
130
+ // Simulate a 401
131
+ nock(url).head('/fakenockdb').reply(401, { error: 'unauthorized', reason: '_reader access is required for this request' });
132
+ backupHttpError(params, 'Unauthorized', 11, done);
133
+ });
134
+
135
+ it('should terminate on Forbidden no _reader', function(done) {
136
+ // Simulate a 403
137
+ nock(url).head('/fakenockdb').reply(403, { error: 'forbidden', reason: '_reader access is required for this request' });
138
+ backupHttpError(params, 'Forbidden', 12, done);
139
+ });
140
+
141
+ it('should terminate on _bulk_get HTTPFatalError', function(done) {
142
+ // Provide a mock complete changes log to allow a resume to skip ahead
143
+ const p = u.p(params, { opts: { resume: true, log: './test/fixtures/test.log' } });
144
+ // Allow the existence and _bulk_get checks to pass
145
+ const n = nock(url).head('/fakenockdb').reply(200);
146
+ n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
147
+ // Simulate a fatal HTTP error when trying to fetch docs
148
+ // Note: 2 outstanding batches, so 2 responses, 1 mock is optional because we can't guarantee timing
149
+ n.post('/fakenockdb/_bulk_get').query(true).reply(400, { error: 'bad_request', reason: 'testing bad response' });
150
+ n.post('/fakenockdb/_bulk_get').query(true).optionally().reply(400, { error: 'bad_request', reason: 'testing bad response' });
151
+ backupHttpError(p, 'HTTPFatalError', 40, done);
152
+ });
153
+
154
+ it('should terminate on NoLogFileName', function(done) {
155
+ // Don't supply a log file name with resume
156
+ const p = u.p(params, { opts: { resume: true } });
157
+ backupHttpError(p, 'NoLogFileName', 20, done);
158
+ });
159
+
160
+ it('should terminate on LogDoesNotExist', function(done) {
161
+ // Use a non-existent log file
162
+ const p = u.p(params, { opts: { resume: true, log: './test/fixtures/doesnotexist.log' } });
163
+ backupHttpError(p, 'LogDoesNotExist', 21, done);
164
+ });
165
+
166
+ it('should terminate on IncompleteChangesInLogFile', function(done) {
167
+ // Use an incomplete changes log file
168
+ const p = u.p(params, { opts: { resume: true, log: './test/fixtures/incomplete_changes.log' } });
169
+ // Allow the existence and _bulk_get checks to pass
170
+ const n = nock(url).head('/fakenockdb').reply(200);
171
+ n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
172
+ // Should fail when it reads the incomplete changes
173
+ backupHttpError(p, 'IncompleteChangesInLogFile', 22, done);
174
+ });
175
+
176
+ it('should terminate on _changes HTTPFatalError', function(done) {
177
+ // Allow the existence and _bulk_get checks to pass
178
+ const n = nock(url).head('/fakenockdb').reply(200);
179
+ n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
180
+ // Simulate a fatal HTTP error when trying to fetch docs (note 2 outstanding batches)
181
+ n.post('/fakenockdb/_changes').query(true).reply(400, { error: 'bad_request', reason: 'testing bad response' });
182
+ backupHttpError(params, 'HTTPFatalError', 40, done);
183
+ });
184
+
185
+ it('should terminate on SpoolChangesError', function(done) {
186
+ // Allow the existence and _bulk_get checks to pass
187
+ const n = nock(url).head('/fakenockdb').reply(200);
188
+ n.post('/fakenockdb/_bulk_get').reply(200, '{"results": []}');
189
+ // Simulate a changes without a last_seq
190
+ n.post('/fakenockdb/_changes').query(true).reply(200,
191
+ {
192
+ results: [{
193
+ seq: '2-g1AAAAEbeJzLYWBgYMlgTmFQSElKzi9KdUhJstTLTS3KLElMT9VLzskvTUnMK9HLSy3JAapkSmRIsv___39WBnMiUy5QgN3MzDIxOdEMWb85dv0gSxThigyN8diS5AAkk-pBFiUyoOkzxKMvjwVIMjQAKaDW_Zh6TQnqPQDRC7I3CwDPDV1k',
194
+ id: 'badger',
195
+ changes: [{ rev: '4-51aa94e4b0ef37271082033bba52b850' }]
196
+ }]
197
+ });
198
+ backupHttpError(params, 'SpoolChangesError', 30, done);
199
+ });
200
+ });
201
+
202
+ describe('for restore', function() {
203
+ it('should terminate on Unauthorized db existence check', function(done) {
204
+ // Simulate a 401
205
+ nock(url).get('/fakenockdb').reply(401, { error: 'unauthorized', reason: '_reader access is required for this request' });
206
+ restoreHttpError(params, 'Unauthorized', 11, done);
207
+ });
208
+
209
+ it('should terminate on Forbidden no _writer', function(done) {
210
+ // Simulate the DB exists (i.e. you can read it)
211
+ const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
212
+ // Simulate a 403 trying to write
213
+ n.post('/fakenockdb/_bulk_docs').reply(403, { error: 'forbidden', reason: '_writer access is required for this request' });
214
+ restoreHttpError(params, 'Forbidden', 12, done);
215
+ });
216
+
217
+ it('should terminate on RestoreDatabaseNotFound', function(done) {
218
+ // Simulate the DB does not exist
219
+ nock(url).get('/fakenockdb').reply(404, { error: 'not_found', reason: 'Database does not exist.' });
220
+ restoreHttpError(params, 'DatabaseNotFound', 10, done);
221
+ });
222
+
223
+ it('should terminate on notEmptyDBErr when database is not empty', function(done) {
224
+ // Simulate the DB that does exist and not empty
225
+ nock(url).get('/fakenockdb').reply(200, { doc_count: 10, doc_del_count: 0 });
226
+ restoreHttpError(params, 'DatabaseNotEmpty', 13, done);
227
+ });
228
+
229
+ it('should terminate on notEmptyDBErr when database is not new', function(done) {
230
+ // Simulate the DB that does exist and not new
231
+ nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 10 });
232
+ restoreHttpError(params, 'DatabaseNotEmpty', 13, done);
233
+ });
234
+
235
+ it('should terminate on _bulk_docs HTTPFatalError', function(done) {
236
+ // Simulate the DB exists
237
+ const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
238
+ // Use a parallelism of one and mock one response
239
+ const p = u.p(params, { opts: { parallelism: 1 } });
240
+ // Simulate a 400 trying to write
241
+ n.post('/fakenockdb/_bulk_docs').reply(400, { error: 'bad_request', reason: 'testing bad response' });
242
+ restoreHttpError(p, 'HTTPFatalError', 40, done);
243
+ });
244
+
245
+ it('should terminate on _bulk_docs HTTPFatalError from system database', function(done) {
246
+ // Simulate that target database exists and is _not_ empty.
247
+ // This should pass validator as we exclude system databases from the check.
248
+ const n = nock(url).get('/_replicator').reply(200, { doc_count: 1, doc_del_count: 0 });
249
+ // Simulate a 400 trying to write
250
+ n.post('/_replicator/_bulk_docs').reply(400, { error: 'bad_request', reason: 'testing bad response' });
251
+ // Use a parallelism of one and mock one response
252
+ const q = u.p(params, { opts: { parallelism: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
253
+ u.testRestore(q, new InfiniteBackupStream(), '_replicator', function(err) {
254
+ if (err) {
255
+ done(err);
100
256
  } else {
101
- callback(null, q.length() <= parallelism * 2);
257
+ assertNock(done);
102
258
  }
103
- },
104
- function(cb) {
105
- setTimeout(cb, 20);
106
- },
107
-
108
- function() {
109
- if (flush && !didError) {
110
- writer.emit('finished', { total: written });
259
+ });
260
+ });
261
+
262
+ it('should terminate on _bulk_docs HTTPFatalError large stream', function(done) {
263
+ // Simulate the DB exists
264
+ const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
265
+ // Simulate a 400 trying to write
266
+ // Provide a body function to handle the stream, but allow any body
267
+ n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).reply(400, { error: 'bad_request', reason: 'testing bad response' });
268
+ // Use only parallelism 1 so we don't have to mock up loads of responses
269
+ const q = u.p(params, { opts: { parallelism: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
270
+ u.testRestore(q, new InfiniteBackupStream(), 'fakenockdb', function(err) {
271
+ if (err) {
272
+ done(err);
273
+ } else {
274
+ assertNock(done);
111
275
  }
112
- // callback when we're happy with the queue size
113
- callback();
114
276
  });
115
- } else {
116
- callback();
117
- }
118
- }
277
+ });
119
278
 
120
- // take an object
121
- writer._transform = function(obj, encoding, done) {
122
- // each obj that arrives here is a line from the backup file
123
- // it should contain an array of objects. The length of the array
124
- // depends on the bufferSize at backup time.
125
- linenumber++;
126
- if (!didError && obj !== '') {
127
- // see if it parses as JSON
128
- try {
129
- const arr = JSON.parse(obj);
130
-
131
- // if it's an array with a length
132
- if (typeof arr === 'object' && arr.length > 0) {
133
- // push each document into a buffer
134
- buffer = buffer.concat(arr);
135
-
136
- // pause the stream
137
- // it's likely that the speed with which data can be read from disk
138
- // may exceed the rate it can be written to CouchDB. To prevent
139
- // the whole file being buffered in memory, we pause the stream here.
140
- // it is resumed, when processBuffer calls back and we call done()
141
- this.pause();
142
-
143
- // break the buffer in to bufferSize chunks to be written to the database
144
- processBuffer(false, done);
145
- } else {
146
- ee.emit('error', new error.BackupError('BackupFileJsonError', `Error on line ${linenumber} of backup file - not an array`));
147
- done();
148
- }
149
- } catch (e) {
150
- ee.emit('error', new error.BackupError('BackupFileJsonError', `Error on line ${linenumber} of backup file - cannot parse as JSON`));
151
- // Could be an incomplete write that was subsequently resumed
152
- done();
153
- }
154
- } else {
155
- done();
156
- }
157
- };
158
-
159
- // called when we need to flush everything
160
- writer._flush = function(done) {
161
- processBuffer(true, done);
162
- };
163
- return writer;
164
- };
279
+ it('should terminate on multiple _bulk_docs HTTPFatalError', function(done) {
280
+ // Simulate the DB exists
281
+ const n = nock(url).get('/fakenockdb').reply(200, { doc_count: 0, doc_del_count: 0 });
282
+ // Simulate a 400 trying to write docs, 5 times because of default parallelism
283
+ // Provide a body function to handle the stream, but allow any body
284
+ // Four of the mocks are optional because of parallelism 5 we can't guarantee that the exit will happen
285
+ // after all 5 requests, but we must get at least one of them
286
+ n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).reply(400, { error: 'bad_request', reason: 'testing bad response' });
287
+ n.post('/fakenockdb/_bulk_docs', function(body) { return true; }).times(4).optionally().reply(400, { error: 'bad_request', reason: 'testing bad response' });
288
+ const q = u.p(params, { opts: { bufferSize: 1 }, expectedRestoreError: { name: 'HTTPFatalError', code: 40 } });
289
+ restoreHttpError(q, 'HTTPFatalError', 40, done);
290
+ });
291
+ });
292
+ });
293
+ });