@itentialopensource/adapter-winston_syslog 1.2.5 → 1.3.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.
Files changed (44) hide show
  1. package/.eslintrc.js +1 -0
  2. package/AUTH.md +1 -1
  3. package/BROKER.md +4 -4
  4. package/CALLS.md +8 -8
  5. package/ENHANCE.md +3 -3
  6. package/PROPERTIES.md +24 -9
  7. package/README.md +24 -23
  8. package/SUMMARY.md +2 -2
  9. package/SYSTEMINFO.md +1 -1
  10. package/TAB1.md +2 -2
  11. package/TAB2.md +6 -2
  12. package/TROUBLESHOOT.md +10 -1
  13. package/UTILITIES.md +473 -0
  14. package/adapter.js +5 -5
  15. package/adapterBase.js +52 -16
  16. package/package.json +26 -30
  17. package/pronghorn.json +17 -15
  18. package/propertiesSchema.json +68 -7
  19. package/report/adapterInfo.json +7 -7
  20. package/report/updateReport1748551891579.json +120 -0
  21. package/sampleProperties.json +4 -0
  22. package/test/integration/adapterTestBasicGet.js +88 -54
  23. package/test/integration/adapterTestConnectivity.js +15 -16
  24. package/test/integration/adapterTestIntegration.js +1 -38
  25. package/test/unit/adapterBaseTestUnit.js +641 -39
  26. package/test/unit/adapterTestUnit.js +17 -54
  27. package/utils/adapterInfo.js +114 -164
  28. package/utils/argParser.js +44 -0
  29. package/utils/checkMigrate.js +77 -38
  30. package/utils/entitiesToDB.js +53 -42
  31. package/utils/logger.js +26 -0
  32. package/utils/modify.js +56 -55
  33. package/utils/mongoDbConnection.js +79 -0
  34. package/utils/mongoUtils.js +162 -0
  35. package/utils/taskMover.js +31 -32
  36. package/utils/tbScript.js +36 -172
  37. package/utils/tbUtils.js +84 -226
  38. package/utils/troubleshootingAdapter.js +68 -84
  39. package/utils/updateAdapterConfig.js +158 -0
  40. package/utils/addAuth.js +0 -94
  41. package/utils/artifactize.js +0 -146
  42. package/utils/basicGet.js +0 -50
  43. package/utils/packModificationScript.js +0 -35
  44. package/utils/patches2bundledDeps.js +0 -90
package/package.json CHANGED
@@ -1,14 +1,13 @@
1
1
  {
2
2
  "name": "@itentialopensource/adapter-winston_syslog",
3
- "version": "1.2.5",
3
+ "version": "1.3.0",
4
4
  "description": "This adapter integrates with winston_syslog and sends logs to any syslog server.",
5
5
  "main": "adapter.js",
6
6
  "systemName": "winston_syslog",
7
7
  "wizardVersion": "2.44.7",
8
- "engineVersion": "1.68.2",
8
+ "engineVersion": "1.69.14",
9
9
  "adapterType": "http",
10
10
  "scripts": {
11
- "artifactize": "npm i && node utils/packModificationScript.js",
12
11
  "preinstall": "node utils/setup.js",
13
12
  "deinstall": "node utils/removeHooks.js",
14
13
  "lint": "node --max_old_space_size=4096 ./node_modules/eslint/bin/eslint.js . --ext .json --ext .js",
@@ -17,7 +16,6 @@
17
16
  "test:unit": "mocha test/unit/adapterTestUnit.js --LOG=error",
18
17
  "test:integration": "mocha test/integration/adapterTestIntegration.js --LOG=error",
19
18
  "test": "npm run test:baseunit && npm run test:unit && npm run test:integration",
20
- "adapter:install": "npm i && node utils/tbScript.js install",
21
19
  "adapter:checkMigrate": "node utils/checkMigrate.js",
22
20
  "adapter:findPath": "node utils/findPath.js",
23
21
  "adapter:migrate": "node utils/modify.js -m",
@@ -32,10 +30,9 @@
32
30
  },
33
31
  "keywords": [
34
32
  "Itential",
35
- "IAP",
33
+ "Itential Platform",
36
34
  "Automation",
37
35
  "Integration",
38
- "App-Artifacts",
39
36
  "Telemetry",
40
37
  "Analytics",
41
38
  "Adapter",
@@ -55,32 +52,31 @@
55
52
  "author": "Itential",
56
53
  "homepage": "https://gitlab.com/itentialopensource/adapters/adapter-winston_syslog#readme",
57
54
  "dependencies": {
58
- "@itentialopensource/adapter-utils": "^5.10.1",
59
- "acorn": "^8.14.0",
60
- "ajv": "^8.17.1",
61
- "axios": "^1.7.9",
62
- "commander": "^11.0.0",
63
- "dns-lookup-promise": "^1.0.4",
64
- "fs-extra": "^11.2.0",
65
- "json-query": "^2.2.2",
66
- "json5": "^2.2.2",
67
- "mocha": "^10.8.2",
68
- "mocha-param": "^2.0.1",
69
- "mongodb": "^4.17.2",
70
- "ping": "^0.4.4",
71
- "prompts": "^2.4.2",
72
- "readline-sync": "^1.4.10",
73
- "semver": "^7.6.3",
74
- "winston": "^3.17.0",
75
- "winston-syslog": "^2.7.0"
55
+ "@itentialopensource/adapter-utils": "5.10.16",
56
+ "acorn": "8.14.1",
57
+ "ajv": "8.17.1",
58
+ "axios": "1.9.0",
59
+ "commander": "11.1.0",
60
+ "fs-extra": "11.3.0",
61
+ "json-query": "2.2.2",
62
+ "json5": "2.2.2",
63
+ "mocha": "10.8.2",
64
+ "mocha-param": "2.0.1",
65
+ "mongodb": "4.17.2",
66
+ "ping": "0.4.4",
67
+ "prompts": "2.4.2",
68
+ "readline-sync": "1.4.10",
69
+ "semver": "7.7.2",
70
+ "winston": "3.17.0",
71
+ "winston-syslog": "2.7.0"
76
72
  },
77
73
  "devDependencies": {
78
- "chai": "^4.3.7",
79
- "eslint": "^8.44.0",
80
- "eslint-config-airbnb-base": "^15.0.0",
81
- "eslint-plugin-import": "^2.27.5",
82
- "eslint-plugin-json": "^3.1.0",
83
- "testdouble": "^3.18.0"
74
+ "chai": "4.5.0",
75
+ "eslint": "8.57.0",
76
+ "eslint-config-airbnb-base": "15.0.0",
77
+ "eslint-plugin-import": "2.31.0",
78
+ "eslint-plugin-json": "3.1.0",
79
+ "testdouble": "3.18.0"
84
80
  },
85
81
  "private": false
86
82
  }
package/pronghorn.json CHANGED
@@ -226,16 +226,6 @@
226
226
  "title": "props",
227
227
  "type": "object"
228
228
  }
229
- },
230
- {
231
- "name": "persistFlag",
232
- "type": "boolean",
233
- "info": "Whether the input properties should be saved",
234
- "required": true,
235
- "schema": {
236
- "title": "persistFlag",
237
- "type": "boolean"
238
- }
239
229
  }
240
230
  ],
241
231
  "output": {
@@ -306,7 +296,19 @@
306
296
  "name": "iapRunAdapterBasicGet",
307
297
  "summary": "Runs basicGet script for adapter",
308
298
  "description": "Runs basicGet script for adapter",
309
- "input": [],
299
+ "input": [
300
+ {
301
+ "name": "maxCalls",
302
+ "required": false,
303
+ "type": "number",
304
+ "info": "How many GET endpoints to test (defaults to 5)",
305
+ "schema": {
306
+ "title": "maxCalls",
307
+ "type": "number",
308
+ "default": 5
309
+ }
310
+ }
311
+ ],
310
312
  "output": {
311
313
  "name": "result",
312
314
  "type": "object",
@@ -327,8 +329,8 @@
327
329
  },
328
330
  {
329
331
  "name": "iapMoveAdapterEntitiesToDB",
330
- "summary": "Moves entities from an adapter into the IAP database",
331
- "description": "Moves entities from an adapter into the IAP database",
332
+ "summary": "Moves entities from an adapter into the Itential Platform database",
333
+ "description": "Moves entities from an adapter into the Itential Platform database",
332
334
  "input": [],
333
335
  "output": {
334
336
  "name": "res",
@@ -998,7 +1000,7 @@
998
1000
  "name": "severity",
999
1001
  "type": "enum",
1000
1002
  "info": "The log level of the message",
1001
- "enumerals" : [
1003
+ "enumerals": [
1002
1004
  "debug",
1003
1005
  "info",
1004
1006
  "notice",
@@ -1028,7 +1030,7 @@
1028
1030
  "name": "facility",
1029
1031
  "type": "enum",
1030
1032
  "info": "Where to send the log message",
1031
- "enumerals" : [
1033
+ "enumerals": [
1032
1034
  "local0",
1033
1035
  "local1",
1034
1036
  "local2",
@@ -801,6 +801,14 @@
801
801
  "security/ca.pem"
802
802
  ]
803
803
  },
804
+ "ca_file_content": {
805
+ "type": "string",
806
+ "description": "The content of the CA file used for SSL",
807
+ "default": "",
808
+ "examples": [
809
+ "-----BEGIN CERTIFICATE-----"
810
+ ]
811
+ },
804
812
  "key_file": {
805
813
  "type": "string",
806
814
  "description": "The fully qualified path name to the key file used for SSL",
@@ -890,32 +898,48 @@
890
898
  "mongo": {
891
899
  "type": "object",
892
900
  "properties": {
901
+ "url": {
902
+ "type": "string",
903
+ "description": "Mongo's complete connection URL. This property overrides host, port, database, username, password and replSet settings.",
904
+ "examples": [
905
+ "mongodb://[username:password@]host1[:port1][,...hostN[:portN]][/[defaultauthdb][?options]]",
906
+ "mongodb+srv://[username:password@]cluster0.xxxxx.mongodb.net/[defaultauthdb][?options]",
907
+ "mongodb+srv://cluster0.xxxxx.mongodb.net/[defaultauthdb][?options]"
908
+ ]
909
+ },
893
910
  "host": {
894
911
  "type": "string",
895
- "description": "host where mongo database can be found",
912
+ "description": "Host information for the Mongo server",
896
913
  "default": "",
897
914
  "examples": [
898
- "localhost"
915
+ "localhost",
916
+ "cluster0.xxxxx.mongodb.net",
917
+ "my-cluster.example.com"
899
918
  ]
900
919
  },
901
920
  "port": {
902
921
  "type": "integer",
903
- "description": "port on which to connect to the mongo database",
922
+ "description": "Port information for the Mongo server. Not used when using mongodb+srv:// protocol",
904
923
  "default": 443,
905
924
  "minimum": 0,
906
925
  "maximum": 65535
907
926
  },
908
927
  "database": {
909
928
  "type": "string",
910
- "description": "The name of the database to store adapter information in",
929
+ "description": "The database for the adapter to use for its data.",
911
930
  "default": "",
912
931
  "examples": [
913
932
  "adapter-xyz"
914
933
  ]
915
934
  },
935
+ "dbAuth": {
936
+ "type": "boolean",
937
+ "description": "Whether to use authentication for MongoDB connection. Default is false.",
938
+ "default": false
939
+ },
916
940
  "username": {
917
941
  "type": "string",
918
- "description": "The user to connect to the database with",
942
+ "description": "If credentials are required to access Mongo, this is the user to login as.",
919
943
  "default": "",
920
944
  "examples": [
921
945
  "username"
@@ -923,7 +947,7 @@
923
947
  },
924
948
  "password": {
925
949
  "type": "string",
926
- "description": "The password to connect to the database with",
950
+ "description": "If credentials are required to access Mongo, this is the password to login with.",
927
951
  "default": "",
928
952
  "examples": [
929
953
  "password"
@@ -931,12 +955,17 @@
931
955
  },
932
956
  "replSet": {
933
957
  "type": "string",
934
- "description": "The replica set for the database",
958
+ "description": "If the database is set up to use replica sets, define it here so it can be added to the database connection. Not used when using mongodb+srv:// protocol",
935
959
  "default": "",
936
960
  "examples": [
937
961
  "my_repolica_set"
938
962
  ]
939
963
  },
964
+ "addSrv": {
965
+ "type": "boolean",
966
+ "description": "Whether the connection requires the mongodb+srv:// protocol. If true, uses mongodb+srv:// protocol. Note: mongodb+srv:// can also be used for non-Atlas deployments that support DNS SRV records",
967
+ "default": false
968
+ },
940
969
  "db_ssl": {
941
970
  "type": "object",
942
971
  "description": "SSL for mongo database connection",
@@ -977,6 +1006,38 @@
977
1006
  }
978
1007
  }
979
1008
  }
1009
+ },
1010
+ "dependencies": {
1011
+ "dbAuth": {
1012
+ "oneOf": [
1013
+ {
1014
+ "properties": {
1015
+ "dbAuth": {
1016
+ "const": false
1017
+ }
1018
+ }
1019
+ },
1020
+ {
1021
+ "properties": {
1022
+ "dbAuth": {
1023
+ "const": true
1024
+ },
1025
+ "username": {
1026
+ "type": "string",
1027
+ "minLength": 1
1028
+ },
1029
+ "password": {
1030
+ "type": "string",
1031
+ "minLength": 1
1032
+ }
1033
+ },
1034
+ "required": [
1035
+ "username",
1036
+ "password"
1037
+ ]
1038
+ }
1039
+ ]
1040
+ }
980
1041
  }
981
1042
  },
982
1043
  "devicebroker": {
@@ -1,10 +1,10 @@
1
1
  {
2
- "version": "1.2.2",
3
- "configLines": 2967,
4
- "scriptLines": 1783,
5
- "codeLines": 2270,
6
- "testLines": 3297,
7
- "testCases": 151,
8
- "totalCodeLines": 7350,
2
+ "version": "1.2.6",
3
+ "configLines": 3448,
4
+ "scriptLines": 2498,
5
+ "codeLines": 2306,
6
+ "testLines": 3858,
7
+ "testCases": 164,
8
+ "totalCodeLines": 8662,
9
9
  "wfTasks": 26
10
10
  }
@@ -0,0 +1,120 @@
1
+ {
2
+ "errors": [],
3
+ "statistics": [
4
+ {
5
+ "owner": "errorJson",
6
+ "description": "New adapter errors available for use",
7
+ "value": 0
8
+ },
9
+ {
10
+ "owner": "errorJson",
11
+ "description": "Adapter errors no longer available for use",
12
+ "value": 0
13
+ },
14
+ {
15
+ "owner": "errorJson",
16
+ "description": "Adapter errors that have been updated (e.g. recommendation changes)",
17
+ "value": 31
18
+ },
19
+ {
20
+ "owner": "packageJson",
21
+ "description": "Number of production dependencies",
22
+ "value": 15
23
+ },
24
+ {
25
+ "owner": "packageJson",
26
+ "description": "Number of development dependencies",
27
+ "value": 6
28
+ },
29
+ {
30
+ "owner": "packageJson",
31
+ "description": "Number of npm scripts",
32
+ "value": 19
33
+ },
34
+ {
35
+ "owner": "packageJson",
36
+ "description": "Runtime Library dependency",
37
+ "value": "5.10.16"
38
+ },
39
+ {
40
+ "owner": "propertiesSchemaJson",
41
+ "description": "Adapter properties defined in the propertiesSchema file",
42
+ "value": 82
43
+ },
44
+ {
45
+ "owner": "markdown",
46
+ "description": "Number of lines in the README.md",
47
+ "value": 345
48
+ },
49
+ {
50
+ "owner": "markdown",
51
+ "description": "Number of lines in the SUMMARY.md",
52
+ "value": 9
53
+ },
54
+ {
55
+ "owner": "markdown",
56
+ "description": "Number of lines in the PROPERTIES.md",
57
+ "value": 662
58
+ },
59
+ {
60
+ "owner": "markdown",
61
+ "description": "Number of lines in the TROUBLESHOOT.md",
62
+ "value": 57
63
+ },
64
+ {
65
+ "owner": "markdown",
66
+ "description": "Number of lines in the ENHANCE.md",
67
+ "value": 70
68
+ },
69
+ {
70
+ "owner": "markdown",
71
+ "description": "Number of lines in the BROKER.md",
72
+ "value": 70
73
+ },
74
+ {
75
+ "owner": "unitTestJS",
76
+ "description": "Number of lines of code in unit tests",
77
+ "value": 1532
78
+ },
79
+ {
80
+ "owner": "unitTestJS",
81
+ "description": "Number of unit tests",
82
+ "value": 72
83
+ },
84
+ {
85
+ "owner": "integrationTestJS",
86
+ "description": "Number of lines of code in integration tests",
87
+ "value": 463
88
+ },
89
+ {
90
+ "owner": "integrationTestJS",
91
+ "description": "Number of integration tests",
92
+ "value": 10
93
+ },
94
+ {
95
+ "owner": "staticFile",
96
+ "description": "Number of lines of code in adapterBase.js",
97
+ "value": 1489
98
+ },
99
+ {
100
+ "owner": "staticFile",
101
+ "description": "Number of static files added",
102
+ "value": 37
103
+ },
104
+ {
105
+ "owner": "Overall",
106
+ "description": "Total lines of Code",
107
+ "value": 3484
108
+ },
109
+ {
110
+ "owner": "Overall",
111
+ "description": "Total Tests",
112
+ "value": 82
113
+ },
114
+ {
115
+ "owner": "Overall",
116
+ "description": "Total Files",
117
+ "value": 6
118
+ }
119
+ ]
120
+ }
@@ -97,18 +97,22 @@
97
97
  "enabled": false,
98
98
  "accept_invalid_cert": false,
99
99
  "ca_file": "",
100
+ "ca_file_content": "",
100
101
  "key_file": "",
101
102
  "cert_file": "",
102
103
  "secure_protocol": "",
103
104
  "ciphers": ""
104
105
  },
105
106
  "mongo": {
107
+ "url": "",
106
108
  "host": "",
107
109
  "port": 0,
108
110
  "database": "",
111
+ "dbAuth": false,
109
112
  "username": "",
110
113
  "password": "",
111
114
  "replSet": "",
115
+ "addSrv": false,
112
116
  "db_ssl": {
113
117
  "enabled": false,
114
118
  "accept_invalid_cert": false,
@@ -1,83 +1,117 @@
1
1
  /* @copyright Itential, LLC 2020 */
2
2
 
3
- /* global describe context before after */
3
+ /* global describe it log before after */
4
4
  /* eslint global-require: warn */
5
5
  /* eslint no-unused-vars: warn */
6
6
  /* eslint import/no-extraneous-dependencies: warn */
7
7
  /* eslint import/no-dynamic-require: warn */
8
8
  /* eslint import/no-unresolved: warn */
9
+ /* eslint no-loop-func: warn */
10
+
11
+ /* This performs a number of GET calls (defaults to 5 calls) which do not reuire an input, to test connectivity and functionality.
12
+ The number of calls can be modified if running from CLI. */
9
13
 
10
- const path = require('path');
11
14
  const assert = require('assert');
12
- const mocha = require('mocha');
13
- const itParam = require('mocha-param');
14
15
 
15
- const utils = require('../../utils/tbUtils');
16
- const basicGet = require('../../utils/basicGet');
17
- const { name } = require('../../package.json');
16
+ const log = require('../../utils/logger');
17
+ const { id } = require('../../package.json');
18
18
  const { methods } = require('../../pronghorn.json');
19
+ const { parseArgs } = require('../../utils/argParser');
20
+
21
+ const {
22
+ properties, maxCalls
23
+ } = parseArgs();
24
+
25
+ // require the adapter that we are going to be using
26
+ const TestAdapter = require('../../adapter');
19
27
 
20
- const getPronghornProps = (iapDir) => {
21
- console.log('Retrieving properties.json file...');
22
- const rawProps = require(path.join(iapDir, 'properties.json'));
23
- console.log('Decrypting properties...');
24
- const pronghornProps = utils.decryptProperties(rawProps, iapDir);
25
- console.log('Found properties.\n');
26
- return pronghornProps;
27
- };
28
+ if (!properties) {
29
+ log.warn('No properties provided. Exiting process.');
30
+ process.exit(1);
31
+ }
28
32
 
29
- let a;
33
+ let successCount = 0;
34
+ let calls = 0;
35
+ let attemptTimeout = 60000;
36
+ if (properties.request && properties.request.attempt_timeout) {
37
+ attemptTimeout = properties.request.attempt_timeout;
38
+ }
39
+
40
+ // turn off stub mode - basic get should not be run in stub mode
41
+ properties.stub = false;
30
42
 
31
43
  describe('[integration] Adapter BasicGET Test', () => {
32
- context('Testing GET calls without query parameters', () => {
33
- before(async () => {
34
- const iapDir = path.join(__dirname, '../../../../../');
35
- if (!utils.areWeUnderIAPinstallationDirectory()) {
36
- const sampleProperties = require('../../sampleProperties.json');
37
- const adapter = { properties: sampleProperties };
38
- a = basicGet.getAdapterInstance(adapter);
44
+ describe('Class Tests', () => {
45
+ const testAdapter = new TestAdapter(
46
+ id,
47
+ properties
48
+ );
49
+
50
+ after((done) => {
51
+ if (successCount === calls) {
52
+ log.info('\x1b[32m%s\x1b[0m', `\n\nSUCCESS: ${successCount} test(s) passed of ${calls} executed!`);
53
+ } else if (successCount > 0) {
54
+ log.error('\x1b[32m%s\x1b[0m', `\n\nPARTIAL SUCCESS: ${successCount} test(s) passed of ${calls} executed!`);
39
55
  } else {
40
- const pronghornProps = getPronghornProps(iapDir);
41
- console.log('Connecting to Database...');
42
- const database = await basicGet.connect(pronghornProps);
43
- console.log('Connection established.');
44
- const adapter = await database.collection(utils.SERVICE_CONFIGS_COLLECTION).findOne(
45
- { model: name }
46
- );
47
- a = basicGet.getAdapterInstance(adapter);
56
+ log.error('\x1b[31m%s\x1b[0m', '\n\nFAILURE: All tests failed.');
48
57
  }
58
+ done();
49
59
  });
50
60
 
51
- after((done) => {
52
- done();
61
+ const basicGets = methods.filter((method) => {
62
+ // ignore iapMetadata as the input since its optional and all functions will have it
63
+ const inputKeys = (method.input || [])
64
+ .map((param) => param.name)
65
+ .filter((name) => name !== 'iapMetadata');
66
+ return method.route.verb === 'GET' && inputKeys.length === 0 && !method.name.startsWith('iap');
53
67
  });
54
68
 
55
- const basicGets = methods.filter((method) => (method.route.verb === 'GET' && method.input.length === 0));
56
69
  if (basicGets.length === 0) {
57
- console.log('No non-parameter GET calls found.');
58
- process.exit(0);
70
+ log.warn('No non-parameter GET calls found.');
71
+ process.exitCode = 0;
72
+ return;
59
73
  }
74
+
60
75
  const functionNames = basicGets.map((g) => g.name);
61
- const request = function request(f, ad) {
62
- return new Promise((resolve, reject) => {
63
- const getRespCode = (resp) => {
64
- if (resp) {
65
- if (resp.metrics.code !== 200) {
66
- console.log('\x1b[31m', `Testing ${f} \nResponseCode: ${resp.metrics.code}`);
76
+ calls = functionNames.length;
77
+ if (calls > maxCalls) {
78
+ calls = maxCalls;
79
+ }
80
+
81
+ // test up to the first 5 get calls without parameters
82
+ for (let f = 0; f < calls; f += 1) {
83
+ const fnName = functionNames[f];
84
+ const method = basicGets.find((m) => m.name === fnName);
85
+ const hasIapMetadata = Array.isArray(method.input) && method.input.some((param) => param.name === 'iapMetadata');
86
+ describe(`#${functionNames[f]}`, () => {
87
+ it('should return valid response without error', (done) => {
88
+ const callback = (data, error) => {
89
+ try {
90
+ assert.equal(undefined, error);
91
+ assert.notEqual(undefined, data);
92
+ assert.notEqual(null, data);
93
+ assert.notEqual(undefined, data.response);
94
+ assert.notEqual(null, data.response);
95
+ successCount += 1;
96
+ done();
97
+ } catch (err) {
98
+ log.error(`Test Failure in ${fnName}: ${err}`);
99
+ done(err);
100
+ }
101
+ };
102
+
103
+ try {
104
+ if (hasIapMetadata) {
105
+ testAdapter[fnName](null, callback);
106
+ } else {
107
+ testAdapter[fnName](callback);
67
108
  }
68
- resolve(resp.metrics.code);
69
- } else {
70
- console.log('\x1b[31m', `call ${f} results in failure`);
71
- reject(new Error(`${f} failed`));
109
+ } catch (err) {
110
+ log.error(`Unexpected error in test for ${fnName}: ${err}`);
111
+ done(err);
72
112
  }
73
- };
74
- ad[f](getRespCode, console.log);
113
+ }).timeout(attemptTimeout);
75
114
  });
76
- };
77
-
78
- itParam('GET call should return 200', functionNames, (fname) => {
79
- console.log(`\t ${fname}`);
80
- return request(fname, a).then((result) => assert.equal(result, 200));
81
- });
115
+ }
82
116
  });
83
117
  });