@cloudant/couchbackup 2.9.12-SNAPSHOT.135 → 2.9.12

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 (395) 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-20.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-22.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-23.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-24.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-25.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-26.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-27.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-28.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-29.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-30.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-44.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-45.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-46.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-47.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 -1
  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-15.pb +1 -1
  25. package/.scannerwork/scanner-report/component-16.pb +1 -1
  26. package/.scannerwork/scanner-report/component-17.pb +1 -1
  27. package/.scannerwork/scanner-report/component-18.pb +1 -1
  28. package/.scannerwork/scanner-report/component-19.pb +1 -1
  29. package/.scannerwork/scanner-report/component-20.pb +1 -0
  30. package/.scannerwork/scanner-report/component-22.pb +1 -0
  31. package/.scannerwork/scanner-report/component-23.pb +1 -0
  32. package/.scannerwork/scanner-report/component-24.pb +1 -0
  33. package/.scannerwork/scanner-report/component-25.pb +1 -0
  34. package/.scannerwork/scanner-report/component-26.pb +1 -0
  35. package/.scannerwork/scanner-report/component-27.pb +1 -0
  36. package/.scannerwork/scanner-report/component-28.pb +1 -0
  37. package/.scannerwork/scanner-report/component-29.pb +1 -0
  38. package/.scannerwork/scanner-report/component-30.pb +1 -0
  39. package/.scannerwork/scanner-report/component-42.pb +1 -1
  40. package/.scannerwork/scanner-report/component-43.pb +1 -1
  41. package/.scannerwork/scanner-report/component-44.pb +1 -0
  42. package/.scannerwork/scanner-report/component-45.pb +1 -0
  43. package/.scannerwork/scanner-report/component-46.pb +1 -0
  44. package/.scannerwork/scanner-report/component-47.pb +1 -0
  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-53.pb +1 -1
  52. package/.scannerwork/scanner-report/component-54.pb +1 -1
  53. package/.scannerwork/scanner-report/component-55.pb +1 -1
  54. package/.scannerwork/scanner-report/component-56.pb +1 -1
  55. package/.scannerwork/scanner-report/component-58.pb +1 -1
  56. package/.scannerwork/scanner-report/component-6.pb +1 -1
  57. package/.scannerwork/scanner-report/component-61.pb +1 -1
  58. package/.scannerwork/scanner-report/component-64.pb +1 -1
  59. package/.scannerwork/scanner-report/component-68.pb +1 -0
  60. package/.scannerwork/scanner-report/component-7.pb +1 -1
  61. package/.scannerwork/scanner-report/component-8.pb +1 -1
  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-12.pb +0 -0
  66. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  67. package/.scannerwork/scanner-report/coverages-14.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-17.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-25.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-26.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-49.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-51.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-8.pb +0 -0
  99. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  100. package/.scannerwork/scanner-report/duplications-10.pb +0 -2
  101. package/.scannerwork/scanner-report/duplications-11.pb +0 -3
  102. package/.scannerwork/scanner-report/duplications-15.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-16.pb +0 -3
  104. package/.scannerwork/scanner-report/duplications-24.pb +2 -0
  105. package/.scannerwork/scanner-report/duplications-26.pb +3 -0
  106. package/.scannerwork/scanner-report/duplications-30.pb +3 -0
  107. package/.scannerwork/scanner-report/duplications-42.pb +0 -2
  108. package/.scannerwork/scanner-report/duplications-43.pb +0 -2
  109. package/.scannerwork/scanner-report/duplications-5.pb +2 -2
  110. package/.scannerwork/scanner-report/duplications-52.pb +3 -0
  111. package/.scannerwork/scanner-report/duplications-55.pb +2 -0
  112. package/.scannerwork/scanner-report/duplications-6.pb +2 -0
  113. package/.scannerwork/scanner-report/duplications-8.pb +0 -3
  114. package/.scannerwork/scanner-report/duplications-9.pb +2 -0
  115. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-12.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-14.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-17.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-25.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-26.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-58.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-64.pb +0 -0
  150. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  151. package/.scannerwork/scanner-report/measures-8.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  153. package/.scannerwork/scanner-report/metadata.pb +0 -0
  154. package/.scannerwork/scanner-report/source-10.txt +87 -201
  155. package/.scannerwork/scanner-report/source-11.txt +36 -113
  156. package/.scannerwork/scanner-report/source-12.txt +22 -49
  157. package/.scannerwork/scanner-report/source-13.txt +115 -78
  158. package/.scannerwork/scanner-report/source-14.txt +146 -45
  159. package/.scannerwork/scanner-report/source-15.txt +58 -30
  160. package/.scannerwork/scanner-report/source-16.txt +103 -229
  161. package/.scannerwork/scanner-report/source-17.txt +89 -21
  162. package/.scannerwork/scanner-report/source-18.txt +164 -20
  163. package/.scannerwork/scanner-report/source-19.txt +17 -128
  164. package/.scannerwork/scanner-report/source-2.txt +151 -151
  165. package/.scannerwork/scanner-report/source-20.txt +281 -0
  166. package/.scannerwork/scanner-report/source-22.txt +56 -0
  167. package/.scannerwork/scanner-report/source-24.txt +145 -0
  168. package/.scannerwork/scanner-report/source-25.txt +34 -0
  169. package/.scannerwork/scanner-report/source-26.txt +119 -0
  170. package/.scannerwork/scanner-report/source-28.txt +47 -0
  171. package/.scannerwork/scanner-report/source-30.txt +131 -0
  172. package/.scannerwork/scanner-report/source-42.txt +348 -157
  173. package/.scannerwork/scanner-report/source-43.txt +122 -165
  174. package/.scannerwork/scanner-report/source-45.txt +142 -0
  175. package/.scannerwork/scanner-report/source-46.txt +68 -0
  176. package/.scannerwork/scanner-report/source-48.txt +22 -115
  177. package/.scannerwork/scanner-report/source-49.txt +81 -35
  178. package/.scannerwork/scanner-report/source-5.txt +152 -122
  179. package/.scannerwork/scanner-report/source-50.txt +598 -19
  180. package/.scannerwork/scanner-report/source-51.txt +46 -58
  181. package/.scannerwork/scanner-report/source-52.txt +227 -147
  182. package/.scannerwork/scanner-report/source-53.txt +45 -160
  183. package/.scannerwork/scanner-report/source-54.txt +12 -75
  184. package/.scannerwork/scanner-report/source-55.txt +194 -250
  185. package/.scannerwork/scanner-report/source-56.txt +78 -104
  186. package/.scannerwork/scanner-report/source-58.txt +94 -21
  187. package/.scannerwork/scanner-report/source-6.txt +167 -45
  188. package/.scannerwork/scanner-report/source-61.txt +509 -104
  189. package/.scannerwork/scanner-report/source-64.txt +401 -39
  190. package/.scannerwork/scanner-report/{source-37.txt → source-68.txt} +50 -50
  191. package/.scannerwork/scanner-report/source-7.txt +32 -133
  192. package/.scannerwork/scanner-report/source-8.txt +57 -96
  193. package/.scannerwork/scanner-report/source-9.txt +75 -12
  194. package/.scannerwork/scanner-report/symbols-10.pb +58 -417
  195. package/.scannerwork/scanner-report/symbols-11.pb +15 -97
  196. package/.scannerwork/scanner-report/symbols-12.pb +17 -35
  197. package/.scannerwork/scanner-report/symbols-13.pb +33 -60
  198. package/.scannerwork/scanner-report/symbols-14.pb +125 -42
  199. package/.scannerwork/scanner-report/symbols-15.pb +41 -26
  200. package/.scannerwork/scanner-report/symbols-16.pb +30 -394
  201. package/.scannerwork/scanner-report/symbols-17.pb +42 -11
  202. package/.scannerwork/scanner-report/symbols-18.pb +143 -9
  203. package/.scannerwork/scanner-report/symbols-19.pb +14 -116
  204. package/.scannerwork/scanner-report/symbols-20.pb +354 -0
  205. package/.scannerwork/scanner-report/symbols-22.pb +19 -0
  206. package/.scannerwork/scanner-report/symbols-24.pb +102 -0
  207. package/.scannerwork/scanner-report/symbols-25.pb +10 -0
  208. package/.scannerwork/scanner-report/symbols-26.pb +77 -0
  209. package/.scannerwork/scanner-report/symbols-28.pb +27 -0
  210. package/.scannerwork/scanner-report/symbols-30.pb +97 -0
  211. package/.scannerwork/scanner-report/symbols-42.pb +486 -145
  212. package/.scannerwork/scanner-report/symbols-43.pb +85 -180
  213. package/.scannerwork/scanner-report/symbols-45.pb +116 -0
  214. package/.scannerwork/scanner-report/symbols-46.pb +45 -0
  215. package/.scannerwork/scanner-report/symbols-48.pb +11 -33
  216. package/.scannerwork/scanner-report/symbols-49.pb +68 -14
  217. package/.scannerwork/scanner-report/symbols-5.pb +152 -101
  218. package/.scannerwork/scanner-report/symbols-50.pb +1253 -19
  219. package/.scannerwork/scanner-report/symbols-51.pb +33 -43
  220. package/.scannerwork/scanner-report/symbols-52.pb +394 -126
  221. package/.scannerwork/scanner-report/symbols-53.pb +42 -143
  222. package/.scannerwork/scanner-report/symbols-54.pb +9 -44
  223. package/.scannerwork/scanner-report/symbols-55.pb +377 -313
  224. package/.scannerwork/scanner-report/symbols-56.pb +60 -30
  225. package/.scannerwork/scanner-report/symbols-58.pb +28 -18
  226. package/.scannerwork/scanner-report/symbols-6.pb +180 -45
  227. package/.scannerwork/scanner-report/symbols-64.pb +610 -19
  228. package/.scannerwork/scanner-report/symbols-7.pb +19 -84
  229. package/.scannerwork/scanner-report/symbols-8.pb +41 -72
  230. package/.scannerwork/scanner-report/symbols-9.pb +44 -9
  231. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +96 -294
  232. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +25 -153
  233. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +21 -66
  234. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +89 -70
  235. package/.scannerwork/scanner-report/syntax-highlightings-14.pb +178 -47
  236. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +44 -34
  237. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +83 -299
  238. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +87 -30
  239. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +209 -16
  240. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +15 -104
  241. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +109 -110
  242. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +285 -0
  243. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +82 -0
  244. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +227 -0
  245. package/.scannerwork/scanner-report/syntax-highlightings-25.pb +50 -0
  246. package/.scannerwork/scanner-report/syntax-highlightings-26.pb +158 -0
  247. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +68 -0
  248. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +182 -0
  249. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +572 -156
  250. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +146 -180
  251. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +134 -0
  252. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +110 -0
  253. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +26 -96
  254. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +75 -24
  255. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +183 -196
  256. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +856 -33
  257. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +60 -60
  258. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +284 -168
  259. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +46 -207
  260. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +15 -57
  261. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +219 -173
  262. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +80 -83
  263. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +108 -20
  264. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +180 -65
  265. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +3737 -105
  266. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +624 -58
  267. package/.scannerwork/scanner-report/{syntax-highlightings-37.pb → syntax-highlightings-68.pb} +19 -19
  268. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +35 -162
  269. package/.scannerwork/scanner-report/syntax-highlightings-8.pb +58 -121
  270. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +57 -15
  271. package/.secrets.baseline +2 -2
  272. package/CHANGES.md +3 -0
  273. package/package.json +2 -2
  274. package/test-16-results.xml +148 -148
  275. package/test-18-results.xml +151 -151
  276. package/test-iam-18-results.xml +50 -50
  277. package/.scannerwork/scanner-report/changesets-3.pb +0 -1
  278. package/.scannerwork/scanner-report/changesets-31.pb +0 -1
  279. package/.scannerwork/scanner-report/changesets-32.pb +0 -1
  280. package/.scannerwork/scanner-report/changesets-33.pb +0 -1
  281. package/.scannerwork/scanner-report/changesets-34.pb +0 -1
  282. package/.scannerwork/scanner-report/changesets-35.pb +0 -1
  283. package/.scannerwork/scanner-report/changesets-38.pb +0 -1
  284. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  285. package/.scannerwork/scanner-report/changesets-57.pb +0 -1
  286. package/.scannerwork/scanner-report/changesets-59.pb +0 -1
  287. package/.scannerwork/scanner-report/changesets-60.pb +0 -1
  288. package/.scannerwork/scanner-report/changesets-61.pb +0 -1
  289. package/.scannerwork/scanner-report/changesets-65.pb +0 -1
  290. package/.scannerwork/scanner-report/changesets-66.pb +0 -1
  291. package/.scannerwork/scanner-report/component-3.pb +0 -1
  292. package/.scannerwork/scanner-report/component-31.pb +0 -1
  293. package/.scannerwork/scanner-report/component-32.pb +0 -1
  294. package/.scannerwork/scanner-report/component-33.pb +0 -1
  295. package/.scannerwork/scanner-report/component-34.pb +0 -1
  296. package/.scannerwork/scanner-report/component-35.pb +0 -1
  297. package/.scannerwork/scanner-report/component-37.pb +0 -1
  298. package/.scannerwork/scanner-report/component-38.pb +0 -1
  299. package/.scannerwork/scanner-report/component-4.pb +0 -1
  300. package/.scannerwork/scanner-report/component-57.pb +0 -1
  301. package/.scannerwork/scanner-report/component-59.pb +0 -1
  302. package/.scannerwork/scanner-report/component-60.pb +0 -1
  303. package/.scannerwork/scanner-report/component-65.pb +0 -1
  304. package/.scannerwork/scanner-report/component-66.pb +0 -1
  305. package/.scannerwork/scanner-report/component-67.pb +0 -1
  306. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  307. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  308. package/.scannerwork/scanner-report/coverages-38.pb +0 -0
  309. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  310. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  311. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  312. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  313. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  314. package/.scannerwork/scanner-report/coverages-66.pb +0 -0
  315. package/.scannerwork/scanner-report/duplications-54.pb +0 -2
  316. package/.scannerwork/scanner-report/duplications-57.pb +0 -2
  317. package/.scannerwork/scanner-report/duplications-65.pb +0 -0
  318. package/.scannerwork/scanner-report/duplications-66.pb +0 -0
  319. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  320. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  321. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  322. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  323. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  324. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  325. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  326. package/.scannerwork/scanner-report/measures-66.pb +0 -0
  327. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  328. package/.scannerwork/scanner-report/source-33.txt +0 -625
  329. package/.scannerwork/scanner-report/source-35.txt +0 -100
  330. package/.scannerwork/scanner-report/source-38.txt +0 -418
  331. package/.scannerwork/scanner-report/source-4.txt +0 -366
  332. package/.scannerwork/scanner-report/source-57.txt +0 -75
  333. package/.scannerwork/scanner-report/source-59.txt +0 -111
  334. package/.scannerwork/scanner-report/source-60.txt +0 -31
  335. package/.scannerwork/scanner-report/source-66.txt +0 -114
  336. package/.scannerwork/scanner-report/source-67.txt +0 -509
  337. package/.scannerwork/scanner-report/symbols-33.pb +0 -1254
  338. package/.scannerwork/scanner-report/symbols-35.pb +0 -69
  339. package/.scannerwork/scanner-report/symbols-38.pb +0 -610
  340. package/.scannerwork/scanner-report/symbols-4.pb +0 -494
  341. package/.scannerwork/scanner-report/symbols-57.pb +0 -42
  342. package/.scannerwork/scanner-report/symbols-59.pb +0 -59
  343. package/.scannerwork/scanner-report/symbols-60.pb +0 -14
  344. package/.scannerwork/scanner-report/symbols-61.pb +0 -42
  345. package/.scannerwork/scanner-report/symbols-66.pb +0 -28
  346. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +0 -887
  347. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +0 -105
  348. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +0 -648
  349. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -630
  350. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +0 -78
  351. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +0 -133
  352. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +0 -45
  353. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +0 -138
  354. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +0 -3747
  355. /package/.scannerwork/scanner-report/{coverages-65.pb → coverages-23.pb} +0 -0
  356. /package/.scannerwork/scanner-report/{coverages-32.pb → coverages-27.pb} +0 -0
  357. /package/.scannerwork/scanner-report/{coverages-3.pb → coverages-29.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{coverages-31.pb → coverages-44.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{coverages-34.pb → coverages-47.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{duplications-31.pb → duplications-20.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{duplications-32.pb → duplications-22.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{duplications-33.pb → duplications-23.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{duplications-34.pb → duplications-25.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{duplications-35.pb → duplications-27.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{duplications-38.pb → duplications-28.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{duplications-3.pb → duplications-29.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-44.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{duplications-59.pb → duplications-45.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{duplications-60.pb → duplications-46.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{duplications-61.pb → duplications-47.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{issues-15.pb → issues-28.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{issues-4.pb → issues-42.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{issues-19.pb → issues-45.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{issues-16.pb → issues-52.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{measures-65.pb → measures-23.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{measures-32.pb → measures-27.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{measures-3.pb → measures-29.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{measures-31.pb → measures-44.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{measures-34.pb → measures-47.pb} +0 -0
  380. /package/.scannerwork/scanner-report/{measures-37.pb → measures-68.pb} +0 -0
  381. /package/.scannerwork/scanner-report/{source-65.txt → source-23.txt} +0 -0
  382. /package/.scannerwork/scanner-report/{source-32.txt → source-27.txt} +0 -0
  383. /package/.scannerwork/scanner-report/{source-3.txt → source-29.txt} +0 -0
  384. /package/.scannerwork/scanner-report/{source-31.txt → source-44.txt} +0 -0
  385. /package/.scannerwork/scanner-report/{source-34.txt → source-47.txt} +0 -0
  386. /package/.scannerwork/scanner-report/{symbols-65.pb → symbols-23.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{symbols-32.pb → symbols-27.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{symbols-3.pb → symbols-29.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{symbols-31.pb → symbols-44.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{symbols-34.pb → symbols-47.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{syntax-highlightings-65.pb → syntax-highlightings-23.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{syntax-highlightings-32.pb → syntax-highlightings-27.pb} +0 -0
  393. /package/.scannerwork/scanner-report/{syntax-highlightings-3.pb → syntax-highlightings-29.pb} +0 -0
  394. /package/.scannerwork/scanner-report/{syntax-highlightings-31.pb → syntax-highlightings-44.pb} +0 -0
  395. /package/.scannerwork/scanner-report/{syntax-highlightings-34.pb → syntax-highlightings-47.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2021 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2018 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,271 +11,215 @@
11
11
  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
12
  // See the License for the specific language governing permissions and
13
13
  // limitations under the License.
14
+
15
+ /* global describe it */
14
16
  'use strict';
15
17
 
16
- const async = require('async');
17
- const events = require('events');
18
+ const assert = require('assert');
19
+ const backup = require('../app.js').backup;
18
20
  const fs = require('fs');
19
- const error = require('./error.js');
20
- const spoolchanges = require('./spoolchanges.js');
21
- const logfilesummary = require('./logfilesummary.js');
22
- const logfilegetbatches = require('./logfilegetbatches.js');
23
-
24
- /**
25
- * Read documents from a database to be backed up.
26
- *
27
- * @param {string} db - `@cloudant/cloudant` DB object for source database.
28
- * @param {number} blocksize - number of documents to download in single request
29
- * @param {number} parallelism - number of concurrent downloads
30
- * @param {string} log - path to log file to use
31
- * @param {boolean} resume - whether to resume from an existing log file
32
- * @returns EventEmitter with following events:
33
- * - `received` - called with a block of documents to write to backup
34
- * - `error` - on error
35
- * - `finished` - when backup process is finished (either complete or errored)
36
- */
37
- module.exports = function(db, options) {
38
- const ee = new events.EventEmitter();
39
- const start = new Date().getTime(); // backup start time
40
- const batchesPerDownloadSession = 50; // max batches to read from log file for download at a time (prevent OOM)
41
-
42
- function proceedWithBackup() {
43
- if (options.resume) {
44
- // pick up from existing log file from previous run
45
- downloadRemainingBatches(options.log, db, ee, start, batchesPerDownloadSession, options.parallelism);
46
- } else {
47
- // create new log file and process
48
- spoolchanges(db, options.log, options.bufferSize, ee, function(err) {
49
- if (err) {
50
- ee.emit('error', err);
51
- } else {
52
- downloadRemainingBatches(options.log, db, ee, start, batchesPerDownloadSession, options.parallelism);
53
- }
54
- });
55
- }
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
+ };
56
46
  }
57
-
58
- validateBulkGetSupport(db, function(err) {
59
- if (err) {
60
- return ee.emit('error', err);
61
- } else {
62
- proceedWithBackup();
63
- }
64
- });
65
-
66
- return ee;
47
+ backup(url, nullStream, opts, cb);
48
+ return true;
67
49
  };
68
50
 
69
- /**
70
- * Validate /_bulk_get support for a specified database.
71
- *
72
- * @param {string} db - nodejs-cloudant db
73
- * @param {function} callback - called on completion with signature (err)
74
- */
75
- function validateBulkGetSupport(db, callback) {
76
- db.service.postBulkGet({ db: db.db, docs: [] }).then(() => { callback(); }).catch(err => {
77
- err = error.convertResponseError(err, function(err) {
78
- switch (err.status) {
79
- case undefined:
80
- // There was no status code on the error
81
- return err;
82
- case 404:
83
- return new error.BackupError('BulkGetError', 'Database does not support /_bulk_get endpoint');
84
- default:
85
- return new error.HTTPError(err);
86
- }
87
- });
88
- callback(err);
89
- });
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
+ };
90
58
  }
91
59
 
92
- /**
93
- * Download remaining batches in a log file, splitting batches into sets
94
- * to avoid enqueueing too many in one go.
95
- *
96
- * @param {string} log - log file name to maintain download state
97
- * @param {string} db - nodejs-cloudant db
98
- * @param {events.EventEmitter} ee - event emitter to emit received events on
99
- * @param {time} startTime - start time for backup process
100
- * @param {number} batchesPerDownloadSession - max batches to enqueue for
101
- * download at a time. As batches contain many doc IDs, this helps avoid
102
- * exhausting memory.
103
- * @param {number} parallelism - number of concurrent downloads
104
- * @returns function to call do download remaining batches with signature
105
- * (err, {batches: batch, docs: doccount}) {@see spoolchanges}.
106
- */
107
- function downloadRemainingBatches(log, db, ee, startTime, batchesPerDownloadSession, parallelism) {
108
- let total = 0; // running total of documents downloaded so far
109
- let noRemainingBatches = false;
60
+ function releaseStderr() {
61
+ process.stderr.write = stderrWriteFun;
62
+ capturedStderr = null;
63
+ }
110
64
 
111
- // Generate a set of batches (up to batchesPerDownloadSession) to download from the
112
- // log file and download them. Set noRemainingBatches to `true` for last batch.
113
- function downloadSingleBatchSet(done) {
114
- // Fetch the doc IDs for the batches in the current set to
115
- // download them.
116
- function batchSetComplete(err, data) {
117
- if (!err) {
118
- total = data.total;
119
- }
120
- done(err);
121
- }
122
- function processRetrievedBatches(err, batches) {
123
- if (!err) {
124
- // process them in parallelised queue
125
- processBatchSet(db, parallelism, log, batches, ee, startTime, total, batchSetComplete);
126
- } else {
127
- batchSetComplete(err);
128
- }
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);
129
74
  }
130
-
131
- readBatchSetIdsFromLogFile(log, batchesPerDownloadSession, function(err, batchSetIds) {
132
- if (err) {
133
- ee.emit('error', err);
134
- // Stop processing changes file for fatal errors
135
- noRemainingBatches = true;
136
- done();
137
- } else {
138
- if (batchSetIds.length === 0) {
139
- noRemainingBatches = true;
140
- return done();
141
- }
142
- logfilegetbatches(log, batchSetIds, processRetrievedBatches);
143
- }
144
- });
145
- }
146
-
147
- // Return true if all batches in log file have been downloaded
148
- function isFinished(callback) { callback(null, noRemainingBatches); }
149
-
150
- function onComplete() {
151
- ee.emit('finished', { total: total });
152
- }
153
-
154
- async.doUntil(downloadSingleBatchSet, isFinished, onComplete);
75
+ };
155
76
  }
156
77
 
157
- /**
158
- * Return a set of uncompleted download batch IDs from the log file.
159
- *
160
- * @param {string} log - log file path
161
- * @param {number} batchesPerDownloadSession - maximum IDs to return
162
- * @param {function} callback - sign (err, batchSetIds array)
163
- */
164
- function readBatchSetIdsFromLogFile(log, batchesPerDownloadSession, callback) {
165
- logfilesummary(log, function processSummary(err, summary) {
166
- if (!err) {
167
- if (!summary.changesComplete) {
168
- callback(new error.BackupError('IncompleteChangesInLogFile',
169
- 'WARNING: Changes did not finish spooling'));
170
- return;
171
- }
172
- if (Object.keys(summary.batches).length === 0) {
173
- return callback(null, []);
174
- }
175
-
176
- // batch IDs are the property names of summary.batches
177
- const batchSetIds = getPropertyNames(summary.batches, batchesPerDownloadSession);
178
- callback(null, batchSetIds);
179
- } else {
180
- callback(err);
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);
181
85
  }
182
- });
86
+ };
183
87
  }
184
88
 
185
- /**
186
- * Download a set of batches retrieved from a log file. When a download is
187
- * complete, add a line to the logfile indicating such.
188
- *
189
- * @param {any} db - nodejs-cloudant database
190
- * @param {any} parallelism - number of concurrent requests to make
191
- * @param {any} log - log file to drive downloads from
192
- * @param {any} batches - batches to download
193
- * @param {any} ee - event emitter for progress. This funciton emits
194
- * received and error events.
195
- * @param {any} start - time backup started, to report deltas
196
- * @param {any} grandtotal - count of documents downloaded prior to this set
197
- * of batches
198
- * @param {any} callback - completion callback, (err, {total: number}).
199
- */
200
- function processBatchSet(db, parallelism, log, batches, ee, start, grandtotal, callback) {
201
- let hasErrored = false;
202
- let total = grandtotal;
203
-
204
- // queue to process the fetch requests in an orderly fashion using _bulk_get
205
- const q = async.queue(function(payload, done) {
206
- const output = [];
207
- const thisBatch = payload.batch;
208
- delete payload.batch;
209
- delete payload.command;
210
-
211
- function logCompletedBatch(batch) {
212
- if (log) {
213
- fs.appendFile(log, ':d batch' + thisBatch + '\n', done);
214
- } else {
215
- done();
216
- }
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();
217
193
  }
218
-
219
- // do the /db/_bulk_get request
220
- db.service.postBulkGet({
221
- db: db.db,
222
- revs: true,
223
- docs: payload.docs
224
- }).then(response => {
225
- // create an output array with the docs returned
226
- response.result.results.forEach(function(d) {
227
- if (d.docs) {
228
- d.docs.forEach(function(doc) {
229
- if (doc.ok) {
230
- output.push(doc.ok);
231
- }
232
- });
233
- }
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');
234
202
  });
235
- total += output.length;
236
- const t = (new Date().getTime() - start) / 1000;
237
- ee.emit('received', {
238
- batch: thisBatch,
239
- data: output,
240
- length: output.length,
241
- time: t,
242
- total: total
243
- }, q, logCompletedBatch);
244
- }).catch(err => {
245
- if (!hasErrored) {
246
- hasErrored = true;
247
- err = error.convertResponseError(err);
248
- // Kill the queue for fatal errors
249
- q.kill();
250
- ee.emit('error', err);
251
- }
252
203
  done();
253
- });
254
- }, parallelism);
255
-
256
- for (const i in batches) {
257
- q.push(batches[i]);
258
- }
259
-
260
- q.drain(function() {
261
- callback(null, { total: total });
204
+ } catch (e) {
205
+ done(e);
206
+ } finally {
207
+ releaseStderr();
208
+ }
262
209
  });
263
- }
264
-
265
- /**
266
- * Returns first N properties on an object.
267
- *
268
- * @param {object} obj - object with properties
269
- * @param {number} count - number of properties to return
270
- */
271
- function getPropertyNames(obj, count) {
272
- // decide which batch numbers to deal with
273
- const batchestofetch = [];
274
- let j = 0;
275
- for (const i in obj) {
276
- batchestofetch.push(parseInt(i));
277
- j++;
278
- if (j >= count) break;
279
- }
280
- return batchestofetch;
281
- }
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
+ });
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2021 IBM Corp. All rights reserved.
1
+ // Copyright © 2018, 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,108 +11,82 @@
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
- 'use strict';
15
-
16
- const path = require('path');
17
- const tmp = require('tmp');
18
-
19
- /**
20
- Return API default settings.
21
- */
22
- function apiDefaults() {
23
- return {
24
- parallelism: 5,
25
- bufferSize: 500,
26
- requestTimeout: 120000,
27
- log: tmp.tmpNameSync(),
28
- resume: false,
29
- mode: 'full'
30
- };
31
- }
32
-
33
- /**
34
- Return CLI default settings.
35
- */
36
- function cliDefaults() {
37
- const defaults = apiDefaults();
38
-
39
- // add additional legacy settings
40
- defaults.db = 'test';
41
- defaults.url = 'http://localhost:5984';
42
-
43
- // add CLI only option
44
- defaults.quiet = false;
45
-
46
- return defaults;
47
- }
48
-
49
- /**
50
- Override settings **in-place** with environment variables.
51
- */
52
- function applyEnvironmentVariables(opts) {
53
- // if we have a custom CouchDB url
54
- if (typeof process.env.COUCH_URL !== 'undefined') {
55
- opts.url = process.env.COUCH_URL;
56
- }
57
-
58
- // if we have a specified databases
59
- if (typeof process.env.COUCH_DATABASE !== 'undefined') {
60
- opts.db = process.env.COUCH_DATABASE;
61
- }
62
-
63
- // if we have a specified buffer size
64
- if (typeof process.env.COUCH_BUFFER_SIZE !== 'undefined') {
65
- opts.bufferSize = parseInt(process.env.COUCH_BUFFER_SIZE);
66
- }
67
14
 
68
- // if we have a specified parallelism
69
- if (typeof process.env.COUCH_PARALLELISM !== 'undefined') {
70
- opts.parallelism = parseInt(process.env.COUCH_PARALLELISM);
71
- }
72
-
73
- // if we have a specified request timeout
74
- if (typeof process.env.COUCH_REQUEST_TIMEOUT !== 'undefined') {
75
- opts.requestTimeout = parseInt(process.env.COUCH_REQUEST_TIMEOUT);
76
- }
77
-
78
- // if we have a specified log file
79
- if (typeof process.env.COUCH_LOG !== 'undefined') {
80
- opts.log = path.normalize(process.env.COUCH_LOG);
81
- }
82
-
83
- // if we are instructed to resume
84
- if (typeof process.env.COUCH_RESUME !== 'undefined' && process.env.COUCH_RESUME === 'true') {
85
- opts.resume = true;
86
- }
87
-
88
- // if we are given an output filename
89
- if (typeof process.env.COUCH_OUTPUT !== 'undefined') {
90
- opts.output = path.normalize(process.env.COUCH_OUTPUT);
91
- }
92
-
93
- // if we only want a shallow copy
94
- if (typeof process.env.COUCH_MODE !== 'undefined' && process.env.COUCH_MODE === 'shallow') {
95
- opts.mode = 'shallow';
96
- }
97
-
98
- // if we are instructed to be quiet
99
- if (typeof process.env.COUCH_QUIET !== 'undefined' && process.env.COUCH_QUIET === 'true') {
100
- opts.quiet = true;
101
- }
102
-
103
- // if we have a specified API key
104
- if (typeof process.env.CLOUDANT_IAM_API_KEY !== 'undefined') {
105
- opts.iamApiKey = process.env.CLOUDANT_IAM_API_KEY;
106
- }
107
-
108
- // if we have a specified IAM token endpoint
109
- if (typeof process.env.CLOUDANT_IAM_TOKEN_URL !== 'undefined') {
110
- opts.iamTokenUrl = process.env.CLOUDANT_IAM_TOKEN_URL;
111
- }
112
- }
15
+ /* global describe it */
16
+ 'use strict';
113
17
 
114
- module.exports = {
115
- apiDefaults: apiDefaults,
116
- cliDefaults: cliDefaults,
117
- applyEnvironmentVariables: applyEnvironmentVariables
118
- };
18
+ const fs = require('fs');
19
+ const readline = require('readline');
20
+ const u = require('./citestutils.js');
21
+ const uuid = require('uuid').v4;
22
+
23
+ const params = { useApi: true };
24
+
25
+ describe(u.scenario('Concurrent database backups', params), function() {
26
+ it('should run concurrent API database backups correctly #slower', function(done) {
27
+ // Allow up to 900 s to backup and compare (it should be much faster)!
28
+ u.setTimeout(this, 900);
29
+
30
+ let doneCount = 0;
31
+ let doneErr;
32
+ const finished = function(err) {
33
+ doneCount++;
34
+ if (doneCount === 2) {
35
+ done(doneErr || err);
36
+ }
37
+ doneErr = err;
38
+ };
39
+
40
+ const checkForEmptyBatches = function(fileName, cb) {
41
+ let foundEmptyBatch = false;
42
+
43
+ const rd = readline.createInterface({
44
+ input: fs.createReadStream(fileName),
45
+ output: fs.createWriteStream('/dev/null'),
46
+ terminal: false
47
+ });
48
+
49
+ rd.on('line', function(line) {
50
+ if (JSON.parse(line).length === 0) {
51
+ // Note: Empty batch arrays indicate that the running backup is
52
+ // incorrectly sharing a log file with another ongoing backup job.
53
+ foundEmptyBatch = true;
54
+ }
55
+ });
56
+
57
+ rd.on('close', function() {
58
+ if (foundEmptyBatch) {
59
+ cb(new Error(`Log file '${fileName}' contains empty batches`));
60
+ } else {
61
+ cb();
62
+ }
63
+ });
64
+ };
65
+
66
+ // [1] Run 'largedb2g' database backup
67
+ const actualBackup1 = `./${uuid()}`;
68
+ const output1 = fs.createWriteStream(actualBackup1);
69
+ output1.on('open', function() {
70
+ u.testBackup(params, 'largedb2g', output1, function(err) {
71
+ if (err) {
72
+ finished(err);
73
+ } else {
74
+ checkForEmptyBatches(actualBackup1, finished);
75
+ }
76
+ });
77
+ });
78
+
79
+ // [2] Run 'largedb1g' database backup
80
+ const actualBackup2 = `./${uuid()}`;
81
+ const output2 = fs.createWriteStream(actualBackup2);
82
+ output2.on('open', function() {
83
+ u.testBackup(params, 'largedb1g', output2, function(err) {
84
+ if (err) {
85
+ finished(err);
86
+ } else {
87
+ checkForEmptyBatches(actualBackup2, finished);
88
+ }
89
+ });
90
+ });
91
+ });
92
+ });