datagrok-tools 4.6.4 → 4.7.1

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.
@@ -2,7 +2,7 @@
2
2
  * @jest-environment jsdom
3
3
  */
4
4
 
5
- import * as utils from './test-node';
5
+ import * as utils from '../bin/utils/test-utils';
6
6
  import puppeteer from 'puppeteer';
7
7
 
8
8
  const P_START_TIMEOUT: number = 3600000;
@@ -16,7 +16,7 @@ beforeAll(async () => {
16
16
  }, P_START_TIMEOUT);
17
17
 
18
18
  afterAll(async () => {
19
- await browser.close();
19
+ await browser?.close();
20
20
  });
21
21
 
22
22
  expect.extend({
@@ -42,16 +42,23 @@ it('TEST', async () => {
42
42
  let r = await page.evaluate((targetPackage):Promise<object> => {
43
43
  return new Promise<object>((resolve, reject) => {
44
44
  (<any>window).grok.functions.eval(targetPackage + ':test()').then((df: any) => {
45
+ let failed = false;
46
+ let skipReport = '';
47
+ let passReport = '';
48
+ let failReport = '';
49
+
50
+ if (df == null) {
51
+ failed = true;
52
+ failReport = 'Fail reason: No package tests found';
53
+ resolve({failReport, skipReport, passReport, failed});
54
+ }
55
+
45
56
  const cStatus = df.columns.byName('success');
46
57
  const cSkipped = df.columns.byName('skipped');
47
58
  const cMessage = df.columns.byName('result');
48
59
  const cCat = df.columns.byName('category');
49
60
  const cName = df.columns.byName('name');
50
61
  const cTime = df.columns.byName('ms');
51
- let failed = false;
52
- let skipReport = '';
53
- let passReport = '';
54
- let failReport = '';
55
62
  for (let i = 0; i < df.rowCount; i++) {
56
63
  if (cStatus.get(i)) {
57
64
  if (cSkipped.get(i)) {
@@ -118,20 +118,8 @@ function createDirectoryContents(name, config, templateDir, packageDir) {
118
118
  Object.assign(_package.dependencies, {
119
119
  '@datagrok-libraries/utils': 'latest'
120
120
  });
121
- Object.assign(_package.devDependencies, {
122
- 'jest-html-reporter': '^3.5.0',
123
- 'jest': '^27.0.0',
124
- '@types/jest': '^27.0.0',
125
- 'js-yaml': '^4.1.0',
126
- '@types/js-yaml': "^4.0.5",
127
- '@types/node-fetch': '^2.6.2',
128
- 'node-fetch': '^2.6.7'
129
- }, ts ? {
130
- 'ts-jest': '^27.0.0',
131
- 'puppeteer': '^13.7.0'
132
- } : {});
133
121
  Object.assign(_package.scripts, {
134
- 'test': 'jest'
122
+ 'test': 'grok test'
135
123
  });
136
124
  } // Save module names for installation prompt
137
125
 
@@ -152,9 +140,6 @@ function createDirectoryContents(name, config, templateDir, packageDir) {
152
140
  if (file === 'package-test.ts' && !ts) return false;
153
141
  if (file === 'tsconfig.json' && !ts) return false;
154
142
  if (file === 'ts.webpack.config.js') return false;
155
- if (file === 'remote.test.ts' && (!ts || !jest)) return false;
156
- if (file === 'test-node.ts' && (!ts || !jest)) return false;
157
- if (file === 'jest.config.js' && !jest) return false;
158
143
 
159
144
  if (file === '.eslintrc.json') {
160
145
  if (!eslint) return false;
@@ -4,13 +4,14 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.help = void 0;
7
- var HELP = "\nUsage: grok <command>\n\nDatagrok's package management tool\n\nCommands:\n add Add an object template\n api Create wrapper functions\n check Check package content (function signatures, etc.)\n config Create and manage config files\n create Create a package\n publish Upload a package\n\nTo get help on a particular command, use:\n grok <command> --help\n\nRead more about the package development workflow:\nhttps://datagrok.ai/help/develop/develop\n";
7
+ var HELP = "\nUsage: grok <command>\n\nDatagrok's package management tool\n\nCommands:\n add Add an object template\n api Create wrapper functions\n check Check package content (function signatures, etc.)\n config Create and manage config files\n create Create a package\n publish Upload a package\n test Run package tests\n\nTo get help on a particular command, use:\n grok <command> --help\n\nRead more about the package development workflow:\nhttps://datagrok.ai/help/develop/develop\n";
8
8
  var HELP_ADD = "\nUsage: grok add <entity> <name>\n\nAdd an object template to your package:\n\ngrok add app <name>\ngrok add connection <name>\ngrok add detector <semantic-type-name>\ngrok add function [tag] <name>\ngrok add query <name>\ngrok add script [tag] <language> <name>\ngrok add view <name>\ngrok add viewer <name>\ngrok add tests\n\nPlease note that entity names may only include letters and numbers\n\nSupported languages for scripts:\njavascript, julia, node, octave, python, r\n\nAvailable tags:\npanel, init\n";
9
9
  var HELP_API = "\nUsage: grok api\n\nCreate wrapper functions for package scripts and queries\n";
10
10
  var HELP_CONFIG = "\nUsage: grok config\n\nCreate or update a configuration file\n\nOptions:\n[--reset] [--server] [--alias] [--key]\n\n--reset Restore the default config file template\n--server Use to add a server to the config (`grok config add --alias alias --server url --key key`)\n--alias Use in conjunction with the `server` option to set the server name\n--key Use in conjunction with the `server` option to set the developer key\n--default Use in conjunction with the `server` option to set the added server as default\n";
11
11
  var HELP_CREATE = "\nUsage: grok create [name]\n\nCreate a package:\n\ngrok create Create a package in the current working directory\ngrok create <name> Create a package in a folder with the specified name\n\nPlease note that the package name may only include letters, numbers, underscores, or hyphens\n\nOptions:\n[--eslint] [--ide] [--js|--ts] [--jest]\n\n--eslint Add a configuration for eslint\n--ide Add an IDE-specific configuration for debugging (vscode)\n--js Create a JavaScript package\n--ts Create a TypeScript package (default)\n--jest Add a configuration for jest\n";
12
12
  var HELP_PUBLISH = "\nUsage: grok publish [host]\n\nUpload a package\n\nOptions:\n[--build|--rebuild] [--debug|--release] [--key] [--suffix]\n\nRunning `grok publish` is the same as running `grok publish defaultHost --build --debug`\n";
13
13
  var HELP_CHECK = "\nUsage: grok check\n\nOptions:\n[--dir]\n\n--dir Check all packages in a specified directory\n\nCheck package content (function signatures, import statements of external modules, etc.)\n";
14
+ var HELP_TEST = "\nUsage: grok test\n\nOptions:\n[--host]\n\n--host Host alias as in the config file\n\nRun package tests\n\nSee instructions:\nhttps://datagrok.ai/help/develop/how-to/test-packages#local-testing\n";
14
15
  var HELP_MIGRATE = "\nUsage: grok migrate\n\nSwitch to `grok` tools by copying your keys to the config\nfile and converting your scripts in the `package.json` file\n";
15
16
  var help = {
16
17
  add: HELP_ADD,
@@ -19,6 +20,7 @@ var help = {
19
20
  config: HELP_CONFIG,
20
21
  create: HELP_CREATE,
21
22
  publish: HELP_PUBLISH,
23
+ test: HELP_TEST,
22
24
  help: HELP
23
25
  };
24
26
  exports.help = help;
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.test = test;
11
+
12
+ var _child_process = require("child_process");
13
+
14
+ var _fs = _interopRequireDefault(require("fs"));
15
+
16
+ var _os = _interopRequireDefault(require("os"));
17
+
18
+ var _path = _interopRequireDefault(require("path"));
19
+
20
+ var _jsYaml = _interopRequireDefault(require("js-yaml"));
21
+
22
+ var utils = _interopRequireWildcard(require("../utils/utils"));
23
+
24
+ var color = _interopRequireWildcard(require("../utils/color-utils"));
25
+
26
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
27
+
28
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
+
30
+ function test(args) {
31
+ var options = Object.keys(args).slice(1);
32
+ var nArgs = args['_'].length;
33
+ var curDir = process.cwd();
34
+
35
+ var grokDir = _path["default"].join(_os["default"].homedir(), '.grok');
36
+
37
+ var confPath = _path["default"].join(grokDir, 'config.yaml');
38
+
39
+ if (nArgs > 1 || options.length > 1 || options.length === 1 && options[0] !== 'host') return false;
40
+
41
+ if (!utils.isPackageDir(curDir)) {
42
+ color.error('File `package.json` not found. Run the command from the package directory');
43
+ return false;
44
+ }
45
+
46
+ if (!_fs["default"].existsSync(confPath)) {
47
+ color.error("File `".concat(confPath, "` not found. Run `grok config` to set up the config file"));
48
+ return false;
49
+ }
50
+
51
+ var config = _jsYaml["default"].load(_fs["default"].readFileSync(confPath, {
52
+ encoding: 'utf-8'
53
+ }));
54
+
55
+ if (args.host) {
56
+ if (args.host in config.servers) {
57
+ process.env.HOST = args.host;
58
+ console.log('Environment variable `HOST` is set to', args.host);
59
+ } else {
60
+ color.error("Unknown server alias. Please add it to ".concat(confPath));
61
+ return false;
62
+ }
63
+ } else if (config["default"]) {
64
+ process.env.HOST = config["default"];
65
+ console.log('Environment variable `HOST` is set to', config["default"]);
66
+ }
67
+
68
+ var packageData = JSON.parse(_fs["default"].readFileSync(_path["default"].join(curDir, 'package.json'), {
69
+ encoding: 'utf-8'
70
+ }));
71
+ var fullName = packageData.friendlyName || packageData.fullName;
72
+
73
+ if (fullName) {
74
+ fullName = utils.kebabToCamelCase(fullName);
75
+ process.env.TARGET_PACKAGE = fullName;
76
+ console.log('Environment variable `TARGET_PACKAGE` is set to', process.env.TARGET_PACKAGE);
77
+ } else {
78
+ color.error('Invalid full package name. Set `friendlyName` or `fullName` field in `package.json`');
79
+ return false;
80
+ }
81
+
82
+ color.info("Building package...");
83
+ (0, _child_process.exec)('npm run build', function (err, stdout, stderr) {
84
+ if (err) throw err;else {
85
+ console.log(stdout);
86
+ color.warn(stderr);
87
+ }
88
+ color.info("Publishing package \"".concat(process.env.TARGET_PACKAGE, "\" to ").concat(process.env.HOST, "..."));
89
+ (0, _child_process.exec)("grok publish ".concat(process.platform === 'win32' ? '%HOST%' : '${HOST}'), function (err, stdout, stderr) {
90
+ if (err) throw err;else {
91
+ console.log(stdout);
92
+ color.warn(stderr);
93
+ }
94
+ color.info('Starting tests...');
95
+ (0, _child_process.exec)('npm run test', {
96
+ cwd: _path["default"].dirname(_path["default"].dirname(__dirname))
97
+ }, function (err, stdout, stderr) {
98
+ if (err) throw err;else {
99
+ console.log(stdout);
100
+ console.log(stderr);
101
+ }
102
+ });
103
+ });
104
+ });
105
+ return true;
106
+ }
package/bin/grok.js CHANGED
@@ -9,6 +9,7 @@ const commands = {
9
9
  config: require('./commands/config').config,
10
10
  create: require('./commands/create').create,
11
11
  publish: require('./commands/publish').publish,
12
+ test: require('./commands/test').test,
12
13
  };
13
14
 
14
15
  const command = argv['_'][0];
@@ -0,0 +1,242 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.getBrowserPage = getBrowserPage;
11
+ exports.getDevKey = getDevKey;
12
+ exports.getToken = getToken;
13
+ exports.getWebUrl = getWebUrl;
14
+
15
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
16
+
17
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
18
+
19
+ var _fs = _interopRequireDefault(require("fs"));
20
+
21
+ var _os = _interopRequireDefault(require("os"));
22
+
23
+ var _path = _interopRequireDefault(require("path"));
24
+
25
+ var _jsYaml = _interopRequireDefault(require("js-yaml"));
26
+
27
+ var utils = _interopRequireWildcard(require("../utils/utils"));
28
+
29
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
30
+
31
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
32
+
33
+ var fetch = require('node-fetch');
34
+
35
+ var grokDir = _path["default"].join(_os["default"].homedir(), '.grok');
36
+
37
+ var confPath = _path["default"].join(grokDir, 'config.yaml');
38
+
39
+ function getToken(_x, _x2) {
40
+ return _getToken.apply(this, arguments);
41
+ }
42
+
43
+ function _getToken() {
44
+ _getToken = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(url, key) {
45
+ var response, json;
46
+ return _regenerator["default"].wrap(function _callee$(_context) {
47
+ while (1) {
48
+ switch (_context.prev = _context.next) {
49
+ case 0:
50
+ _context.next = 2;
51
+ return fetch("".concat(url, "/users/login/dev/").concat(key), {
52
+ method: 'POST'
53
+ });
54
+
55
+ case 2:
56
+ response = _context.sent;
57
+ _context.next = 5;
58
+ return response.json();
59
+
60
+ case 5:
61
+ json = _context.sent;
62
+
63
+ if (!(json.isSuccess == true)) {
64
+ _context.next = 10;
65
+ break;
66
+ }
67
+
68
+ return _context.abrupt("return", json.token);
69
+
70
+ case 10:
71
+ throw 'Unable to login to server. Check your dev key';
72
+
73
+ case 11:
74
+ case "end":
75
+ return _context.stop();
76
+ }
77
+ }
78
+ }, _callee);
79
+ }));
80
+ return _getToken.apply(this, arguments);
81
+ }
82
+
83
+ function getWebUrl(_x3, _x4) {
84
+ return _getWebUrl.apply(this, arguments);
85
+ }
86
+
87
+ function _getWebUrl() {
88
+ _getWebUrl = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(url, token) {
89
+ var response, json;
90
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
91
+ while (1) {
92
+ switch (_context2.prev = _context2.next) {
93
+ case 0:
94
+ _context2.next = 2;
95
+ return fetch("".concat(url, "/admin/plugins/admin/settings"), {
96
+ headers: {
97
+ Authorization: token
98
+ }
99
+ });
100
+
101
+ case 2:
102
+ response = _context2.sent;
103
+ _context2.next = 5;
104
+ return response.json();
105
+
106
+ case 5:
107
+ json = _context2.sent;
108
+ return _context2.abrupt("return", json.settings.webRoot);
109
+
110
+ case 7:
111
+ case "end":
112
+ return _context2.stop();
113
+ }
114
+ }
115
+ }, _callee2);
116
+ }));
117
+ return _getWebUrl.apply(this, arguments);
118
+ }
119
+
120
+ function getDevKey(hostKey) {
121
+ var config = _jsYaml["default"].load(_fs["default"].readFileSync(confPath, 'utf8'));
122
+
123
+ var host = hostKey == '' ? config["default"] : hostKey;
124
+ host = host.trim();
125
+ var urls = utils.mapURL(config);
126
+ var key = '';
127
+ var url = '';
128
+
129
+ try {
130
+ var _url = new URL(host).href;
131
+ if (_url.endsWith('/')) _url = _url.slice(0, -1);
132
+ if (_url in urls) key = config['servers'][urls[_url]]['key'];
133
+ } catch (error) {
134
+ if (config['servers'][host] == null) throw "Unknown server alias. Please add it to ".concat(confPath);
135
+ url = config['servers'][host]['url'];
136
+ key = config['servers'][host]['key'];
137
+ }
138
+
139
+ return {
140
+ url: url,
141
+ key: key
142
+ };
143
+ }
144
+
145
+ function getBrowserPage(_x5) {
146
+ return _getBrowserPage.apply(this, arguments);
147
+ }
148
+
149
+ function _getBrowserPage() {
150
+ _getBrowserPage = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(puppeteer) {
151
+ var _process$env$HOST;
152
+
153
+ var url, cfg, key, token, browser, page;
154
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
155
+ while (1) {
156
+ switch (_context3.prev = _context3.next) {
157
+ case 0:
158
+ url = (_process$env$HOST = process.env.HOST) !== null && _process$env$HOST !== void 0 ? _process$env$HOST : '';
159
+ cfg = getDevKey(url);
160
+ url = cfg.url;
161
+ key = cfg.key;
162
+ _context3.next = 6;
163
+ return getToken(url, key);
164
+
165
+ case 6:
166
+ token = _context3.sent;
167
+ _context3.next = 9;
168
+ return getWebUrl(url, token);
169
+
170
+ case 9:
171
+ url = _context3.sent;
172
+ console.log("Using web root: ".concat(url));
173
+ _context3.next = 13;
174
+ return puppeteer.launch({
175
+ args: ['--disable-dev-shm-usage', '--disable-features=site-per-process'],
176
+ ignoreHTTPSErrors: true
177
+ });
178
+
179
+ case 13:
180
+ browser = _context3.sent;
181
+ _context3.next = 16;
182
+ return browser.newPage();
183
+
184
+ case 16:
185
+ page = _context3.sent;
186
+ _context3.next = 19;
187
+ return page.setDefaultNavigationTimeout(0);
188
+
189
+ case 19:
190
+ _context3.next = 21;
191
+ return page["goto"]("".concat(url, "/oauth/"));
192
+
193
+ case 21:
194
+ _context3.next = 23;
195
+ return page.setCookie({
196
+ name: 'auth',
197
+ value: token
198
+ });
199
+
200
+ case 23:
201
+ _context3.next = 25;
202
+ return page.evaluate(function (token) {
203
+ window.localStorage.setItem('auth', token);
204
+ }, token);
205
+
206
+ case 25:
207
+ _context3.next = 27;
208
+ return page["goto"](url);
209
+
210
+ case 27:
211
+ _context3.prev = 27;
212
+ _context3.next = 30;
213
+ return page.waitForFunction(function () {
214
+ return document.querySelector('.grok-preloader') == null;
215
+ }, {
216
+ timeout: 3600000
217
+ });
218
+
219
+ case 30:
220
+ _context3.next = 35;
221
+ break;
222
+
223
+ case 32:
224
+ _context3.prev = 32;
225
+ _context3.t0 = _context3["catch"](27);
226
+ throw _context3.t0;
227
+
228
+ case 35:
229
+ return _context3.abrupt("return", {
230
+ browser: browser,
231
+ page: page
232
+ });
233
+
234
+ case 36:
235
+ case "end":
236
+ return _context3.stop();
237
+ }
238
+ }
239
+ }, _callee3, null, [[27, 32]]);
240
+ }));
241
+ return _getBrowserPage.apply(this, arguments);
242
+ }
@@ -11,7 +11,7 @@
11
11
  "password": "#{PASSWORD}"
12
12
  }
13
13
  },
14
- "dataSource": "PostgreSQL",
14
+ "dataSource": "PostgresDart",
15
15
  "description": "#{DB_NAME} db",
16
16
  "tags": ["demo"]
17
17
  }
@@ -9,4 +9,8 @@ category('Examples', () => {
9
9
  test('Fail', () => {
10
10
  throw 'Exception';
11
11
  });
12
+
13
+ test('Skipped', async () => {
14
+ expect(1 === 1 , false);
15
+ }, {skipReason: 'TASK-ID'});
12
16
  });
@@ -1,7 +1,4 @@
1
1
  module.exports = {
2
- "roots": [
3
- "<rootDir>/src"
4
- ],
5
2
  "testMatch": [
6
3
  "**/__jest__/**/*.test.+(ts|tsx)"
7
4
  ],
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "datagrok-tools",
3
- "version": "4.6.4",
3
+ "version": "4.7.1",
4
4
  "description": "Utility to upload and publish packages to Datagrok",
5
5
  "homepage": "https://github.com/datagrok-ai/public/tree/master/tools#readme",
6
6
  "dependencies": {
@@ -10,17 +10,22 @@
10
10
  "fs": "latest",
11
11
  "ignore-walk": "^3.0.3",
12
12
  "inquirer": "^7.1.0",
13
+ "jest": "^27.0.0",
14
+ "jest-html-reporter": "^3.5.0",
13
15
  "js-yaml": "^4.1.0",
14
16
  "minimist": "^1.2.5",
15
17
  "node-fetch": "^2.6.0",
16
18
  "node-recursive-directory": "^1.2.0",
17
19
  "os": "^0.1.1",
18
- "path": "^0.12.7"
20
+ "path": "^0.12.7",
21
+ "puppeteer": "^13.7.0",
22
+ "ts-jest": "^27.0.0"
19
23
  },
20
24
  "scripts": {
21
25
  "link": "npm link",
22
26
  "prepublishOnly": "babel bin --extensions .ts -d bin",
23
- "babel": "babel bin --extensions .ts -d bin"
27
+ "babel": "babel bin --extensions .ts -d bin",
28
+ "test": "jest"
24
29
  },
25
30
  "bin": {
26
31
  "datagrok-upload": "./bin/_deprecated/upload.js",
@@ -43,6 +48,7 @@
43
48
  "@babel/preset-typescript": "7.15.0",
44
49
  "@types/ignore-walk": "^4.0.0",
45
50
  "@types/inquirer": "^8.1.3",
51
+ "@types/jest": "^27.0.0",
46
52
  "@types/js-yaml": "^4.0.4",
47
53
  "@types/node": "^16.11.6",
48
54
  "webpack": "^4.43.0",
@@ -1,97 +0,0 @@
1
- import * as path from "path";
2
- import * as os from "os";
3
- import * as fs from "fs";
4
- // @ts-ignore
5
- import * as yaml from 'js-yaml';
6
- const fetch = require('node-fetch');
7
-
8
- export async function getToken(url: string, key: string) {
9
- let response = await fetch(`${url}/users/login/dev/${key}`, {method: 'POST'});
10
- let json = await response.json();
11
- if (json.isSuccess == true)
12
- return json.token;
13
- else
14
- throw 'Unable to login to server. Check your dev key';
15
- }
16
-
17
- export async function getWebUrl(url: string, token: string) {
18
- let response = await fetch(`${url}/admin/plugins/admin/settings`, {headers: {Authorization: token}});
19
- let json = await response.json();
20
- return json.settings.webRoot;
21
- }
22
-
23
- const grokDir = path.join(os.homedir(), '.grok');
24
- const confPath = path.join(grokDir, 'config.yaml');
25
-
26
- function mapURL(conf: Config): Indexable {
27
- let urls: Indexable = {};
28
- for (let server in conf.servers) {
29
- urls[conf['servers'][server]['url']] = conf['servers'][server];
30
- }
31
- return urls;
32
- }
33
-
34
- export function getDevKey(hostKey: string): {url: string, key: string} {
35
- let config = yaml.load(fs.readFileSync(confPath, 'utf8')) as any;
36
- let host = hostKey == '' ? config.default : hostKey;
37
- host = host.trim();
38
- let urls = mapURL(config);
39
- let key = '';
40
- let url = '';
41
- try {
42
- let url = new URL(host).href;
43
- if (url.endsWith('/')) url = url.slice(0, -1);
44
- if (url in urls) key = config['servers'][urls[url]]['key'];
45
- } catch (error) {
46
- if (config['servers'][host] == null)
47
- throw `Unknown server alias. Please add it to ${confPath}`;
48
- url = config['servers'][host]['url'];
49
- key = config['servers'][host]['key'];
50
- }
51
- return {url, key};
52
- }
53
-
54
- export async function getBrowserPage(puppeteer: any): Promise<{browser: any, page: any}> {
55
- let url:string = process.env.HOST ?? '';
56
- let cfg = getDevKey(url);
57
- url = cfg.url;
58
-
59
- let key = cfg.key;
60
- let token = await getToken(url, key);
61
- url = await getWebUrl(url, token);
62
- console.log(`Using web root: ${url}`);
63
-
64
- let browser = await puppeteer.launch({
65
- args: ['--disable-dev-shm-usage', '--disable-features=site-per-process'],
66
- ignoreHTTPSErrors: true,
67
- });
68
-
69
- let page = await browser.newPage();
70
- await page.setDefaultNavigationTimeout(0);
71
- await page.goto(`${url}/oauth/`);
72
- await page.setCookie({name: 'auth', value: token});
73
- await page.evaluate((token: any) => {
74
- window.localStorage.setItem('auth', token);
75
- }, token);
76
- await page.goto(url);
77
- try {
78
- // await page.waitForSelector('.grok-preloader', { timeout: 1800000 });
79
- await page.waitForFunction(() => document.querySelector('.grok-preloader') == null, {timeout: 3600000});
80
- } catch (error) {
81
- throw error;
82
- }
83
- return {browser, page};
84
- }
85
-
86
-
87
- interface Config {
88
- servers: {
89
- [alias: string]: {
90
- url: string,
91
- key: string
92
- }
93
- },
94
- default: string,
95
- }
96
-
97
- interface Indexable { [key: string]: any }