@cloudant/couchbackup 2.9.13-SNAPSHOT.144 → 2.9.13
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/changesets-11.pb +1 -0
- package/.scannerwork/scanner-report/changesets-12.pb +1 -0
- package/.scannerwork/scanner-report/changesets-14.pb +1 -0
- package/.scannerwork/scanner-report/changesets-15.pb +1 -0
- package/.scannerwork/scanner-report/changesets-16.pb +1 -0
- package/.scannerwork/scanner-report/changesets-17.pb +1 -0
- package/.scannerwork/scanner-report/changesets-18.pb +1 -0
- package/.scannerwork/scanner-report/changesets-19.pb +1 -0
- package/.scannerwork/scanner-report/changesets-2.pb +1 -0
- package/.scannerwork/scanner-report/changesets-20.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-55.pb +1 -0
- package/.scannerwork/scanner-report/changesets-56.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-61.pb +1 -0
- package/.scannerwork/scanner-report/changesets-63.pb +1 -0
- package/.scannerwork/scanner-report/changesets-64.pb +1 -0
- package/.scannerwork/scanner-report/component-1.pb +1 -1
- package/.scannerwork/scanner-report/component-11.pb +1 -0
- package/.scannerwork/scanner-report/component-12.pb +1 -0
- package/.scannerwork/scanner-report/component-14.pb +1 -0
- package/.scannerwork/scanner-report/component-15.pb +1 -0
- package/.scannerwork/scanner-report/component-16.pb +1 -0
- package/.scannerwork/scanner-report/component-17.pb +1 -0
- package/.scannerwork/scanner-report/component-18.pb +1 -0
- package/.scannerwork/scanner-report/component-19.pb +1 -0
- package/.scannerwork/scanner-report/component-2.pb +1 -0
- package/.scannerwork/scanner-report/component-20.pb +1 -0
- 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-35.pb +1 -1
- package/.scannerwork/scanner-report/component-36.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-40.pb +1 -1
- package/.scannerwork/scanner-report/component-41.pb +1 -1
- package/.scannerwork/scanner-report/component-42.pb +1 -1
- package/.scannerwork/scanner-report/component-43.pb +1 -1
- 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-5.pb +1 -1
- package/.scannerwork/scanner-report/component-50.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 -0
- package/.scannerwork/scanner-report/component-56.pb +1 -0
- package/.scannerwork/scanner-report/component-57.pb +1 -0
- package/.scannerwork/scanner-report/component-58.pb +1 -1
- package/.scannerwork/scanner-report/component-59.pb +1 -1
- package/.scannerwork/scanner-report/component-60.pb +1 -1
- package/.scannerwork/scanner-report/component-61.pb +1 -0
- package/.scannerwork/scanner-report/component-62.pb +1 -1
- package/.scannerwork/scanner-report/component-63.pb +1 -0
- package/.scannerwork/scanner-report/component-64.pb +1 -0
- package/.scannerwork/scanner-report/component-8.pb +1 -1
- package/.scannerwork/scanner-report/coverages-11.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-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-35.pb +0 -0
- package/.scannerwork/scanner-report/coverages-36.pb +0 -0
- package/.scannerwork/scanner-report/coverages-40.pb +0 -0
- package/.scannerwork/scanner-report/coverages-41.pb +0 -0
- package/.scannerwork/scanner-report/coverages-42.pb +0 -0
- package/.scannerwork/scanner-report/coverages-43.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-5.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-59.pb +0 -0
- package/.scannerwork/scanner-report/coverages-60.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-64.pb +0 -0
- package/.scannerwork/scanner-report/duplications-11.pb +2 -0
- package/.scannerwork/scanner-report/duplications-12.pb +2 -0
- package/.scannerwork/scanner-report/duplications-21.pb +3 -0
- package/.scannerwork/scanner-report/duplications-22.pb +2 -0
- package/.scannerwork/scanner-report/duplications-23.pb +3 -0
- package/.scannerwork/scanner-report/duplications-42.pb +3 -0
- package/.scannerwork/scanner-report/duplications-44.pb +0 -2
- package/.scannerwork/scanner-report/duplications-45.pb +2 -0
- package/.scannerwork/scanner-report/duplications-54.pb +0 -2
- package/.scannerwork/scanner-report/duplications-60.pb +2 -0
- package/.scannerwork/scanner-report/duplications-61.pb +2 -0
- package/.scannerwork/scanner-report/duplications-62.pb +0 -2
- package/.scannerwork/scanner-report/duplications-63.pb +0 -0
- package/.scannerwork/scanner-report/duplications-64.pb +0 -0
- package/.scannerwork/scanner-report/issues-23.pb +3 -2
- package/.scannerwork/scanner-report/issues-36.pb +3 -0
- package/.scannerwork/scanner-report/measures-11.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-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-35.pb +0 -0
- package/.scannerwork/scanner-report/measures-36.pb +0 -0
- package/.scannerwork/scanner-report/measures-40.pb +0 -0
- package/.scannerwork/scanner-report/measures-41.pb +0 -0
- package/.scannerwork/scanner-report/measures-42.pb +0 -0
- package/.scannerwork/scanner-report/measures-43.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-5.pb +0 -0
- package/.scannerwork/scanner-report/measures-50.pb +0 -0
- package/.scannerwork/scanner-report/measures-52.pb +0 -0
- package/.scannerwork/scanner-report/measures-53.pb +12 -11
- 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-59.pb +0 -0
- package/.scannerwork/scanner-report/measures-60.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-64.pb +0 -0
- package/.scannerwork/scanner-report/measures-8.pb +0 -0
- package/.scannerwork/scanner-report/metadata.pb +0 -0
- package/.scannerwork/scanner-report/source-11.txt +175 -0
- package/.scannerwork/scanner-report/source-14.txt +68 -0
- package/.scannerwork/scanner-report/source-15.txt +100 -0
- package/.scannerwork/scanner-report/{source-28.txt → source-16.txt} +14 -7
- package/.scannerwork/scanner-report/source-17.txt +63 -0
- package/.scannerwork/scanner-report/source-20.txt +625 -0
- package/.scannerwork/scanner-report/source-21.txt +97 -14
- package/.scannerwork/scanner-report/source-22.txt +203 -46
- package/.scannerwork/scanner-report/source-23.txt +213 -111
- package/.scannerwork/scanner-report/source-35.txt +346 -14
- package/.scannerwork/scanner-report/source-36.txt +125 -46
- package/.scannerwork/scanner-report/source-40.txt +19 -403
- package/.scannerwork/scanner-report/source-41.txt +15 -115
- package/.scannerwork/scanner-report/source-42.txt +113 -36
- package/.scannerwork/scanner-report/source-43.txt +64 -253
- package/.scannerwork/scanner-report/source-44.txt +132 -51
- package/.scannerwork/scanner-report/source-45.txt +267 -138
- package/.scannerwork/scanner-report/source-46.txt +130 -101
- package/.scannerwork/scanner-report/source-47.txt +37 -61
- package/.scannerwork/scanner-report/source-48.txt +62 -16
- package/.scannerwork/scanner-report/source-5.txt +382 -64
- package/.scannerwork/scanner-report/source-50.txt +509 -46
- package/.scannerwork/scanner-report/source-52.txt +16 -163
- package/.scannerwork/scanner-report/source-53.txt +148 -74
- package/.scannerwork/scanner-report/source-54.txt +18 -64
- package/.scannerwork/scanner-report/source-55.txt +129 -0
- package/.scannerwork/scanner-report/source-56.txt +281 -0
- package/.scannerwork/scanner-report/source-57.txt +118 -0
- package/.scannerwork/scanner-report/source-58.txt +84 -36
- package/.scannerwork/scanner-report/source-59.txt +60 -57
- package/.scannerwork/scanner-report/source-60.txt +75 -509
- package/.scannerwork/scanner-report/source-61.txt +92 -0
- package/.scannerwork/scanner-report/source-62.txt +35 -156
- package/.scannerwork/scanner-report/source-64.txt +164 -0
- package/.scannerwork/scanner-report/source-8.txt +167 -625
- package/.scannerwork/scanner-report/symbols-11.pb +153 -0
- package/.scannerwork/scanner-report/symbols-14.pb +45 -0
- package/.scannerwork/scanner-report/symbols-15.pb +69 -0
- package/.scannerwork/scanner-report/symbols-16.pb +14 -0
- package/.scannerwork/scanner-report/symbols-17.pb +43 -0
- package/.scannerwork/scanner-report/symbols-21.pb +77 -14
- package/.scannerwork/scanner-report/symbols-22.pb +417 -44
- package/.scannerwork/scanner-report/symbols-23.pb +387 -109
- package/.scannerwork/scanner-report/symbols-35.pb +494 -10
- package/.scannerwork/scanner-report/symbols-36.pb +115 -42
- package/.scannerwork/scanner-report/symbols-40.pb +10 -610
- package/.scannerwork/scanner-report/symbols-41.pb +9 -33
- package/.scannerwork/scanner-report/symbols-42.pb +97 -15
- package/.scannerwork/scanner-report/symbols-43.pb +60 -354
- package/.scannerwork/scanner-report/symbols-44.pb +111 -41
- package/.scannerwork/scanner-report/symbols-45.pb +482 -122
- package/.scannerwork/scanner-report/symbols-46.pb +85 -30
- package/.scannerwork/scanner-report/symbols-47.pb +18 -45
- package/.scannerwork/scanner-report/symbols-48.pb +29 -13
- package/.scannerwork/scanner-report/symbols-5.pb +610 -69
- package/.scannerwork/scanner-report/symbols-52.pb +13 -143
- package/.scannerwork/scanner-report/symbols-53.pb +143 -41
- package/.scannerwork/scanner-report/symbols-54.pb +18 -42
- package/.scannerwork/scanner-report/symbols-55.pb +33 -0
- package/.scannerwork/scanner-report/symbols-56.pb +354 -0
- package/.scannerwork/scanner-report/symbols-57.pb +30 -0
- package/.scannerwork/scanner-report/symbols-58.pb +41 -18
- package/.scannerwork/scanner-report/symbols-59.pb +45 -29
- package/.scannerwork/scanner-report/symbols-60.pb +42 -0
- package/.scannerwork/scanner-report/symbols-61.pb +44 -0
- package/.scannerwork/scanner-report/symbols-62.pb +14 -152
- package/.scannerwork/scanner-report/symbols-64.pb +126 -0
- package/.scannerwork/scanner-report/syntax-highlightings-11.pb +214 -0
- package/.scannerwork/scanner-report/syntax-highlightings-14.pb +110 -0
- package/.scannerwork/scanner-report/syntax-highlightings-15.pb +105 -0
- package/.scannerwork/scanner-report/syntax-highlightings-16.pb +54 -0
- package/.scannerwork/scanner-report/syntax-highlightings-17.pb +82 -0
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +887 -0
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +123 -19
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +281 -60
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +292 -97
- package/.scannerwork/scanner-report/syntax-highlightings-35.pb +594 -14
- package/.scannerwork/scanner-report/syntax-highlightings-36.pb +98 -46
- package/.scannerwork/scanner-report/syntax-highlightings-40.pb +21 -619
- package/.scannerwork/scanner-report/syntax-highlightings-41.pb +16 -97
- package/.scannerwork/scanner-report/syntax-highlightings-42.pb +153 -25
- package/.scannerwork/scanner-report/syntax-highlightings-43.pb +65 -240
- package/.scannerwork/scanner-report/syntax-highlightings-44.pb +189 -44
- package/.scannerwork/scanner-report/syntax-highlightings-45.pb +593 -147
- package/.scannerwork/scanner-report/syntax-highlightings-46.pb +154 -76
- package/.scannerwork/scanner-report/syntax-highlightings-47.pb +61 -74
- package/.scannerwork/scanner-report/syntax-highlightings-48.pb +91 -33
- package/.scannerwork/scanner-report/syntax-highlightings-5.pb +613 -70
- package/.scannerwork/scanner-report/syntax-highlightings-50.pb +3736 -53
- package/.scannerwork/scanner-report/syntax-highlightings-52.pb +15 -213
- package/.scannerwork/scanner-report/syntax-highlightings-53.pb +205 -78
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +27 -53
- package/.scannerwork/scanner-report/syntax-highlightings-55.pb +129 -0
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +285 -0
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +113 -0
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +97 -63
- package/.scannerwork/scanner-report/syntax-highlightings-59.pb +74 -82
- package/.scannerwork/scanner-report/syntax-highlightings-60.pb +67 -3736
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +90 -0
- package/.scannerwork/scanner-report/syntax-highlightings-62.pb +23 -183
- package/.scannerwork/scanner-report/syntax-highlightings-64.pb +213 -0
- package/.scannerwork/scanner-report/syntax-highlightings-8.pb +809 -747
- package/CHANGES.md +5 -0
- package/package.json +1 -1
- package/test-18-results.xml +163 -163
- package/test-iam-18-results.xml +49 -49
- package/.scannerwork/scanner-report/changesets-24.pb +0 -1
- package/.scannerwork/scanner-report/changesets-25.pb +0 -1
- 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-3.pb +0 -1
- package/.scannerwork/scanner-report/changesets-30.pb +0 -1
- package/.scannerwork/scanner-report/changesets-31.pb +0 -1
- package/.scannerwork/scanner-report/changesets-32.pb +0 -1
- package/.scannerwork/scanner-report/changesets-33.pb +0 -1
- package/.scannerwork/scanner-report/changesets-34.pb +0 -1
- package/.scannerwork/scanner-report/changesets-4.pb +0 -1
- package/.scannerwork/scanner-report/changesets-49.pb +0 -1
- package/.scannerwork/scanner-report/changesets-50.pb +0 -1
- package/.scannerwork/scanner-report/changesets-6.pb +0 -1
- package/.scannerwork/scanner-report/changesets-65.pb +0 -1
- package/.scannerwork/scanner-report/changesets-7.pb +0 -1
- package/.scannerwork/scanner-report/changesets-8.pb +0 -1
- package/.scannerwork/scanner-report/changesets-9.pb +0 -1
- package/.scannerwork/scanner-report/component-24.pb +0 -1
- package/.scannerwork/scanner-report/component-25.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-3.pb +0 -1
- package/.scannerwork/scanner-report/component-30.pb +0 -1
- package/.scannerwork/scanner-report/component-31.pb +0 -1
- package/.scannerwork/scanner-report/component-32.pb +0 -1
- package/.scannerwork/scanner-report/component-33.pb +0 -1
- package/.scannerwork/scanner-report/component-34.pb +0 -1
- package/.scannerwork/scanner-report/component-4.pb +0 -1
- package/.scannerwork/scanner-report/component-49.pb +0 -1
- package/.scannerwork/scanner-report/component-6.pb +0 -1
- package/.scannerwork/scanner-report/component-65.pb +0 -1
- package/.scannerwork/scanner-report/component-67.pb +0 -1
- package/.scannerwork/scanner-report/component-7.pb +0 -1
- package/.scannerwork/scanner-report/component-9.pb +0 -1
- 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-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-50.pb +0 -0
- package/.scannerwork/scanner-report/coverages-6.pb +0 -0
- package/.scannerwork/scanner-report/coverages-9.pb +0 -0
- package/.scannerwork/scanner-report/duplications-27.pb +0 -2
- package/.scannerwork/scanner-report/duplications-30.pb +0 -3
- package/.scannerwork/scanner-report/duplications-33.pb +0 -3
- package/.scannerwork/scanner-report/duplications-34.pb +0 -2
- package/.scannerwork/scanner-report/duplications-6.pb +0 -3
- package/.scannerwork/scanner-report/duplications-65.pb +0 -2
- package/.scannerwork/scanner-report/issues-33.pb +0 -4
- 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 -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 -15
- package/.scannerwork/scanner-report/measures-4.pb +0 -0
- package/.scannerwork/scanner-report/measures-6.pb +0 -0
- package/.scannerwork/scanner-report/measures-67.pb +0 -0
- package/.scannerwork/scanner-report/measures-9.pb +0 -0
- package/.scannerwork/scanner-report/source-27.txt +0 -225
- package/.scannerwork/scanner-report/source-29.txt +0 -156
- package/.scannerwork/scanner-report/source-30.txt +0 -131
- package/.scannerwork/scanner-report/source-32.txt +0 -92
- package/.scannerwork/scanner-report/source-33.txt +0 -244
- package/.scannerwork/scanner-report/source-34.txt +0 -293
- package/.scannerwork/scanner-report/source-4.txt +0 -366
- package/.scannerwork/scanner-report/source-6.txt +0 -119
- package/.scannerwork/scanner-report/source-67.txt +0 -167
- package/.scannerwork/scanner-report/source-9.txt +0 -147
- package/.scannerwork/scanner-report/symbols-27.pb +0 -418
- package/.scannerwork/scanner-report/symbols-28.pb +0 -9
- package/.scannerwork/scanner-report/symbols-29.pb +0 -112
- package/.scannerwork/scanner-report/symbols-30.pb +0 -97
- package/.scannerwork/scanner-report/symbols-32.pb +0 -60
- package/.scannerwork/scanner-report/symbols-33.pb +0 -394
- package/.scannerwork/scanner-report/symbols-34.pb +0 -486
- package/.scannerwork/scanner-report/symbols-4.pb +0 -494
- package/.scannerwork/scanner-report/symbols-50.pb +0 -20
- package/.scannerwork/scanner-report/symbols-6.pb +0 -77
- package/.scannerwork/scanner-report/symbols-9.pb +0 -85
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +0 -331
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +0 -48
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +0 -223
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +0 -182
- package/.scannerwork/scanner-report/syntax-highlightings-32.pb +0 -110
- package/.scannerwork/scanner-report/syntax-highlightings-33.pb +0 -329
- package/.scannerwork/scanner-report/syntax-highlightings-34.pb +0 -659
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -630
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +0 -158
- package/.scannerwork/scanner-report/syntax-highlightings-67.pb +0 -949
- package/.scannerwork/scanner-report/syntax-highlightings-9.pb +0 -191
- /package/.scannerwork/scanner-report/{coverages-65.pb → coverages-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-24.pb → coverages-18.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-31.pb → coverages-19.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-3.pb → coverages-2.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-8.pb → coverages-20.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-26.pb → coverages-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-7.pb → coverages-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-25.pb → coverages-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-49.pb → coverages-63.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-24.pb → duplications-14.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-15.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-29.pb → duplications-16.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-3.pb → duplications-17.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-31.pb → duplications-18.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-32.pb → duplications-19.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-2.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-41.pb → duplications-20.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-26.pb → duplications-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-49.pb → duplications-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-7.pb → duplications-55.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-8.pb → duplications-56.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-9.pb → duplications-57.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-4.pb → issues-35.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-25.pb → issues-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-65.pb → measures-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-24.pb → measures-18.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-31.pb → measures-19.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-3.pb → measures-2.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-26.pb → measures-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-7.pb → measures-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-25.pb → measures-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-49.pb → measures-63.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-65.txt → source-12.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-24.txt → source-18.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-31.txt → source-19.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-3.txt → source-2.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-26.txt → source-37.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-7.txt → source-38.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-25.txt → source-39.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-49.txt → source-63.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-65.pb → symbols-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-24.pb → symbols-18.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-31.pb → symbols-19.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-3.pb → symbols-2.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-8.pb → symbols-20.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-26.pb → symbols-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-7.pb → symbols-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-25.pb → symbols-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-49.pb → symbols-63.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-65.pb → syntax-highlightings-12.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-24.pb → syntax-highlightings-18.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-31.pb → syntax-highlightings-19.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-3.pb → syntax-highlightings-2.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-26.pb → syntax-highlightings-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-7.pb → syntax-highlightings-38.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-25.pb → syntax-highlightings-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-49.pb → syntax-highlightings-63.pb} +0 -0
|
@@ -1,625 +1,167 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
let count = 0;
|
|
170
|
-
/**
|
|
171
|
-
* In some tests we need to wait for both the backup process
|
|
172
|
-
* and the outputStream to "close". If we callback from either
|
|
173
|
-
* event the other might not be ready and lead to flaky tests.
|
|
174
|
-
*
|
|
175
|
-
* This function delegates to the callback but only after the
|
|
176
|
-
* correct number of invocations. That is 2 when we have an
|
|
177
|
-
* output stream or 1 otherwise, and only once in the case of
|
|
178
|
-
* an error.
|
|
179
|
-
*/
|
|
180
|
-
function gatingCallback(err) {
|
|
181
|
-
count += 1;
|
|
182
|
-
if (err) {
|
|
183
|
-
if (count === 1) {
|
|
184
|
-
callback(err);
|
|
185
|
-
}
|
|
186
|
-
} else {
|
|
187
|
-
// Output stream case we want a callback from process
|
|
188
|
-
// and the stream.
|
|
189
|
-
if (outputStream && count === 2) {
|
|
190
|
-
callback();
|
|
191
|
-
} else if (!outputStream && count === 1) {
|
|
192
|
-
callback();
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
// Note use spawn not fork for stdio options not supported with fork in Node 4.x
|
|
198
|
-
backup = spawn('node', args, { stdio: ['ignore', destination, 'pipe'] })
|
|
199
|
-
.on('error', function(err) {
|
|
200
|
-
gatingCallback(err);
|
|
201
|
-
})
|
|
202
|
-
.on('close', function(code, signal) {
|
|
203
|
-
console.log(`Backup process close ${code} ${signal}`);
|
|
204
|
-
try {
|
|
205
|
-
if (params.abort) {
|
|
206
|
-
// The tail should be stopped when we match a line and abort, but if
|
|
207
|
-
// something didn't work we need to make sure the tail is stopped
|
|
208
|
-
tail.unwatch();
|
|
209
|
-
// Assert that the process was aborted as expected
|
|
210
|
-
assert.strictEqual(signal, 'SIGTERM', `The backup should have terminated with SIGTERM, but was ${signal}.`);
|
|
211
|
-
} else if (params.expectedBackupError) {
|
|
212
|
-
assert.strictEqual(code, params.expectedBackupError.code, `The backup exited with unexpected code ${code}.`);
|
|
213
|
-
} else {
|
|
214
|
-
assert.strictEqual(code, 0, `The backup should exit normally, got exit code ${code} and signal ${signal}.`);
|
|
215
|
-
}
|
|
216
|
-
gatingCallback();
|
|
217
|
-
} catch (err) {
|
|
218
|
-
gatingCallback(err);
|
|
219
|
-
}
|
|
220
|
-
});
|
|
221
|
-
// Pipe the stdout to the supplied outputStream
|
|
222
|
-
if (destination === 'pipe') {
|
|
223
|
-
backup.stdout.pipe(backupStream);
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
// Forward the spawned process stderr (we don't use inherit because we want
|
|
227
|
-
// to access this stream directly as well)
|
|
228
|
-
backup.stderr.on('data', function(data) {
|
|
229
|
-
console.error(`${data}`);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
// Check for errors on the spawned processes
|
|
233
|
-
if (gzip) {
|
|
234
|
-
gzip.on('close', function(code) {
|
|
235
|
-
try {
|
|
236
|
-
assert.strictEqual(code, 0, `The compression should exit normally, got exit code ${code}.`);
|
|
237
|
-
} catch (err) {
|
|
238
|
-
gatingCallback(err);
|
|
239
|
-
}
|
|
240
|
-
});
|
|
241
|
-
}
|
|
242
|
-
if (openssl) {
|
|
243
|
-
openssl.on('close', function(code) {
|
|
244
|
-
try {
|
|
245
|
-
assert.strictEqual(code, 0, `The encryption should exit normally, got exit code ${code}.`);
|
|
246
|
-
} catch (err) {
|
|
247
|
-
gatingCallback(err);
|
|
248
|
-
}
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
|
-
if (outputStream) {
|
|
252
|
-
// Callback when the destination stream closes.
|
|
253
|
-
outputStream.on('close', gatingCallback);
|
|
254
|
-
} else if (!params.opts.output) {
|
|
255
|
-
gatingCallback(new Error('Unexpected test without outputStream or output option.'));
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
return backup;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
function backupAbort(usingApi, backup) {
|
|
262
|
-
setImmediate(function() {
|
|
263
|
-
if (usingApi) {
|
|
264
|
-
// Currently no way to abort an API backup
|
|
265
|
-
console.error('UNSUPPORTED: cannot abort API backups at this time.');
|
|
266
|
-
} else {
|
|
267
|
-
backup.kill();
|
|
268
|
-
}
|
|
269
|
-
});
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
function testRestore(params, inputStream, databaseName, callback) {
|
|
273
|
-
let restoreStream = inputStream;
|
|
274
|
-
|
|
275
|
-
// Configure API key if needed
|
|
276
|
-
augmentParamsWithApiKey(params);
|
|
277
|
-
|
|
278
|
-
// Pipe via decompression if requested
|
|
279
|
-
if (params.compression) {
|
|
280
|
-
if (params.useApi) {
|
|
281
|
-
// If use API use the Node zlib stream
|
|
282
|
-
restoreStream = zlib.createGunzip();
|
|
283
|
-
inputStream.pipe(restoreStream);
|
|
284
|
-
} else {
|
|
285
|
-
// Spawn process for gunzip
|
|
286
|
-
const gunzip = spawn('gunzip', [], { stdio: ['pipe', 'pipe', 'inherit'] });
|
|
287
|
-
// Pipe the streams as needed
|
|
288
|
-
inputStream.pipe(gunzip.stdin);
|
|
289
|
-
restoreStream = gunzip.stdout;
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
// Pipe via decryption if requested
|
|
294
|
-
if (params.encryption) {
|
|
295
|
-
if (params.useApi) {
|
|
296
|
-
callback(new Error('Not implemented: cannot test encrypted API backups at this time.'));
|
|
297
|
-
} else {
|
|
298
|
-
// Spawn process for openssl
|
|
299
|
-
const dopenssl = spawn('openssl', ['aes-128-cbc', '-d', '-pass', 'pass:12345'], { stdio: ['pipe', 'pipe', 'inherit'] });
|
|
300
|
-
// Pipe the streams as needed
|
|
301
|
-
inputStream.pipe(dopenssl.stdin);
|
|
302
|
-
restoreStream = dopenssl.stdout;
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
if (params.useApi) {
|
|
307
|
-
app.restore(restoreStream, dbUrl(process.env.COUCH_URL, databaseName), params.opts, function(err, data) {
|
|
308
|
-
if (err) {
|
|
309
|
-
if (params.expectedRestoreError) {
|
|
310
|
-
try {
|
|
311
|
-
assert.strictEqual(err.name, params.expectedRestoreError.name, 'The restore should receive the expected error.');
|
|
312
|
-
err = null;
|
|
313
|
-
} catch (caught) {
|
|
314
|
-
err = caught;
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
} else {
|
|
318
|
-
console.log(data);
|
|
319
|
-
}
|
|
320
|
-
callback(err);
|
|
321
|
-
}).on('error', function(err) {
|
|
322
|
-
console.error(`Caught non-fatal error: ${err}`);
|
|
323
|
-
});
|
|
324
|
-
} else {
|
|
325
|
-
// Set up default args
|
|
326
|
-
const args = ['./bin/couchrestore.bin.js', '--db', databaseName];
|
|
327
|
-
if (params.opts) {
|
|
328
|
-
if (params.opts.bufferSize) {
|
|
329
|
-
args.push('--buffer-size');
|
|
330
|
-
args.push(params.opts.bufferSize);
|
|
331
|
-
}
|
|
332
|
-
if (params.opts.parallelism) {
|
|
333
|
-
args.push('--parallelism');
|
|
334
|
-
args.push(params.opts.parallelism);
|
|
335
|
-
}
|
|
336
|
-
if (params.opts.requestTimeout) {
|
|
337
|
-
args.push('--request-timeout');
|
|
338
|
-
args.push(params.opts.requestTimeout);
|
|
339
|
-
}
|
|
340
|
-
if (params.opts.iamApiKey) {
|
|
341
|
-
args.push('--iam-api-key');
|
|
342
|
-
args.push(params.opts.iamApiKey);
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
|
|
346
|
-
// Note use spawn not fork for stdio options not supported with fork in Node 4.x
|
|
347
|
-
const restore = spawn('node', args, { stdio: ['pipe', 'inherit', 'inherit'] });
|
|
348
|
-
// Pipe to write the readable inputStream into stdin
|
|
349
|
-
restoreStream.pipe(restore.stdin);
|
|
350
|
-
restore.stdin.on('error', function(err) {
|
|
351
|
-
// Suppress errors that might arise from piping of input streams
|
|
352
|
-
// from the test process to the child process (this appears to be handled
|
|
353
|
-
// gracefully in the shell)
|
|
354
|
-
console.error(`Test stream error code ${err.code}`);
|
|
355
|
-
});
|
|
356
|
-
restore.on('close', function(code) {
|
|
357
|
-
try {
|
|
358
|
-
if (params.expectedRestoreError) {
|
|
359
|
-
assert.strictEqual(code, params.expectedRestoreError.code, `The backup exited with unexpected code ${code}.`);
|
|
360
|
-
} else {
|
|
361
|
-
assert.strictEqual(code, 0, `The restore should exit normally, got exit code ${code}`);
|
|
362
|
-
}
|
|
363
|
-
callback();
|
|
364
|
-
} catch (err) {
|
|
365
|
-
callback(err);
|
|
366
|
-
}
|
|
367
|
-
});
|
|
368
|
-
restore.on('error', function(err) {
|
|
369
|
-
callback(err);
|
|
370
|
-
});
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
|
|
374
|
-
// Serial backup and restore via a file on disk
|
|
375
|
-
function testBackupAndRestoreViaFile(params, srcDb, backupFile, targetDb, callback) {
|
|
376
|
-
testBackupToFile(params, srcDb, backupFile, function(err) {
|
|
377
|
-
if (err) {
|
|
378
|
-
callback(err);
|
|
379
|
-
} else {
|
|
380
|
-
testRestoreFromFile(params, backupFile, targetDb, function(err) {
|
|
381
|
-
if (!err) {
|
|
382
|
-
dbCompare(srcDb, targetDb, callback);
|
|
383
|
-
} else {
|
|
384
|
-
callback(err);
|
|
385
|
-
}
|
|
386
|
-
});
|
|
387
|
-
}
|
|
388
|
-
});
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
function testBackupToFile(params, srcDb, backupFile, callback, processCallback) {
|
|
392
|
-
// Open the file for appending if this is a resume
|
|
393
|
-
const output = fs.createWriteStream(backupFile, { flags: (params.opts && params.opts.resume) ? 'a' : 'w' });
|
|
394
|
-
output.on('open', function() {
|
|
395
|
-
const backupProcess = testBackup(params, srcDb, output, function(err) {
|
|
396
|
-
if (err) {
|
|
397
|
-
callback(err);
|
|
398
|
-
} else {
|
|
399
|
-
callback();
|
|
400
|
-
}
|
|
401
|
-
});
|
|
402
|
-
if (processCallback) {
|
|
403
|
-
processCallback(backupProcess);
|
|
404
|
-
}
|
|
405
|
-
});
|
|
406
|
-
}
|
|
407
|
-
|
|
408
|
-
function testRestoreFromFile(params, backupFile, targetDb, callback) {
|
|
409
|
-
const input = fs.createReadStream(backupFile);
|
|
410
|
-
input.on('open', function() {
|
|
411
|
-
testRestore(params, input, targetDb, function(err) {
|
|
412
|
-
if (err) {
|
|
413
|
-
callback(err);
|
|
414
|
-
} else {
|
|
415
|
-
callback();
|
|
416
|
-
}
|
|
417
|
-
});
|
|
418
|
-
});
|
|
419
|
-
}
|
|
420
|
-
|
|
421
|
-
function testDirectBackupAndRestore(params, srcDb, targetDb, callback) {
|
|
422
|
-
// Allow a 64 MB highWaterMark for the passthrough during testing
|
|
423
|
-
const passthrough = new stream.PassThrough({ highWaterMark: 67108864 });
|
|
424
|
-
testBackupAndRestore(params, srcDb, passthrough, passthrough, targetDb, callback);
|
|
425
|
-
}
|
|
426
|
-
|
|
427
|
-
function testBackupAndRestore(params, srcDb, backupStream, restoreStream, targetDb, callback) {
|
|
428
|
-
testBackup(params, srcDb, backupStream, function(err) {
|
|
429
|
-
if (err) {
|
|
430
|
-
callback(err);
|
|
431
|
-
}
|
|
432
|
-
});
|
|
433
|
-
testRestore(params, restoreStream, targetDb, function(err) {
|
|
434
|
-
if (err) {
|
|
435
|
-
callback(err);
|
|
436
|
-
} else {
|
|
437
|
-
dbCompare(srcDb, targetDb, callback);
|
|
438
|
-
}
|
|
439
|
-
});
|
|
440
|
-
}
|
|
441
|
-
|
|
442
|
-
function assertResumedBackup(params, resumedBackup, restoreCallback) {
|
|
443
|
-
// Validate that the resume backup didn't need to write all the docs
|
|
444
|
-
if (params.useApi) {
|
|
445
|
-
resumedBackup.once('finished', function(summary) {
|
|
446
|
-
assertWrittenFewerThan(summary.total, params.exclusiveMaxExpected, restoreCallback);
|
|
447
|
-
});
|
|
448
|
-
} else {
|
|
449
|
-
// For the CLI case we need to see the output because we don't have
|
|
450
|
-
// the finished event.
|
|
451
|
-
const listener = function(data) {
|
|
452
|
-
const matches = data.toString().match(/.*Finished - Total document revisions written: (\d+).*/);
|
|
453
|
-
if (matches !== null) {
|
|
454
|
-
assertWrittenFewerThan(matches[1], params.exclusiveMaxExpected, restoreCallback);
|
|
455
|
-
resumedBackup.stderr.removeListener('data', listener);
|
|
456
|
-
}
|
|
457
|
-
};
|
|
458
|
-
resumedBackup.stderr.on('data', listener);
|
|
459
|
-
}
|
|
460
|
-
}
|
|
461
|
-
|
|
462
|
-
function testBackupAbortResumeRestore(params, srcDb, backupFile, targetDb, callback) {
|
|
463
|
-
const restore = function(err) {
|
|
464
|
-
if (err) {
|
|
465
|
-
callback(err);
|
|
466
|
-
} else {
|
|
467
|
-
testRestoreFromFile(params, backupFile, targetDb, function(err) {
|
|
468
|
-
if (err) {
|
|
469
|
-
callback(err);
|
|
470
|
-
} else {
|
|
471
|
-
dbCompare(srcDb, targetDb, callback);
|
|
472
|
-
}
|
|
473
|
-
});
|
|
474
|
-
}
|
|
475
|
-
};
|
|
476
|
-
|
|
477
|
-
const resume = function(err) {
|
|
478
|
-
if (err) {
|
|
479
|
-
callback(err);
|
|
480
|
-
}
|
|
481
|
-
// Remove the abort parameter and add the resume parameter
|
|
482
|
-
delete params.abort;
|
|
483
|
-
params.opts.resume = true;
|
|
484
|
-
|
|
485
|
-
// Resume backup and restore to validate it was successful.
|
|
486
|
-
if (params.opts && params.opts.output) {
|
|
487
|
-
const resumedBackup = testBackup(params, srcDb, null, function(err) {
|
|
488
|
-
if (err) {
|
|
489
|
-
callback(err);
|
|
490
|
-
}
|
|
491
|
-
});
|
|
492
|
-
assertResumedBackup(params, resumedBackup, restore);
|
|
493
|
-
} else {
|
|
494
|
-
testBackupToFile(params, srcDb, backupFile, function(err) {
|
|
495
|
-
if (err) {
|
|
496
|
-
callback(err);
|
|
497
|
-
}
|
|
498
|
-
},
|
|
499
|
-
function(backupProcess) {
|
|
500
|
-
assertResumedBackup(params, backupProcess, restore);
|
|
501
|
-
});
|
|
502
|
-
}
|
|
503
|
-
};
|
|
504
|
-
|
|
505
|
-
if (params.opts && params.opts.output) {
|
|
506
|
-
testBackup(params, srcDb, null, resume);
|
|
507
|
-
} else {
|
|
508
|
-
testBackupToFile(params, srcDb, backupFile, resume);
|
|
509
|
-
}
|
|
510
|
-
}
|
|
511
|
-
|
|
512
|
-
function dbCompare(db1Name, db2Name, callback) {
|
|
513
|
-
const client = request.client(process.env.COUCH_BACKEND_URL, {});
|
|
514
|
-
compare.compare(db1Name, db2Name, client.service)
|
|
515
|
-
.then(result => {
|
|
516
|
-
try {
|
|
517
|
-
assert.strictEqual(result, true, 'The database comparison should succeed, but failed');
|
|
518
|
-
callback();
|
|
519
|
-
} catch (err) {
|
|
520
|
-
callback(err);
|
|
521
|
-
}
|
|
522
|
-
})
|
|
523
|
-
.catch(err => callback(err));
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
function sortByIdThenRev(o1, o2) {
|
|
527
|
-
if (o1._id < o2._id) return -1;
|
|
528
|
-
if (o1._id > o2._id) return 1;
|
|
529
|
-
if (o1._rev < o2._rev) return -1;
|
|
530
|
-
if (o1._rev > o2._rev) return 1;
|
|
531
|
-
return 0;
|
|
532
|
-
}
|
|
533
|
-
|
|
534
|
-
function readSortAndDeepEqual(actualContentPath, expectedContentPath, callback) {
|
|
535
|
-
const backupContent = JSON.parse(fs.readFileSync(actualContentPath, 'utf8'));
|
|
536
|
-
const expectedContent = JSON.parse(fs.readFileSync(expectedContentPath, 'utf8'));
|
|
537
|
-
// Array order of the docs is important for equality, but not for backup
|
|
538
|
-
backupContent.sort(sortByIdThenRev);
|
|
539
|
-
expectedContent.sort(sortByIdThenRev);
|
|
540
|
-
// Assert that the backup matches the expected
|
|
541
|
-
try {
|
|
542
|
-
assert.deepStrictEqual(backupContent, expectedContent);
|
|
543
|
-
callback();
|
|
544
|
-
} catch (err) {
|
|
545
|
-
callback(err);
|
|
546
|
-
}
|
|
547
|
-
}
|
|
548
|
-
|
|
549
|
-
function setTimeout(context, timeout) {
|
|
550
|
-
// Increase timeout using TEST_TIMEOUT_MULTIPLIER
|
|
551
|
-
const multiplier = (typeof process.env.TEST_TIMEOUT_MULTIPLIER !== 'undefined') ? parseInt(process.env.TEST_TIMEOUT_MULTIPLIER) : 1;
|
|
552
|
-
timeout *= multiplier;
|
|
553
|
-
// Set the mocha timeout
|
|
554
|
-
context.timeout(timeout * 1000);
|
|
555
|
-
}
|
|
556
|
-
|
|
557
|
-
function assertGzipFile(path, callback) {
|
|
558
|
-
try {
|
|
559
|
-
// 1f 8b is the gzip magic number
|
|
560
|
-
const expectedBytes = Buffer.from([0x1f, 0x8b]);
|
|
561
|
-
const buffer = Buffer.alloc(2);
|
|
562
|
-
const fd = fs.openSync(path, 'r');
|
|
563
|
-
// Read the first two bytes
|
|
564
|
-
fs.readSync(fd, buffer, 0, 2, 0);
|
|
565
|
-
fs.closeSync(fd);
|
|
566
|
-
// Assert the magic number corresponds to gz extension
|
|
567
|
-
assert.deepStrictEqual(buffer, expectedBytes, 'The backup file should be gz compressed.');
|
|
568
|
-
callback();
|
|
569
|
-
} catch (err) {
|
|
570
|
-
callback(err);
|
|
571
|
-
}
|
|
572
|
-
}
|
|
573
|
-
|
|
574
|
-
function assertEncryptedFile(path, callback) {
|
|
575
|
-
try {
|
|
576
|
-
// Openssl encrypted files start with Salted
|
|
577
|
-
const expectedBytes = Buffer.from('Salted');
|
|
578
|
-
const buffer = Buffer.alloc(6);
|
|
579
|
-
const fd = fs.openSync(path, 'r');
|
|
580
|
-
// Read the first six bytes
|
|
581
|
-
fs.readSync(fd, buffer, 0, 6, 0);
|
|
582
|
-
fs.closeSync(fd);
|
|
583
|
-
// Assert first 6 characters of the file are "Salted"
|
|
584
|
-
assert.deepStrictEqual(buffer, expectedBytes, 'The backup file should be encrypted.');
|
|
585
|
-
callback();
|
|
586
|
-
} catch (err) {
|
|
587
|
-
callback(err);
|
|
588
|
-
}
|
|
589
|
-
}
|
|
590
|
-
|
|
591
|
-
function assertWrittenFewerThan(total, number, callback) {
|
|
592
|
-
try {
|
|
593
|
-
assert(total < number && total > 0, `Saw ${total} but expected between 1 and ${number - 1} documents for the resumed backup.`);
|
|
594
|
-
callback();
|
|
595
|
-
} catch (err) {
|
|
596
|
-
callback(err);
|
|
597
|
-
}
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
function augmentParamsWithApiKey(params) {
|
|
601
|
-
if (process.env.COUCHBACKUP_TEST_IAM_API_KEY) {
|
|
602
|
-
if (!params.opts) {
|
|
603
|
-
params.opts = {};
|
|
604
|
-
}
|
|
605
|
-
params.opts.iamApiKey = process.env.COUCHBACKUP_TEST_IAM_API_KEY;
|
|
606
|
-
params.opts.iamTokenUrl = process.env.CLOUDANT_IAM_TOKEN_URL;
|
|
607
|
-
}
|
|
608
|
-
}
|
|
609
|
-
|
|
610
|
-
module.exports = {
|
|
611
|
-
scenario,
|
|
612
|
-
p: params,
|
|
613
|
-
setTimeout,
|
|
614
|
-
dbCompare,
|
|
615
|
-
readSortAndDeepEqual,
|
|
616
|
-
assertGzipFile,
|
|
617
|
-
assertEncryptedFile,
|
|
618
|
-
testBackup,
|
|
619
|
-
testRestore,
|
|
620
|
-
testDirectBackupAndRestore,
|
|
621
|
-
testBackupToFile,
|
|
622
|
-
testRestoreFromFile,
|
|
623
|
-
testBackupAndRestoreViaFile,
|
|
624
|
-
testBackupAbortResumeRestore
|
|
625
|
-
};
|
|
1
|
+
<testsuites name="test-iam">
|
|
2
|
+
<testsuite name="Basic backup and restore using API" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:52:41" time="4.856">
|
|
3
|
+
<testcase classname="test-iam.Basic backup and restore using API" name="should backup animaldb to a file correctly" time="1.053">
|
|
4
|
+
<system-out><![CDATA[{ total: 15 }
|
|
5
|
+
]]></system-out>
|
|
6
|
+
</testcase>
|
|
7
|
+
<testcase classname="test-iam.Basic backup and restore using API" name="should restore animaldb to a database correctly" time="1.845">
|
|
8
|
+
<system-out><![CDATA[{ total: 15 }
|
|
9
|
+
]]></system-out>
|
|
10
|
+
</testcase>
|
|
11
|
+
<testcase classname="test-iam.Basic backup and restore using API" name="should execute a shallow mode backup successfully" time="0.773">
|
|
12
|
+
<system-out><![CDATA[{ total: 11 }
|
|
13
|
+
]]></system-out>
|
|
14
|
+
</testcase>
|
|
15
|
+
</testsuite>
|
|
16
|
+
<testsuite name="Basic backup and restore using API Buffer size tests using API" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:52:46" time="11.293">
|
|
17
|
+
<testcase classname="test-iam.Basic backup and restore using API Buffer size tests using API" name="should backup/restore animaldb with the same buffer size" time="3.675">
|
|
18
|
+
<system-out><![CDATA[{ total: 15 }
|
|
19
|
+
{ total: 15 }
|
|
20
|
+
]]></system-out>
|
|
21
|
+
</testcase>
|
|
22
|
+
<testcase classname="test-iam.Basic backup and restore using API Buffer size tests using API" name="should backup/restore animaldb with backup buffer > restore buffer" time="3.436">
|
|
23
|
+
<system-out><![CDATA[{ total: 15 }
|
|
24
|
+
{ total: 15 }
|
|
25
|
+
]]></system-out>
|
|
26
|
+
</testcase>
|
|
27
|
+
<testcase classname="test-iam.Basic backup and restore using API Buffer size tests using API" name="should backup/restore animaldb with backup buffer < restore buffer" time="3.379">
|
|
28
|
+
<system-out><![CDATA[{ total: 15 }
|
|
29
|
+
{ total: 15 }
|
|
30
|
+
]]></system-out>
|
|
31
|
+
</testcase>
|
|
32
|
+
</testsuite>
|
|
33
|
+
<testsuite name="Basic backup and restore using CLI" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:52:57" time="6.14">
|
|
34
|
+
<testcase classname="test-iam.Basic backup and restore using CLI" name="should backup animaldb to a file correctly" time="1.6">
|
|
35
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
36
|
+
]]></system-out>
|
|
37
|
+
</testcase>
|
|
38
|
+
<testcase classname="test-iam.Basic backup and restore using CLI" name="should restore animaldb to a database correctly" time="2.446">
|
|
39
|
+
</testcase>
|
|
40
|
+
<testcase classname="test-iam.Basic backup and restore using CLI" name="should execute a shallow mode backup successfully" time="1.298">
|
|
41
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
42
|
+
]]></system-out>
|
|
43
|
+
</testcase>
|
|
44
|
+
</testsuite>
|
|
45
|
+
<testsuite name="Basic backup and restore using CLI Buffer size tests using CLI" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:53:03" time="16.561">
|
|
46
|
+
<testcase classname="test-iam.Basic backup and restore using CLI Buffer size tests using CLI" name="should backup/restore animaldb with the same buffer size" time="5.326">
|
|
47
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
48
|
+
]]></system-out>
|
|
49
|
+
</testcase>
|
|
50
|
+
<testcase classname="test-iam.Basic backup and restore using CLI Buffer size tests using CLI" name="should backup/restore animaldb with backup buffer > restore buffer" time="5.352">
|
|
51
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
52
|
+
]]></system-out>
|
|
53
|
+
</testcase>
|
|
54
|
+
<testcase classname="test-iam.Basic backup and restore using CLI Buffer size tests using CLI" name="should backup/restore animaldb with backup buffer < restore buffer" time="5.082">
|
|
55
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
56
|
+
]]></system-out>
|
|
57
|
+
</testcase>
|
|
58
|
+
</testsuite>
|
|
59
|
+
<testsuite name="Compression tests using API" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:53:20" time="6.735">
|
|
60
|
+
<testcase classname="test-iam.Compression tests using API" name="should backup animaldb to a compressed file" time="0.819">
|
|
61
|
+
<system-out><![CDATA[{ total: 15 }
|
|
62
|
+
]]></system-out>
|
|
63
|
+
</testcase>
|
|
64
|
+
<testcase classname="test-iam.Compression tests using API" name="should backup and restore animaldb via a compressed file" time="2.808">
|
|
65
|
+
<system-out><![CDATA[{ total: 15 }
|
|
66
|
+
{ total: 15 }
|
|
67
|
+
]]></system-out>
|
|
68
|
+
</testcase>
|
|
69
|
+
<testcase classname="test-iam.Compression tests using API" name="should backup and restore animaldb via a compressed stream" time="2.317">
|
|
70
|
+
<system-out><![CDATA[{ total: 15 }
|
|
71
|
+
{ total: 15 }
|
|
72
|
+
]]></system-out>
|
|
73
|
+
</testcase>
|
|
74
|
+
</testsuite>
|
|
75
|
+
<testsuite name="Compression tests using CLI" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:53:27" time="9.994">
|
|
76
|
+
<testcase classname="test-iam.Compression tests using CLI" name="should backup animaldb to a compressed file" time="1.69">
|
|
77
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
78
|
+
]]></system-out>
|
|
79
|
+
</testcase>
|
|
80
|
+
<testcase classname="test-iam.Compression tests using CLI" name="should backup and restore animaldb via a compressed file" time="4.54">
|
|
81
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
82
|
+
]]></system-out>
|
|
83
|
+
</testcase>
|
|
84
|
+
<testcase classname="test-iam.Compression tests using CLI" name="should backup and restore animaldb via a compressed stream" time="2.978">
|
|
85
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
86
|
+
]]></system-out>
|
|
87
|
+
</testcase>
|
|
88
|
+
</testsuite>
|
|
89
|
+
<testsuite name="End to end backup and restore using API" tests="2" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:53:37" time="324.393">
|
|
90
|
+
<testcase classname="test-iam.End to end backup and restore using API" name="should backup and restore animaldb" time="2.227">
|
|
91
|
+
<system-out><![CDATA[{ total: 15 }
|
|
92
|
+
{ total: 15 }
|
|
93
|
+
]]></system-out>
|
|
94
|
+
</testcase>
|
|
95
|
+
<testcase classname="test-iam.End to end backup and restore using API" name="should backup and restore largedb1g #slow" time="321.389">
|
|
96
|
+
<system-out><![CDATA[{ total: 522948 }
|
|
97
|
+
{ total: 522948 }
|
|
98
|
+
]]></system-out>
|
|
99
|
+
</testcase>
|
|
100
|
+
</testsuite>
|
|
101
|
+
<testsuite name="End to end backup and restore using CLI" tests="2" errors="0" failures="0" skipped="0" timestamp="2023-09-28T16:59:01" time="520.316">
|
|
102
|
+
<testcase classname="test-iam.End to end backup and restore using CLI" name="should backup and restore animaldb" time="2.871">
|
|
103
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
104
|
+
]]></system-out>
|
|
105
|
+
</testcase>
|
|
106
|
+
<testcase classname="test-iam.End to end backup and restore using CLI" name="should backup and restore largedb1g #slow" time="516.671">
|
|
107
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
108
|
+
]]></system-out>
|
|
109
|
+
</testcase>
|
|
110
|
+
</testsuite>
|
|
111
|
+
<testsuite name="Encryption tests" tests="1" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:07:41" time="4.707">
|
|
112
|
+
<testcase classname="test-iam.Encryption tests" name="should backup and restore animaldb via an encrypted file" time="4.444">
|
|
113
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
114
|
+
]]></system-out>
|
|
115
|
+
</testcase>
|
|
116
|
+
</testsuite>
|
|
117
|
+
<testsuite name="Write error tests" tests="1" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:07:46" time="0.271">
|
|
118
|
+
<testcase classname="test-iam.Write error tests" name="calls callback with error set when stream is not writeable" time="0.011">
|
|
119
|
+
</testcase>
|
|
120
|
+
</testsuite>
|
|
121
|
+
<testsuite name="Event tests" tests="2" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:07:46" time="2.397">
|
|
122
|
+
<testcase classname="test-iam.Event tests" name="should get a finished event when using stdout" time="0.961">
|
|
123
|
+
</testcase>
|
|
124
|
+
<testcase classname="test-iam.Event tests" name="should get a finished event when using file output" time="0.905">
|
|
125
|
+
</testcase>
|
|
126
|
+
</testsuite>
|
|
127
|
+
<testsuite name="Resume tests using API" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:07:49" time="5.265">
|
|
128
|
+
<testcase classname="test-iam.Resume tests using API" name="should create a log file" time="0.822">
|
|
129
|
+
<system-out><![CDATA[{ total: 15 }
|
|
130
|
+
]]></system-out>
|
|
131
|
+
</testcase>
|
|
132
|
+
<testcase classname="test-iam.Resume tests using API" name="should restore corrupted animaldb to a database correctly" time="1.835">
|
|
133
|
+
<system-out><![CDATA[{ total: 15 }
|
|
134
|
+
]]></system-out>
|
|
135
|
+
</testcase>
|
|
136
|
+
<testcase classname="test-iam.Resume tests using API" name="should restore resumed animaldb with blank line to a database correctly" time="1.812">
|
|
137
|
+
<system-out><![CDATA[{ total: 15 }
|
|
138
|
+
]]></system-out>
|
|
139
|
+
</testcase>
|
|
140
|
+
</testsuite>
|
|
141
|
+
<testsuite name="Resume tests using CLI" tests="3" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:07:54" time="7.179">
|
|
142
|
+
<testcase classname="test-iam.Resume tests using CLI" name="should create a log file" time="1.54">
|
|
143
|
+
<system-out><![CDATA[Backup process close 0 null
|
|
144
|
+
]]></system-out>
|
|
145
|
+
</testcase>
|
|
146
|
+
<testcase classname="test-iam.Resume tests using CLI" name="should restore corrupted animaldb to a database correctly" time="2.435">
|
|
147
|
+
</testcase>
|
|
148
|
+
<testcase classname="test-iam.Resume tests using CLI" name="should restore resumed animaldb with blank line to a database correctly" time="2.412">
|
|
149
|
+
</testcase>
|
|
150
|
+
</testsuite>
|
|
151
|
+
<testsuite name="Resume tests" tests="2" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:08:01" time="35.404">
|
|
152
|
+
<testcase classname="test-iam.Resume tests" name="should correctly backup and restore backup10m" time="17.7">
|
|
153
|
+
<system-out><![CDATA[Backup process close null SIGTERM
|
|
154
|
+
Backup process close 0 null
|
|
155
|
+
]]></system-out>
|
|
156
|
+
</testcase>
|
|
157
|
+
<testcase classname="test-iam.Resume tests" name="should correctly backup and restore backup10m using --output" time="17.166">
|
|
158
|
+
<system-out><![CDATA[Backup process close null SIGTERM
|
|
159
|
+
Backup process close 0 null
|
|
160
|
+
]]></system-out>
|
|
161
|
+
</testcase>
|
|
162
|
+
</testsuite>
|
|
163
|
+
<testsuite name="Longer spool changes checks" tests="1" errors="0" failures="0" skipped="0" timestamp="2023-09-28T17:08:36" time="47.065">
|
|
164
|
+
<testcase classname="test-iam.Longer spool changes checks" name="#slow should keep collecting changes (25M)" time="46.804">
|
|
165
|
+
</testcase>
|
|
166
|
+
</testsuite>
|
|
167
|
+
</testsuites>
|