@cloudant/couchbackup 2.9.12 → 2.9.13-SNAPSHOT.139
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-21.pb +1 -0
- package/.scannerwork/scanner-report/changesets-37.pb +1 -0
- package/.scannerwork/scanner-report/changesets-38.pb +1 -0
- package/.scannerwork/scanner-report/changesets-39.pb +1 -0
- package/.scannerwork/scanner-report/changesets-4.pb +1 -0
- package/.scannerwork/scanner-report/changesets-40.pb +1 -0
- package/.scannerwork/scanner-report/changesets-57.pb +1 -0
- package/.scannerwork/scanner-report/changesets-60.pb +1 -0
- package/.scannerwork/scanner-report/changesets-62.pb +1 -0
- package/.scannerwork/scanner-report/changesets-66.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 -1
- package/.scannerwork/scanner-report/component-13.pb +1 -1
- package/.scannerwork/scanner-report/component-14.pb +1 -1
- package/.scannerwork/scanner-report/component-15.pb +1 -1
- package/.scannerwork/scanner-report/component-16.pb +1 -1
- package/.scannerwork/scanner-report/component-17.pb +1 -1
- package/.scannerwork/scanner-report/component-18.pb +1 -1
- package/.scannerwork/scanner-report/component-19.pb +1 -1
- package/.scannerwork/scanner-report/component-20.pb +1 -1
- package/.scannerwork/scanner-report/component-21.pb +1 -0
- 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-37.pb +1 -0
- package/.scannerwork/scanner-report/component-38.pb +1 -0
- package/.scannerwork/scanner-report/component-39.pb +1 -0
- package/.scannerwork/scanner-report/component-4.pb +1 -0
- package/.scannerwork/scanner-report/component-40.pb +1 -0
- package/.scannerwork/scanner-report/component-44.pb +1 -1
- package/.scannerwork/scanner-report/component-45.pb +1 -1
- package/.scannerwork/scanner-report/component-46.pb +1 -1
- 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-53.pb +1 -1
- package/.scannerwork/scanner-report/component-54.pb +1 -1
- package/.scannerwork/scanner-report/component-55.pb +1 -1
- package/.scannerwork/scanner-report/component-56.pb +1 -1
- package/.scannerwork/scanner-report/component-57.pb +1 -0
- package/.scannerwork/scanner-report/component-58.pb +1 -1
- package/.scannerwork/scanner-report/component-6.pb +1 -1
- package/.scannerwork/scanner-report/component-60.pb +1 -0
- package/.scannerwork/scanner-report/component-62.pb +1 -0
- package/.scannerwork/scanner-report/component-66.pb +1 -0
- package/.scannerwork/scanner-report/component-7.pb +1 -1
- package/.scannerwork/scanner-report/component-8.pb +1 -1
- 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-12.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-15.pb +0 -0
- package/.scannerwork/scanner-report/coverages-16.pb +0 -0
- package/.scannerwork/scanner-report/coverages-17.pb +0 -0
- package/.scannerwork/scanner-report/coverages-18.pb +0 -0
- package/.scannerwork/scanner-report/coverages-19.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-37.pb +0 -0
- package/.scannerwork/scanner-report/coverages-38.pb +0 -0
- package/.scannerwork/scanner-report/coverages-4.pb +0 -0
- package/.scannerwork/scanner-report/coverages-40.pb +0 -0
- package/.scannerwork/scanner-report/coverages-44.pb +0 -0
- package/.scannerwork/scanner-report/coverages-45.pb +0 -0
- package/.scannerwork/scanner-report/coverages-46.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-53.pb +0 -0
- package/.scannerwork/scanner-report/coverages-54.pb +0 -0
- package/.scannerwork/scanner-report/coverages-55.pb +0 -0
- package/.scannerwork/scanner-report/coverages-56.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-62.pb +0 -0
- package/.scannerwork/scanner-report/coverages-66.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-12.pb +2 -0
- package/.scannerwork/scanner-report/duplications-15.pb +0 -2
- package/.scannerwork/scanner-report/duplications-16.pb +2 -0
- package/.scannerwork/scanner-report/duplications-17.pb +3 -0
- package/.scannerwork/scanner-report/duplications-22.pb +2 -0
- package/.scannerwork/scanner-report/duplications-24.pb +3 -2
- package/.scannerwork/scanner-report/duplications-25.pb +3 -0
- package/.scannerwork/scanner-report/duplications-46.pb +2 -0
- package/.scannerwork/scanner-report/duplications-5.pb +0 -2
- package/.scannerwork/scanner-report/duplications-52.pb +0 -3
- package/.scannerwork/scanner-report/duplications-55.pb +0 -2
- package/.scannerwork/scanner-report/duplications-57.pb +0 -0
- package/.scannerwork/scanner-report/duplications-58.pb +2 -0
- package/.scannerwork/scanner-report/duplications-60.pb +2 -0
- package/.scannerwork/scanner-report/duplications-62.pb +2 -0
- package/.scannerwork/scanner-report/duplications-66.pb +0 -0
- package/.scannerwork/scanner-report/duplications-9.pb +0 -2
- package/.scannerwork/scanner-report/measures-10.pb +0 -0
- package/.scannerwork/scanner-report/measures-11.pb +0 -0
- package/.scannerwork/scanner-report/measures-12.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-15.pb +0 -0
- package/.scannerwork/scanner-report/measures-16.pb +0 -0
- package/.scannerwork/scanner-report/measures-17.pb +0 -0
- package/.scannerwork/scanner-report/measures-18.pb +0 -0
- package/.scannerwork/scanner-report/measures-19.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-37.pb +0 -0
- package/.scannerwork/scanner-report/measures-38.pb +0 -0
- package/.scannerwork/scanner-report/measures-4.pb +0 -0
- package/.scannerwork/scanner-report/measures-40.pb +0 -0
- package/.scannerwork/scanner-report/measures-44.pb +0 -0
- package/.scannerwork/scanner-report/measures-45.pb +0 -0
- package/.scannerwork/scanner-report/measures-46.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-53.pb +0 -0
- package/.scannerwork/scanner-report/measures-54.pb +0 -0
- package/.scannerwork/scanner-report/measures-55.pb +0 -0
- package/.scannerwork/scanner-report/measures-56.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-6.pb +0 -0
- package/.scannerwork/scanner-report/measures-60.pb +0 -0
- package/.scannerwork/scanner-report/measures-62.pb +0 -0
- package/.scannerwork/scanner-report/measures-66.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 +14 -96
- package/.scannerwork/scanner-report/source-11.txt +19 -39
- package/.scannerwork/scanner-report/source-12.txt +126 -22
- package/.scannerwork/scanner-report/source-13.txt +33 -115
- package/.scannerwork/scanner-report/source-14.txt +584 -123
- package/.scannerwork/scanner-report/source-15.txt +127 -60
- package/.scannerwork/scanner-report/source-16.txt +202 -95
- package/.scannerwork/scanner-report/source-17.txt +99 -84
- package/.scannerwork/scanner-report/source-18.txt +18 -160
- package/.scannerwork/scanner-report/source-19.txt +52 -15
- package/.scannerwork/scanner-report/source-20.txt +346 -261
- package/.scannerwork/scanner-report/source-21.txt +63 -0
- package/.scannerwork/scanner-report/source-22.txt +277 -40
- package/.scannerwork/scanner-report/source-23.txt +131 -52
- package/.scannerwork/scanner-report/source-24.txt +213 -114
- package/.scannerwork/scanner-report/source-25.txt +110 -13
- package/.scannerwork/scanner-report/source-37.txt +92 -0
- package/.scannerwork/scanner-report/source-38.txt +100 -0
- package/.scannerwork/scanner-report/source-4.txt +56 -0
- package/.scannerwork/scanner-report/source-40.txt +35 -0
- package/.scannerwork/scanner-report/source-44.txt +403 -20
- package/.scannerwork/scanner-report/source-45.txt +24 -120
- package/.scannerwork/scanner-report/source-46.txt +71 -47
- package/.scannerwork/scanner-report/source-47.txt +64 -20
- package/.scannerwork/scanner-report/source-48.txt +39 -21
- package/.scannerwork/scanner-report/source-49.txt +82 -78
- package/.scannerwork/scanner-report/source-5.txt +60 -158
- package/.scannerwork/scanner-report/source-50.txt +71 -578
- package/.scannerwork/scanner-report/source-51.txt +255 -42
- package/.scannerwork/scanner-report/source-52.txt +17 -230
- package/.scannerwork/scanner-report/source-53.txt +25 -47
- package/.scannerwork/scanner-report/source-54.txt +115 -15
- package/.scannerwork/scanner-report/source-55.txt +87 -201
- package/.scannerwork/scanner-report/source-56.txt +151 -65
- package/.scannerwork/scanner-report/source-57.txt +164 -0
- package/.scannerwork/scanner-report/source-58.txt +51 -90
- package/.scannerwork/scanner-report/source-6.txt +509 -190
- package/.scannerwork/scanner-report/source-60.txt +190 -0
- package/.scannerwork/scanner-report/source-62.txt +175 -0
- package/.scannerwork/scanner-report/source-66.txt +114 -0
- package/.scannerwork/scanner-report/source-7.txt +167 -46
- package/.scannerwork/scanner-report/source-8.txt +46 -58
- package/.scannerwork/scanner-report/source-9.txt +19 -75
- package/.scannerwork/scanner-report/symbols-10.pb +9 -59
- package/.scannerwork/scanner-report/symbols-11.pb +9 -14
- package/.scannerwork/scanner-report/symbols-12.pb +102 -18
- package/.scannerwork/scanner-report/symbols-13.pb +26 -32
- package/.scannerwork/scanner-report/symbols-14.pb +1241 -113
- package/.scannerwork/scanner-report/symbols-15.pb +115 -41
- package/.scannerwork/scanner-report/symbols-16.pb +417 -29
- package/.scannerwork/scanner-report/symbols-17.pb +76 -41
- package/.scannerwork/scanner-report/symbols-18.pb +14 -144
- package/.scannerwork/scanner-report/symbols-19.pb +44 -13
- package/.scannerwork/scanner-report/symbols-20.pb +462 -322
- package/.scannerwork/scanner-report/symbols-21.pb +43 -0
- package/.scannerwork/scanner-report/symbols-22.pb +485 -18
- package/.scannerwork/scanner-report/symbols-23.pb +111 -29
- package/.scannerwork/scanner-report/symbols-24.pb +393 -101
- package/.scannerwork/scanner-report/symbols-25.pb +97 -10
- package/.scannerwork/scanner-report/symbols-37.pb +60 -0
- package/.scannerwork/scanner-report/symbols-38.pb +69 -0
- package/.scannerwork/scanner-report/symbols-4.pb +19 -0
- package/.scannerwork/scanner-report/symbols-40.pb +17 -0
- package/.scannerwork/scanner-report/symbols-44.pb +610 -17
- package/.scannerwork/scanner-report/symbols-45.pb +19 -115
- package/.scannerwork/scanner-report/symbols-46.pb +43 -44
- package/.scannerwork/scanner-report/symbols-47.pb +46 -14
- package/.scannerwork/scanner-report/symbols-48.pb +15 -11
- package/.scannerwork/scanner-report/symbols-49.pb +41 -68
- package/.scannerwork/scanner-report/symbols-5.pb +29 -152
- package/.scannerwork/scanner-report/symbols-50.pb +30 -1254
- package/.scannerwork/scanner-report/symbols-51.pb +354 -36
- package/.scannerwork/scanner-report/symbols-52.pb +13 -393
- package/.scannerwork/scanner-report/symbols-53.pb +17 -42
- package/.scannerwork/scanner-report/symbols-54.pb +33 -9
- package/.scannerwork/scanner-report/symbols-55.pb +58 -417
- package/.scannerwork/scanner-report/symbols-56.pb +144 -60
- package/.scannerwork/scanner-report/symbols-57.pb +126 -0
- package/.scannerwork/scanner-report/symbols-58.pb +42 -28
- package/.scannerwork/scanner-report/symbols-62.pb +153 -0
- package/.scannerwork/scanner-report/symbols-66.pb +28 -0
- package/.scannerwork/scanner-report/symbols-8.pb +33 -43
- package/.scannerwork/scanner-report/symbols-9.pb +11 -44
- package/.scannerwork/scanner-report/syntax-highlightings-10.pb +16 -101
- package/.scannerwork/scanner-report/syntax-highlightings-11.pb +21 -25
- package/.scannerwork/scanner-report/syntax-highlightings-12.pb +198 -21
- package/.scannerwork/scanner-report/syntax-highlightings-13.pb +31 -92
- package/.scannerwork/scanner-report/syntax-highlightings-14.pb +815 -141
- package/.scannerwork/scanner-report/syntax-highlightings-15.pb +102 -46
- package/.scannerwork/scanner-report/syntax-highlightings-16.pb +301 -83
- package/.scannerwork/scanner-report/syntax-highlightings-17.pb +128 -86
- package/.scannerwork/scanner-report/syntax-highlightings-18.pb +22 -211
- package/.scannerwork/scanner-report/syntax-highlightings-19.pb +80 -15
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +523 -178
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +82 -0
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +630 -53
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +194 -74
- package/.scannerwork/scanner-report/syntax-highlightings-24.pb +285 -183
- package/.scannerwork/scanner-report/syntax-highlightings-25.pb +145 -13
- package/.scannerwork/scanner-report/syntax-highlightings-37.pb +110 -0
- package/.scannerwork/scanner-report/syntax-highlightings-38.pb +105 -0
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +82 -0
- package/.scannerwork/scanner-report/syntax-highlightings-40.pb +63 -0
- package/.scannerwork/scanner-report/syntax-highlightings-44.pb +619 -34
- package/.scannerwork/scanner-report/syntax-highlightings-45.pb +35 -105
- package/.scannerwork/scanner-report/syntax-highlightings-46.pb +56 -76
- package/.scannerwork/scanner-report/syntax-highlightings-47.pb +62 -21
- package/.scannerwork/scanner-report/syntax-highlightings-48.pb +25 -30
- package/.scannerwork/scanner-report/syntax-highlightings-49.pb +84 -73
- package/.scannerwork/scanner-report/syntax-highlightings-5.pb +71 -182
- package/.scannerwork/scanner-report/syntax-highlightings-50.pb +83 -857
- package/.scannerwork/scanner-report/syntax-highlightings-51.pb +247 -57
- package/.scannerwork/scanner-report/syntax-highlightings-52.pb +15 -299
- package/.scannerwork/scanner-report/syntax-highlightings-53.pb +20 -52
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +97 -16
- package/.scannerwork/scanner-report/syntax-highlightings-55.pb +96 -294
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +202 -69
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +213 -0
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +45 -105
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +3725 -202
- package/.scannerwork/scanner-report/syntax-highlightings-60.pb +225 -0
- package/.scannerwork/scanner-report/syntax-highlightings-62.pb +214 -0
- package/.scannerwork/scanner-report/syntax-highlightings-66.pb +138 -0
- package/.scannerwork/scanner-report/syntax-highlightings-7.pb +938 -53
- package/.scannerwork/scanner-report/syntax-highlightings-8.pb +60 -60
- package/.scannerwork/scanner-report/syntax-highlightings-9.pb +29 -60
- package/README.md +1 -1
- package/package.json +2 -2
- package/test-18-results.xml +159 -159
- package/test-iam-18-results.xml +50 -50
- package/.scannerwork/scanner-report/changesets-26.pb +0 -1
- package/.scannerwork/scanner-report/changesets-27.pb +0 -1
- package/.scannerwork/scanner-report/changesets-28.pb +0 -1
- package/.scannerwork/scanner-report/changesets-29.pb +0 -1
- package/.scannerwork/scanner-report/changesets-30.pb +0 -1
- package/.scannerwork/scanner-report/changesets-42.pb +0 -1
- package/.scannerwork/scanner-report/changesets-43.pb +0 -1
- package/.scannerwork/scanner-report/changesets-6.pb +0 -1
- package/.scannerwork/scanner-report/changesets-64.pb +0 -1
- package/.scannerwork/scanner-report/changesets-7.pb +0 -1
- package/.scannerwork/scanner-report/component-2.pb +0 -1
- package/.scannerwork/scanner-report/component-26.pb +0 -1
- package/.scannerwork/scanner-report/component-27.pb +0 -1
- package/.scannerwork/scanner-report/component-28.pb +0 -1
- package/.scannerwork/scanner-report/component-29.pb +0 -1
- package/.scannerwork/scanner-report/component-30.pb +0 -1
- package/.scannerwork/scanner-report/component-42.pb +0 -1
- package/.scannerwork/scanner-report/component-43.pb +0 -1
- package/.scannerwork/scanner-report/component-61.pb +0 -1
- package/.scannerwork/scanner-report/component-64.pb +0 -1
- package/.scannerwork/scanner-report/component-68.pb +0 -1
- 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-30.pb +0 -0
- package/.scannerwork/scanner-report/coverages-42.pb +0 -0
- package/.scannerwork/scanner-report/coverages-64.pb +0 -0
- package/.scannerwork/scanner-report/coverages-7.pb +0 -0
- package/.scannerwork/scanner-report/duplications-26.pb +0 -3
- package/.scannerwork/scanner-report/duplications-29.pb +0 -2
- package/.scannerwork/scanner-report/duplications-30.pb +0 -3
- package/.scannerwork/scanner-report/duplications-6.pb +0 -2
- package/.scannerwork/scanner-report/measures-2.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 +0 -15
- package/.scannerwork/scanner-report/measures-30.pb +0 -0
- package/.scannerwork/scanner-report/measures-42.pb +0 -0
- package/.scannerwork/scanner-report/measures-61.pb +0 -0
- package/.scannerwork/scanner-report/measures-64.pb +0 -0
- package/.scannerwork/scanner-report/measures-68.pb +0 -0
- package/.scannerwork/scanner-report/source-2.txt +0 -509
- package/.scannerwork/scanner-report/source-26.txt +0 -119
- package/.scannerwork/scanner-report/source-27.txt +0 -156
- package/.scannerwork/scanner-report/source-28.txt +0 -47
- package/.scannerwork/scanner-report/source-29.txt +0 -293
- package/.scannerwork/scanner-report/source-30.txt +0 -131
- package/.scannerwork/scanner-report/source-42.txt +0 -366
- package/.scannerwork/scanner-report/source-61.txt +0 -509
- package/.scannerwork/scanner-report/source-64.txt +0 -418
- package/.scannerwork/scanner-report/source-68.txt +0 -167
- package/.scannerwork/scanner-report/symbols-26.pb +0 -77
- package/.scannerwork/scanner-report/symbols-27.pb +0 -112
- package/.scannerwork/scanner-report/symbols-28.pb +0 -27
- package/.scannerwork/scanner-report/symbols-29.pb +0 -486
- package/.scannerwork/scanner-report/symbols-30.pb +0 -97
- package/.scannerwork/scanner-report/symbols-42.pb +0 -494
- package/.scannerwork/scanner-report/symbols-64.pb +0 -610
- package/.scannerwork/scanner-report/symbols-7.pb +0 -20
- package/.scannerwork/scanner-report/syntax-highlightings-2.pb +0 -3749
- package/.scannerwork/scanner-report/syntax-highlightings-26.pb +0 -158
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +0 -223
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +0 -68
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +0 -659
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +0 -182
- package/.scannerwork/scanner-report/syntax-highlightings-42.pb +0 -630
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +0 -3748
- package/.scannerwork/scanner-report/syntax-highlightings-64.pb +0 -648
- package/.scannerwork/scanner-report/syntax-highlightings-68.pb +0 -949
- package/test-16-results.xml +0 -509
- /package/.scannerwork/scanner-report/{coverages-43.pb → coverages-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-6.pb → coverages-60.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-10.pb → duplications-21.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-27.pb → duplications-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-28.pb → duplications-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-42.pb → duplications-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-43.pb → duplications-4.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-64.pb → duplications-40.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-7.pb → duplications-54.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-28.pb → issues-13.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-45.pb → issues-15.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-42.pb → issues-20.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-52.pb → issues-24.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-43.pb → measures-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-43.txt → source-39.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-43.pb → symbols-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-6.pb → symbols-60.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-43.pb → syntax-highlightings-39.pb} +0 -0
|
@@ -11,271 +11,356 @@
|
|
|
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 afterEach before after it */
|
|
14
16
|
'use strict';
|
|
15
17
|
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
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
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
validateBulkGetSupport(db, function(err) {
|
|
59
|
-
if (err) {
|
|
60
|
-
return ee.emit('error', err);
|
|
61
|
-
} else {
|
|
62
|
-
proceedWithBackup();
|
|
63
|
-
}
|
|
18
|
+
const assert = require('assert');
|
|
19
|
+
const parser = require('../includes/parser.js');
|
|
20
|
+
|
|
21
|
+
describe('#unit Default parameters', function() {
|
|
22
|
+
let processEnvCopy;
|
|
23
|
+
let processArgvCopy;
|
|
24
|
+
|
|
25
|
+
before('Set process data for test', function() {
|
|
26
|
+
// Copy env and argv so we can reset them after the tests
|
|
27
|
+
processEnvCopy = JSON.parse(JSON.stringify(process.env));
|
|
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';
|
|
64
42
|
});
|
|
65
43
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
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);
|
|
44
|
+
after('Reset process data', function() {
|
|
45
|
+
process.env = processEnvCopy;
|
|
46
|
+
process.argv = processArgvCopy;
|
|
89
47
|
});
|
|
90
|
-
|
|
91
|
-
|
|
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;
|
|
110
|
-
|
|
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
|
-
}
|
|
129
|
-
}
|
|
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);
|
|
155
|
-
}
|
|
156
|
-
|
|
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);
|
|
181
|
-
}
|
|
48
|
+
|
|
49
|
+
afterEach(function() {
|
|
50
|
+
delete require.cache[require.resolve('commander')];
|
|
182
51
|
});
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
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();
|
|
364
|
+
});
|
|
262
365
|
});
|
|
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
|
-
}
|
|
366
|
+
});
|