@cloudant/couchbackup 2.9.13 → 2.9.14-SNAPSHOT.146

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 (376) 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-10.pb +2 -0
  4. package/.scannerwork/scanner-report/changesets-13.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-30.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-31.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-32.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-33.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-34.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-49.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-50.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-6.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-7.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-8.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-9.pb +1 -0
  16. package/.scannerwork/scanner-report/component-1.pb +3 -1
  17. package/.scannerwork/scanner-report/component-10.pb +2 -0
  18. package/.scannerwork/scanner-report/component-11.pb +1 -1
  19. package/.scannerwork/scanner-report/component-12.pb +1 -1
  20. package/.scannerwork/scanner-report/component-13.pb +1 -0
  21. package/.scannerwork/scanner-report/component-14.pb +1 -1
  22. package/.scannerwork/scanner-report/component-15.pb +1 -1
  23. package/.scannerwork/scanner-report/component-16.pb +1 -1
  24. package/.scannerwork/scanner-report/component-17.pb +1 -1
  25. package/.scannerwork/scanner-report/component-18.pb +1 -1
  26. package/.scannerwork/scanner-report/component-30.pb +1 -0
  27. package/.scannerwork/scanner-report/component-31.pb +1 -0
  28. package/.scannerwork/scanner-report/component-32.pb +1 -0
  29. package/.scannerwork/scanner-report/component-33.pb +1 -0
  30. package/.scannerwork/scanner-report/component-34.pb +1 -0
  31. package/.scannerwork/scanner-report/component-35.pb +1 -1
  32. package/.scannerwork/scanner-report/component-36.pb +1 -1
  33. package/.scannerwork/scanner-report/component-37.pb +1 -1
  34. package/.scannerwork/scanner-report/component-39.pb +1 -1
  35. package/.scannerwork/scanner-report/component-4.pb +1 -0
  36. package/.scannerwork/scanner-report/component-40.pb +1 -1
  37. package/.scannerwork/scanner-report/component-42.pb +1 -1
  38. package/.scannerwork/scanner-report/component-43.pb +1 -1
  39. package/.scannerwork/scanner-report/component-44.pb +1 -1
  40. package/.scannerwork/scanner-report/component-45.pb +1 -1
  41. package/.scannerwork/scanner-report/component-46.pb +1 -1
  42. package/.scannerwork/scanner-report/component-47.pb +1 -1
  43. package/.scannerwork/scanner-report/component-48.pb +1 -1
  44. package/.scannerwork/scanner-report/component-49.pb +1 -0
  45. package/.scannerwork/scanner-report/component-5.pb +1 -1
  46. package/.scannerwork/scanner-report/component-50.pb +1 -1
  47. package/.scannerwork/scanner-report/component-51.pb +1 -1
  48. package/.scannerwork/scanner-report/component-52.pb +1 -1
  49. package/.scannerwork/scanner-report/component-54.pb +1 -1
  50. package/.scannerwork/scanner-report/component-55.pb +1 -1
  51. package/.scannerwork/scanner-report/component-56.pb +1 -1
  52. package/.scannerwork/scanner-report/component-59.pb +1 -1
  53. package/.scannerwork/scanner-report/component-6.pb +1 -0
  54. package/.scannerwork/scanner-report/component-60.pb +1 -1
  55. package/.scannerwork/scanner-report/component-62.pb +1 -1
  56. package/.scannerwork/scanner-report/component-64.pb +1 -1
  57. package/.scannerwork/scanner-report/component-7.pb +1 -0
  58. package/.scannerwork/scanner-report/component-8.pb +1 -1
  59. package/.scannerwork/scanner-report/component-9.pb +1 -0
  60. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  61. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  62. package/.scannerwork/scanner-report/coverages-12.pb +0 -0
  63. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  64. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  65. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  66. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  67. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  71. package/.scannerwork/scanner-report/{coverages-38.pb → coverages-34.pb} +0 -0
  72. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-39.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-40.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-47.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-49.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-51.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-52.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-59.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  98. package/.scannerwork/scanner-report/duplications-11.pb +0 -2
  99. package/.scannerwork/scanner-report/duplications-12.pb +0 -2
  100. package/.scannerwork/scanner-report/duplications-15.pb +2 -0
  101. package/.scannerwork/scanner-report/duplications-17.pb +3 -0
  102. package/.scannerwork/scanner-report/duplications-30.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-37.pb +0 -2
  104. package/.scannerwork/scanner-report/duplications-42.pb +0 -3
  105. package/.scannerwork/scanner-report/duplications-43.pb +2 -0
  106. package/.scannerwork/scanner-report/duplications-45.pb +0 -2
  107. package/.scannerwork/scanner-report/duplications-55.pb +2 -0
  108. package/.scannerwork/scanner-report/duplications-59.pb +2 -0
  109. package/.scannerwork/scanner-report/duplications-60.pb +1 -1
  110. package/.scannerwork/scanner-report/duplications-9.pb +3 -0
  111. package/.scannerwork/scanner-report/issues-36.pb +2 -2
  112. package/.scannerwork/scanner-report/issues-37.pb +3 -0
  113. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  114. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  115. package/.scannerwork/scanner-report/measures-12.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-44.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-47.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  150. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  151. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  153. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  154. package/.scannerwork/scanner-report/metadata.pb +0 -0
  155. package/.scannerwork/scanner-report/source-10.txt +63 -0
  156. package/.scannerwork/scanner-report/source-11.txt +64 -147
  157. package/.scannerwork/scanner-report/source-12.txt +45 -167
  158. package/.scannerwork/scanner-report/{source-41.txt → source-13.txt} +14 -7
  159. package/.scannerwork/scanner-report/source-14.txt +47 -47
  160. package/.scannerwork/scanner-report/source-15.txt +262 -69
  161. package/.scannerwork/scanner-report/source-16.txt +603 -14
  162. package/.scannerwork/scanner-report/source-17.txt +91 -35
  163. package/.scannerwork/scanner-report/source-18.txt +128 -40
  164. package/.scannerwork/scanner-report/source-30.txt +145 -0
  165. package/.scannerwork/scanner-report/source-33.txt +147 -0
  166. package/.scannerwork/scanner-report/{source-38.txt → source-34.txt} +9 -10
  167. package/.scannerwork/scanner-report/source-35.txt +10 -347
  168. package/.scannerwork/scanner-report/source-36.txt +29 -124
  169. package/.scannerwork/scanner-report/source-37.txt +118 -121
  170. package/.scannerwork/scanner-report/source-39.txt +40 -31
  171. package/.scannerwork/scanner-report/source-4.txt +509 -0
  172. package/.scannerwork/scanner-report/source-40.txt +62 -19
  173. package/.scannerwork/scanner-report/source-42.txt +90 -107
  174. package/.scannerwork/scanner-report/source-43.txt +50 -67
  175. package/.scannerwork/scanner-report/source-44.txt +40 -142
  176. package/.scannerwork/scanner-report/source-45.txt +105 -269
  177. package/.scannerwork/scanner-report/source-46.txt +32 -133
  178. package/.scannerwork/scanner-report/source-47.txt +14 -39
  179. package/.scannerwork/scanner-report/source-48.txt +90 -56
  180. package/.scannerwork/scanner-report/source-49.txt +281 -0
  181. package/.scannerwork/scanner-report/source-5.txt +20 -403
  182. package/.scannerwork/scanner-report/source-50.txt +41 -509
  183. package/.scannerwork/scanner-report/source-51.txt +84 -21
  184. package/.scannerwork/scanner-report/source-52.txt +63 -14
  185. package/.scannerwork/scanner-report/source-54.txt +138 -20
  186. package/.scannerwork/scanner-report/source-55.txt +76 -113
  187. package/.scannerwork/scanner-report/source-56.txt +78 -241
  188. package/.scannerwork/scanner-report/source-59.txt +175 -65
  189. package/.scannerwork/scanner-report/source-6.txt +100 -0
  190. package/.scannerwork/scanner-report/source-60.txt +152 -52
  191. package/.scannerwork/scanner-report/source-62.txt +167 -54
  192. package/.scannerwork/scanner-report/source-64.txt +387 -133
  193. package/.scannerwork/scanner-report/source-7.txt +366 -0
  194. package/.scannerwork/scanner-report/source-8.txt +36 -167
  195. package/.scannerwork/scanner-report/source-9.txt +131 -0
  196. package/.scannerwork/scanner-report/symbols-10.pb +43 -0
  197. package/.scannerwork/scanner-report/symbols-11.pb +60 -153
  198. package/.scannerwork/scanner-report/symbols-12.pb +45 -180
  199. package/.scannerwork/scanner-report/symbols-13.pb +14 -0
  200. package/.scannerwork/scanner-report/symbols-14.pb +35 -44
  201. package/.scannerwork/scanner-report/symbols-15.pb +485 -68
  202. package/.scannerwork/scanner-report/symbols-16.pb +1253 -13
  203. package/.scannerwork/scanner-report/symbols-17.pb +76 -42
  204. package/.scannerwork/scanner-report/symbols-18.pb +110 -34
  205. package/.scannerwork/scanner-report/symbols-30.pb +102 -0
  206. package/.scannerwork/scanner-report/symbols-33.pb +85 -0
  207. package/.scannerwork/scanner-report/symbols-34.pb +10 -0
  208. package/.scannerwork/scanner-report/symbols-35.pb +9 -494
  209. package/.scannerwork/scanner-report/symbols-36.pb +27 -116
  210. package/.scannerwork/scanner-report/symbols-37.pb +111 -97
  211. package/.scannerwork/scanner-report/symbols-39.pb +19 -27
  212. package/.scannerwork/scanner-report/symbols-40.pb +29 -9
  213. package/.scannerwork/scanner-report/symbols-42.pb +28 -97
  214. package/.scannerwork/scanner-report/symbols-43.pb +42 -60
  215. package/.scannerwork/scanner-report/symbols-44.pb +14 -111
  216. package/.scannerwork/scanner-report/symbols-45.pb +33 -486
  217. package/.scannerwork/scanner-report/symbols-46.pb +19 -84
  218. package/.scannerwork/scanner-report/symbols-47.pb +13 -18
  219. package/.scannerwork/scanner-report/symbols-48.pb +58 -29
  220. package/.scannerwork/scanner-report/symbols-49.pb +354 -0
  221. package/.scannerwork/scanner-report/symbols-5.pb +17 -610
  222. package/.scannerwork/scanner-report/symbols-50.pb +18 -0
  223. package/.scannerwork/scanner-report/symbols-51.pb +39 -15
  224. package/.scannerwork/scanner-report/symbols-52.pb +45 -13
  225. package/.scannerwork/scanner-report/symbols-54.pb +126 -20
  226. package/.scannerwork/scanner-report/symbols-55.pb +44 -33
  227. package/.scannerwork/scanner-report/symbols-56.pb +30 -354
  228. package/.scannerwork/scanner-report/symbols-59.pb +180 -46
  229. package/.scannerwork/scanner-report/symbols-6.pb +69 -0
  230. package/.scannerwork/scanner-report/symbols-60.pb +152 -41
  231. package/.scannerwork/scanner-report/symbols-64.pb +604 -120
  232. package/.scannerwork/scanner-report/symbols-7.pb +494 -0
  233. package/.scannerwork/scanner-report/symbols-9.pb +97 -0
  234. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +82 -0
  235. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +72 -176
  236. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +65 -180
  237. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +54 -0
  238. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +59 -74
  239. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +618 -64
  240. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +854 -21
  241. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +119 -43
  242. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +185 -57
  243. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +227 -0
  244. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +191 -0
  245. package/.scannerwork/scanner-report/{syntax-highlightings-41.pb → syntax-highlightings-34.pb} +15 -13
  246. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +15 -597
  247. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +31 -97
  248. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +96 -189
  249. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +59 -45
  250. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +3747 -0
  251. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +82 -29
  252. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +102 -146
  253. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +43 -75
  254. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +24 -193
  255. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +91 -621
  256. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +35 -162
  257. package/.scannerwork/scanner-report/syntax-highlightings-47.pb +33 -70
  258. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +108 -78
  259. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +285 -0
  260. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +34 -619
  261. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +39 -3736
  262. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +83 -17
  263. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +65 -15
  264. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +178 -29
  265. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +49 -88
  266. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +78 -250
  267. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +194 -64
  268. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +105 -0
  269. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +183 -47
  270. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +938 -43
  271. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +586 -151
  272. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +630 -0
  273. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +48 -938
  274. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +182 -0
  275. package/package.json +1 -1
  276. package/test-18-results.xml +152 -152
  277. package/test-iam-18-results.xml +50 -50
  278. package/.scannerwork/scanner-report/changesets-19.pb +0 -1
  279. package/.scannerwork/scanner-report/changesets-2.pb +0 -1
  280. package/.scannerwork/scanner-report/changesets-20.pb +0 -1
  281. package/.scannerwork/scanner-report/changesets-21.pb +0 -1
  282. package/.scannerwork/scanner-report/changesets-22.pb +0 -1
  283. package/.scannerwork/scanner-report/changesets-23.pb +0 -1
  284. package/.scannerwork/scanner-report/changesets-38.pb +0 -1
  285. package/.scannerwork/scanner-report/changesets-41.pb +0 -1
  286. package/.scannerwork/scanner-report/changesets-57.pb +0 -1
  287. package/.scannerwork/scanner-report/changesets-58.pb +0 -1
  288. package/.scannerwork/scanner-report/changesets-61.pb +0 -1
  289. package/.scannerwork/scanner-report/changesets-62.pb +0 -1
  290. package/.scannerwork/scanner-report/changesets-63.pb +0 -1
  291. package/.scannerwork/scanner-report/component-19.pb +0 -1
  292. package/.scannerwork/scanner-report/component-2.pb +0 -1
  293. package/.scannerwork/scanner-report/component-20.pb +0 -1
  294. package/.scannerwork/scanner-report/component-21.pb +0 -1
  295. package/.scannerwork/scanner-report/component-22.pb +0 -1
  296. package/.scannerwork/scanner-report/component-23.pb +0 -1
  297. package/.scannerwork/scanner-report/component-38.pb +0 -1
  298. package/.scannerwork/scanner-report/component-41.pb +0 -1
  299. package/.scannerwork/scanner-report/component-57.pb +0 -1
  300. package/.scannerwork/scanner-report/component-58.pb +0 -1
  301. package/.scannerwork/scanner-report/component-61.pb +0 -1
  302. package/.scannerwork/scanner-report/component-63.pb +0 -1
  303. package/.scannerwork/scanner-report/coverages-2.pb +0 -0
  304. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  305. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  306. package/.scannerwork/scanner-report/coverages-41.pb +0 -0
  307. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  308. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  309. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  310. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  311. package/.scannerwork/scanner-report/coverages-63.pb +0 -0
  312. package/.scannerwork/scanner-report/duplications-21.pb +0 -3
  313. package/.scannerwork/scanner-report/duplications-61.pb +0 -2
  314. package/.scannerwork/scanner-report/issues-39.pb +0 -3
  315. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  316. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  317. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  318. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  319. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  320. package/.scannerwork/scanner-report/measures-41.pb +0 -0
  321. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  322. package/.scannerwork/scanner-report/measures-58.pb +0 -15
  323. package/.scannerwork/scanner-report/measures-61.pb +0 -0
  324. package/.scannerwork/scanner-report/measures-63.pb +0 -0
  325. package/.scannerwork/scanner-report/source-19.txt +0 -36
  326. package/.scannerwork/scanner-report/source-2.txt +0 -114
  327. package/.scannerwork/scanner-report/source-20.txt +0 -625
  328. package/.scannerwork/scanner-report/source-21.txt +0 -119
  329. package/.scannerwork/scanner-report/source-57.txt +0 -118
  330. package/.scannerwork/scanner-report/source-58.txt +0 -104
  331. package/.scannerwork/scanner-report/source-61.txt +0 -92
  332. package/.scannerwork/scanner-report/source-63.txt +0 -111
  333. package/.scannerwork/scanner-report/symbols-2.pb +0 -28
  334. package/.scannerwork/scanner-report/symbols-20.pb +0 -1254
  335. package/.scannerwork/scanner-report/symbols-21.pb +0 -77
  336. package/.scannerwork/scanner-report/symbols-38.pb +0 -17
  337. package/.scannerwork/scanner-report/symbols-41.pb +0 -9
  338. package/.scannerwork/scanner-report/symbols-57.pb +0 -30
  339. package/.scannerwork/scanner-report/symbols-58.pb +0 -42
  340. package/.scannerwork/scanner-report/symbols-61.pb +0 -44
  341. package/.scannerwork/scanner-report/symbols-62.pb +0 -15
  342. package/.scannerwork/scanner-report/symbols-63.pb +0 -59
  343. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +0 -59
  344. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +0 -138
  345. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -887
  346. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -158
  347. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +0 -63
  348. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +0 -113
  349. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +0 -116
  350. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +0 -90
  351. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +0 -133
  352. /package/.scannerwork/scanner-report/{coverages-22.pb → coverages-31.pb} +0 -0
  353. /package/.scannerwork/scanner-report/{coverages-23.pb → coverages-32.pb} +0 -0
  354. /package/.scannerwork/scanner-report/{coverages-19.pb → coverages-8.pb} +0 -0
  355. /package/.scannerwork/scanner-report/{duplications-19.pb → duplications-10.pb} +0 -0
  356. /package/.scannerwork/scanner-report/{duplications-2.pb → duplications-13.pb} +0 -0
  357. /package/.scannerwork/scanner-report/{duplications-22.pb → duplications-31.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{duplications-23.pb → duplications-32.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-33.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{duplications-35.pb → duplications-34.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{duplications-38.pb → duplications-49.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{duplications-57.pb → duplications-50.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{duplications-58.pb → duplications-6.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{duplications-62.pb → duplications-7.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{duplications-63.pb → duplications-8.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{issues-23.pb → issues-32.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{issues-35.pb → issues-7.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{measures-22.pb → measures-31.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{measures-23.pb → measures-32.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{source-22.txt → source-31.txt} +0 -0
  371. /package/.scannerwork/scanner-report/{source-23.txt → source-32.txt} +0 -0
  372. /package/.scannerwork/scanner-report/{symbols-22.pb → symbols-31.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{symbols-23.pb → symbols-32.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{symbols-19.pb → symbols-8.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{syntax-highlightings-22.pb → syntax-highlightings-31.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{syntax-highlightings-23.pb → syntax-highlightings-32.pb} +0 -0
@@ -15,49 +15,105 @@
15
15
  /* global describe it */
16
16
  'use strict';
17
17
 
18
+ const assert = require('assert');
18
19
  const fs = require('fs');
19
20
  const u = require('./citestutils.js');
20
21
 
21
- describe('Event tests', function() {
22
- it('should get a finished event when using stdout', function(done) {
23
- u.setTimeout(this, 40);
24
- // Use the API so we can get events
25
- const params = { useApi: true };
26
- const backup = u.testBackup(params, 'animaldb', process.stdout, function(err) {
27
- if (err) {
28
- done(err);
29
- }
30
- });
31
- backup.on('finished', function() {
32
- try {
33
- // Test will time out if the finished event is not emitted
34
- done();
35
- } catch (err) {
36
- done(err);
37
- }
38
- });
39
- });
40
- it('should get a finished event when using file output', function(done) {
41
- u.setTimeout(this, 40);
42
- // Use the API so we can get events
43
- const params = { useApi: true };
44
- const actualBackup = `./${this.fileName}`;
45
- // Create a file and backup to it
46
- const output = fs.createWriteStream(actualBackup);
47
- output.on('open', function() {
48
- const backup = u.testBackup(params, 'animaldb', output, function(err) {
22
+ [{ useApi: true }, { useApi: false }].forEach(function(params) {
23
+ describe(u.scenario('Resume tests', params), function() {
24
+ it('should create a log file', function(done) {
25
+ // Allow up to 90 s for this test
26
+ u.setTimeout(this, 60);
27
+
28
+ const actualBackup = `./${this.fileName}`;
29
+ const logFile = `./${this.fileName}` + '.log';
30
+ // Use abort parameter to terminate the backup a given number of ms after
31
+ // the first data write to the output file.
32
+ const p = u.p(params, { opts: { log: logFile } });
33
+ u.testBackupToFile(p, 'animaldb', actualBackup, function(err) {
49
34
  if (err) {
50
35
  done(err);
36
+ } else {
37
+ // Assert the log file exists
38
+ try {
39
+ assert.ok(fs.existsSync(logFile), 'The log file should exist.');
40
+ done();
41
+ } catch (err) {
42
+ done(err);
43
+ }
51
44
  }
52
45
  });
53
- backup.on('finished', function() {
54
- try {
55
- // Test will time out if the finished event is not emitted
56
- done();
57
- } catch (err) {
58
- done(err);
59
- }
46
+ });
47
+
48
+ it('should restore corrupted animaldb to a database correctly', function(done) {
49
+ // Allow up to 60 s to restore and compare (again it should be faster)!
50
+ u.setTimeout(this, 60);
51
+ const input = fs.createReadStream('./test/fixtures/animaldb_corrupted.json');
52
+ const dbName = this.dbName;
53
+ input.on('open', function() {
54
+ u.testRestore(params, input, dbName, function(err) {
55
+ if (err) {
56
+ done(err);
57
+ } else {
58
+ u.dbCompare('animaldb', dbName, done);
59
+ }
60
+ });
61
+ });
62
+ });
63
+
64
+ it('should restore resumed animaldb with blank line to a database correctly', function(done) {
65
+ // Allow up to 60 s to restore and compare (again it should be faster)!
66
+ u.setTimeout(this, 60);
67
+ const input = fs.createReadStream('./test/fixtures/animaldb_resumed_blank.json');
68
+ const dbName = this.dbName;
69
+ input.on('open', function() {
70
+ u.testRestore(params, input, dbName, function(err) {
71
+ if (err) {
72
+ done(err);
73
+ } else {
74
+ u.dbCompare('animaldb', dbName, done);
75
+ }
76
+ });
60
77
  });
61
78
  });
62
79
  });
63
80
  });
81
+
82
+ describe('Resume tests', function() {
83
+ // Currently cannot abort API backups, when we do this test should be run for
84
+ // both API and CLI
85
+ it('should correctly backup and restore backup10m', function(done) {
86
+ // Allow up to 90 s for this test
87
+ u.setTimeout(this, 90);
88
+
89
+ const actualBackup = `./${this.fileName}`;
90
+ const logFile = `./${this.fileName}` + '.log';
91
+ // Use abort parameter to terminate the backup a given number of ms after
92
+ // the first data write to the output file.
93
+ const p = u.p(params, { abort: true }, { opts: { log: logFile } });
94
+ const restoreDb = this.dbName;
95
+ // Set the database doc count as fewer than this should be written during
96
+ // resumed backup.
97
+ p.exclusiveMaxExpected = 5096;
98
+
99
+ u.testBackupAbortResumeRestore(p, 'backup10m', actualBackup, restoreDb, done);
100
+ });
101
+ // Note --output is only valid for CLI usage, this test should only run for CLI
102
+ const params = { useApi: false };
103
+ it('should correctly backup and restore backup10m using --output', function(done) {
104
+ // Allow up to 90 s for this test
105
+ u.setTimeout(this, 90);
106
+
107
+ const actualBackup = `./${this.fileName}`;
108
+ const logFile = `./${this.fileName}` + '.log';
109
+ // Use abort parameter to terminate the backup a given number of ms after
110
+ // the first data write to the output file.
111
+ const p = u.p(params, { abort: true }, { opts: { output: actualBackup, log: logFile } });
112
+ const restoreDb = this.dbName;
113
+ // Set the database doc count as fewer than this should be written during
114
+ // resumed backup.
115
+ p.exclusiveMaxExpected = 5096;
116
+
117
+ u.testBackupAbortResumeRestore(p, 'backup10m', actualBackup, restoreDb, done);
118
+ });
119
+ });
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2018 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.
@@ -15,54 +15,142 @@
15
15
  /* global describe it */
16
16
  'use strict';
17
17
 
18
- const fs = require('fs');
19
- const u = require('./citestutils.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');
20
22
 
21
- [{ useApi: true }, { useApi: false }].forEach(function(params) {
22
- describe(u.scenario('Compression tests', params), function() {
23
- const p = u.p(params, { compression: true });
23
+ const url = 'http://localhost:7777';
24
+ const dbName = 'fakenockdb';
25
+ const longTestTimeout = 3000;
24
26
 
25
- it('should backup animaldb to a compressed file', function(done) {
26
- // Allow up to 60 s for backup of animaldb
27
- u.setTimeout(this, 60);
28
- const compressedBackup = `./${this.fileName}`;
29
- const output = fs.createWriteStream(compressedBackup);
30
- output.on('open', function() {
31
- u.testBackup(p, 'animaldb', output, function(err) {
32
- if (err) {
33
- done(err);
34
- } else {
35
- u.assertGzipFile(compressedBackup, done);
36
- }
37
- });
38
- });
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', function(done) {
63
+ nock(url)
64
+ .post(`/${dbName}/_changes`)
65
+ .query(true)
66
+ .times(3)
67
+ .replyWithError({ code: 'ECONNRESET', message: 'socket hang up' });
68
+
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();
39
74
  });
75
+ }).timeout(longTestTimeout);
40
76
 
41
- it('should backup and restore animaldb via a compressed file', function(done) {
42
- // Allow up to 60 s for backup and restore of animaldb
43
- u.setTimeout(this, 60);
44
- const compressedBackup = `./${this.fileName}`;
45
- u.testBackupAndRestoreViaFile(p, 'animaldb', compressedBackup, this.dbName, function(err) {
46
- if (err) {
47
- done(err);
48
- } else {
49
- u.assertGzipFile(compressedBackup, done);
50
- }
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' };
51
85
  });
86
+
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);
94
+
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);
101
+
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();
52
122
  });
123
+ });
124
+ });
53
125
 
54
- it('should backup and restore animaldb via a compressed stream', function(done) {
55
- // Allow up to 60 s for backup and restore of animaldb
56
- u.setTimeout(this, 60);
57
- u.testDirectBackupAndRestore(p, 'animaldb', this.dbName, done);
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();
58
139
  });
140
+ });
59
141
 
60
- it('should backup and restore largedb2g via a compressed file #slower', function(done) {
61
- // Takes ~ 25 min using CLI, but sometimes over an hour with API
62
- u.setTimeout(this, 180 * 60);
63
- const compressedBackup = `./${this.fileName}`;
64
- params.compression = true;
65
- u.testBackupAndRestoreViaFile(p, 'largedb2g', compressedBackup, this.dbName, done);
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();
66
154
  });
67
155
  });
68
156
  });
@@ -0,0 +1,145 @@
1
+ // Copyright © 2017, 2022 IBM Corp. All rights reserved.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // http://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+
15
+ /* global describe it beforeEach */
16
+ 'use strict';
17
+
18
+ const assert = require('assert');
19
+ const backup = require('../includes/shallowbackup.js');
20
+ const request = require('../includes/request.js');
21
+ const fs = require('fs');
22
+ const nock = require('nock');
23
+
24
+ // Function to create a DB object and call the shallow backup function
25
+ // This is normally done by app.js
26
+ function shallowBackup(dbUrl, opts) {
27
+ const db = request.client(dbUrl, opts);
28
+ // Disable compression to make body assertions easier
29
+ db.service.setEnableGzipCompression(false);
30
+ return backup(db, opts);
31
+ }
32
+
33
+ // Note all these tests include a body parameter of include_docs and a query
34
+ // string of include_docs because of a quirk of nano that when using the fetch
35
+ // method always adds the include_docs query string.
36
+ describe('#unit Perform backup using shallow backup', function() {
37
+ const dbUrl = 'http://localhost:5984/animaldb';
38
+ // Query string keys are stringified by Nano
39
+ const badgerKey = 'badger\0';
40
+ const kookaburraKey = 'kookaburra\0';
41
+ const snipeKey = 'snipe\0';
42
+
43
+ beforeEach('Reset nocks', function() {
44
+ nock.cleanAll();
45
+ });
46
+
47
+ it('should perform a shallow backup', function(done) {
48
+ const couch = nock(dbUrl)
49
+ // batch 1
50
+ .post('/_all_docs', { limit: 3, include_docs: true })
51
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_1.json', 'utf8')))
52
+ // batch 2
53
+ .post('/_all_docs', { limit: 3, start_key: badgerKey, include_docs: true })
54
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_2.json', 'utf8')))
55
+ // batch 3
56
+ .post('/_all_docs', { limit: 3, start_key: kookaburraKey, include_docs: true })
57
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_3.json', 'utf8')))
58
+ // batch 4
59
+ .post('/_all_docs', { limit: 3, start_key: snipeKey, include_docs: true })
60
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_4.json', 'utf8')));
61
+
62
+ shallowBackup(dbUrl, { bufferSize: 3, parallelism: 1 })
63
+ .on('error', function(err) {
64
+ assert.fail(err);
65
+ })
66
+ .on('received', function(data) {
67
+ if (data.batch === 3) {
68
+ assert.strictEqual(data.length, 2); // smaller last batch
69
+ } else {
70
+ assert.strictEqual(data.length, 3);
71
+ }
72
+ })
73
+ .on('finished', function(data) {
74
+ assert.strictEqual(data.total, 11);
75
+ assert.ok(couch.isDone());
76
+ done();
77
+ });
78
+ });
79
+
80
+ it('should perform a shallow backup with transient error', function(done) {
81
+ const couch = nock(dbUrl)
82
+ // batch 1
83
+ .post('/_all_docs', { limit: 3, include_docs: true })
84
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_1.json', 'utf8')))
85
+ // batch 2
86
+ .post('/_all_docs', { limit: 3, start_key: badgerKey, include_docs: true })
87
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_2.json', 'utf8')))
88
+ // batch 3 - transient error
89
+ .post('/_all_docs', { limit: 3, start_key: kookaburraKey, include_docs: true })
90
+ .reply(500, { error: 'Internal Server Error' })
91
+ // batch 3 - retry
92
+ .post('/_all_docs', { limit: 3, start_key: kookaburraKey, include_docs: true })
93
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_3.json', 'utf8')))
94
+ // batch 4
95
+ .post('/_all_docs', { limit: 3, start_key: snipeKey, include_docs: true })
96
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_4.json', 'utf8')));
97
+
98
+ shallowBackup(dbUrl, { bufferSize: 3, parallelism: 1 })
99
+ .on('error', function(err) {
100
+ assert.strictEqual(err.name, 'HTTPError');
101
+ })
102
+ .on('received', function(data) {
103
+ if (data.batch === 3) {
104
+ assert.strictEqual(data.length, 2); // smaller last batch
105
+ } else {
106
+ assert.strictEqual(data.length, 3);
107
+ }
108
+ })
109
+ .on('finished', function(data) {
110
+ assert.strictEqual(data.total, 11);
111
+ assert.ok(couch.isDone());
112
+ done();
113
+ });
114
+ });
115
+
116
+ it('should fail to perform a shallow backup on fatal error', function(done) {
117
+ const couch = nock(dbUrl)
118
+ // batch 1
119
+ .post('/_all_docs', { limit: 3, include_docs: true })
120
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_1.json', 'utf8')))
121
+ // batch 2
122
+ .post('/_all_docs', { limit: 3, start_key: badgerKey, include_docs: true })
123
+ .reply(200, JSON.parse(fs.readFileSync('./test/fixtures/animaldb_all_docs_2.json', 'utf8')))
124
+ // batch 3 - fatal error
125
+ .post('/_all_docs', { limit: 3, start_key: kookaburraKey, include_docs: true })
126
+ .reply(401, { error: 'Unauthorized' });
127
+
128
+ let errCount = 0;
129
+
130
+ shallowBackup(dbUrl, { bufferSize: 3, parallelism: 1 })
131
+ .on('error', function(err) {
132
+ errCount++;
133
+ assert.strictEqual(err.name, 'Unauthorized');
134
+ })
135
+ .on('received', function(data) {
136
+ assert.strictEqual(data.length, 3);
137
+ })
138
+ .on('finished', function(data) {
139
+ assert.strictEqual(data.total, 6);
140
+ assert.ok(couch.isDone());
141
+ assert.strictEqual(errCount, 1);
142
+ done();
143
+ });
144
+ });
145
+ });
@@ -0,0 +1,147 @@
1
+ // Copyright © 2017, 2021 IBM Corp. All rights reserved.
2
+ //
3
+ // Licensed under the Apache License, Version 2.0 (the "License");
4
+ // you may not use this file except in compliance with the License.
5
+ // You may obtain a copy of the License at
6
+ //
7
+ // http://www.apache.org/licenses/LICENSE-2.0
8
+ //
9
+ // Unless required by applicable law or agreed to in writing, software
10
+ // distributed under the License is distributed on an "AS IS" BASIS,
11
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ // See the License for the specific language governing permissions and
13
+ // limitations under the License.
14
+
15
+ /* global describe it beforeEach */
16
+ 'use strict';
17
+
18
+ const assert = require('assert');
19
+ const fs = require('fs');
20
+ const nock = require('nock');
21
+ const request = require('../includes/request.js');
22
+ const writer = require('../includes/writer.js');
23
+ const noopEmitter = new (require('events')).EventEmitter();
24
+ const liner = require('../includes/liner.js');
25
+
26
+ const longTestTimeout = 3000;
27
+
28
+ // The writer expects a line-by-line stream so this utility function does that
29
+ // processing for the tests (which normally happens in the internal restore
30
+ // function).
31
+ function testLinestream(fixture = './test/fixtures/animaldb_expected.json') {
32
+ return fs.createReadStream(fixture)
33
+ .pipe(liner());
34
+ }
35
+
36
+ describe('#unit Check database restore writer', function() {
37
+ const dbUrl = 'http://localhost:5984/animaldb';
38
+ const db = request.client(dbUrl, { parallelism: 1 });
39
+
40
+ beforeEach('Reset nocks', function() {
41
+ nock.cleanAll();
42
+ });
43
+
44
+ it('should complete successfully', function(done) {
45
+ nock(dbUrl)
46
+ .post('/_bulk_docs')
47
+ .reply(200, []); // success
48
+
49
+ testLinestream()
50
+ .pipe(writer(db, 500, 1, noopEmitter))
51
+ .on('error', function(err) {
52
+ done(err);
53
+ })
54
+ .on('finished', function(data) {
55
+ assert.strictEqual(data.total, 15);
56
+ assert.ok(nock.isDone());
57
+ done();
58
+ });
59
+ });
60
+
61
+ it('should terminate on a fatal error', function(done) {
62
+ nock(dbUrl)
63
+ .post('/_bulk_docs')
64
+ .reply(401, { error: 'Unauthorized' }); // fatal error
65
+
66
+ testLinestream()
67
+ .pipe(writer(db, 500, 1, noopEmitter))
68
+ .on('error', function(err) {
69
+ assert.strictEqual(err.name, 'Unauthorized');
70
+ assert.strictEqual(err.message, 'Access is denied due to invalid credentials.');
71
+ assert.ok(nock.isDone());
72
+ done();
73
+ });
74
+ });
75
+
76
+ it('should retry on transient errors', function(done) {
77
+ nock(dbUrl)
78
+ .post('/_bulk_docs')
79
+ .reply(429, { error: 'Too Many Requests' }) // transient error
80
+ .post('/_bulk_docs')
81
+ .reply(500, { error: 'Internal Server Error' }) // transient error
82
+ .post('/_bulk_docs')
83
+ .reply(200, { ok: true }); // third time lucky success
84
+
85
+ testLinestream()
86
+ .pipe(writer(db, 500, 1, noopEmitter))
87
+ .on('error', function(err) {
88
+ done(err);
89
+ })
90
+ .on('finished', function(data) {
91
+ assert.strictEqual(data.total, 15);
92
+ assert.ok(nock.isDone());
93
+ done();
94
+ });
95
+ }).timeout(longTestTimeout);
96
+
97
+ it('should fail after 3 transient errors', function(done) {
98
+ nock(dbUrl)
99
+ .post('/_bulk_docs')
100
+ .reply(429, { error: 'Too Many Requests' }) // transient error
101
+ .post('/_bulk_docs')
102
+ .reply(500, { error: 'Internal Server Error' }) // transient error
103
+ .post('/_bulk_docs')
104
+ .reply(503, { error: 'Service Unavailable' }); // Final transient error
105
+
106
+ testLinestream()
107
+ .pipe(writer(db, 500, 1, noopEmitter))
108
+ .on('error', function(err) {
109
+ assert.strictEqual(err.name, 'HTTPFatalError');
110
+ assert.strictEqual(err.message, `503 : post ${dbUrl}/_bulk_docs - Error: Service Unavailable`);
111
+ assert.ok(nock.isDone());
112
+ done();
113
+ });
114
+ }).timeout(longTestTimeout);
115
+
116
+ it('should restore shallow backups without rev info successfully', function(done) {
117
+ nock(dbUrl)
118
+ .post('/_bulk_docs')
119
+ .reply(200, [{ ok: true, id: 'foo', rev: '1-abc' }]); // success
120
+
121
+ testLinestream('./test/fixtures/animaldb_old_shallow.json')
122
+ .pipe(writer(db, 500, 1, noopEmitter))
123
+ .on('error', function(err) {
124
+ done(err);
125
+ })
126
+ .on('finished', function(data) {
127
+ assert.strictEqual(data.total, 11);
128
+ assert.ok(nock.isDone());
129
+ done();
130
+ });
131
+ });
132
+
133
+ it('should get a batch error for non-empty array response with new_edits false', function(done) {
134
+ nock(dbUrl)
135
+ .post('/_bulk_docs')
136
+ .reply(200, [{ id: 'foo', error: 'foo', reason: 'bar' }]);
137
+
138
+ testLinestream()
139
+ .pipe(writer(db, 500, 1, noopEmitter))
140
+ .on('error', function(err) {
141
+ assert.strictEqual(err.name, 'Error');
142
+ assert.strictEqual(err.message, 'Error writing batch with new_edits:false and 1 items');
143
+ assert.ok(nock.isDone());
144
+ done();
145
+ });
146
+ });
147
+ });
@@ -16,19 +16,18 @@
16
16
  'use strict';
17
17
 
18
18
  const assert = require('assert');
19
- const logfilegetbatches = require('../includes/logfilegetbatches.js');
19
+ const logfilesummary = require('../includes/logfilesummary.js');
20
20
 
21
- describe('#unit Fetching batches from a log file', function() {
22
- it('should fetch multiple batches correctly', function(done) {
23
- logfilegetbatches('./test/fixtures/test.log', [1, 4], function(err, data) {
21
+ describe('#unit Fetching summary from the log file', function() {
22
+ it('should fetch a summary correctly', function(done) {
23
+ logfilesummary('./test/fixtures/test.log', function(err, data) {
24
24
  assert.ok(!err);
25
25
  assert.ok(data);
26
- assert.strictEqual(typeof data, 'object');
27
- assert.strictEqual(Object.keys(data).length, 2);
28
- assert.deepStrictEqual(data['1'].docs, [{ id: '6' }, { id: '7' }, { id: '8' }, { id: '9' }, { id: '10' }]);
29
- assert.strictEqual(data['1'].batch, 1);
30
- assert.deepStrictEqual(data['4'].docs, [{ id: '21' }, { id: '22' }]);
31
- assert.strictEqual(data['4'].batch, 4);
26
+ assert.strictEqual(data.changesComplete, true);
27
+ assert.strictEqual(typeof data.batches, 'object');
28
+ assert.strictEqual(Object.keys(data.batches).length, 2);
29
+ assert.deepStrictEqual(data.batches['1'], true);
30
+ assert.deepStrictEqual(data.batches['4'], true);
32
31
  done();
33
32
  });
34
33
  });