@cloudant/couchbackup 2.9.10-SNAPSHOT.113 → 2.9.10

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 (399) 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/analysis.log +1 -1
  4. package/.scannerwork/scanner-report/changesets-12.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-13.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-2.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-28.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-29.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-3.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-31.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-34.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-35.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-4.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-67.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-68.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-7.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-8.pb +1 -0
  18. package/.scannerwork/scanner-report/component-1.pb +2 -2
  19. package/.scannerwork/scanner-report/component-10.pb +1 -1
  20. package/.scannerwork/scanner-report/component-11.pb +1 -1
  21. package/.scannerwork/scanner-report/component-12.pb +1 -0
  22. package/.scannerwork/scanner-report/component-13.pb +1 -1
  23. package/.scannerwork/scanner-report/component-14.pb +1 -1
  24. package/.scannerwork/scanner-report/component-19.pb +1 -1
  25. package/.scannerwork/scanner-report/component-2.pb +1 -0
  26. package/.scannerwork/scanner-report/component-20.pb +1 -1
  27. package/.scannerwork/scanner-report/component-21.pb +1 -1
  28. package/.scannerwork/scanner-report/component-22.pb +1 -1
  29. package/.scannerwork/scanner-report/component-23.pb +1 -1
  30. package/.scannerwork/scanner-report/component-24.pb +1 -1
  31. package/.scannerwork/scanner-report/component-25.pb +1 -1
  32. package/.scannerwork/scanner-report/component-26.pb +1 -1
  33. package/.scannerwork/scanner-report/component-27.pb +1 -1
  34. package/.scannerwork/scanner-report/component-28.pb +1 -0
  35. package/.scannerwork/scanner-report/component-29.pb +1 -0
  36. package/.scannerwork/scanner-report/component-3.pb +1 -0
  37. package/.scannerwork/scanner-report/component-30.pb +1 -1
  38. package/.scannerwork/scanner-report/component-31.pb +1 -0
  39. package/.scannerwork/scanner-report/component-32.pb +1 -1
  40. package/.scannerwork/scanner-report/component-33.pb +1 -1
  41. package/.scannerwork/scanner-report/component-34.pb +1 -0
  42. package/.scannerwork/scanner-report/component-35.pb +1 -0
  43. package/.scannerwork/scanner-report/component-4.pb +1 -0
  44. package/.scannerwork/scanner-report/component-47.pb +1 -1
  45. package/.scannerwork/scanner-report/component-48.pb +1 -1
  46. package/.scannerwork/scanner-report/component-49.pb +1 -1
  47. package/.scannerwork/scanner-report/component-5.pb +1 -1
  48. package/.scannerwork/scanner-report/component-50.pb +1 -1
  49. package/.scannerwork/scanner-report/component-51.pb +1 -1
  50. package/.scannerwork/scanner-report/component-52.pb +1 -1
  51. package/.scannerwork/scanner-report/component-54.pb +1 -1
  52. package/.scannerwork/scanner-report/component-56.pb +1 -1
  53. package/.scannerwork/scanner-report/component-59.pb +1 -1
  54. package/.scannerwork/scanner-report/component-6.pb +1 -1
  55. package/.scannerwork/scanner-report/component-60.pb +1 -1
  56. package/.scannerwork/scanner-report/component-65.pb +1 -0
  57. package/.scannerwork/scanner-report/component-66.pb +1 -0
  58. package/.scannerwork/scanner-report/component-67.pb +1 -1
  59. package/.scannerwork/scanner-report/component-68.pb +1 -1
  60. package/.scannerwork/scanner-report/component-7.pb +1 -0
  61. package/.scannerwork/scanner-report/component-8.pb +1 -0
  62. package/.scannerwork/scanner-report/component-9.pb +1 -1
  63. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  64. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  65. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  66. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  67. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-2.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-23.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-25.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-26.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-29.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-3.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-32.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-34.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-47.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-49.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-51.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-67.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-68.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  99. package/.scannerwork/scanner-report/coverages-8.pb +0 -0
  100. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  101. package/.scannerwork/scanner-report/duplications-2.pb +2 -0
  102. package/.scannerwork/scanner-report/duplications-21.pb +3 -0
  103. package/.scannerwork/scanner-report/duplications-24.pb +0 -2
  104. package/.scannerwork/scanner-report/duplications-26.pb +0 -2
  105. package/.scannerwork/scanner-report/duplications-27.pb +2 -0
  106. package/.scannerwork/scanner-report/duplications-29.pb +2 -0
  107. package/.scannerwork/scanner-report/duplications-32.pb +3 -2
  108. package/.scannerwork/scanner-report/duplications-33.pb +0 -2
  109. package/.scannerwork/scanner-report/duplications-34.pb +2 -0
  110. package/.scannerwork/scanner-report/duplications-4.pb +2 -0
  111. package/.scannerwork/scanner-report/duplications-49.pb +0 -3
  112. package/.scannerwork/scanner-report/duplications-5.pb +0 -2
  113. package/.scannerwork/scanner-report/duplications-52.pb +3 -0
  114. package/.scannerwork/scanner-report/duplications-56.pb +0 -3
  115. package/.scannerwork/scanner-report/duplications-59.pb +2 -2
  116. package/.scannerwork/scanner-report/duplications-6.pb +0 -2
  117. package/.scannerwork/scanner-report/duplications-60.pb +2 -0
  118. package/.scannerwork/scanner-report/issues-21.pb +4 -0
  119. package/.scannerwork/scanner-report/issues-49.pb +5 -3
  120. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-23.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-25.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-26.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-29.pb +15 -0
  136. package/.scannerwork/scanner-report/measures-3.pb +16 -0
  137. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-32.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-47.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  150. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  151. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  153. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  154. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  155. package/.scannerwork/scanner-report/measures-65.pb +0 -0
  156. package/.scannerwork/scanner-report/measures-66.pb +0 -0
  157. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  158. package/.scannerwork/scanner-report/measures-68.pb +0 -0
  159. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  160. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  161. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  162. package/.scannerwork/scanner-report/metadata.pb +0 -0
  163. package/.scannerwork/scanner-report/source-10.txt +257 -53
  164. package/.scannerwork/scanner-report/source-11.txt +100 -96
  165. package/.scannerwork/scanner-report/source-13.txt +129 -509
  166. package/.scannerwork/scanner-report/source-14.txt +83 -59
  167. package/.scannerwork/scanner-report/source-19.txt +88 -255
  168. package/.scannerwork/scanner-report/source-2.txt +75 -0
  169. package/.scannerwork/scanner-report/source-20.txt +20 -96
  170. package/.scannerwork/scanner-report/source-21.txt +228 -162
  171. package/.scannerwork/scanner-report/source-22.txt +22 -115
  172. package/.scannerwork/scanner-report/source-23.txt +584 -123
  173. package/.scannerwork/scanner-report/source-24.txt +18 -59
  174. package/.scannerwork/scanner-report/source-25.txt +142 -40
  175. package/.scannerwork/scanner-report/source-26.txt +132 -77
  176. package/.scannerwork/scanner-report/source-27.txt +124 -83
  177. package/.scannerwork/scanner-report/{source-62.txt → source-28.txt} +13 -6
  178. package/.scannerwork/scanner-report/source-29.txt +293 -0
  179. package/.scannerwork/scanner-report/source-3.txt +178 -0
  180. package/.scannerwork/scanner-report/source-30.txt +63 -389
  181. package/.scannerwork/scanner-report/source-32.txt +90 -252
  182. package/.scannerwork/scanner-report/source-33.txt +41 -118
  183. package/.scannerwork/scanner-report/source-34.txt +225 -0
  184. package/.scannerwork/scanner-report/source-35.txt +47 -0
  185. package/.scannerwork/scanner-report/source-4.txt +92 -0
  186. package/.scannerwork/scanner-report/source-47.txt +38 -11
  187. package/.scannerwork/scanner-report/source-48.txt +45 -133
  188. package/.scannerwork/scanner-report/source-49.txt +329 -207
  189. package/.scannerwork/scanner-report/source-5.txt +87 -166
  190. package/.scannerwork/scanner-report/source-50.txt +10 -347
  191. package/.scannerwork/scanner-report/source-51.txt +83 -19
  192. package/.scannerwork/scanner-report/source-52.txt +82 -31
  193. package/.scannerwork/scanner-report/source-54.txt +167 -47
  194. package/.scannerwork/scanner-report/source-56.txt +394 -95
  195. package/.scannerwork/scanner-report/source-59.txt +161 -196
  196. package/.scannerwork/scanner-report/source-6.txt +145 -156
  197. package/.scannerwork/scanner-report/source-60.txt +158 -18
  198. package/.scannerwork/scanner-report/source-65.txt +509 -0
  199. package/.scannerwork/scanner-report/source-66.txt +509 -0
  200. package/.scannerwork/scanner-report/source-67.txt +77 -509
  201. package/.scannerwork/scanner-report/source-68.txt +56 -167
  202. package/.scannerwork/scanner-report/source-7.txt +80 -0
  203. package/.scannerwork/scanner-report/source-8.txt +54 -0
  204. package/.scannerwork/scanner-report/source-9.txt +14 -39
  205. package/.scannerwork/scanner-report/symbols-10.pb +354 -30
  206. package/.scannerwork/scanner-report/symbols-11.pb +29 -27
  207. package/.scannerwork/scanner-report/symbols-13.pb +33 -0
  208. package/.scannerwork/scanner-report/symbols-14.pb +41 -45
  209. package/.scannerwork/scanner-report/symbols-19.pb +28 -354
  210. package/.scannerwork/scanner-report/symbols-2.pb +42 -0
  211. package/.scannerwork/scanner-report/symbols-20.pb +16 -58
  212. package/.scannerwork/scanner-report/symbols-21.pb +384 -134
  213. package/.scannerwork/scanner-report/symbols-22.pb +14 -33
  214. package/.scannerwork/scanner-report/symbols-23.pb +1241 -113
  215. package/.scannerwork/scanner-report/symbols-24.pb +9 -41
  216. package/.scannerwork/scanner-report/symbols-25.pb +111 -14
  217. package/.scannerwork/scanner-report/symbols-26.pb +84 -43
  218. package/.scannerwork/scanner-report/symbols-27.pb +102 -42
  219. package/.scannerwork/scanner-report/symbols-28.pb +11 -0
  220. package/.scannerwork/scanner-report/symbols-29.pb +486 -0
  221. package/.scannerwork/scanner-report/symbols-3.pb +144 -0
  222. package/.scannerwork/scanner-report/symbols-30.pb +60 -610
  223. package/.scannerwork/scanner-report/symbols-32.pb +97 -486
  224. package/.scannerwork/scanner-report/symbols-33.pb +36 -102
  225. package/.scannerwork/scanner-report/symbols-34.pb +418 -0
  226. package/.scannerwork/scanner-report/symbols-4.pb +44 -0
  227. package/.scannerwork/scanner-report/symbols-47.pb +43 -14
  228. package/.scannerwork/scanner-report/symbols-48.pb +44 -111
  229. package/.scannerwork/scanner-report/symbols-49.pb +455 -355
  230. package/.scannerwork/scanner-report/symbols-5.pb +59 -180
  231. package/.scannerwork/scanner-report/symbols-50.pb +9 -494
  232. package/.scannerwork/scanner-report/symbols-51.pb +69 -11
  233. package/.scannerwork/scanner-report/symbols-52.pb +74 -33
  234. package/.scannerwork/scanner-report/symbols-56.pb +610 -77
  235. package/.scannerwork/scanner-report/symbols-59.pb +178 -416
  236. package/.scannerwork/scanner-report/symbols-6.pb +120 -147
  237. package/.scannerwork/scanner-report/symbols-60.pb +152 -16
  238. package/.scannerwork/scanner-report/symbols-67.pb +30 -0
  239. package/.scannerwork/scanner-report/symbols-68.pb +19 -0
  240. package/.scannerwork/scanner-report/symbols-7.pb +46 -0
  241. package/.scannerwork/scanner-report/symbols-8.pb +15 -0
  242. package/.scannerwork/scanner-report/symbols-9.pb +13 -18
  243. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +255 -73
  244. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +79 -104
  245. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +118 -3736
  246. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +81 -60
  247. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +103 -250
  248. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +78 -0
  249. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +29 -99
  250. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +269 -183
  251. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +22 -97
  252. package/.scannerwork/scanner-report/syntax-highlightings-23.pb +815 -141
  253. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +17 -45
  254. package/.scannerwork/scanner-report/syntax-highlightings-25.pb +193 -24
  255. package/.scannerwork/scanner-report/syntax-highlightings-26.pb +157 -56
  256. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +195 -84
  257. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +59 -0
  258. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +659 -0
  259. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +243 -0
  260. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +74 -612
  261. package/.scannerwork/scanner-report/syntax-highlightings-32.pb +147 -624
  262. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +57 -189
  263. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +331 -0
  264. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +68 -0
  265. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +90 -0
  266. package/.scannerwork/scanner-report/syntax-highlightings-47.pb +47 -19
  267. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +63 -176
  268. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +498 -197
  269. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +100 -192
  270. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +15 -597
  271. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +71 -25
  272. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +118 -55
  273. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +938 -57
  274. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +619 -129
  275. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +170 -276
  276. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +155 -156
  277. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +185 -34
  278. package/.scannerwork/scanner-report/syntax-highlightings-65.pb +3748 -0
  279. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +3747 -0
  280. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +72 -3717
  281. package/.scannerwork/scanner-report/syntax-highlightings-68.pb +54 -921
  282. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +95 -0
  283. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +54 -0
  284. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +33 -70
  285. package/CHANGES.md +6 -2
  286. package/package.json +1 -1
  287. package/test-16-results.xml +150 -150
  288. package/test-18-results.xml +149 -149
  289. package/test-iam-18-results.xml +50 -50
  290. package/.scannerwork/scanner-report/changesets-16.pb +0 -1
  291. package/.scannerwork/scanner-report/changesets-17.pb +0 -1
  292. package/.scannerwork/scanner-report/changesets-18.pb +0 -1
  293. package/.scannerwork/scanner-report/changesets-45.pb +0 -1
  294. package/.scannerwork/scanner-report/changesets-46.pb +0 -1
  295. package/.scannerwork/scanner-report/changesets-53.pb +0 -1
  296. package/.scannerwork/scanner-report/changesets-54.pb +0 -1
  297. package/.scannerwork/scanner-report/changesets-55.pb +0 -1
  298. package/.scannerwork/scanner-report/changesets-57.pb +0 -1
  299. package/.scannerwork/scanner-report/changesets-58.pb +0 -1
  300. package/.scannerwork/scanner-report/changesets-61.pb +0 -1
  301. package/.scannerwork/scanner-report/changesets-62.pb +0 -1
  302. package/.scannerwork/scanner-report/changesets-63.pb +0 -1
  303. package/.scannerwork/scanner-report/changesets-64.pb +0 -1
  304. package/.scannerwork/scanner-report/component-16.pb +0 -1
  305. package/.scannerwork/scanner-report/component-17.pb +0 -1
  306. package/.scannerwork/scanner-report/component-18.pb +0 -1
  307. package/.scannerwork/scanner-report/component-45.pb +0 -1
  308. package/.scannerwork/scanner-report/component-46.pb +0 -1
  309. package/.scannerwork/scanner-report/component-53.pb +0 -1
  310. package/.scannerwork/scanner-report/component-55.pb +0 -1
  311. package/.scannerwork/scanner-report/component-57.pb +0 -1
  312. package/.scannerwork/scanner-report/component-58.pb +0 -1
  313. package/.scannerwork/scanner-report/component-61.pb +0 -1
  314. package/.scannerwork/scanner-report/component-62.pb +0 -1
  315. package/.scannerwork/scanner-report/component-63.pb +0 -1
  316. package/.scannerwork/scanner-report/component-64.pb +0 -1
  317. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  318. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  319. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  320. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  321. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  322. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  323. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  324. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  325. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  326. package/.scannerwork/scanner-report/coverages-63.pb +0 -0
  327. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  328. package/.scannerwork/scanner-report/duplications-58.pb +0 -0
  329. package/.scannerwork/scanner-report/duplications-61.pb +0 -3
  330. package/.scannerwork/scanner-report/duplications-63.pb +0 -0
  331. package/.scannerwork/scanner-report/duplications-64.pb +0 -0
  332. package/.scannerwork/scanner-report/issues-50.pb +0 -6
  333. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  334. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  335. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  336. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  337. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  338. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  339. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  340. package/.scannerwork/scanner-report/measures-61.pb +0 -0
  341. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  342. package/.scannerwork/scanner-report/measures-63.pb +0 -0
  343. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  344. package/.scannerwork/scanner-report/source-16.txt +0 -118
  345. package/.scannerwork/scanner-report/source-18.txt +0 -31
  346. package/.scannerwork/scanner-report/source-45.txt +0 -625
  347. package/.scannerwork/scanner-report/source-53.txt +0 -92
  348. package/.scannerwork/scanner-report/source-55.txt +0 -147
  349. package/.scannerwork/scanner-report/source-57.txt +0 -68
  350. package/.scannerwork/scanner-report/source-58.txt +0 -63
  351. package/.scannerwork/scanner-report/source-61.txt +0 -131
  352. package/.scannerwork/scanner-report/source-63.txt +0 -34
  353. package/.scannerwork/scanner-report/source-64.txt +0 -100
  354. package/.scannerwork/scanner-report/symbols-16.pb +0 -30
  355. package/.scannerwork/scanner-report/symbols-18.pb +0 -14
  356. package/.scannerwork/scanner-report/symbols-45.pb +0 -1254
  357. package/.scannerwork/scanner-report/symbols-53.pb +0 -60
  358. package/.scannerwork/scanner-report/symbols-55.pb +0 -85
  359. package/.scannerwork/scanner-report/symbols-57.pb +0 -45
  360. package/.scannerwork/scanner-report/symbols-58.pb +0 -43
  361. package/.scannerwork/scanner-report/symbols-61.pb +0 -97
  362. package/.scannerwork/scanner-report/symbols-62.pb +0 -9
  363. package/.scannerwork/scanner-report/symbols-63.pb +0 -10
  364. package/.scannerwork/scanner-report/symbols-64.pb +0 -69
  365. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +0 -113
  366. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +0 -45
  367. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +0 -887
  368. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +0 -110
  369. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +0 -191
  370. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +0 -110
  371. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +0 -82
  372. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +0 -182
  373. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +0 -48
  374. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +0 -50
  375. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +0 -105
  376. /package/.scannerwork/scanner-report/{coverages-17.pb → coverages-12.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{coverages-46.pb → coverages-31.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{coverages-54.pb → coverages-35.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{duplications-16.pb → duplications-12.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{duplications-17.pb → duplications-13.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{duplications-18.pb → duplications-28.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{duplications-45.pb → duplications-3.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{duplications-46.pb → duplications-31.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-35.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{duplications-53.pb → duplications-67.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{duplications-54.pb → duplications-68.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{duplications-55.pb → duplications-7.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{duplications-57.pb → duplications-8.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{issues-46.pb → issues-31.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{issues-54.pb → issues-35.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{measures-17.pb → measures-12.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{measures-46.pb → measures-31.pb} +0 -0
  393. /package/.scannerwork/scanner-report/{source-17.txt → source-12.txt} +0 -0
  394. /package/.scannerwork/scanner-report/{source-46.txt → source-31.txt} +0 -0
  395. /package/.scannerwork/scanner-report/{symbols-17.pb → symbols-12.pb} +0 -0
  396. /package/.scannerwork/scanner-report/{symbols-46.pb → symbols-31.pb} +0 -0
  397. /package/.scannerwork/scanner-report/{symbols-54.pb → symbols-35.pb} +0 -0
  398. /package/.scannerwork/scanner-report/{syntax-highlightings-17.pb → syntax-highlightings-12.pb} +0 -0
  399. /package/.scannerwork/scanner-report/{syntax-highlightings-46.pb → syntax-highlightings-31.pb} +0 -0
@@ -0,0 +1,225 @@
1
+ // Copyright © 2017, 2018 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 */
16
+ 'use strict';
17
+
18
+ const assert = require('assert');
19
+ const backup = require('../app.js').backup;
20
+ const fs = require('fs');
21
+ const nock = require('nock');
22
+
23
+ const goodUrl = 'http://localhost:5984/db';
24
+ // The real validateArgs function of app.js isn't
25
+ // exported - so we call the exported backup method
26
+ // instead. We don't get as far as a real backup when
27
+ // testing error cases. For success cases we nock the
28
+ // goodUrl and
29
+ const validateArgs = function(url, opts, callback) {
30
+ const nullStream = fs.createWriteStream('/dev/null');
31
+ let cb = callback;
32
+ if (url === goodUrl) {
33
+ // Nock the goodUrl
34
+ nock(goodUrl).head('').reply(404, { error: 'not_found', reason: 'missing' });
35
+ // replace the callback to handle the nock response
36
+ // to avoid attempting a real backup
37
+ cb = function(err) {
38
+ nullStream.end();
39
+ if (err.name === 'DatabaseNotFound') {
40
+ // This is what we expect if we reached the backup
41
+ // This is success for valid args cases.
42
+ err = null;
43
+ }
44
+ callback(err);
45
+ };
46
+ }
47
+ backup(url, nullStream, opts, cb);
48
+ return true;
49
+ };
50
+
51
+ const stderrWriteFun = process.stderr.write;
52
+ let capturedStderr;
53
+
54
+ function captureStderr() {
55
+ process.stderr.write = function(string, encoding, fd) {
56
+ capturedStderr += string;
57
+ };
58
+ }
59
+
60
+ function releaseStderr() {
61
+ process.stderr.write = stderrWriteFun;
62
+ capturedStderr = null;
63
+ }
64
+
65
+ function assertErrorMessage(msg, done) {
66
+ return function(err, data) {
67
+ try {
68
+ assert(err.message, 'There should be an error message');
69
+ assert(err.message.indexOf(msg) >= 0);
70
+ assert(data === null || data === undefined, 'There should only be an error.');
71
+ done();
72
+ } catch (e) {
73
+ done(e);
74
+ }
75
+ };
76
+ }
77
+
78
+ function assertNoError(done) {
79
+ return function(err, data) {
80
+ try {
81
+ assert(err === null, 'There should be no error message.');
82
+ done();
83
+ } catch (e) {
84
+ done(e);
85
+ }
86
+ };
87
+ }
88
+
89
+ describe('#unit Validate arguments', function() {
90
+ it('returns error for invalid URL type', function(done) {
91
+ validateArgs(true, {}, assertErrorMessage('Invalid URL, must be type string', done));
92
+ });
93
+ it('returns no error for valid URL type', function(done) {
94
+ validateArgs(goodUrl, {}, assertNoError(done));
95
+ });
96
+ it('returns error for invalid (no host) URL', function(done) {
97
+ validateArgs('http://', {}, assertErrorMessage('Invalid URL', done));
98
+ });
99
+ it('returns error for invalid (no protocol) URL', function(done) {
100
+ validateArgs('invalid', {}, assertErrorMessage('Invalid URL', done));
101
+ });
102
+ it('returns error for invalid (wrong protocol) URL', function(done) {
103
+ validateArgs('ftp://invalid.example.com', {}, assertErrorMessage('Invalid URL protocol.', done));
104
+ });
105
+ it('returns error for invalid (no path) URL', function(done) {
106
+ validateArgs('https://invalid.example.com', {}, assertErrorMessage('Invalid URL, missing path element (no database).', done));
107
+ });
108
+ it('returns error for invalid (no protocol, no host) URL', function(done) {
109
+ validateArgs('invalid', {}, assertErrorMessage('Invalid URL', done));
110
+ });
111
+ it('returns error for invalid buffer size type', function(done) {
112
+ validateArgs(goodUrl, { bufferSize: '123' }, assertErrorMessage('Invalid buffer size option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
113
+ });
114
+ it('returns error for zero buffer size', function(done) {
115
+ validateArgs(goodUrl, { bufferSize: 0 }, assertErrorMessage('Invalid buffer size option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
116
+ });
117
+ it('returns error for float buffer size', function(done) {
118
+ validateArgs(goodUrl, { bufferSize: 1.23 }, assertErrorMessage('Invalid buffer size option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
119
+ });
120
+ it('returns no error for valid buffer size type', function(done) {
121
+ validateArgs(goodUrl, { bufferSize: 123 }, assertNoError(done));
122
+ });
123
+ it('returns error for invalid log type', function(done) {
124
+ validateArgs(goodUrl, { log: true }, assertErrorMessage('Invalid log option, must be type string', done));
125
+ });
126
+ it('returns no error for valid log type', function(done) {
127
+ validateArgs(goodUrl, { log: 'log.txt' }, assertNoError(done));
128
+ });
129
+ it('returns error for invalid mode type', function(done) {
130
+ validateArgs(goodUrl, { mode: true }, assertErrorMessage('Invalid mode option, must be either "full" or "shallow"', done));
131
+ });
132
+ it('returns error for invalid mode string', function(done) {
133
+ validateArgs(goodUrl, { mode: 'foobar' }, assertErrorMessage('Invalid mode option, must be either "full" or "shallow"', done));
134
+ });
135
+ it('returns no error for valid mode type', function(done) {
136
+ validateArgs(goodUrl, { mode: 'full' }, assertNoError(done));
137
+ });
138
+ it('returns error for invalid output type', function(done) {
139
+ validateArgs(goodUrl, { output: true }, assertErrorMessage('Invalid output option, must be type string', done));
140
+ });
141
+ it('returns no error for valid output type', function(done) {
142
+ validateArgs(goodUrl, { output: 'output.txt' }, assertNoError(done));
143
+ });
144
+ it('returns error for invalid parallelism type', function(done) {
145
+ validateArgs(goodUrl, { parallelism: '123' }, assertErrorMessage('Invalid parallelism option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
146
+ });
147
+ it('returns error for zero parallelism', function(done) {
148
+ validateArgs(goodUrl, { parallelism: 0 }, assertErrorMessage('Invalid parallelism option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
149
+ });
150
+ it('returns error for float parallelism', function(done) {
151
+ validateArgs(goodUrl, { parallelism: 1.23 }, assertErrorMessage('Invalid parallelism option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
152
+ });
153
+ it('returns no error for valid parallelism type', function(done) {
154
+ validateArgs(goodUrl, { parallelism: 123 }, assertNoError(done));
155
+ });
156
+ it('returns error for invalid request timeout type', function(done) {
157
+ validateArgs(goodUrl, { requestTimeout: '123' }, assertErrorMessage('Invalid request timeout option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
158
+ });
159
+ it('returns error for zero request timeout', function(done) {
160
+ validateArgs(goodUrl, { requestTimeout: 0 }, assertErrorMessage('Invalid request timeout option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
161
+ });
162
+ it('returns error for float request timout', function(done) {
163
+ validateArgs(goodUrl, { requestTimeout: 1.23 }, assertErrorMessage('Invalid request timeout option, must be a positive integer in the range (0, MAX_SAFE_INTEGER]', done));
164
+ });
165
+ it('returns no error for valid request timeout type', function(done) {
166
+ validateArgs(goodUrl, { requestTimeout: 123 }, assertNoError(done));
167
+ });
168
+ it('returns error for invalid resume type', function(done) {
169
+ validateArgs(goodUrl, { resume: 'true' }, assertErrorMessage('Invalid resume option, must be type boolean', done));
170
+ });
171
+ it('returns no error for valid resume type', function(done) {
172
+ validateArgs(goodUrl, { resume: false }, assertNoError(done));
173
+ });
174
+ it('returns error for invalid key type', function(done) {
175
+ validateArgs(goodUrl, { iamApiKey: true }, assertErrorMessage('Invalid iamApiKey option, must be type string', done));
176
+ });
177
+ it('returns error for key and URL credentials supplied', function(done) {
178
+ validateArgs('https://a:b@example.com/db', { iamApiKey: 'abc123' }, assertErrorMessage('URL user information must not be supplied when using IAM API key.', done));
179
+ });
180
+ it('warns for log arg in shallow mode', function(done) {
181
+ captureStderr();
182
+ try {
183
+ validateArgs(goodUrl, { mode: 'shallow', log: 'test' }, function(err, data) {
184
+ assert.ok(err);
185
+ assert.ok(!data);
186
+ assert(capturedStderr.indexOf('The options "log" and "resume" are invalid when using shallow mode.') > -1, 'Log warning message was not present');
187
+ });
188
+ done();
189
+ } catch (e) {
190
+ done(e);
191
+ } finally {
192
+ releaseStderr();
193
+ }
194
+ });
195
+ it('warns for resume arg in shallow mode', function(done) {
196
+ captureStderr();
197
+ try {
198
+ validateArgs(goodUrl, { mode: 'shallow', log: 'test', resume: true }, function(err, data) {
199
+ assert.ok(err);
200
+ assert.ok(!data);
201
+ assert(capturedStderr.indexOf('The options "log" and "resume" are invalid when using shallow mode.') > -1, 'Log warning message was not present');
202
+ });
203
+ done();
204
+ } catch (e) {
205
+ done(e);
206
+ } finally {
207
+ releaseStderr();
208
+ }
209
+ });
210
+ it('warns for parallism arg in shallow mode', function(done) {
211
+ captureStderr();
212
+ try {
213
+ validateArgs(goodUrl, { mode: 'shallow', parallelsim: 10 }, function(err, data) {
214
+ assert.ok(err);
215
+ assert.ok(!data);
216
+ assert(capturedStderr.indexOf('The option "parallelism" has no effect when using shallow mode.') > -1, 'Log warning message was not present');
217
+ });
218
+ done();
219
+ } catch (e) {
220
+ done(e);
221
+ } finally {
222
+ releaseStderr();
223
+ }
224
+ });
225
+ });
@@ -0,0 +1,47 @@
1
+ // Copyright © 2017, 2018 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 */
16
+ 'use strict';
17
+
18
+ const assert = require('assert');
19
+ const fs = require('fs');
20
+ const u = require('./citestutils.js');
21
+
22
+ describe('Write error tests', function() {
23
+ it('calls callback with error set when stream is not writeable', function(done) {
24
+ u.setTimeout(this, 10);
25
+ const dirname = fs.mkdtempSync('test_backup_');
26
+ // make temp dir read only
27
+ fs.chmodSync(dirname, 0o444);
28
+ const filename = dirname + '/test.backup';
29
+ const backupStream = fs.createWriteStream(filename, { flags: 'w' });
30
+ const params = { useApi: true };
31
+ // try to do backup and check err was set in callback
32
+ u.testBackup(params, 'animaldb', backupStream, function(resultErr) {
33
+ let err = null;
34
+ try {
35
+ // cleanup temp dir
36
+ fs.rmdirSync(dirname);
37
+ // error should have been set
38
+ assert.ok(resultErr);
39
+ assert.strictEqual(resultErr.code, 'EACCES');
40
+ } catch (thrownErr) {
41
+ err = thrownErr;
42
+ } finally {
43
+ done(err);
44
+ }
45
+ });
46
+ });
47
+ });
@@ -0,0 +1,92 @@
1
+ // Copyright © 2017 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
+ 'use strict';
15
+
16
+ const fs = require('fs');
17
+ const stream = require('stream');
18
+ const liner = require('./liner.js');
19
+
20
+ const onLine = function(onCommand, getDocs) {
21
+ const change = new stream.Transform({ objectMode: true });
22
+
23
+ change._transform = function(line, encoding, done) {
24
+ if (line && line[0] === ':') {
25
+ const obj = {
26
+ command: null,
27
+ batch: null,
28
+ docs: []
29
+ };
30
+
31
+ let matches;
32
+
33
+ // extract command
34
+ matches = line.match(/^:([a-z_]+) ?/);
35
+ if (matches) {
36
+ obj.command = matches[1];
37
+ }
38
+
39
+ // extract batch
40
+ matches = line.match(/ batch([0-9]+)/);
41
+ if (matches) {
42
+ obj.batch = parseInt(matches[1]);
43
+ }
44
+
45
+ // extract doc ids
46
+ if (getDocs && obj.command === 't') {
47
+ const json = line.replace(/^.* batch[0-9]+ /, '').trim();
48
+ obj.docs = JSON.parse(json);
49
+ }
50
+ onCommand(obj);
51
+ }
52
+ done();
53
+ };
54
+ return change;
55
+ };
56
+
57
+ /**
58
+ * Generate a list of remaining batches from a download file.
59
+ *
60
+ * @param {string} log - log file name
61
+ * @param {function} callback - callback with err, {changesComplete: N, batches: N}.
62
+ * changesComplete signifies whether the log file appeared to
63
+ * have completed reading the changes feed (contains :changes_complete).
64
+ * batches are remaining batch IDs for download.
65
+ */
66
+ module.exports = function(log, callback) {
67
+ // our sense of state
68
+ const state = {
69
+
70
+ };
71
+ let changesComplete = false;
72
+
73
+ // called with each line from the log file
74
+ const onCommand = function(obj) {
75
+ if (obj.command === 't') {
76
+ state[obj.batch] = true;
77
+ } else if (obj.command === 'd') {
78
+ delete state[obj.batch];
79
+ } else if (obj.command === 'changes_complete') {
80
+ changesComplete = true;
81
+ }
82
+ };
83
+
84
+ // stream through the previous log file
85
+ fs.createReadStream(log)
86
+ .pipe(liner())
87
+ .pipe(onLine(onCommand, false))
88
+ .on('finish', function() {
89
+ const obj = { changesComplete: changesComplete, batches: state };
90
+ callback(null, obj);
91
+ });
92
+ };
@@ -15,22 +15,49 @@
15
15
  /* global describe it */
16
16
  'use strict';
17
17
 
18
+ const fs = require('fs');
18
19
  const u = require('./citestutils.js');
19
20
 
20
- describe('Encryption tests', function() {
21
- // Note CLI only to use openssl command
22
- const p = { useApi: false, encryption: true };
23
-
24
- it('should backup and restore animaldb via an encrypted file', function(done) {
25
- // Allow up to 60 s for backup and restore of animaldb
26
- u.setTimeout(this, 60);
27
- const encryptedBackup = `./${this.fileName}`;
28
- u.testBackupAndRestoreViaFile(p, 'animaldb', encryptedBackup, this.dbName, function(err) {
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) {
29
27
  if (err) {
30
28
  done(err);
31
- } else {
32
- u.assertEncryptedFile(encryptedBackup, done);
33
29
  }
34
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) {
49
+ if (err) {
50
+ done(err);
51
+ }
52
+ });
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
+ }
60
+ });
61
+ });
35
62
  });
36
63
  });
@@ -12,145 +12,57 @@
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
14
 
15
- /* global describe it */
15
+ /* global beforeEach afterEach */
16
16
  'use strict';
17
17
 
18
- const assert = require('assert');
19
- const nock = require('nock');
20
- const request = require('../includes/request.js');
21
- const changes = require('../includes/spoolchanges.js');
18
+ const { CloudantV1 } = require('@ibm-cloud/cloudant');
19
+ const url = new URL((process.env.COUCH_BACKEND_URL) ? process.env.COUCH_BACKEND_URL : 'https://no-couch-backend-url-set.test');
20
+ const { BasicAuthenticator, NoAuthAuthenticator } = require('ibm-cloud-sdk-core');
21
+ const authenticator = (url.username) ? new BasicAuthenticator({ username: url.username, password: decodeURIComponent(url.password) }) : new NoAuthAuthenticator();
22
+ const serviceOpts = {
23
+ authenticator: authenticator
24
+ };
25
+ const cloudant = new CloudantV1(serviceOpts);
26
+ // Remove auth from URL before using for service
27
+ cloudant.setServiceUrl(new URL(url.pathname, url.origin).toString());
28
+ const uuid = require('uuid').v4;
29
+ const fs = require('fs');
22
30
 
23
- const url = 'http://localhost:7777';
24
- const dbName = 'fakenockdb';
25
- const longTestTimeout = 3000;
31
+ // Mocha hooks that will be at the root context so run for all tests
26
32
 
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();
74
- });
75
- }).timeout(longTestTimeout);
76
-
77
- it('should terminate on bad HTTP status code response', function(done) {
78
- nock(url)
79
- .post(`/${dbName}/_changes`)
80
- .query(true)
81
- .times(3)
82
- .reply(500, function(uri, requestBody) {
83
- this.req.response.statusMessage = 'Internal Server Error';
84
- return { error: 'foo', reason: 'bar' };
85
- });
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
33
+ beforeEach('Create test database', function(done) {
34
+ // Don't run hook for unit tests, just for CI
35
+ if (!this.currentTest.fullTitle().includes('#unit')) {
36
+ // Allow 10 seconds to create the DB
100
37
  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();
122
- });
123
- });
38
+ const unique = uuid();
39
+ this.fileName = `${unique}`;
40
+ this.dbName = 'couchbackup_test_' + unique;
41
+ cloudant.putDatabase({ db: this.dbName }).then(() => { done(); }).catch((err) => { done(err); });
42
+ } else {
43
+ done();
44
+ }
124
45
  });
125
46
 
126
- describe('Longer spool changes checks', function() {
127
- it('#slow should keep collecting changes (25M)', function(done) {
128
- // This test might take up to 5 minutes
129
- this.timeout(5 * 60 * 1000);
130
- // Note changes spooling uses a constant batch size, we are setting
131
- // a test value here and setting the buffer to match
132
- const batch = 100000;
133
- // Use sparse changes for this test
134
- provideChanges(batch, 25000000);
135
- changes(db, '/dev/null', batch, null, function(err) {
136
- assert.ok(!err);
137
- assert.ok(nock.isDone());
138
- done();
139
- });
140
- });
47
+ afterEach('Delete test database', function(done) {
48
+ // Don't run hook for unit tests, just for CI
49
+ if (!this.currentTest.fullTitle().includes('#unit')) {
50
+ // Allow 10 seconds to delete the DB
51
+ this.timeout(10 * 1000);
52
+ deleteIfExists(this.fileName);
53
+ deleteIfExists(`${this.fileName}.log`);
54
+ cloudant.deleteDatabase({ db: this.dbName }).then(() => { done(); }).catch((err) => { done(err); });
55
+ } else {
56
+ done();
57
+ }
58
+ });
141
59
 
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();
154
- });
60
+ function deleteIfExists(fileName) {
61
+ fs.unlink(fileName, function(err) {
62
+ if (err) {
63
+ if (err.code !== 'ENOENT') {
64
+ console.error(`${err.code} ${err.message}`);
65
+ }
66
+ }
155
67
  });
156
- });
68
+ }