@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.
- package/.scannerwork/report-task.txt +2 -2
- package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
- package/.scannerwork/scanner-report/analysis.log +1 -1
- package/.scannerwork/scanner-report/changesets-12.pb +1 -0
- package/.scannerwork/scanner-report/changesets-13.pb +1 -0
- package/.scannerwork/scanner-report/changesets-2.pb +1 -0
- package/.scannerwork/scanner-report/changesets-28.pb +1 -0
- package/.scannerwork/scanner-report/changesets-29.pb +1 -0
- package/.scannerwork/scanner-report/changesets-3.pb +1 -0
- package/.scannerwork/scanner-report/changesets-31.pb +1 -0
- package/.scannerwork/scanner-report/changesets-34.pb +1 -0
- package/.scannerwork/scanner-report/changesets-35.pb +1 -0
- package/.scannerwork/scanner-report/changesets-4.pb +1 -0
- package/.scannerwork/scanner-report/changesets-67.pb +1 -0
- package/.scannerwork/scanner-report/changesets-68.pb +1 -0
- package/.scannerwork/scanner-report/changesets-7.pb +1 -0
- package/.scannerwork/scanner-report/changesets-8.pb +1 -0
- package/.scannerwork/scanner-report/component-1.pb +2 -2
- package/.scannerwork/scanner-report/component-10.pb +1 -1
- package/.scannerwork/scanner-report/component-11.pb +1 -1
- package/.scannerwork/scanner-report/component-12.pb +1 -0
- package/.scannerwork/scanner-report/component-13.pb +1 -1
- package/.scannerwork/scanner-report/component-14.pb +1 -1
- package/.scannerwork/scanner-report/component-19.pb +1 -1
- package/.scannerwork/scanner-report/component-2.pb +1 -0
- package/.scannerwork/scanner-report/component-20.pb +1 -1
- package/.scannerwork/scanner-report/component-21.pb +1 -1
- package/.scannerwork/scanner-report/component-22.pb +1 -1
- package/.scannerwork/scanner-report/component-23.pb +1 -1
- package/.scannerwork/scanner-report/component-24.pb +1 -1
- package/.scannerwork/scanner-report/component-25.pb +1 -1
- package/.scannerwork/scanner-report/component-26.pb +1 -1
- package/.scannerwork/scanner-report/component-27.pb +1 -1
- package/.scannerwork/scanner-report/component-28.pb +1 -0
- package/.scannerwork/scanner-report/component-29.pb +1 -0
- package/.scannerwork/scanner-report/component-3.pb +1 -0
- package/.scannerwork/scanner-report/component-30.pb +1 -1
- package/.scannerwork/scanner-report/component-31.pb +1 -0
- package/.scannerwork/scanner-report/component-32.pb +1 -1
- package/.scannerwork/scanner-report/component-33.pb +1 -1
- package/.scannerwork/scanner-report/component-34.pb +1 -0
- package/.scannerwork/scanner-report/component-35.pb +1 -0
- package/.scannerwork/scanner-report/component-4.pb +1 -0
- package/.scannerwork/scanner-report/component-47.pb +1 -1
- package/.scannerwork/scanner-report/component-48.pb +1 -1
- package/.scannerwork/scanner-report/component-49.pb +1 -1
- package/.scannerwork/scanner-report/component-5.pb +1 -1
- package/.scannerwork/scanner-report/component-50.pb +1 -1
- package/.scannerwork/scanner-report/component-51.pb +1 -1
- package/.scannerwork/scanner-report/component-52.pb +1 -1
- package/.scannerwork/scanner-report/component-54.pb +1 -1
- package/.scannerwork/scanner-report/component-56.pb +1 -1
- package/.scannerwork/scanner-report/component-59.pb +1 -1
- package/.scannerwork/scanner-report/component-6.pb +1 -1
- package/.scannerwork/scanner-report/component-60.pb +1 -1
- package/.scannerwork/scanner-report/component-65.pb +1 -0
- package/.scannerwork/scanner-report/component-66.pb +1 -0
- package/.scannerwork/scanner-report/component-67.pb +1 -1
- package/.scannerwork/scanner-report/component-68.pb +1 -1
- package/.scannerwork/scanner-report/component-7.pb +1 -0
- package/.scannerwork/scanner-report/component-8.pb +1 -0
- package/.scannerwork/scanner-report/component-9.pb +1 -1
- package/.scannerwork/scanner-report/coverages-10.pb +0 -0
- package/.scannerwork/scanner-report/coverages-11.pb +0 -0
- package/.scannerwork/scanner-report/coverages-13.pb +0 -0
- package/.scannerwork/scanner-report/coverages-14.pb +0 -0
- package/.scannerwork/scanner-report/coverages-19.pb +0 -0
- package/.scannerwork/scanner-report/coverages-2.pb +0 -0
- package/.scannerwork/scanner-report/coverages-20.pb +0 -0
- package/.scannerwork/scanner-report/coverages-21.pb +0 -0
- package/.scannerwork/scanner-report/coverages-22.pb +0 -0
- package/.scannerwork/scanner-report/coverages-23.pb +0 -0
- package/.scannerwork/scanner-report/coverages-24.pb +0 -0
- package/.scannerwork/scanner-report/coverages-25.pb +0 -0
- package/.scannerwork/scanner-report/coverages-26.pb +0 -0
- package/.scannerwork/scanner-report/coverages-27.pb +0 -0
- package/.scannerwork/scanner-report/coverages-28.pb +0 -0
- package/.scannerwork/scanner-report/coverages-29.pb +0 -0
- package/.scannerwork/scanner-report/coverages-3.pb +0 -0
- package/.scannerwork/scanner-report/coverages-30.pb +0 -0
- package/.scannerwork/scanner-report/coverages-32.pb +0 -0
- package/.scannerwork/scanner-report/coverages-33.pb +0 -0
- package/.scannerwork/scanner-report/coverages-34.pb +0 -0
- package/.scannerwork/scanner-report/coverages-4.pb +0 -0
- package/.scannerwork/scanner-report/coverages-47.pb +0 -0
- package/.scannerwork/scanner-report/coverages-48.pb +0 -0
- package/.scannerwork/scanner-report/coverages-49.pb +0 -0
- package/.scannerwork/scanner-report/coverages-5.pb +0 -0
- package/.scannerwork/scanner-report/coverages-50.pb +0 -0
- package/.scannerwork/scanner-report/coverages-51.pb +0 -0
- package/.scannerwork/scanner-report/coverages-52.pb +0 -0
- package/.scannerwork/scanner-report/coverages-56.pb +0 -0
- package/.scannerwork/scanner-report/coverages-59.pb +0 -0
- package/.scannerwork/scanner-report/coverages-6.pb +0 -0
- package/.scannerwork/scanner-report/coverages-60.pb +0 -0
- package/.scannerwork/scanner-report/coverages-67.pb +0 -0
- package/.scannerwork/scanner-report/coverages-68.pb +0 -0
- package/.scannerwork/scanner-report/coverages-7.pb +0 -0
- package/.scannerwork/scanner-report/coverages-8.pb +0 -0
- package/.scannerwork/scanner-report/coverages-9.pb +0 -0
- package/.scannerwork/scanner-report/duplications-2.pb +2 -0
- package/.scannerwork/scanner-report/duplications-21.pb +3 -0
- package/.scannerwork/scanner-report/duplications-24.pb +0 -2
- package/.scannerwork/scanner-report/duplications-26.pb +0 -2
- package/.scannerwork/scanner-report/duplications-27.pb +2 -0
- package/.scannerwork/scanner-report/duplications-29.pb +2 -0
- package/.scannerwork/scanner-report/duplications-32.pb +3 -2
- package/.scannerwork/scanner-report/duplications-33.pb +0 -2
- package/.scannerwork/scanner-report/duplications-34.pb +2 -0
- package/.scannerwork/scanner-report/duplications-4.pb +2 -0
- package/.scannerwork/scanner-report/duplications-49.pb +0 -3
- package/.scannerwork/scanner-report/duplications-5.pb +0 -2
- package/.scannerwork/scanner-report/duplications-52.pb +3 -0
- package/.scannerwork/scanner-report/duplications-56.pb +0 -3
- package/.scannerwork/scanner-report/duplications-59.pb +2 -2
- package/.scannerwork/scanner-report/duplications-6.pb +0 -2
- package/.scannerwork/scanner-report/duplications-60.pb +2 -0
- package/.scannerwork/scanner-report/issues-21.pb +4 -0
- package/.scannerwork/scanner-report/issues-49.pb +5 -3
- package/.scannerwork/scanner-report/measures-10.pb +0 -0
- package/.scannerwork/scanner-report/measures-11.pb +0 -0
- package/.scannerwork/scanner-report/measures-13.pb +0 -0
- package/.scannerwork/scanner-report/measures-14.pb +0 -0
- package/.scannerwork/scanner-report/measures-19.pb +0 -0
- package/.scannerwork/scanner-report/measures-2.pb +0 -0
- package/.scannerwork/scanner-report/measures-20.pb +0 -0
- package/.scannerwork/scanner-report/measures-21.pb +0 -0
- package/.scannerwork/scanner-report/measures-22.pb +0 -0
- package/.scannerwork/scanner-report/measures-23.pb +0 -0
- package/.scannerwork/scanner-report/measures-24.pb +0 -0
- package/.scannerwork/scanner-report/measures-25.pb +0 -0
- package/.scannerwork/scanner-report/measures-26.pb +0 -0
- package/.scannerwork/scanner-report/measures-27.pb +0 -0
- package/.scannerwork/scanner-report/measures-28.pb +0 -0
- package/.scannerwork/scanner-report/measures-29.pb +15 -0
- package/.scannerwork/scanner-report/measures-3.pb +16 -0
- package/.scannerwork/scanner-report/measures-30.pb +0 -0
- package/.scannerwork/scanner-report/measures-32.pb +0 -0
- package/.scannerwork/scanner-report/measures-33.pb +0 -0
- package/.scannerwork/scanner-report/measures-34.pb +0 -0
- package/.scannerwork/scanner-report/measures-35.pb +0 -0
- package/.scannerwork/scanner-report/measures-4.pb +0 -0
- package/.scannerwork/scanner-report/measures-47.pb +0 -0
- package/.scannerwork/scanner-report/measures-48.pb +0 -0
- package/.scannerwork/scanner-report/measures-49.pb +0 -0
- package/.scannerwork/scanner-report/measures-5.pb +0 -0
- package/.scannerwork/scanner-report/measures-50.pb +0 -0
- package/.scannerwork/scanner-report/measures-51.pb +0 -0
- package/.scannerwork/scanner-report/measures-52.pb +0 -0
- package/.scannerwork/scanner-report/measures-54.pb +0 -0
- package/.scannerwork/scanner-report/measures-56.pb +0 -0
- package/.scannerwork/scanner-report/measures-59.pb +0 -0
- package/.scannerwork/scanner-report/measures-6.pb +0 -0
- package/.scannerwork/scanner-report/measures-60.pb +0 -0
- package/.scannerwork/scanner-report/measures-65.pb +0 -0
- package/.scannerwork/scanner-report/measures-66.pb +0 -0
- package/.scannerwork/scanner-report/measures-67.pb +0 -0
- package/.scannerwork/scanner-report/measures-68.pb +0 -0
- package/.scannerwork/scanner-report/measures-7.pb +0 -0
- package/.scannerwork/scanner-report/measures-8.pb +0 -0
- package/.scannerwork/scanner-report/measures-9.pb +0 -0
- package/.scannerwork/scanner-report/metadata.pb +0 -0
- package/.scannerwork/scanner-report/source-10.txt +257 -53
- package/.scannerwork/scanner-report/source-11.txt +100 -96
- package/.scannerwork/scanner-report/source-13.txt +129 -509
- package/.scannerwork/scanner-report/source-14.txt +83 -59
- package/.scannerwork/scanner-report/source-19.txt +88 -255
- package/.scannerwork/scanner-report/source-2.txt +75 -0
- package/.scannerwork/scanner-report/source-20.txt +20 -96
- package/.scannerwork/scanner-report/source-21.txt +228 -162
- package/.scannerwork/scanner-report/source-22.txt +22 -115
- package/.scannerwork/scanner-report/source-23.txt +584 -123
- package/.scannerwork/scanner-report/source-24.txt +18 -59
- package/.scannerwork/scanner-report/source-25.txt +142 -40
- package/.scannerwork/scanner-report/source-26.txt +132 -77
- package/.scannerwork/scanner-report/source-27.txt +124 -83
- package/.scannerwork/scanner-report/{source-62.txt → source-28.txt} +13 -6
- package/.scannerwork/scanner-report/source-29.txt +293 -0
- package/.scannerwork/scanner-report/source-3.txt +178 -0
- package/.scannerwork/scanner-report/source-30.txt +63 -389
- package/.scannerwork/scanner-report/source-32.txt +90 -252
- package/.scannerwork/scanner-report/source-33.txt +41 -118
- package/.scannerwork/scanner-report/source-34.txt +225 -0
- package/.scannerwork/scanner-report/source-35.txt +47 -0
- package/.scannerwork/scanner-report/source-4.txt +92 -0
- package/.scannerwork/scanner-report/source-47.txt +38 -11
- package/.scannerwork/scanner-report/source-48.txt +45 -133
- package/.scannerwork/scanner-report/source-49.txt +329 -207
- package/.scannerwork/scanner-report/source-5.txt +87 -166
- package/.scannerwork/scanner-report/source-50.txt +10 -347
- package/.scannerwork/scanner-report/source-51.txt +83 -19
- package/.scannerwork/scanner-report/source-52.txt +82 -31
- package/.scannerwork/scanner-report/source-54.txt +167 -47
- package/.scannerwork/scanner-report/source-56.txt +394 -95
- package/.scannerwork/scanner-report/source-59.txt +161 -196
- package/.scannerwork/scanner-report/source-6.txt +145 -156
- package/.scannerwork/scanner-report/source-60.txt +158 -18
- package/.scannerwork/scanner-report/source-65.txt +509 -0
- package/.scannerwork/scanner-report/source-66.txt +509 -0
- package/.scannerwork/scanner-report/source-67.txt +77 -509
- package/.scannerwork/scanner-report/source-68.txt +56 -167
- package/.scannerwork/scanner-report/source-7.txt +80 -0
- package/.scannerwork/scanner-report/source-8.txt +54 -0
- package/.scannerwork/scanner-report/source-9.txt +14 -39
- package/.scannerwork/scanner-report/symbols-10.pb +354 -30
- package/.scannerwork/scanner-report/symbols-11.pb +29 -27
- package/.scannerwork/scanner-report/symbols-13.pb +33 -0
- package/.scannerwork/scanner-report/symbols-14.pb +41 -45
- package/.scannerwork/scanner-report/symbols-19.pb +28 -354
- package/.scannerwork/scanner-report/symbols-2.pb +42 -0
- package/.scannerwork/scanner-report/symbols-20.pb +16 -58
- package/.scannerwork/scanner-report/symbols-21.pb +384 -134
- package/.scannerwork/scanner-report/symbols-22.pb +14 -33
- package/.scannerwork/scanner-report/symbols-23.pb +1241 -113
- package/.scannerwork/scanner-report/symbols-24.pb +9 -41
- package/.scannerwork/scanner-report/symbols-25.pb +111 -14
- package/.scannerwork/scanner-report/symbols-26.pb +84 -43
- package/.scannerwork/scanner-report/symbols-27.pb +102 -42
- package/.scannerwork/scanner-report/symbols-28.pb +11 -0
- package/.scannerwork/scanner-report/symbols-29.pb +486 -0
- package/.scannerwork/scanner-report/symbols-3.pb +144 -0
- package/.scannerwork/scanner-report/symbols-30.pb +60 -610
- package/.scannerwork/scanner-report/symbols-32.pb +97 -486
- package/.scannerwork/scanner-report/symbols-33.pb +36 -102
- package/.scannerwork/scanner-report/symbols-34.pb +418 -0
- package/.scannerwork/scanner-report/symbols-4.pb +44 -0
- package/.scannerwork/scanner-report/symbols-47.pb +43 -14
- package/.scannerwork/scanner-report/symbols-48.pb +44 -111
- package/.scannerwork/scanner-report/symbols-49.pb +455 -355
- package/.scannerwork/scanner-report/symbols-5.pb +59 -180
- package/.scannerwork/scanner-report/symbols-50.pb +9 -494
- package/.scannerwork/scanner-report/symbols-51.pb +69 -11
- package/.scannerwork/scanner-report/symbols-52.pb +74 -33
- package/.scannerwork/scanner-report/symbols-56.pb +610 -77
- package/.scannerwork/scanner-report/symbols-59.pb +178 -416
- package/.scannerwork/scanner-report/symbols-6.pb +120 -147
- package/.scannerwork/scanner-report/symbols-60.pb +152 -16
- package/.scannerwork/scanner-report/symbols-67.pb +30 -0
- package/.scannerwork/scanner-report/symbols-68.pb +19 -0
- package/.scannerwork/scanner-report/symbols-7.pb +46 -0
- package/.scannerwork/scanner-report/symbols-8.pb +15 -0
- package/.scannerwork/scanner-report/symbols-9.pb +13 -18
- package/.scannerwork/scanner-report/syntax-highlightings-10.pb +255 -73
- package/.scannerwork/scanner-report/syntax-highlightings-11.pb +79 -104
- package/.scannerwork/scanner-report/syntax-highlightings-13.pb +118 -3736
- package/.scannerwork/scanner-report/syntax-highlightings-14.pb +81 -60
- package/.scannerwork/scanner-report/syntax-highlightings-19.pb +103 -250
- package/.scannerwork/scanner-report/syntax-highlightings-2.pb +78 -0
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +29 -99
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +269 -183
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +22 -97
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +815 -141
- package/.scannerwork/scanner-report/syntax-highlightings-24.pb +17 -45
- package/.scannerwork/scanner-report/syntax-highlightings-25.pb +193 -24
- package/.scannerwork/scanner-report/syntax-highlightings-26.pb +157 -56
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +195 -84
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +59 -0
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +659 -0
- package/.scannerwork/scanner-report/syntax-highlightings-3.pb +243 -0
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +74 -612
- package/.scannerwork/scanner-report/syntax-highlightings-32.pb +147 -624
- package/.scannerwork/scanner-report/syntax-highlightings-33.pb +57 -189
- package/.scannerwork/scanner-report/syntax-highlightings-34.pb +331 -0
- package/.scannerwork/scanner-report/syntax-highlightings-35.pb +68 -0
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +90 -0
- package/.scannerwork/scanner-report/syntax-highlightings-47.pb +47 -19
- package/.scannerwork/scanner-report/syntax-highlightings-48.pb +63 -176
- package/.scannerwork/scanner-report/syntax-highlightings-49.pb +498 -197
- package/.scannerwork/scanner-report/syntax-highlightings-5.pb +100 -192
- package/.scannerwork/scanner-report/syntax-highlightings-50.pb +15 -597
- package/.scannerwork/scanner-report/syntax-highlightings-51.pb +71 -25
- package/.scannerwork/scanner-report/syntax-highlightings-52.pb +118 -55
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +938 -57
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +619 -129
- package/.scannerwork/scanner-report/syntax-highlightings-59.pb +170 -276
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +155 -156
- package/.scannerwork/scanner-report/syntax-highlightings-60.pb +185 -34
- package/.scannerwork/scanner-report/syntax-highlightings-65.pb +3748 -0
- package/.scannerwork/scanner-report/syntax-highlightings-66.pb +3747 -0
- package/.scannerwork/scanner-report/syntax-highlightings-67.pb +72 -3717
- package/.scannerwork/scanner-report/syntax-highlightings-68.pb +54 -921
- package/.scannerwork/scanner-report/syntax-highlightings-7.pb +95 -0
- package/.scannerwork/scanner-report/syntax-highlightings-8.pb +54 -0
- package/.scannerwork/scanner-report/syntax-highlightings-9.pb +33 -70
- package/CHANGES.md +6 -2
- package/package.json +1 -1
- package/test-16-results.xml +150 -150
- package/test-18-results.xml +149 -149
- package/test-iam-18-results.xml +50 -50
- package/.scannerwork/scanner-report/changesets-16.pb +0 -1
- package/.scannerwork/scanner-report/changesets-17.pb +0 -1
- package/.scannerwork/scanner-report/changesets-18.pb +0 -1
- package/.scannerwork/scanner-report/changesets-45.pb +0 -1
- package/.scannerwork/scanner-report/changesets-46.pb +0 -1
- package/.scannerwork/scanner-report/changesets-53.pb +0 -1
- package/.scannerwork/scanner-report/changesets-54.pb +0 -1
- package/.scannerwork/scanner-report/changesets-55.pb +0 -1
- package/.scannerwork/scanner-report/changesets-57.pb +0 -1
- package/.scannerwork/scanner-report/changesets-58.pb +0 -1
- package/.scannerwork/scanner-report/changesets-61.pb +0 -1
- package/.scannerwork/scanner-report/changesets-62.pb +0 -1
- package/.scannerwork/scanner-report/changesets-63.pb +0 -1
- package/.scannerwork/scanner-report/changesets-64.pb +0 -1
- package/.scannerwork/scanner-report/component-16.pb +0 -1
- package/.scannerwork/scanner-report/component-17.pb +0 -1
- package/.scannerwork/scanner-report/component-18.pb +0 -1
- package/.scannerwork/scanner-report/component-45.pb +0 -1
- package/.scannerwork/scanner-report/component-46.pb +0 -1
- package/.scannerwork/scanner-report/component-53.pb +0 -1
- package/.scannerwork/scanner-report/component-55.pb +0 -1
- package/.scannerwork/scanner-report/component-57.pb +0 -1
- package/.scannerwork/scanner-report/component-58.pb +0 -1
- package/.scannerwork/scanner-report/component-61.pb +0 -1
- package/.scannerwork/scanner-report/component-62.pb +0 -1
- package/.scannerwork/scanner-report/component-63.pb +0 -1
- package/.scannerwork/scanner-report/component-64.pb +0 -1
- package/.scannerwork/scanner-report/coverages-16.pb +0 -0
- package/.scannerwork/scanner-report/coverages-18.pb +0 -0
- package/.scannerwork/scanner-report/coverages-45.pb +0 -0
- package/.scannerwork/scanner-report/coverages-53.pb +0 -0
- package/.scannerwork/scanner-report/coverages-55.pb +0 -0
- package/.scannerwork/scanner-report/coverages-57.pb +0 -0
- package/.scannerwork/scanner-report/coverages-58.pb +0 -0
- package/.scannerwork/scanner-report/coverages-61.pb +0 -0
- package/.scannerwork/scanner-report/coverages-62.pb +0 -0
- package/.scannerwork/scanner-report/coverages-63.pb +0 -0
- package/.scannerwork/scanner-report/coverages-64.pb +0 -0
- package/.scannerwork/scanner-report/duplications-58.pb +0 -0
- package/.scannerwork/scanner-report/duplications-61.pb +0 -3
- package/.scannerwork/scanner-report/duplications-63.pb +0 -0
- package/.scannerwork/scanner-report/duplications-64.pb +0 -0
- package/.scannerwork/scanner-report/issues-50.pb +0 -6
- package/.scannerwork/scanner-report/measures-16.pb +0 -0
- package/.scannerwork/scanner-report/measures-18.pb +0 -0
- package/.scannerwork/scanner-report/measures-45.pb +0 -0
- package/.scannerwork/scanner-report/measures-53.pb +0 -0
- package/.scannerwork/scanner-report/measures-55.pb +0 -0
- package/.scannerwork/scanner-report/measures-57.pb +0 -0
- package/.scannerwork/scanner-report/measures-58.pb +0 -0
- package/.scannerwork/scanner-report/measures-61.pb +0 -0
- package/.scannerwork/scanner-report/measures-62.pb +0 -0
- package/.scannerwork/scanner-report/measures-63.pb +0 -0
- package/.scannerwork/scanner-report/measures-64.pb +0 -0
- package/.scannerwork/scanner-report/source-16.txt +0 -118
- package/.scannerwork/scanner-report/source-18.txt +0 -31
- package/.scannerwork/scanner-report/source-45.txt +0 -625
- package/.scannerwork/scanner-report/source-53.txt +0 -92
- package/.scannerwork/scanner-report/source-55.txt +0 -147
- package/.scannerwork/scanner-report/source-57.txt +0 -68
- package/.scannerwork/scanner-report/source-58.txt +0 -63
- package/.scannerwork/scanner-report/source-61.txt +0 -131
- package/.scannerwork/scanner-report/source-63.txt +0 -34
- package/.scannerwork/scanner-report/source-64.txt +0 -100
- package/.scannerwork/scanner-report/symbols-16.pb +0 -30
- package/.scannerwork/scanner-report/symbols-18.pb +0 -14
- package/.scannerwork/scanner-report/symbols-45.pb +0 -1254
- package/.scannerwork/scanner-report/symbols-53.pb +0 -60
- package/.scannerwork/scanner-report/symbols-55.pb +0 -85
- package/.scannerwork/scanner-report/symbols-57.pb +0 -45
- package/.scannerwork/scanner-report/symbols-58.pb +0 -43
- package/.scannerwork/scanner-report/symbols-61.pb +0 -97
- package/.scannerwork/scanner-report/symbols-62.pb +0 -9
- package/.scannerwork/scanner-report/symbols-63.pb +0 -10
- package/.scannerwork/scanner-report/symbols-64.pb +0 -69
- package/.scannerwork/scanner-report/syntax-highlightings-16.pb +0 -113
- package/.scannerwork/scanner-report/syntax-highlightings-18.pb +0 -45
- package/.scannerwork/scanner-report/syntax-highlightings-45.pb +0 -887
- package/.scannerwork/scanner-report/syntax-highlightings-53.pb +0 -110
- package/.scannerwork/scanner-report/syntax-highlightings-55.pb +0 -191
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +0 -110
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +0 -82
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +0 -182
- package/.scannerwork/scanner-report/syntax-highlightings-62.pb +0 -48
- package/.scannerwork/scanner-report/syntax-highlightings-63.pb +0 -50
- package/.scannerwork/scanner-report/syntax-highlightings-64.pb +0 -105
- /package/.scannerwork/scanner-report/{coverages-17.pb → coverages-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-46.pb → coverages-31.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-54.pb → coverages-35.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-16.pb → duplications-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-17.pb → duplications-13.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-18.pb → duplications-28.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-45.pb → duplications-3.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-46.pb → duplications-31.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-35.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-53.pb → duplications-67.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-54.pb → duplications-68.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-55.pb → duplications-7.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-57.pb → duplications-8.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-46.pb → issues-31.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-54.pb → issues-35.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-17.pb → measures-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-46.pb → measures-31.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-17.txt → source-12.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-46.txt → source-31.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-17.pb → symbols-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-46.pb → symbols-31.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-54.pb → symbols-35.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-17.pb → syntax-highlightings-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-46.pb → syntax-highlightings-31.pb} +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright © 2017,
|
|
1
|
+
// Copyright © 2017, 2022 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,180 +11,101 @@
|
|
|
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
|
-
// Small script which backs up a Cloudant or CouchDB database to an S3
|
|
16
|
-
// bucket, using an intermediary file on disk.
|
|
17
|
-
//
|
|
18
|
-
// The script generates the backup object name by combining together the path
|
|
19
|
-
// part of the database URL and the current time.
|
|
20
|
-
|
|
21
14
|
'use strict';
|
|
22
15
|
|
|
23
|
-
const stream = require('stream');
|
|
24
16
|
const fs = require('fs');
|
|
25
|
-
const
|
|
26
|
-
|
|
27
|
-
const
|
|
28
|
-
const
|
|
29
|
-
const debug = require('debug')('s3-backup');
|
|
30
|
-
const tmp = require('tmp');
|
|
31
|
-
const VError = require('verror').VError;
|
|
32
|
-
|
|
33
|
-
/*
|
|
34
|
-
Main function, run from base of file.
|
|
35
|
-
*/
|
|
36
|
-
function main() {
|
|
37
|
-
const argv = require('yargs')
|
|
38
|
-
.usage('Usage: $0 [options]')
|
|
39
|
-
.example('$0 -s https://user:pass@host/db -b <bucket>', 'Backup db to bucket')
|
|
40
|
-
.options({
|
|
41
|
-
source: { alias: 's', nargs: 1, demandOption: true, describe: 'Source database URL' },
|
|
42
|
-
bucket: { alias: 'b', nargs: 1, demandOption: true, describe: 'Destination bucket' },
|
|
43
|
-
prefix: { alias: 'p', nargs: 1, describe: 'Prefix for backup object key', default: 'couchbackup' },
|
|
44
|
-
s3url: { nargs: 1, describe: 'S3 endpoint URL' },
|
|
45
|
-
awsprofile: { nargs: 1, describe: 'The profile section to use in the ~/.aws/credentials file', default: 'default' }
|
|
46
|
-
})
|
|
47
|
-
.help('h').alias('h', 'help')
|
|
48
|
-
.epilog('Copyright (C) IBM 2017')
|
|
49
|
-
.argv;
|
|
50
|
-
|
|
51
|
-
const sourceUrl = argv.source;
|
|
52
|
-
const backupBucket = argv.bucket;
|
|
53
|
-
const backupName = new url.URL(sourceUrl).pathname.split('/').filter(function(x) { return x; }).join('-');
|
|
54
|
-
const backupKeyPrefix = `${argv.prefix}-${backupName}`;
|
|
55
|
-
|
|
56
|
-
const backupKey = `${backupKeyPrefix}-${new Date().toISOString()}`;
|
|
57
|
-
const backupTmpFile = tmp.fileSync();
|
|
58
|
-
|
|
59
|
-
const s3Endpoint = argv.s3url;
|
|
60
|
-
const awsProfile = argv.awsprofile;
|
|
61
|
-
|
|
62
|
-
// Creds are from ~/.aws/credentials, environment etc. (see S3 docs).
|
|
63
|
-
const awsOpts = {
|
|
64
|
-
signatureVersion: 'v4',
|
|
65
|
-
credentials: new AWS.SharedIniFileCredentials({ profile: awsProfile })
|
|
66
|
-
};
|
|
67
|
-
if (typeof s3Endpoint !== 'undefined') {
|
|
68
|
-
awsOpts.endpoint = new AWS.Endpoint(s3Endpoint);
|
|
69
|
-
}
|
|
70
|
-
const s3 = new AWS.S3(awsOpts);
|
|
71
|
-
|
|
72
|
-
debug(`Creating a new backup of ${s(sourceUrl)} at ${backupBucket}/${backupKey}...`);
|
|
73
|
-
bucketAccessible(s3, backupBucket)
|
|
74
|
-
.then(() => {
|
|
75
|
-
return createBackupFile(sourceUrl, backupTmpFile.name);
|
|
76
|
-
})
|
|
77
|
-
.then(() => {
|
|
78
|
-
return uploadNewBackup(s3, backupTmpFile.name, backupBucket, backupKey);
|
|
79
|
-
})
|
|
80
|
-
.then(() => {
|
|
81
|
-
debug('Backup successful!');
|
|
82
|
-
backupTmpFile.removeCallback();
|
|
83
|
-
debug('done.');
|
|
84
|
-
})
|
|
85
|
-
.catch((reason) => {
|
|
86
|
-
debug(`Error: ${reason}`);
|
|
87
|
-
});
|
|
88
|
-
}
|
|
17
|
+
const liner = require('./liner.js');
|
|
18
|
+
const change = require('./change.js');
|
|
19
|
+
const error = require('./error.js');
|
|
20
|
+
const debug = require('debug')('couchbackup:spoolchanges');
|
|
89
21
|
|
|
90
22
|
/**
|
|
91
|
-
*
|
|
92
|
-
*
|
|
23
|
+
* Write log file for all changes from a database, ready for downloading
|
|
24
|
+
* in batches.
|
|
93
25
|
*
|
|
94
|
-
* @param {
|
|
95
|
-
* @param {
|
|
96
|
-
* @
|
|
26
|
+
* @param {string} dbUrl - URL of database
|
|
27
|
+
* @param {string} log - path to log file to use
|
|
28
|
+
* @param {number} bufferSize - the number of changes per batch/log line
|
|
29
|
+
* @param {function(err)} callback - a callback to run on completion
|
|
97
30
|
*/
|
|
98
|
-
function
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
31
|
+
module.exports = function(db, log, bufferSize, ee, callback) {
|
|
32
|
+
// list of document ids to process
|
|
33
|
+
const buffer = [];
|
|
34
|
+
let batch = 0;
|
|
35
|
+
let lastSeq = null;
|
|
36
|
+
const logStream = fs.createWriteStream(log);
|
|
37
|
+
let pending = 0;
|
|
38
|
+
// The number of changes to fetch per request
|
|
39
|
+
const limit = 100000;
|
|
40
|
+
|
|
41
|
+
// send documents ids to the queue in batches of bufferSize + the last batch
|
|
42
|
+
const processBuffer = function(lastOne) {
|
|
43
|
+
if (buffer.length >= bufferSize || (lastOne && buffer.length > 0)) {
|
|
44
|
+
debug('writing', buffer.length, 'changes to the backup file');
|
|
45
|
+
const b = { docs: buffer.splice(0, bufferSize), batch: batch };
|
|
46
|
+
logStream.write(':t batch' + batch + ' ' + JSON.stringify(b.docs) + '\n');
|
|
47
|
+
ee.emit('changes', batch);
|
|
48
|
+
batch++;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
112
51
|
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
(err) => {
|
|
126
|
-
if (err) {
|
|
127
|
-
return reject(new VError(err, 'CouchBackup process failed'));
|
|
128
|
-
}
|
|
129
|
-
debug('couchbackup to file done; uploading to S3');
|
|
130
|
-
resolve('creating backup file complete');
|
|
52
|
+
// called once per received change
|
|
53
|
+
const onChange = function(c) {
|
|
54
|
+
if (c) {
|
|
55
|
+
if (c.error) {
|
|
56
|
+
ee.emit('error', new error.BackupError('InvalidChange', `Received invalid change: ${c}`));
|
|
57
|
+
} else if (c.changes) {
|
|
58
|
+
const obj = { id: c.id };
|
|
59
|
+
buffer.push(obj);
|
|
60
|
+
processBuffer(false);
|
|
61
|
+
} else if (c.last_seq) {
|
|
62
|
+
lastSeq = c.last_seq;
|
|
63
|
+
pending = c.pending;
|
|
131
64
|
}
|
|
132
|
-
);
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
/**
|
|
137
|
-
* Upload a backup file to an S3 bucket.
|
|
138
|
-
*
|
|
139
|
-
* @param {any} s3 Object store client
|
|
140
|
-
* @param {any} backupTmpFilePath Path of backup file to write.
|
|
141
|
-
* @param {any} bucket Object store bucket name
|
|
142
|
-
* @param {any} key Object store key name
|
|
143
|
-
* @returns Promise
|
|
144
|
-
*/
|
|
145
|
-
function uploadNewBackup(s3, backupTmpFilePath, bucket, key) {
|
|
146
|
-
return new Promise((resolve, reject) => {
|
|
147
|
-
debug(`Uploading from ${backupTmpFilePath} to ${bucket}/${key}`);
|
|
148
|
-
|
|
149
|
-
function uploadFromStream(s3, bucket, key) {
|
|
150
|
-
const pass = new stream.PassThrough();
|
|
151
|
-
|
|
152
|
-
const params = {
|
|
153
|
-
Bucket: bucket,
|
|
154
|
-
Key: key,
|
|
155
|
-
Body: pass
|
|
156
|
-
};
|
|
157
|
-
s3.upload(params, function(err, data) {
|
|
158
|
-
debug('S3 upload done');
|
|
159
|
-
if (err) {
|
|
160
|
-
debug(err);
|
|
161
|
-
reject(new VError(err, 'Upload failed'));
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
debug('Upload succeeded');
|
|
165
|
-
debug(data);
|
|
166
|
-
resolve();
|
|
167
|
-
}).httpUploadProgress = (progress) => {
|
|
168
|
-
debug(`S3 upload progress: ${progress}`);
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
return pass;
|
|
172
65
|
}
|
|
66
|
+
};
|
|
173
67
|
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
68
|
+
function getChanges(since = 0) {
|
|
69
|
+
debug('making changes request since ' + since);
|
|
70
|
+
return db.service.postChangesAsStream({ db: db.db, since: since, limit: limit, seqInterval: limit })
|
|
71
|
+
.then(response => {
|
|
72
|
+
response.result.pipe(liner())
|
|
73
|
+
.on('error', function(err) {
|
|
74
|
+
logStream.end();
|
|
75
|
+
callback(err);
|
|
76
|
+
})
|
|
77
|
+
.pipe(change(onChange))
|
|
78
|
+
.on('error', function(err) {
|
|
79
|
+
logStream.end();
|
|
80
|
+
callback(err);
|
|
81
|
+
})
|
|
82
|
+
.on('finish', function() {
|
|
83
|
+
processBuffer(true);
|
|
84
|
+
if (!lastSeq) {
|
|
85
|
+
logStream.end();
|
|
86
|
+
debug('changes request terminated before last_seq was sent');
|
|
87
|
+
callback(new error.BackupError('SpoolChangesError', 'Changes request terminated before last_seq was sent'));
|
|
88
|
+
} else {
|
|
89
|
+
debug(`changes request completed with last_seq: ${lastSeq} and ${pending} changes pending.`);
|
|
90
|
+
if (pending > 0) {
|
|
91
|
+
// Return the next promise
|
|
92
|
+
return getChanges(lastSeq);
|
|
93
|
+
} else {
|
|
94
|
+
debug('finished streaming database changes');
|
|
95
|
+
logStream.end(':changes_complete ' + lastSeq + '\n', 'utf8', callback);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
})
|
|
100
|
+
.catch(err => {
|
|
101
|
+
logStream.end();
|
|
102
|
+
if (err.status && err.status >= 400) {
|
|
103
|
+
callback(error.convertResponseError(err));
|
|
104
|
+
} else if (err.name !== 'SpoolChangesError') {
|
|
105
|
+
callback(new error.BackupError('SpoolChangesError', `Failed changes request - ${err.message}`));
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
189
109
|
|
|
190
|
-
|
|
110
|
+
getChanges();
|
|
111
|
+
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright © 2017
|
|
1
|
+
// Copyright © 2017 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.
|
|
@@ -12,355 +12,18 @@
|
|
|
12
12
|
// See the License for the specific language governing permissions and
|
|
13
13
|
// limitations under the License.
|
|
14
14
|
|
|
15
|
-
/* global describe
|
|
15
|
+
/* global describe it */
|
|
16
16
|
'use strict';
|
|
17
17
|
|
|
18
|
-
const
|
|
19
|
-
const parser = require('../includes/parser.js');
|
|
18
|
+
const u = require('./citestutils.js');
|
|
20
19
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
processArgvCopy = JSON.parse(JSON.stringify(process.argv));
|
|
29
|
-
|
|
30
|
-
// setup environment variables
|
|
31
|
-
process.env.COUCH_URL = 'http://user:pass@myurl.com';
|
|
32
|
-
process.env.COUCH_DATABASE = 'mydb';
|
|
33
|
-
process.env.COUCH_BUFFER_SIZE = '1000';
|
|
34
|
-
process.env.COUCH_PARALLELISM = '20';
|
|
35
|
-
process.env.COUCH_REQUEST_TIMEOUT = '20000';
|
|
36
|
-
process.env.COUCH_LOG = 'my.log';
|
|
37
|
-
process.env.COUCH_RESUME = 'true';
|
|
38
|
-
process.env.COUCH_OUTPUT = 'myfile.txt';
|
|
39
|
-
process.env.COUCH_MODE = 'shallow';
|
|
40
|
-
process.env.CLOUDANT_IAM_API_KEY = 'ABC123-ZYX987_cba789-xyz321';
|
|
41
|
-
process.env.COUCH_QUIET = 'true';
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
after('Reset process data', function() {
|
|
45
|
-
process.env = processEnvCopy;
|
|
46
|
-
process.argv = processArgvCopy;
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
afterEach(function() {
|
|
50
|
-
delete require.cache[require.resolve('commander')];
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
describe('Backup command-line', function() {
|
|
54
|
-
it('respects the COUCH_URL env variable if the --url backup command-line parameter is missing', function(done) {
|
|
55
|
-
process.argv = ['node', 'test'];
|
|
56
|
-
const program = parser.parseBackupArgs();
|
|
57
|
-
assert.strictEqual(typeof program.url, 'string');
|
|
58
|
-
assert.strictEqual(program.url, process.env.COUCH_URL);
|
|
59
|
-
done();
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it('respects the COUCH_DATABASE env variable if the --db backup command-line parameter is missing', function(done) {
|
|
63
|
-
process.argv = ['node', 'test'];
|
|
64
|
-
const program = parser.parseBackupArgs();
|
|
65
|
-
assert.strictEqual(typeof program.db, 'string');
|
|
66
|
-
assert.strictEqual(program.db, process.env.COUCH_DATABASE);
|
|
67
|
-
done();
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('respects the COUCH_BUFFER_SIZE env variable if the --buffer-size backup command-line parameter is missing', function(done) {
|
|
71
|
-
process.argv = ['node', 'test'];
|
|
72
|
-
const program = parser.parseBackupArgs();
|
|
73
|
-
assert.strictEqual(typeof program.bufferSize, 'number');
|
|
74
|
-
assert.strictEqual(program.bufferSize, parseInt(process.env.COUCH_BUFFER_SIZE, 10));
|
|
75
|
-
done();
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
it('respects the COUCH_PARALLELISM env variable if the --parallelism backup command-line parameter is missing', function(done) {
|
|
79
|
-
process.argv = ['node', 'test'];
|
|
80
|
-
const program = parser.parseBackupArgs();
|
|
81
|
-
assert.strictEqual(typeof program.parallelism, 'number');
|
|
82
|
-
assert.strictEqual(program.parallelism, parseInt(process.env.COUCH_PARALLELISM, 10));
|
|
83
|
-
done();
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
it('respects the COUCH_REQUEST_TIMEOUT env variable if the --request-timeout backup command-line parameter is missing', function(done) {
|
|
87
|
-
process.argv = ['node', 'test'];
|
|
88
|
-
const program = parser.parseBackupArgs();
|
|
89
|
-
assert.strictEqual(typeof program.requestTimeout, 'number');
|
|
90
|
-
assert.strictEqual(program.requestTimeout, parseInt(process.env.COUCH_REQUEST_TIMEOUT, 10));
|
|
91
|
-
done();
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('respects the CLOUDANT_IAM_API_KEY env variable if the --iam-api-key backup command-line parameter is missing', function(done) {
|
|
95
|
-
process.argv = ['node', 'test'];
|
|
96
|
-
const program = parser.parseBackupArgs();
|
|
97
|
-
assert.strictEqual(typeof program.iamApiKey, 'string');
|
|
98
|
-
assert.strictEqual(program.iamApiKey, process.env.CLOUDANT_IAM_API_KEY);
|
|
99
|
-
done();
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
it('respects the COUCH_LOG env variable if the --log backup command-line parameter is missing', function(done) {
|
|
103
|
-
process.argv = ['node', 'test'];
|
|
104
|
-
const program = parser.parseBackupArgs();
|
|
105
|
-
assert.strictEqual(typeof program.log, 'string');
|
|
106
|
-
assert.strictEqual(program.log, process.env.COUCH_LOG);
|
|
107
|
-
done();
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
it('respects the COUCH_RESUME env variable if the --resume backup command-line parameter is missing', function(done) {
|
|
111
|
-
process.argv = ['node', 'test'];
|
|
112
|
-
const program = parser.parseBackupArgs();
|
|
113
|
-
assert.strictEqual(typeof program.resume, 'boolean');
|
|
114
|
-
assert.strictEqual(program.resume, true);
|
|
115
|
-
done();
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
it('respects the COUCH_OUTPUT env variable if the --output backup command-line parameter is missing', function(done) {
|
|
119
|
-
process.argv = ['node', 'test'];
|
|
120
|
-
const program = parser.parseBackupArgs();
|
|
121
|
-
assert.strictEqual(typeof program.output, 'string');
|
|
122
|
-
assert.strictEqual(program.output, process.env.COUCH_OUTPUT);
|
|
123
|
-
done();
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
it('respects the COUCH_MODE env variable if the --mode backup command-line parameter is missing', function(done) {
|
|
127
|
-
process.argv = ['node', 'test'];
|
|
128
|
-
const program = parser.parseBackupArgs();
|
|
129
|
-
assert.strictEqual(typeof program.mode, 'string');
|
|
130
|
-
assert.strictEqual(program.mode, process.env.COUCH_MODE);
|
|
131
|
-
done();
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
it('respects the COUCH_QUIET env variable if the --quiet backup command-line parameter is missing', function(done) {
|
|
135
|
-
process.argv = ['node', 'test'];
|
|
136
|
-
const program = parser.parseBackupArgs();
|
|
137
|
-
assert.strictEqual(typeof program.quiet, 'boolean');
|
|
138
|
-
assert.strictEqual(program.quiet, true);
|
|
139
|
-
done();
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
it('respects the backup --url command-line parameter', function(done) {
|
|
143
|
-
const url = 'http://user:pass@myurl2.com';
|
|
144
|
-
process.argv = ['node', 'test', '--url', url];
|
|
145
|
-
const program = parser.parseBackupArgs();
|
|
146
|
-
assert.strictEqual(typeof program.url, 'string');
|
|
147
|
-
assert.strictEqual(program.url, url);
|
|
148
|
-
done();
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
it('respects the backup --db command-line parameter', function(done) {
|
|
152
|
-
const db = 'mydb2';
|
|
153
|
-
process.argv = ['node', 'test', '--db', db];
|
|
154
|
-
const program = parser.parseBackupArgs();
|
|
155
|
-
assert.strictEqual(typeof program.db, 'string');
|
|
156
|
-
assert.strictEqual(program.db, db);
|
|
157
|
-
done();
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it('respects the backup --buffer-size command-line parameter', function(done) {
|
|
161
|
-
const bufferSize = 500;
|
|
162
|
-
process.argv = ['node', 'test', '--buffer-size', bufferSize];
|
|
163
|
-
const program = parser.parseBackupArgs();
|
|
164
|
-
assert.strictEqual(typeof program.bufferSize, 'number');
|
|
165
|
-
assert.strictEqual(program.bufferSize, bufferSize);
|
|
166
|
-
done();
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
it('respects the backup --parallelism command-line parameter', function(done) {
|
|
170
|
-
const parallelism = 10;
|
|
171
|
-
process.argv = ['node', 'test', '--parallelism', parallelism];
|
|
172
|
-
const program = parser.parseBackupArgs();
|
|
173
|
-
assert.strictEqual(typeof program.parallelism, 'number');
|
|
174
|
-
assert.strictEqual(program.parallelism, parallelism);
|
|
175
|
-
done();
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
it('respects the backup --request-timeout command-line parameter', function(done) {
|
|
179
|
-
const requestTimeout = 10000;
|
|
180
|
-
process.argv = ['node', 'test', '--request-timeout', requestTimeout];
|
|
181
|
-
const program = parser.parseBackupArgs();
|
|
182
|
-
assert.strictEqual(typeof program.requestTimeout, 'number');
|
|
183
|
-
assert.strictEqual(program.requestTimeout, requestTimeout);
|
|
184
|
-
done();
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
it('respects the backup --iam-api-key command-line parameter', function(done) {
|
|
188
|
-
const key = '123abc-789zyx_CBA987-XYZ321';
|
|
189
|
-
process.argv = ['node', 'test', '--iam-api-key', key];
|
|
190
|
-
const program = parser.parseBackupArgs();
|
|
191
|
-
assert.strictEqual(typeof program.iamApiKey, 'string');
|
|
192
|
-
assert.strictEqual(program.iamApiKey, key);
|
|
193
|
-
done();
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
it('respects the backup --log command-line parameter', function(done) {
|
|
197
|
-
const filename = 'my2.log';
|
|
198
|
-
process.argv = ['node', 'test', '--log', filename];
|
|
199
|
-
const program = parser.parseBackupArgs();
|
|
200
|
-
assert.strictEqual(typeof program.log, 'string');
|
|
201
|
-
assert.strictEqual(program.log, filename);
|
|
202
|
-
done();
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
it('respects the backup --resume command-line parameter', function(done) {
|
|
206
|
-
process.argv = ['node', 'test', '--resume'];
|
|
207
|
-
const program = parser.parseBackupArgs();
|
|
208
|
-
assert.strictEqual(typeof program.resume, 'boolean');
|
|
209
|
-
assert.strictEqual(program.resume, true);
|
|
210
|
-
done();
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
it('respects the backup --output command-line parameter', function(done) {
|
|
214
|
-
const filename = 'myfile2.txt';
|
|
215
|
-
process.argv = ['node', 'test', '--output', filename];
|
|
216
|
-
const program = parser.parseBackupArgs();
|
|
217
|
-
assert.strictEqual(typeof program.output, 'string');
|
|
218
|
-
assert.strictEqual(program.output, filename);
|
|
219
|
-
done();
|
|
220
|
-
});
|
|
221
|
-
|
|
222
|
-
it('respects the backup --mode full command-line parameter', function(done) {
|
|
223
|
-
process.argv = ['node', 'test', '--mode', 'full'];
|
|
224
|
-
const program = parser.parseBackupArgs();
|
|
225
|
-
assert.strictEqual(typeof program.mode, 'string');
|
|
226
|
-
assert.strictEqual(program.mode, 'full');
|
|
227
|
-
done();
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
it('respects the backup --mode shallow command-line parameter', function(done) {
|
|
231
|
-
process.argv = ['node', 'test', '--mode', 'shallow'];
|
|
232
|
-
const program = parser.parseBackupArgs();
|
|
233
|
-
assert.strictEqual(typeof program.mode, 'string');
|
|
234
|
-
assert.strictEqual(program.mode, 'shallow');
|
|
235
|
-
done();
|
|
236
|
-
});
|
|
237
|
-
|
|
238
|
-
it('respects the backup --quiet command-line parameter', function(done) {
|
|
239
|
-
process.argv = ['node', 'test', '--quiet'];
|
|
240
|
-
const program = parser.parseBackupArgs();
|
|
241
|
-
assert.strictEqual(typeof program.quiet, 'boolean');
|
|
242
|
-
assert.strictEqual(program.quiet, true);
|
|
243
|
-
done();
|
|
244
|
-
});
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
describe('Restore command-line', function() {
|
|
248
|
-
it('respects the COUCH_URL env variable if the --url restore command-line parameter is missing', function(done) {
|
|
249
|
-
process.argv = ['node', 'test'];
|
|
250
|
-
const program = parser.parseRestoreArgs();
|
|
251
|
-
assert.strictEqual(typeof program.url, 'string');
|
|
252
|
-
assert.strictEqual(program.url, process.env.COUCH_URL);
|
|
253
|
-
done();
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
it('respects the COUCH_DATABASE env variable if the --db restore command-line parameter is missing', function(done) {
|
|
257
|
-
process.argv = ['node', 'test'];
|
|
258
|
-
const program = parser.parseRestoreArgs();
|
|
259
|
-
assert.strictEqual(typeof program.db, 'string');
|
|
260
|
-
assert.strictEqual(program.db, process.env.COUCH_DATABASE);
|
|
261
|
-
done();
|
|
262
|
-
});
|
|
263
|
-
|
|
264
|
-
it('respects the COUCH_BUFFER_SIZE env variable if the --buffer-size restore command-line parameter is missing', function(done) {
|
|
265
|
-
process.argv = ['node', 'test'];
|
|
266
|
-
const program = parser.parseRestoreArgs();
|
|
267
|
-
assert.strictEqual(typeof program.bufferSize, 'number');
|
|
268
|
-
assert.strictEqual(program.bufferSize, parseInt(process.env.COUCH_BUFFER_SIZE, 10));
|
|
269
|
-
done();
|
|
270
|
-
});
|
|
271
|
-
|
|
272
|
-
it('respects the COUCH_PARALLELISM env variable if the --parallelism restore command-line parameter is missing', function(done) {
|
|
273
|
-
process.argv = ['node', 'test'];
|
|
274
|
-
const program = parser.parseRestoreArgs();
|
|
275
|
-
assert.strictEqual(typeof program.parallelism, 'number');
|
|
276
|
-
assert.strictEqual(program.parallelism, parseInt(process.env.COUCH_PARALLELISM, 10));
|
|
277
|
-
done();
|
|
278
|
-
});
|
|
279
|
-
|
|
280
|
-
it('respects the COUCH_REQUEST_TIMEOUT env variable if the --request-timeout restore command-line parameter is missing', function(done) {
|
|
281
|
-
process.argv = ['node', 'test'];
|
|
282
|
-
const program = parser.parseRestoreArgs();
|
|
283
|
-
assert.strictEqual(typeof program.requestTimeout, 'number');
|
|
284
|
-
assert.strictEqual(program.requestTimeout, parseInt(process.env.COUCH_REQUEST_TIMEOUT, 10));
|
|
285
|
-
done();
|
|
286
|
-
});
|
|
287
|
-
|
|
288
|
-
it('respects the CLOUDANT_IAM_API_KEY env variable if the --iam-api-key restore command-line parameter is missing', function(done) {
|
|
289
|
-
process.argv = ['node', 'test'];
|
|
290
|
-
const program = parser.parseRestoreArgs();
|
|
291
|
-
assert.strictEqual(typeof program.iamApiKey, 'string');
|
|
292
|
-
assert.strictEqual(program.iamApiKey, process.env.CLOUDANT_IAM_API_KEY);
|
|
293
|
-
done();
|
|
294
|
-
});
|
|
295
|
-
|
|
296
|
-
it('respects the COUCH_QUIET env variable if the --quiet restorer command-line parameter is missing', function(done) {
|
|
297
|
-
process.argv = ['node', 'test'];
|
|
298
|
-
const program = parser.parseBackupArgs();
|
|
299
|
-
assert.strictEqual(typeof program.quiet, 'boolean');
|
|
300
|
-
assert.strictEqual(program.quiet, true);
|
|
301
|
-
done();
|
|
302
|
-
});
|
|
303
|
-
|
|
304
|
-
it('respects the restore --url command-line parameter', function(done) {
|
|
305
|
-
const url = 'https://a:b@myurl3.com';
|
|
306
|
-
process.argv = ['node', 'test', '--url', url];
|
|
307
|
-
const program = parser.parseRestoreArgs();
|
|
308
|
-
assert.strictEqual(typeof program.url, 'string');
|
|
309
|
-
assert.strictEqual(program.url, url);
|
|
310
|
-
done();
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it('respects the restore --db command-line parameter', function(done) {
|
|
314
|
-
const db = 'mydb3';
|
|
315
|
-
process.argv = ['node', 'test', '--db', db];
|
|
316
|
-
const program = parser.parseRestoreArgs();
|
|
317
|
-
assert.strictEqual(typeof program.db, 'string');
|
|
318
|
-
assert.strictEqual(program.db, db);
|
|
319
|
-
done();
|
|
320
|
-
});
|
|
321
|
-
|
|
322
|
-
it('respects the restore --buffer-size command-line parameter', function(done) {
|
|
323
|
-
const bufferSize = 250;
|
|
324
|
-
process.argv = ['node', 'test', '--buffer-size', bufferSize];
|
|
325
|
-
const program = parser.parseRestoreArgs();
|
|
326
|
-
assert.strictEqual(typeof program.bufferSize, 'number');
|
|
327
|
-
assert.strictEqual(program.bufferSize, bufferSize);
|
|
328
|
-
done();
|
|
329
|
-
});
|
|
330
|
-
|
|
331
|
-
it('respects the restore --parallelism command-line parameter', function(done) {
|
|
332
|
-
const parallelism = 5;
|
|
333
|
-
process.argv = ['node', 'test', '--parallelism', parallelism];
|
|
334
|
-
const program = parser.parseRestoreArgs();
|
|
335
|
-
assert.strictEqual(typeof program.parallelism, 'number');
|
|
336
|
-
assert.strictEqual(program.parallelism, parallelism);
|
|
337
|
-
done();
|
|
338
|
-
});
|
|
339
|
-
|
|
340
|
-
it('respects the restore --request-timeout command-line parameter', function(done) {
|
|
341
|
-
const requestTimeout = 10000;
|
|
342
|
-
process.argv = ['node', 'test', '--request-timeout', requestTimeout];
|
|
343
|
-
const program = parser.parseRestoreArgs();
|
|
344
|
-
assert.strictEqual(typeof program.requestTimeout, 'number');
|
|
345
|
-
assert.strictEqual(program.requestTimeout, requestTimeout);
|
|
346
|
-
done();
|
|
347
|
-
});
|
|
348
|
-
|
|
349
|
-
it('respects the restore --iam-api-key command-line parameter', function(done) {
|
|
350
|
-
const key = '123abc-789zyx_CBA987-XYZ321';
|
|
351
|
-
process.argv = ['node', 'test', '--iam-api-key', key];
|
|
352
|
-
const program = parser.parseRestoreArgs();
|
|
353
|
-
assert.strictEqual(typeof program.iamApiKey, 'string');
|
|
354
|
-
assert.strictEqual(program.iamApiKey, key);
|
|
355
|
-
done();
|
|
356
|
-
});
|
|
357
|
-
|
|
358
|
-
it('respects the restore --quiet command-line parameter', function(done) {
|
|
359
|
-
process.argv = ['node', 'test', '--quiet'];
|
|
360
|
-
const program = parser.parseRestoreArgs();
|
|
361
|
-
assert.strictEqual(typeof program.quiet, 'boolean');
|
|
362
|
-
assert.strictEqual(program.quiet, true);
|
|
363
|
-
done();
|
|
20
|
+
[{ useApi: true }, { useApi: false }].forEach(function(params) {
|
|
21
|
+
describe(u.scenario('#slowest End to end backup and restore', params), function() {
|
|
22
|
+
// 10 GB is about the largest the CI can handle before getting very upset
|
|
23
|
+
// about how long things are taking
|
|
24
|
+
it('should backup and restore largedb10g', function(done) {
|
|
25
|
+
u.setTimeout(this, 350 * 60);
|
|
26
|
+
u.testDirectBackupAndRestore(params, 'largedb10g', this.dbName, done);
|
|
364
27
|
});
|
|
365
28
|
});
|
|
366
29
|
});
|