@cloudant/couchbackup 2.9.8 → 2.9.9-SNAPSHOT.96

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 (438) 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-11.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-12.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-13.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-14.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-15.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-16.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-17.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-18.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-2.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-3.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-59.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-62.pb +1 -0
  22. package/.scannerwork/scanner-report/changesets-63.pb +1 -0
  23. package/.scannerwork/scanner-report/changesets-64.pb +1 -0
  24. package/.scannerwork/scanner-report/changesets-8.pb +1 -0
  25. package/.scannerwork/scanner-report/changesets-9.pb +1 -0
  26. package/.scannerwork/scanner-report/component-1.pb +2 -1
  27. package/.scannerwork/scanner-report/component-10.pb +2 -0
  28. package/.scannerwork/scanner-report/component-11.pb +1 -0
  29. package/.scannerwork/scanner-report/component-12.pb +1 -0
  30. package/.scannerwork/scanner-report/component-13.pb +1 -0
  31. package/.scannerwork/scanner-report/component-14.pb +1 -0
  32. package/.scannerwork/scanner-report/component-15.pb +1 -0
  33. package/.scannerwork/scanner-report/component-16.pb +1 -0
  34. package/.scannerwork/scanner-report/component-17.pb +1 -0
  35. package/.scannerwork/scanner-report/component-18.pb +1 -0
  36. package/.scannerwork/scanner-report/component-2.pb +1 -0
  37. package/.scannerwork/scanner-report/component-23.pb +1 -1
  38. package/.scannerwork/scanner-report/component-24.pb +1 -1
  39. package/.scannerwork/scanner-report/component-28.pb +1 -1
  40. package/.scannerwork/scanner-report/component-29.pb +1 -1
  41. package/.scannerwork/scanner-report/component-3.pb +1 -0
  42. package/.scannerwork/scanner-report/component-30.pb +1 -1
  43. package/.scannerwork/scanner-report/component-31.pb +1 -1
  44. package/.scannerwork/scanner-report/component-32.pb +1 -1
  45. package/.scannerwork/scanner-report/component-33.pb +1 -1
  46. package/.scannerwork/scanner-report/component-34.pb +1 -1
  47. package/.scannerwork/scanner-report/component-35.pb +1 -1
  48. package/.scannerwork/scanner-report/component-36.pb +1 -1
  49. package/.scannerwork/scanner-report/component-37.pb +1 -1
  50. package/.scannerwork/scanner-report/component-38.pb +1 -1
  51. package/.scannerwork/scanner-report/component-39.pb +1 -0
  52. package/.scannerwork/scanner-report/component-5.pb +1 -1
  53. package/.scannerwork/scanner-report/component-51.pb +1 -1
  54. package/.scannerwork/scanner-report/component-52.pb +1 -1
  55. package/.scannerwork/scanner-report/component-53.pb +1 -1
  56. package/.scannerwork/scanner-report/component-54.pb +1 -1
  57. package/.scannerwork/scanner-report/component-55.pb +1 -1
  58. package/.scannerwork/scanner-report/component-56.pb +1 -0
  59. package/.scannerwork/scanner-report/component-57.pb +1 -1
  60. package/.scannerwork/scanner-report/component-58.pb +1 -1
  61. package/.scannerwork/scanner-report/component-59.pb +1 -1
  62. package/.scannerwork/scanner-report/component-6.pb +1 -1
  63. package/.scannerwork/scanner-report/component-60.pb +1 -0
  64. package/.scannerwork/scanner-report/component-61.pb +1 -1
  65. package/.scannerwork/scanner-report/component-62.pb +1 -0
  66. package/.scannerwork/scanner-report/component-63.pb +1 -0
  67. package/.scannerwork/scanner-report/component-64.pb +1 -0
  68. package/.scannerwork/scanner-report/component-65.pb +1 -1
  69. package/.scannerwork/scanner-report/component-69.pb +1 -1
  70. package/.scannerwork/scanner-report/component-7.pb +1 -1
  71. package/.scannerwork/scanner-report/component-70.pb +1 -0
  72. package/.scannerwork/scanner-report/component-8.pb +1 -0
  73. package/.scannerwork/scanner-report/component-9.pb +1 -0
  74. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-2.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-23.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-31.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-32.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-34.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-38.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-51.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  99. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  100. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  101. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  102. package/.scannerwork/scanner-report/duplications-23.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-24.pb +2 -0
  104. package/.scannerwork/scanner-report/duplications-32.pb +0 -2
  105. package/.scannerwork/scanner-report/duplications-33.pb +2 -0
  106. package/.scannerwork/scanner-report/duplications-36.pb +0 -2
  107. package/.scannerwork/scanner-report/duplications-5.pb +0 -3
  108. package/.scannerwork/scanner-report/duplications-52.pb +3 -0
  109. package/.scannerwork/scanner-report/duplications-53.pb +3 -0
  110. package/.scannerwork/scanner-report/duplications-57.pb +2 -0
  111. package/.scannerwork/scanner-report/duplications-6.pb +2 -0
  112. package/.scannerwork/scanner-report/duplications-60.pb +3 -0
  113. package/.scannerwork/scanner-report/duplications-62.pb +0 -0
  114. package/.scannerwork/scanner-report/duplications-63.pb +0 -0
  115. package/.scannerwork/scanner-report/duplications-64.pb +0 -0
  116. package/.scannerwork/scanner-report/duplications-8.pb +0 -0
  117. package/.scannerwork/scanner-report/duplications-9.pb +2 -0
  118. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-23.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-29.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-3.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-31.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-32.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-58.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-61.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-65.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-69.pb +0 -0
  153. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  154. package/.scannerwork/scanner-report/measures-70.pb +0 -0
  155. package/.scannerwork/scanner-report/metadata.pb +0 -0
  156. package/.scannerwork/scanner-report/source-11.txt +111 -0
  157. package/.scannerwork/scanner-report/source-13.txt +164 -0
  158. package/.scannerwork/scanner-report/source-16.txt +80 -0
  159. package/.scannerwork/scanner-report/source-18.txt +46 -0
  160. package/.scannerwork/scanner-report/source-2.txt +114 -0
  161. package/.scannerwork/scanner-report/source-23.txt +162 -64
  162. package/.scannerwork/scanner-report/source-24.txt +133 -583
  163. package/.scannerwork/scanner-report/source-28.txt +509 -142
  164. package/.scannerwork/scanner-report/source-29.txt +509 -366
  165. package/.scannerwork/scanner-report/source-3.txt +418 -0
  166. package/.scannerwork/scanner-report/source-30.txt +39 -19
  167. package/.scannerwork/scanner-report/source-31.txt +57 -80
  168. package/.scannerwork/scanner-report/source-32.txt +16 -127
  169. package/.scannerwork/scanner-report/source-33.txt +189 -120
  170. package/.scannerwork/scanner-report/source-34.txt +596 -39
  171. package/.scannerwork/scanner-report/source-35.txt +17 -129
  172. package/.scannerwork/scanner-report/source-36.txt +43 -200
  173. package/.scannerwork/scanner-report/source-37.txt +15 -93
  174. package/.scannerwork/scanner-report/source-38.txt +92 -167
  175. package/.scannerwork/scanner-report/source-39.txt +366 -0
  176. package/.scannerwork/scanner-report/source-5.txt +89 -229
  177. package/.scannerwork/scanner-report/source-51.txt +135 -59
  178. package/.scannerwork/scanner-report/source-52.txt +228 -95
  179. package/.scannerwork/scanner-report/source-53.txt +104 -31
  180. package/.scannerwork/scanner-report/source-54.txt +130 -147
  181. package/.scannerwork/scanner-report/source-55.txt +100 -509
  182. package/.scannerwork/scanner-report/source-57.txt +120 -52
  183. package/.scannerwork/scanner-report/source-58.txt +31 -40
  184. package/.scannerwork/scanner-report/source-59.txt +36 -509
  185. package/.scannerwork/scanner-report/source-6.txt +71 -47
  186. package/.scannerwork/scanner-report/source-61.txt +293 -509
  187. package/.scannerwork/scanner-report/source-62.txt +142 -0
  188. package/.scannerwork/scanner-report/source-64.txt +68 -0
  189. package/.scannerwork/scanner-report/source-65.txt +509 -190
  190. package/.scannerwork/scanner-report/source-69.txt +509 -418
  191. package/.scannerwork/scanner-report/source-7.txt +38 -31
  192. package/.scannerwork/scanner-report/source-70.txt +167 -0
  193. package/.scannerwork/scanner-report/symbols-11.pb +59 -0
  194. package/.scannerwork/scanner-report/symbols-13.pb +126 -0
  195. package/.scannerwork/scanner-report/symbols-16.pb +46 -0
  196. package/.scannerwork/scanner-report/symbols-18.pb +20 -0
  197. package/.scannerwork/scanner-report/symbols-2.pb +28 -0
  198. package/.scannerwork/scanner-report/symbols-23.pb +180 -60
  199. package/.scannerwork/scanner-report/symbols-24.pb +143 -1244
  200. package/.scannerwork/scanner-report/symbols-30.pb +19 -14
  201. package/.scannerwork/scanner-report/symbols-31.pb +29 -68
  202. package/.scannerwork/scanner-report/symbols-32.pb +10 -102
  203. package/.scannerwork/scanner-report/symbols-33.pb +410 -104
  204. package/.scannerwork/scanner-report/symbols-34.pb +1251 -33
  205. package/.scannerwork/scanner-report/symbols-35.pb +17 -85
  206. package/.scannerwork/scanner-report/symbols-36.pb +35 -417
  207. package/.scannerwork/scanner-report/symbols-37.pb +11 -28
  208. package/.scannerwork/scanner-report/symbols-38.pb +60 -0
  209. package/.scannerwork/scanner-report/symbols-5.pb +41 -393
  210. package/.scannerwork/scanner-report/symbols-51.pb +110 -44
  211. package/.scannerwork/scanner-report/symbols-52.pb +393 -58
  212. package/.scannerwork/scanner-report/symbols-53.pb +76 -19
  213. package/.scannerwork/scanner-report/symbols-54.pb +80 -121
  214. package/.scannerwork/scanner-report/symbols-55.pb +69 -0
  215. package/.scannerwork/scanner-report/symbols-57.pb +102 -30
  216. package/.scannerwork/scanner-report/symbols-58.pb +27 -19
  217. package/.scannerwork/scanner-report/symbols-59.pb +14 -0
  218. package/.scannerwork/scanner-report/symbols-6.pb +43 -44
  219. package/.scannerwork/scanner-report/symbols-64.pb +45 -0
  220. package/.scannerwork/scanner-report/symbols-7.pb +15 -27
  221. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +133 -0
  222. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +213 -0
  223. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +95 -0
  224. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +64 -0
  225. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +138 -0
  226. package/.scannerwork/scanner-report/syntax-highlightings-23.pb +186 -71
  227. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +142 -815
  228. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +3736 -123
  229. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +3504 -385
  230. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +648 -0
  231. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +63 -35
  232. package/.scannerwork/scanner-report/syntax-highlightings-31.pb +73 -75
  233. package/.scannerwork/scanner-report/syntax-highlightings-32.pb +14 -191
  234. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +270 -162
  235. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +849 -57
  236. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +27 -155
  237. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +58 -294
  238. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +24 -103
  239. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +99 -937
  240. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +630 -0
  241. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +85 -298
  242. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +190 -62
  243. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +292 -96
  244. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +127 -33
  245. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +151 -173
  246. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +94 -3735
  247. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +200 -76
  248. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +45 -59
  249. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +43 -3736
  250. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +56 -76
  251. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +398 -3487
  252. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +134 -0
  253. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +110 -0
  254. package/.scannerwork/scanner-report/syntax-highlightings-65.pb +3725 -202
  255. package/.scannerwork/scanner-report/syntax-highlightings-69.pb +3544 -445
  256. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +24 -38
  257. package/.scannerwork/scanner-report/syntax-highlightings-70.pb +949 -0
  258. package/package.json +1 -1
  259. package/test-14-results.xml +158 -158
  260. package/test-16-results.xml +139 -139
  261. package/test-18-results.xml +155 -155
  262. package/test-19-results.xml +151 -151
  263. package/test-iam-18-results.xml +50 -50
  264. package/.scannerwork/scanner-report/changesets-19.pb +0 -1
  265. package/.scannerwork/scanner-report/changesets-20.pb +0 -1
  266. package/.scannerwork/scanner-report/changesets-21.pb +0 -1
  267. package/.scannerwork/scanner-report/changesets-22.pb +0 -1
  268. package/.scannerwork/scanner-report/changesets-25.pb +0 -1
  269. package/.scannerwork/scanner-report/changesets-26.pb +0 -1
  270. package/.scannerwork/scanner-report/changesets-27.pb +0 -1
  271. package/.scannerwork/scanner-report/changesets-28.pb +0 -1
  272. package/.scannerwork/scanner-report/changesets-29.pb +0 -1
  273. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  274. package/.scannerwork/scanner-report/changesets-41.pb +0 -1
  275. package/.scannerwork/scanner-report/changesets-42.pb +0 -1
  276. package/.scannerwork/scanner-report/changesets-43.pb +0 -1
  277. package/.scannerwork/scanner-report/changesets-44.pb +0 -1
  278. package/.scannerwork/scanner-report/changesets-45.pb +0 -1
  279. package/.scannerwork/scanner-report/changesets-46.pb +0 -1
  280. package/.scannerwork/scanner-report/changesets-47.pb +0 -1
  281. package/.scannerwork/scanner-report/changesets-48.pb +0 -1
  282. package/.scannerwork/scanner-report/changesets-49.pb +0 -1
  283. package/.scannerwork/scanner-report/changesets-50.pb +0 -1
  284. package/.scannerwork/scanner-report/changesets-65.pb +0 -1
  285. package/.scannerwork/scanner-report/changesets-66.pb +0 -1
  286. package/.scannerwork/scanner-report/changesets-69.pb +0 -1
  287. package/.scannerwork/scanner-report/component-19.pb +0 -1
  288. package/.scannerwork/scanner-report/component-20.pb +0 -1
  289. package/.scannerwork/scanner-report/component-21.pb +0 -1
  290. package/.scannerwork/scanner-report/component-22.pb +0 -1
  291. package/.scannerwork/scanner-report/component-25.pb +0 -1
  292. package/.scannerwork/scanner-report/component-26.pb +0 -1
  293. package/.scannerwork/scanner-report/component-27.pb +0 -1
  294. package/.scannerwork/scanner-report/component-4.pb +0 -1
  295. package/.scannerwork/scanner-report/component-40.pb +0 -1
  296. package/.scannerwork/scanner-report/component-41.pb +0 -1
  297. package/.scannerwork/scanner-report/component-42.pb +0 -1
  298. package/.scannerwork/scanner-report/component-43.pb +0 -1
  299. package/.scannerwork/scanner-report/component-44.pb +0 -1
  300. package/.scannerwork/scanner-report/component-45.pb +0 -1
  301. package/.scannerwork/scanner-report/component-46.pb +0 -1
  302. package/.scannerwork/scanner-report/component-47.pb +0 -1
  303. package/.scannerwork/scanner-report/component-48.pb +0 -1
  304. package/.scannerwork/scanner-report/component-49.pb +0 -1
  305. package/.scannerwork/scanner-report/component-50.pb +0 -1
  306. package/.scannerwork/scanner-report/component-66.pb +0 -1
  307. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  308. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  309. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  310. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  311. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  312. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  313. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  314. package/.scannerwork/scanner-report/coverages-65.pb +0 -0
  315. package/.scannerwork/scanner-report/coverages-66.pb +0 -0
  316. package/.scannerwork/scanner-report/duplications-19.pb +0 -3
  317. package/.scannerwork/scanner-report/duplications-22.pb +0 -3
  318. package/.scannerwork/scanner-report/duplications-43.pb +0 -2
  319. package/.scannerwork/scanner-report/duplications-45.pb +0 -2
  320. package/.scannerwork/scanner-report/duplications-65.pb +0 -2
  321. package/.scannerwork/scanner-report/duplications-66.pb +0 -2
  322. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  323. package/.scannerwork/scanner-report/measures-21.pb +0 -15
  324. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  325. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  326. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  327. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  328. package/.scannerwork/scanner-report/measures-42.pb +0 -15
  329. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  330. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  331. package/.scannerwork/scanner-report/measures-66.pb +0 -0
  332. package/.scannerwork/scanner-report/source-20.txt +0 -35
  333. package/.scannerwork/scanner-report/source-21.txt +0 -293
  334. package/.scannerwork/scanner-report/source-22.txt +0 -119
  335. package/.scannerwork/scanner-report/source-27.txt +0 -36
  336. package/.scannerwork/scanner-report/source-4.txt +0 -34
  337. package/.scannerwork/scanner-report/source-40.txt +0 -509
  338. package/.scannerwork/scanner-report/source-42.txt +0 -104
  339. package/.scannerwork/scanner-report/source-43.txt +0 -92
  340. package/.scannerwork/scanner-report/source-46.txt +0 -54
  341. package/.scannerwork/scanner-report/source-66.txt +0 -175
  342. package/.scannerwork/scanner-report/symbols-20.pb +0 -17
  343. package/.scannerwork/scanner-report/symbols-22.pb +0 -77
  344. package/.scannerwork/scanner-report/symbols-27.pb +0 -11
  345. package/.scannerwork/scanner-report/symbols-4.pb +0 -10
  346. package/.scannerwork/scanner-report/symbols-42.pb +0 -42
  347. package/.scannerwork/scanner-report/symbols-43.pb +0 -44
  348. package/.scannerwork/scanner-report/symbols-46.pb +0 -15
  349. package/.scannerwork/scanner-report/symbols-65.pb +0 -180
  350. package/.scannerwork/scanner-report/symbols-66.pb +0 -153
  351. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -63
  352. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -659
  353. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +0 -158
  354. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +0 -59
  355. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -50
  356. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +0 -3749
  357. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +0 -116
  358. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +0 -90
  359. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +0 -54
  360. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +0 -214
  361. /package/.scannerwork/scanner-report/{coverages-49.pb → coverages-10.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{coverages-44.pb → coverages-12.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{coverages-41.pb → coverages-14.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{coverages-47.pb → coverages-15.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{coverages-48.pb → coverages-17.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{coverages-69.pb → coverages-3.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{coverages-29.pb → coverages-39.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{coverages-25.pb → coverages-56.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{coverages-19.pb → coverages-60.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{coverages-21.pb → coverages-61.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{coverages-28.pb → coverages-62.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{coverages-26.pb → coverages-63.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{coverages-50.pb → coverages-8.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{coverages-45.pb → coverages-9.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-10.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{duplications-26.pb → duplications-11.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{duplications-27.pb → duplications-12.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{duplications-28.pb → duplications-13.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{duplications-29.pb → duplications-14.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-15.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{duplications-41.pb → duplications-16.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{duplications-42.pb → duplications-17.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{duplications-44.pb → duplications-18.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{duplications-46.pb → duplications-2.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{duplications-47.pb → duplications-3.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{duplications-48.pb → duplications-38.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{duplications-49.pb → duplications-39.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-55.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{duplications-69.pb → duplications-59.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{duplications-21.pb → duplications-61.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{issues-29.pb → issues-39.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{issues-5.pb → issues-52.pb} +0 -0
  393. /package/.scannerwork/scanner-report/{issues-7.pb → issues-58.pb} +0 -0
  394. /package/.scannerwork/scanner-report/{issues-28.pb → issues-62.pb} +0 -0
  395. /package/.scannerwork/scanner-report/{measures-49.pb → measures-10.pb} +0 -0
  396. /package/.scannerwork/scanner-report/{measures-44.pb → measures-12.pb} +0 -0
  397. /package/.scannerwork/scanner-report/{measures-41.pb → measures-14.pb} +0 -0
  398. /package/.scannerwork/scanner-report/{measures-47.pb → measures-15.pb} +0 -0
  399. /package/.scannerwork/scanner-report/{measures-48.pb → measures-17.pb} +0 -0
  400. /package/.scannerwork/scanner-report/{measures-25.pb → measures-56.pb} +0 -0
  401. /package/.scannerwork/scanner-report/{measures-19.pb → measures-60.pb} +0 -0
  402. /package/.scannerwork/scanner-report/{measures-26.pb → measures-63.pb} +0 -0
  403. /package/.scannerwork/scanner-report/{measures-50.pb → measures-8.pb} +0 -0
  404. /package/.scannerwork/scanner-report/{measures-45.pb → measures-9.pb} +0 -0
  405. /package/.scannerwork/scanner-report/{source-49.txt → source-10.txt} +0 -0
  406. /package/.scannerwork/scanner-report/{source-44.txt → source-12.txt} +0 -0
  407. /package/.scannerwork/scanner-report/{source-41.txt → source-14.txt} +0 -0
  408. /package/.scannerwork/scanner-report/{source-47.txt → source-15.txt} +0 -0
  409. /package/.scannerwork/scanner-report/{source-48.txt → source-17.txt} +0 -0
  410. /package/.scannerwork/scanner-report/{source-25.txt → source-56.txt} +0 -0
  411. /package/.scannerwork/scanner-report/{source-19.txt → source-60.txt} +0 -0
  412. /package/.scannerwork/scanner-report/{source-26.txt → source-63.txt} +0 -0
  413. /package/.scannerwork/scanner-report/{source-50.txt → source-8.txt} +0 -0
  414. /package/.scannerwork/scanner-report/{source-45.txt → source-9.txt} +0 -0
  415. /package/.scannerwork/scanner-report/{symbols-49.pb → symbols-10.pb} +0 -0
  416. /package/.scannerwork/scanner-report/{symbols-44.pb → symbols-12.pb} +0 -0
  417. /package/.scannerwork/scanner-report/{symbols-41.pb → symbols-14.pb} +0 -0
  418. /package/.scannerwork/scanner-report/{symbols-47.pb → symbols-15.pb} +0 -0
  419. /package/.scannerwork/scanner-report/{symbols-48.pb → symbols-17.pb} +0 -0
  420. /package/.scannerwork/scanner-report/{symbols-69.pb → symbols-3.pb} +0 -0
  421. /package/.scannerwork/scanner-report/{symbols-29.pb → symbols-39.pb} +0 -0
  422. /package/.scannerwork/scanner-report/{symbols-25.pb → symbols-56.pb} +0 -0
  423. /package/.scannerwork/scanner-report/{symbols-19.pb → symbols-60.pb} +0 -0
  424. /package/.scannerwork/scanner-report/{symbols-21.pb → symbols-61.pb} +0 -0
  425. /package/.scannerwork/scanner-report/{symbols-28.pb → symbols-62.pb} +0 -0
  426. /package/.scannerwork/scanner-report/{symbols-26.pb → symbols-63.pb} +0 -0
  427. /package/.scannerwork/scanner-report/{symbols-50.pb → symbols-8.pb} +0 -0
  428. /package/.scannerwork/scanner-report/{symbols-45.pb → symbols-9.pb} +0 -0
  429. /package/.scannerwork/scanner-report/{syntax-highlightings-49.pb → syntax-highlightings-10.pb} +0 -0
  430. /package/.scannerwork/scanner-report/{syntax-highlightings-44.pb → syntax-highlightings-12.pb} +0 -0
  431. /package/.scannerwork/scanner-report/{syntax-highlightings-41.pb → syntax-highlightings-14.pb} +0 -0
  432. /package/.scannerwork/scanner-report/{syntax-highlightings-47.pb → syntax-highlightings-15.pb} +0 -0
  433. /package/.scannerwork/scanner-report/{syntax-highlightings-48.pb → syntax-highlightings-17.pb} +0 -0
  434. /package/.scannerwork/scanner-report/{syntax-highlightings-25.pb → syntax-highlightings-56.pb} +0 -0
  435. /package/.scannerwork/scanner-report/{syntax-highlightings-19.pb → syntax-highlightings-60.pb} +0 -0
  436. /package/.scannerwork/scanner-report/{syntax-highlightings-26.pb → syntax-highlightings-63.pb} +0 -0
  437. /package/.scannerwork/scanner-report/{syntax-highlightings-50.pb → syntax-highlightings-8.pb} +0 -0
  438. /package/.scannerwork/scanner-report/{syntax-highlightings-45.pb → syntax-highlightings-9.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2022 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,101 +11,234 @@
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 beforeEach */
14
16
  'use strict';
15
17
 
16
- const fs = require('fs');
17
- const liner = require('./liner.js');
18
- const change = require('./change.js');
19
- const error = require('./error.js');
20
- const debug = require('debug')('couchbackup:spoolchanges');
21
-
22
- /**
23
- * Write log file for all changes from a database, ready for downloading
24
- * in batches.
25
- *
26
- * @param {string} dbUrl - URL of database
27
- * @param {string} log - path to log file to use
28
- * @param {number} bufferSize - the number of changes per batch/log line
29
- * @param {function(err)} callback - a callback to run on completion
30
- */
31
- module.exports = function(db, log, bufferSize, ee, callback) {
32
- // list of document ids to process
33
- const buffer = [];
34
- let batch = 0;
35
- let lastSeq = null;
36
- const logStream = fs.createWriteStream(log);
37
- let pending = 0;
38
- // The number of changes to fetch per request
39
- const limit = 100000;
40
-
41
- // send documents ids to the queue in batches of bufferSize + the last batch
42
- const processBuffer = function(lastOne) {
43
- if (buffer.length >= bufferSize || (lastOne && buffer.length > 0)) {
44
- debug('writing', buffer.length, 'changes to the backup file');
45
- const b = { docs: buffer.splice(0, bufferSize), batch: batch };
46
- logStream.write(':t batch' + batch + ' ' + JSON.stringify(b.docs) + '\n');
47
- ee.emit('changes', batch);
48
- batch++;
49
- }
50
- };
51
-
52
- // called once per received change
53
- const onChange = function(c) {
54
- if (c) {
55
- if (c.error) {
56
- ee.emit('error', new error.BackupError('InvalidChange', `Received invalid change: ${c}`));
57
- } else if (c.changes) {
58
- const obj = { id: c.id };
59
- buffer.push(obj);
60
- processBuffer(false);
61
- } else if (c.last_seq) {
62
- lastSeq = c.last_seq;
63
- pending = c.pending;
64
- }
65
- }
66
- };
67
-
68
- function getChanges(since = 0) {
69
- debug('making changes request since ' + since);
70
- return db.service.postChangesAsStream({ db: db.db, since: since, limit: limit, seqInterval: limit })
71
- .then(response => {
72
- response.result.pipe(liner())
73
- .on('error', function(err) {
74
- logStream.end();
75
- callback(err);
76
- })
77
- .pipe(change(onChange))
78
- .on('error', function(err) {
79
- logStream.end();
80
- callback(err);
81
- })
82
- .on('finish', function() {
83
- processBuffer(true);
84
- if (!lastSeq) {
85
- logStream.end();
86
- debug('changes request terminated before last_seq was sent');
87
- callback(new error.BackupError('SpoolChangesError', 'Changes request terminated before last_seq was sent'));
88
- } else {
89
- debug(`changes request completed with last_seq: ${lastSeq} and ${pending} changes pending.`);
90
- if (pending > 0) {
91
- // Return the next promise
92
- return getChanges(lastSeq);
93
- } else {
94
- debug('finished streaming database changes');
95
- logStream.end(':changes_complete ' + lastSeq + '\n', 'utf8', callback);
96
- }
97
- }
98
- });
99
- })
100
- .catch(err => {
101
- logStream.end();
102
- if (err.status && err.status >= 400) {
103
- callback(error.convertResponseError(err));
104
- } else if (err.name !== 'SpoolChangesError') {
105
- callback(new error.BackupError('SpoolChangesError', `Failed changes request - ${err.message}`));
106
- }
18
+ const assert = require('assert');
19
+ const nock = require('nock');
20
+ const request = require('../includes/request.js');
21
+ const error = require('../includes/error.js');
22
+
23
+ const url = 'http://localhost:7777/testdb';
24
+ const db = request.client(url, { parallelism: 1 });
25
+ const timeoutDb = request.client(url, { parallelism: 1, requestTimeout: 500 });
26
+ const longTestTimeout = 3000;
27
+
28
+ beforeEach('Clean nock', function() {
29
+ nock.cleanAll();
30
+ });
31
+
32
+ describe('#unit Check request headers', function() {
33
+ it('should have a couchbackup user-agent', function(done) {
34
+ const couch = nock(url)
35
+ .matchHeader('user-agent', /couchbackup-cloudant\/\d+\.\d+\.\d+(?:-SNAPSHOT)? \(Node.js v\d+\.\d+\.\d+\)/)
36
+ .head('/good')
37
+ .reply(200);
38
+
39
+ db.service.headDocument({ db: db.db, docId: 'good' }).then(response => {
40
+ assert.ok(couch.isDone());
41
+ done();
42
+ }).catch(err => {
43
+ done(err);
44
+ });
45
+ });
46
+ });
47
+
48
+ describe('#unit Check request response error callback', function() {
49
+ it('should not callback with error for 200 response', function(done) {
50
+ const couch = nock(url)
51
+ .get('/good')
52
+ .reply(200, { ok: true });
53
+
54
+ db.service.getDocument({ db: db.db, docId: 'good' }).then(response => {
55
+ assert.ok(response.result);
56
+ assert.ok(couch.isDone());
57
+ done();
58
+ }).catch(err => {
59
+ err = error.convertResponseError(err);
60
+ done(err);
61
+ });
62
+ });
63
+
64
+ it('should callback with error after 3 500 responses', function(done) {
65
+ const couch = nock(url)
66
+ .get('/bad')
67
+ .times(3)
68
+ .reply(500, function(uri, requestBody) {
69
+ this.req.response.statusMessage = 'Internal Server Error';
70
+ return { error: 'foo', reason: 'bar' };
71
+ });
72
+
73
+ db.service.getDocument({ db: db.db, docId: 'bad' }).then(response => {
74
+ done(new Error('Successful response when error expected.'));
75
+ }).catch(err => {
76
+ err = error.convertResponseError(err);
77
+ assert.strictEqual(err.name, 'HTTPFatalError');
78
+ assert.strictEqual(err.message, `500 Internal Server Error: get ${url}/bad - Error: foo, Reason: bar`);
79
+ assert.ok(couch.isDone());
80
+ done();
81
+ }).catch(err => {
82
+ // Handle assertion errors
83
+ done(err);
84
+ });
85
+ }).timeout(longTestTimeout);
86
+
87
+ it('should callback with error after 3 POST 503 responses', function(done) {
88
+ const couch = nock(url)
89
+ .post('/_bulk_get')
90
+ .query(true)
91
+ .times(3)
92
+ .reply(503, function(uri, requestBody) {
93
+ this.req.response.statusMessage = 'Service Unavailable';
94
+ return { error: 'service_unavailable', reason: 'Service unavailable' };
95
+ });
96
+
97
+ db.service.postBulkGet({ db: db.db, revs: true, docs: [] }).then(response => {
98
+ done(new Error('Successful response when error expected.'));
99
+ }).catch(err => {
100
+ err = error.convertResponseError(err);
101
+ assert.strictEqual(err.name, 'HTTPFatalError');
102
+ assert.strictEqual(err.message, `503 Service Unavailable: post ${url}/_bulk_get - Error: service_unavailable, Reason: Service unavailable`);
103
+ assert.ok(couch.isDone());
104
+ done();
105
+ }).catch(err => {
106
+ // Handle assertion errors
107
+ done(err);
108
+ });
109
+ }).timeout(longTestTimeout);
110
+
111
+ it('should callback with error after 3 429 responses', function(done) {
112
+ const couch = nock(url)
113
+ .get('/bad')
114
+ .times(3)
115
+ .reply(429, function(uri, requestBody) {
116
+ this.req.response.statusMessage = 'Too Many Requests';
117
+ return { error: 'foo', reason: 'bar' };
118
+ });
119
+
120
+ db.service.getDocument({ db: db.db, docId: 'bad' }).then(response => {
121
+ done(new Error('Successful response when error expected.'));
122
+ }).catch(err => {
123
+ err = error.convertResponseError(err);
124
+ assert.strictEqual(err.name, 'HTTPFatalError');
125
+ assert.strictEqual(err.message, `429 Too Many Requests: get ${url}/bad - Error: foo, Reason: bar`);
126
+ assert.ok(couch.isDone());
127
+ done();
128
+ }).catch(err => {
129
+ // Handle assertion errors
130
+ done(err);
131
+ });
132
+ }).timeout(longTestTimeout);
133
+
134
+ it('should callback with fatal error for 404 response', function(done) {
135
+ const couch = nock(url)
136
+ .get('/bad')
137
+ .reply(404, function(uri, requestBody) {
138
+ this.req.response.statusMessage = 'Not Found';
139
+ return { error: 'foo', reason: 'bar' };
107
140
  });
108
- }
109
141
 
110
- getChanges();
111
- };
142
+ db.service.getDocument({ db: db.db, docId: 'bad' }).then(response => {
143
+ done(new Error('Successful response when error expected.'));
144
+ }).catch(err => {
145
+ err = error.convertResponseError(err);
146
+ assert.strictEqual(err.name, 'HTTPFatalError');
147
+ assert.strictEqual(err.message, `404 Not Found: get ${url}/bad - Error: foo, Reason: bar`);
148
+ assert.ok(couch.isDone());
149
+ done();
150
+ }).catch(err => {
151
+ // Handle assertion errors
152
+ done(err);
153
+ });
154
+ });
155
+
156
+ it('should callback with same error for no status code error response', function(done) {
157
+ const couch = nock(url)
158
+ .get('/bad')
159
+ .times(3)
160
+ .replyWithError('testing badness');
161
+
162
+ db.service.getDocument({ db: db.db, docId: 'bad' }).then(response => {
163
+ done(new Error('Successful response when error expected.'));
164
+ }).catch(err => {
165
+ const err2 = error.convertResponseError(err);
166
+ assert.strictEqual(err, err2);
167
+ assert.ok(couch.isDone());
168
+ done();
169
+ }).catch(err => {
170
+ // Handle assertion errors
171
+ done(err);
172
+ });
173
+ }).timeout(longTestTimeout);
174
+
175
+ it('should retry request if HTTP request gets timed out', function(done) {
176
+ const couch = nock(url)
177
+ .post('/_bulk_get')
178
+ .query(true)
179
+ .delay(1000)
180
+ .reply(200, { results: { docs: [{ id: '1', ok: { _id: '1' } }] } })
181
+ .post('/_bulk_get')
182
+ .query(true)
183
+ .reply(200, { results: { docs: [{ id: '1', ok: { _id: '1' } }, { id: '2', ok: { _id: '2' } }] } });
184
+
185
+ timeoutDb.service.postBulkGet({ db: db.db, revs: true, docs: [] }).then(response => {
186
+ assert.ok(response);
187
+ assert.ok(response.result);
188
+ assert.ok(response.result.results);
189
+ assert.ok(response.result.results.docs);
190
+ assert.strictEqual(response.result.results.docs.length, 2);
191
+ assert.ok(couch.isDone());
192
+ done();
193
+ }).catch(err => {
194
+ done(err);
195
+ });
196
+ });
197
+
198
+ it('should callback with error code ESOCKETTIMEDOUT if 3 HTTP requests gets timed out', function(done) {
199
+ // Increase the timeout for this test to allow for the delays
200
+ this.timeout(3000);
201
+ const couch = nock(url)
202
+ .post('/_bulk_get')
203
+ .query(true)
204
+ .delay(1000)
205
+ .times(3)
206
+ .reply(200, { ok: true });
207
+
208
+ timeoutDb.service.postBulkGet({ db: db.db, revs: true, docs: [] }).then(response => {
209
+ done(new Error('Successful response when error expected.'));
210
+ }).catch(err => {
211
+ err = error.convertResponseError(err);
212
+ // Note axios returns ECONNABORTED rather than ESOCKETTIMEDOUT
213
+ // See https://github.com/axios/axios/issues/2710 via https://github.com/axios/axios/issues/1543`
214
+ assert.strictEqual(err.statusText, 'ECONNABORTED');
215
+ assert.strictEqual(err.message, `timeout of 500ms exceeded: post ${url}/_bulk_get ECONNABORTED`);
216
+ assert.ok(couch.isDone());
217
+ done();
218
+ }).catch(err => {
219
+ // Handle assertion errors
220
+ done(err);
221
+ });
222
+ });
223
+ describe('#unit Check credentials', function() {
224
+ it('should properly decode username and password', function(done) {
225
+ const username = 'user%123';
226
+ const password = 'colon:at@321';
227
+ const url = `http://${encodeURIComponent(username)}:${encodeURIComponent(password)}@localhost:7777/testdb`;
228
+ const sessionUrl = 'http://localhost:7777';
229
+ const couch = nock(sessionUrl)
230
+ .post('/_session', { username: username, password: password })
231
+ .reply(200, { ok: true }, { 'Set-Cookie': 'AuthSession=ABC123DEF4356;' })
232
+ .get('/')
233
+ .reply(200);
234
+ const db = request.client(url, { parallelism: 1 });
235
+ db.service.getServerInformation().then(response => {
236
+ assert.ok(response);
237
+ assert.ok(couch.isDone());
238
+ done();
239
+ }).catch(err => {
240
+ done(err);
241
+ });
242
+ });
243
+ });
244
+ });
@@ -11,36 +11,109 @@
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
- // stolen from http://strongloop.com/strongblog/practical-examples-of-the-new-node-js-streams-api/
17
- const stream = require('stream');
18
-
19
- module.exports = function() {
20
- const liner = new stream.Transform({ objectMode: true });
21
-
22
- liner._transform = function(chunk, encoding, done) {
23
- let data = chunk.toString();
24
- if (this._lastLineData) {
25
- data = this._lastLineData + data;
26
- }
27
-
28
- const lines = data.split('\n');
29
- this._lastLineData = lines.splice(lines.length - 1, 1)[0];
30
-
31
- for (const i in lines) {
32
- this.push(lines[i]);
33
- }
34
- done();
35
- };
36
-
37
- liner._flush = function(done) {
38
- if (this._lastLineData) {
39
- this.push(this._lastLineData);
40
- }
41
- this._lastLineData = null;
42
- done();
43
- };
44
-
45
- return liner;
46
- };
18
+ const assert = require('assert');
19
+ const fs = require('fs');
20
+ const u = require('./citestutils.js');
21
+
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) {
34
+ if (err) {
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
+ }
44
+ }
45
+ });
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
+ });
77
+ });
78
+ });
79
+ });
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
+ });