@sprucelabs/jest-sheets-reporter 1.3.123 → 2.0.0
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/build/SheetsReporterUtility.js +1 -1
- package/build/__tests__/implementation/GoogleAdapter.test.d.ts +4 -0
- package/build/__tests__/implementation/GoogleAdapter.test.js +54 -0
- package/build/adapters/{MockAdapter.d.ts → DummyAdapter.d.ts} +1 -1
- package/build/adapters/{MockAdapter.js → DummyAdapter.js} +5 -5
- package/build/adapters/GoogleAdapter.js +6 -1
- package/package.json +3 -3
|
@@ -26,7 +26,7 @@ class SheetsReporterUtility {
|
|
|
26
26
|
static resolveAdapterPath(adapterFilepath) {
|
|
27
27
|
const filePath = adapterFilepath !== null && adapterFilepath !== void 0 ? adapterFilepath : process.env.SHEETS_REPORTER_ADAPTER;
|
|
28
28
|
if (!filePath) {
|
|
29
|
-
throw new Error(`SheetsReporter has no adapter set, try adding SHEETS_REPORTER_ADAPTER="
|
|
29
|
+
throw new Error(`SheetsReporter has no adapter set, try adding SHEETS_REPORTER_ADAPTER="DummyAdapter" or SHEETS_REPORTER_ADAPTER="GoogleAdapter" to your env.`);
|
|
30
30
|
}
|
|
31
31
|
const basePath = filePath.search(new RegExp(path_1.default.sep)) > -1
|
|
32
32
|
? process.cwd()
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
25
|
+
if (mod && mod.__esModule) return mod;
|
|
26
|
+
var result = {};
|
|
27
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
28
|
+
__setModuleDefault(result, mod);
|
|
29
|
+
return result;
|
|
30
|
+
};
|
|
31
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
32
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
33
|
+
};
|
|
34
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
35
|
+
const test_1 = __importStar(require("@sprucelabs/test"));
|
|
36
|
+
const GoogleAdapter_1 = __importDefault(require("../../adapters/GoogleAdapter"));
|
|
37
|
+
class GoogleAdapterTest extends test_1.default {
|
|
38
|
+
static async badKeyThrowsErrorWithLinkToDocs() {
|
|
39
|
+
const adapter = new GoogleAdapter_1.default({
|
|
40
|
+
privateKey: '234',
|
|
41
|
+
serviceEmail: 'test@test.com',
|
|
42
|
+
});
|
|
43
|
+
await test_1.assert.doesThrowAsync(() => adapter.updateCell({
|
|
44
|
+
cell: 'B1',
|
|
45
|
+
sheetId: '12345',
|
|
46
|
+
worksheetId: 0,
|
|
47
|
+
value: '100',
|
|
48
|
+
}), 'https://theoephraim.github.io/node-google-spreadsheet/#/getting-started/authentication');
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
__decorate([
|
|
52
|
+
(0, test_1.test)()
|
|
53
|
+
], GoogleAdapterTest, "badKeyThrowsErrorWithLinkToDocs", null);
|
|
54
|
+
exports.default = GoogleAdapterTest;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import SheetsReporterTestAdapter from './TestAdapter';
|
|
2
|
-
export default class
|
|
2
|
+
export default class SheetsReporterDummyAdapter extends SheetsReporterTestAdapter {
|
|
3
3
|
private static cellCache;
|
|
4
4
|
constructor();
|
|
5
5
|
updateCell(options: {
|
|
@@ -4,22 +4,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
const TestAdapter_1 = __importDefault(require("./TestAdapter"));
|
|
7
|
-
class
|
|
7
|
+
class SheetsReporterDummyAdapter extends TestAdapter_1.default {
|
|
8
8
|
constructor() {
|
|
9
9
|
super({ serviceEmail: 'not-needed@nothing.com', privateKey: 'nothing' });
|
|
10
10
|
}
|
|
11
11
|
async updateCell(options) {
|
|
12
12
|
const key = `${options.sheetId}${options.worksheetId}${options.cell}`;
|
|
13
|
-
|
|
13
|
+
SheetsReporterDummyAdapter.cellCache[key] = options.value;
|
|
14
14
|
}
|
|
15
15
|
async fetchCellValue(sheetId, worksheetId, cell) {
|
|
16
16
|
const key = `${sheetId}${worksheetId}${cell}`;
|
|
17
|
-
return
|
|
17
|
+
return SheetsReporterDummyAdapter.cellCache[key];
|
|
18
18
|
}
|
|
19
19
|
async createRandomWorksheet() {
|
|
20
20
|
return -1;
|
|
21
21
|
}
|
|
22
22
|
async deleteWorksheet() { }
|
|
23
23
|
}
|
|
24
|
-
exports.default =
|
|
25
|
-
|
|
24
|
+
exports.default = SheetsReporterDummyAdapter;
|
|
25
|
+
SheetsReporterDummyAdapter.cellCache = {};
|
|
@@ -43,7 +43,12 @@ class SheetsReporterGoogleAdapter {
|
|
|
43
43
|
resolve();
|
|
44
44
|
}
|
|
45
45
|
catch (err) {
|
|
46
|
-
|
|
46
|
+
const isBadKey = err.reason === 'no start line';
|
|
47
|
+
if (isBadKey) {
|
|
48
|
+
reject(new Error(`Bad private key! Checkout this for next steps:\n\nhttps://theoephraim.github.io/node-google-spreadsheet/#/getting-started/authentication`));
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
if (operation.retry(err) && isBadKey) {
|
|
47
52
|
console.error('Sheets reporter error', err);
|
|
48
53
|
return;
|
|
49
54
|
}
|
package/package.json
CHANGED
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"@sprucelabs/resolve-path-aliases"
|
|
14
14
|
]
|
|
15
15
|
},
|
|
16
|
-
"version": "
|
|
16
|
+
"version": "2.0.0",
|
|
17
17
|
"main": "./build/SheetsReporter.js",
|
|
18
18
|
"types": "./build/SheetsReporter.d.ts",
|
|
19
19
|
"description": "Have your Jest tests update a Google Spreadsheet™®©. 📡",
|
|
@@ -63,12 +63,12 @@
|
|
|
63
63
|
"devDependencies": {
|
|
64
64
|
"@sprucelabs/resolve-path-aliases": "^1.0.244",
|
|
65
65
|
"@sprucelabs/semantic-release": "^4.0.8",
|
|
66
|
-
"@sprucelabs/test": "^7.7.
|
|
66
|
+
"@sprucelabs/test": "^7.7.371",
|
|
67
67
|
"@types/google-spreadsheet": "^3.3.0",
|
|
68
68
|
"@types/node": "^18.8.3",
|
|
69
69
|
"chokidar-cli": "^3.0.0",
|
|
70
70
|
"concurrently": "^7.4.0",
|
|
71
|
-
"eslint": "^8.
|
|
71
|
+
"eslint": "^8.25.0",
|
|
72
72
|
"eslint-config-spruce": "^10.11.4",
|
|
73
73
|
"jest": "^29.1.2",
|
|
74
74
|
"jest-reporters": "^0.0.2",
|