@git.zone/tstest 1.4.0 → 1.7.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/dist_ts/00_commitinfo_data.js +1 -1
- package/dist_ts/index.js +9 -2
- package/dist_ts/tstest.classes.tap.parser.d.ts +4 -0
- package/dist_ts/tstest.classes.tap.parser.js +114 -24
- package/dist_ts/tstest.classes.testdirectory.d.ts +10 -0
- package/dist_ts/tstest.classes.testdirectory.js +31 -1
- package/dist_ts/tstest.classes.tstest.d.ts +3 -1
- package/dist_ts/tstest.classes.tstest.js +52 -27
- package/dist_ts/tstest.plugins.d.ts +1 -1
- package/dist_ts/tstest.plugins.js +2 -2
- package/dist_ts_tapbundle/00_commitinfo_data.d.ts +8 -0
- package/dist_ts_tapbundle/00_commitinfo_data.js +9 -0
- package/dist_ts_tapbundle/index.d.ts +6 -0
- package/dist_ts_tapbundle/index.js +7 -0
- package/dist_ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
- package/dist_ts_tapbundle/tapbundle.classes.pretask.js +13 -0
- package/dist_ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
- package/dist_ts_tapbundle/tapbundle.classes.tap.js +418 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptools.d.ts +107 -0
- package/dist_ts_tapbundle/tapbundle.classes.taptools.js +229 -0
- package/dist_ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
- package/dist_ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
- package/dist_ts_tapbundle/tapbundle.plugins.d.ts +7 -0
- package/dist_ts_tapbundle/tapbundle.plugins.js +9 -0
- package/dist_ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/00_commitinfo_data.js +9 -0
- package/dist_ts_tapbundle/ts_tapbundle/index.d.ts +6 -0
- package/dist_ts_tapbundle/ts_tapbundle/index.js +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.d.ts +10 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.pretask.js +13 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.d.ts +104 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tap.js +401 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.classes.tapwrap.js +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.plugins.js +10 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle/ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.d.ts +7 -0
- package/dist_ts_tapbundle/ts_tapbundle/webhelpers.js +35 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/classes.pathinject.js +13 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle/ts_tapbundle_node/plugins.js +14 -0
- package/dist_ts_tapbundle/webhelpers.d.ts +7 -0
- package/dist_ts_tapbundle/webhelpers.js +35 -0
- package/dist_ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
- package/dist_ts_tapbundle_node/classes.tapnodetools.js +81 -0
- package/dist_ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
- package/dist_ts_tapbundle_node/classes.testfileprovider.js +16 -0
- package/dist_ts_tapbundle_node/index.d.ts +1 -0
- package/dist_ts_tapbundle_node/index.js +2 -0
- package/dist_ts_tapbundle_node/paths.d.ts +2 -0
- package/dist_ts_tapbundle_node/paths.js +4 -0
- package/dist_ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle_node/plugins.js +14 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.d.ts +38 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptest.js +110 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.d.ts +109 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.classes.taptools.js +241 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.d.ts +8 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.plugins.js +10 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.d.ts +3 -0
- package/dist_ts_tapbundle_node/ts_tapbundle/tapbundle.tapcreator.js +5 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.d.ts +5 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.pathinject.js +13 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.d.ts +25 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.tapnodetools.js +81 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.d.ts +6 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/classes.testfileprovider.js +16 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/index.d.ts +2 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/index.js +3 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.d.ts +2 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/paths.js +4 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.d.ts +11 -0
- package/dist_ts_tapbundle_node/ts_tapbundle_node/plugins.js +14 -0
- package/package.json +23 -10
- package/readme.hints.md +62 -0
- package/readme.plan.md +253 -30
- package/ts/00_commitinfo_data.ts +1 -1
- package/ts/index.ts +8 -1
- package/ts/tspublish.json +3 -0
- package/ts/tstest.classes.tap.parser.ts +111 -25
- package/ts/tstest.classes.testdirectory.ts +39 -0
- package/ts/tstest.classes.tstest.ts +61 -27
- package/ts/tstest.plugins.ts +1 -1
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
+
import { tap } from './tapbundle.classes.tap.js';
|
|
3
|
+
class WebHelpers {
|
|
4
|
+
constructor() {
|
|
5
|
+
const smartenv = new plugins.smartenv.Smartenv();
|
|
6
|
+
// Initialize HTML template tag function
|
|
7
|
+
this.html = (strings, ...values) => {
|
|
8
|
+
let result = '';
|
|
9
|
+
for (let i = 0; i < strings.length; i++) {
|
|
10
|
+
result += strings[i];
|
|
11
|
+
if (i < values.length) {
|
|
12
|
+
result += values[i];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return result;
|
|
16
|
+
};
|
|
17
|
+
// Initialize fixture function based on environment
|
|
18
|
+
if (smartenv.isBrowser) {
|
|
19
|
+
this.fixture = async (htmlString) => {
|
|
20
|
+
const container = document.createElement('div');
|
|
21
|
+
container.innerHTML = htmlString.trim();
|
|
22
|
+
const element = container.firstChild;
|
|
23
|
+
return element;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
// Node.js environment - provide a stub or alternative implementation
|
|
28
|
+
this.fixture = async (htmlString) => {
|
|
29
|
+
throw new Error('WebHelpers.fixture is only available in browser environment');
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export const webhelpers = new WebHelpers();
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzX3RhcGJ1bmRsZS93ZWJoZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRWpELE1BQU0sVUFBVTtJQUlkO1FBQ0UsTUFBTSxRQUFRLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBRWpELHdDQUF3QztRQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsT0FBNkIsRUFBRSxHQUFHLE1BQWEsRUFBRSxFQUFFO1lBQzlELElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQztZQUNoQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO2dCQUN4QyxNQUFNLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNyQixJQUFJLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUM7b0JBQ3RCLE1BQU0sSUFBSSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3RCLENBQUM7WUFDSCxDQUFDO1lBQ0QsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQyxDQUFDO1FBRUYsbURBQW1EO1FBQ25ELElBQUksUUFBUSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxFQUFFLFVBQWtCLEVBQXdCLEVBQUU7Z0JBQ2hFLE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ2hELFNBQVMsQ0FBQyxTQUFTLEdBQUcsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUN4QyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUMsVUFBeUIsQ0FBQztnQkFDcEQsT0FBTyxPQUFPLENBQUM7WUFDakIsQ0FBQyxDQUFDO1FBQ0osQ0FBQzthQUFNLENBQUM7WUFDTixxRUFBcUU7WUFDckUsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLEVBQUUsVUFBa0IsRUFBZ0IsRUFBRTtnQkFDeEQsTUFBTSxJQUFJLEtBQUssQ0FBQyw2REFBNkQsQ0FBQyxDQUFDO1lBQ2pGLENBQUMsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQyJ9
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { TestFileProvider } from './classes.testfileprovider.js';
|
|
2
|
+
import * as plugins from './plugins.js';
|
|
3
|
+
declare class TapNodeTools {
|
|
4
|
+
private smartshellInstance;
|
|
5
|
+
testFileProvider: TestFileProvider;
|
|
6
|
+
constructor();
|
|
7
|
+
private qenv;
|
|
8
|
+
getQenv(): Promise<plugins.qenv.Qenv>;
|
|
9
|
+
getEnvVarOnDemand(envVarNameArg: string): Promise<string>;
|
|
10
|
+
runCommand(commandArg: string): Promise<any>;
|
|
11
|
+
createHttpsCert(commonName?: string, allowSelfSigned?: boolean): Promise<{
|
|
12
|
+
key: string;
|
|
13
|
+
cert: string;
|
|
14
|
+
}>;
|
|
15
|
+
/**
|
|
16
|
+
* create and return a smartmongo instance
|
|
17
|
+
*/
|
|
18
|
+
createSmartmongo(): Promise<import("@push.rocks/smartmongo").SmartMongo>;
|
|
19
|
+
/**
|
|
20
|
+
* create and return a smarts3 instance
|
|
21
|
+
*/
|
|
22
|
+
createSmarts3(): Promise<import("@push.rocks/smarts3").Smarts3>;
|
|
23
|
+
}
|
|
24
|
+
export declare const tapNodeTools: TapNodeTools;
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { TestFileProvider } from './classes.testfileprovider.js';
|
|
2
|
+
import * as plugins from './plugins.js';
|
|
3
|
+
class TapNodeTools {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.testFileProvider = new TestFileProvider();
|
|
6
|
+
}
|
|
7
|
+
async getQenv() {
|
|
8
|
+
this.qenv = this.qenv || new plugins.qenv.Qenv('./', '.nogit/');
|
|
9
|
+
return this.qenv;
|
|
10
|
+
}
|
|
11
|
+
async getEnvVarOnDemand(envVarNameArg) {
|
|
12
|
+
const qenv = await this.getQenv();
|
|
13
|
+
return qenv.getEnvVarOnDemand(envVarNameArg);
|
|
14
|
+
}
|
|
15
|
+
async runCommand(commandArg) {
|
|
16
|
+
if (!this.smartshellInstance) {
|
|
17
|
+
this.smartshellInstance = new plugins.smartshell.Smartshell({
|
|
18
|
+
executor: 'bash',
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
const result = await this.smartshellInstance.exec(commandArg);
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
async createHttpsCert(commonName = 'localhost', allowSelfSigned = true) {
|
|
25
|
+
if (allowSelfSigned) {
|
|
26
|
+
// set node to allow self-signed certificates
|
|
27
|
+
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
|
28
|
+
}
|
|
29
|
+
// Generate a key pair
|
|
30
|
+
const keys = plugins.smartcrypto.nodeForge.pki.rsa.generateKeyPair(2048);
|
|
31
|
+
// Create a self-signed certificate
|
|
32
|
+
const cert = plugins.smartcrypto.nodeForge.pki.createCertificate();
|
|
33
|
+
cert.publicKey = keys.publicKey;
|
|
34
|
+
cert.serialNumber = '01';
|
|
35
|
+
cert.validity.notBefore = new Date();
|
|
36
|
+
cert.validity.notAfter = new Date();
|
|
37
|
+
cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 1);
|
|
38
|
+
const attrs = [
|
|
39
|
+
{ name: 'commonName', value: commonName },
|
|
40
|
+
{ name: 'countryName', value: 'US' },
|
|
41
|
+
{ shortName: 'ST', value: 'California' },
|
|
42
|
+
{ name: 'localityName', value: 'San Francisco' },
|
|
43
|
+
{ name: 'organizationName', value: 'My Company' },
|
|
44
|
+
{ shortName: 'OU', value: 'Dev' },
|
|
45
|
+
];
|
|
46
|
+
cert.setSubject(attrs);
|
|
47
|
+
cert.setIssuer(attrs);
|
|
48
|
+
// Sign the certificate with its own private key (self-signed)
|
|
49
|
+
cert.sign(keys.privateKey, plugins.smartcrypto.nodeForge.md.sha256.create());
|
|
50
|
+
// PEM encode the private key and certificate
|
|
51
|
+
const pemKey = plugins.smartcrypto.nodeForge.pki.privateKeyToPem(keys.privateKey);
|
|
52
|
+
const pemCert = plugins.smartcrypto.nodeForge.pki.certificateToPem(cert);
|
|
53
|
+
return {
|
|
54
|
+
key: pemKey,
|
|
55
|
+
cert: pemCert,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* create and return a smartmongo instance
|
|
60
|
+
*/
|
|
61
|
+
async createSmartmongo() {
|
|
62
|
+
const smartmongoMod = await import('@push.rocks/smartmongo');
|
|
63
|
+
const smartmongoInstance = new smartmongoMod.SmartMongo();
|
|
64
|
+
await smartmongoInstance.start();
|
|
65
|
+
return smartmongoInstance;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* create and return a smarts3 instance
|
|
69
|
+
*/
|
|
70
|
+
async createSmarts3() {
|
|
71
|
+
const smarts3Mod = await import('@push.rocks/smarts3');
|
|
72
|
+
const smarts3Instance = new smarts3Mod.Smarts3({
|
|
73
|
+
port: 3003,
|
|
74
|
+
cleanSlate: true,
|
|
75
|
+
});
|
|
76
|
+
await smarts3Instance.start();
|
|
77
|
+
return smarts3Instance;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
export const tapNodeTools = new TapNodeTools();
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy50YXBub2RldG9vbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90c190YXBidW5kbGVfbm9kZS9jbGFzc2VzLnRhcG5vZGV0b29scy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNqRSxPQUFPLEtBQUssT0FBTyxNQUFNLGNBQWMsQ0FBQztBQUV4QyxNQUFNLFlBQVk7SUFJaEI7UUFGTyxxQkFBZ0IsR0FBRyxJQUFJLGdCQUFnQixFQUFFLENBQUM7SUFFbEMsQ0FBQztJQUdULEtBQUssQ0FBQyxPQUFPO1FBQ2xCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNoRSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUNNLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxhQUFxQjtRQUNsRCxNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRU0sS0FBSyxDQUFDLFVBQVUsQ0FBQyxVQUFrQjtRQUN4QyxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLGtCQUFrQixHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUM7Z0JBQzFELFFBQVEsRUFBRSxNQUFNO2FBQ2pCLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDOUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVN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
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as plugins from './plugins.js';
|
|
2
|
+
import * as paths from './paths.js';
|
|
3
|
+
export const fileUrls = {
|
|
4
|
+
dockerAlpineImage: 'https://code.foss.global/testassets/docker/raw/branch/main/alpine.tar',
|
|
5
|
+
};
|
|
6
|
+
export class TestFileProvider {
|
|
7
|
+
async getDockerAlpineImageAsLocalTarball() {
|
|
8
|
+
const filePath = plugins.path.join(paths.testFilesDir, 'alpine.tar');
|
|
9
|
+
// fetch the docker alpine image
|
|
10
|
+
const response = await plugins.smartrequest.getBinary(fileUrls.dockerAlpineImage);
|
|
11
|
+
await plugins.smartfile.fs.ensureDir(paths.testFilesDir);
|
|
12
|
+
await plugins.smartfile.memory.toFs(response.body, filePath);
|
|
13
|
+
return filePath;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy50ZXN0ZmlsZXByb3ZpZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHNfdGFwYnVuZGxlX25vZGUvY2xhc3Nlcy50ZXN0ZmlsZXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxLQUFLLE1BQU0sWUFBWSxDQUFDO0FBRXBDLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRztJQUN0QixpQkFBaUIsRUFBRSx1RUFBdUU7Q0FDM0YsQ0FBQTtBQUVELE1BQU0sT0FBTyxnQkFBZ0I7SUFDcEIsS0FBSyxDQUFDLGtDQUFrQztRQUM3QyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFBO1FBQ3BFLGdDQUFnQztRQUNoQyxNQUFNLFFBQVEsR0FBRyxNQUFNLE9BQU8sQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQ2xGLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN6RCxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQzdELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7Q0FDRiJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './classes.tapnodetools.js';
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './classes.tapnodetools.js';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90c190YXBidW5kbGVfbm9kZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDIn0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import * as plugins from './plugins.js';
|
|
2
|
+
export const cwd = process.cwd();
|
|
3
|
+
export const testFilesDir = plugins.path.join(cwd, './.nogit/testfiles/');
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90c190YXBidW5kbGVfbm9kZS9wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLGNBQWMsQ0FBQztBQUV4QyxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBQ2pDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUMsQ0FBQyJ9
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
import * as fs from 'fs';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
export { crypto, fs, path, };
|
|
5
|
+
import * as qenv from '@push.rocks/qenv';
|
|
6
|
+
import * as smartcrypto from '@push.rocks/smartcrypto';
|
|
7
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
8
|
+
import * as smartpath from '@push.rocks/smartpath';
|
|
9
|
+
import * as smartrequest from '@push.rocks/smartrequest';
|
|
10
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
11
|
+
export { qenv, smartcrypto, smartfile, smartpath, smartrequest, smartshell, };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
// node native
|
|
2
|
+
import * as crypto from 'crypto';
|
|
3
|
+
import * as fs from 'fs';
|
|
4
|
+
import * as path from 'path';
|
|
5
|
+
export { crypto, fs, path, };
|
|
6
|
+
// @push.rocks scope
|
|
7
|
+
import * as qenv from '@push.rocks/qenv';
|
|
8
|
+
import * as smartcrypto from '@push.rocks/smartcrypto';
|
|
9
|
+
import * as smartfile from '@push.rocks/smartfile';
|
|
10
|
+
import * as smartpath from '@push.rocks/smartpath';
|
|
11
|
+
import * as smartrequest from '@push.rocks/smartrequest';
|
|
12
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
13
|
+
export { qenv, smartcrypto, smartfile, smartpath, smartrequest, smartshell, };
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzX3RhcGJ1bmRsZV9ub2RlL3BsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYztBQUNkLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBQ2pDLE9BQU8sS0FBSyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBQ3pCLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSxNQUFNLEVBQUMsRUFBRSxFQUFFLElBQUksR0FBRyxDQUFDO0FBRTVCLG9CQUFvQjtBQUNwQixPQUFPLEtBQUssSUFBSSxNQUFNLGtCQUFrQixDQUFDO0FBQ3pDLE9BQU8sS0FBSyxXQUFXLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxLQUFLLFNBQVMsTUFBTSx1QkFBdUIsQ0FBQztBQUNuRCxPQUFPLEtBQUssU0FBUyxNQUFNLHVCQUF1QixDQUFDO0FBQ25ELE9BQU8sS0FBSyxZQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxLQUFLLFVBQVUsTUFBTSx3QkFBd0IsQ0FBQztBQUVyRCxPQUFPLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEdBQUcsQ0FBQyJ9
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { TapTools } from './tapbundle.classes.taptools.js';
|
|
2
|
+
import { HrtMeasurement } from '@push.rocks/smarttime';
|
|
3
|
+
export type TTestStatus = 'success' | 'error' | 'pending' | 'errorAfterSuccess' | 'timeout' | 'skipped';
|
|
4
|
+
export interface ITestFunction<T> {
|
|
5
|
+
(tapTools?: TapTools): Promise<T>;
|
|
6
|
+
}
|
|
7
|
+
export declare class TapTest<T = unknown> {
|
|
8
|
+
description: string;
|
|
9
|
+
failureAllowed: boolean;
|
|
10
|
+
hrtMeasurement: HrtMeasurement;
|
|
11
|
+
parallel: boolean;
|
|
12
|
+
status: TTestStatus;
|
|
13
|
+
tapTools: TapTools;
|
|
14
|
+
testFunction: ITestFunction<T>;
|
|
15
|
+
testKey: number;
|
|
16
|
+
timeoutMs?: number;
|
|
17
|
+
isTodo: boolean;
|
|
18
|
+
todoReason?: string;
|
|
19
|
+
tags: string[];
|
|
20
|
+
priority: 'high' | 'medium' | 'low';
|
|
21
|
+
fileName?: string;
|
|
22
|
+
private testDeferred;
|
|
23
|
+
testPromise: Promise<TapTest<T>>;
|
|
24
|
+
private testResultDeferred;
|
|
25
|
+
testResultPromise: Promise<T>;
|
|
26
|
+
/**
|
|
27
|
+
* constructor
|
|
28
|
+
*/
|
|
29
|
+
constructor(optionsArg: {
|
|
30
|
+
description: string;
|
|
31
|
+
testFunction: ITestFunction<T>;
|
|
32
|
+
parallel: boolean;
|
|
33
|
+
});
|
|
34
|
+
/**
|
|
35
|
+
* run the test
|
|
36
|
+
*/
|
|
37
|
+
run(testKeyArg: number): Promise<void>;
|
|
38
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
+
import { tapCreator } from './tapbundle.tapcreator.js';
|
|
3
|
+
import { TapTools, SkipError } from './tapbundle.classes.taptools.js';
|
|
4
|
+
// imported interfaces
|
|
5
|
+
import { Deferred } from '@push.rocks/smartpromise';
|
|
6
|
+
import { HrtMeasurement } from '@push.rocks/smarttime';
|
|
7
|
+
export class TapTest {
|
|
8
|
+
/**
|
|
9
|
+
* constructor
|
|
10
|
+
*/
|
|
11
|
+
constructor(optionsArg) {
|
|
12
|
+
this.isTodo = false;
|
|
13
|
+
this.tags = [];
|
|
14
|
+
this.priority = 'medium';
|
|
15
|
+
this.testDeferred = plugins.smartpromise.defer();
|
|
16
|
+
this.testPromise = this.testDeferred.promise;
|
|
17
|
+
this.testResultDeferred = plugins.smartpromise.defer();
|
|
18
|
+
this.testResultPromise = this.testResultDeferred.promise;
|
|
19
|
+
this.description = optionsArg.description;
|
|
20
|
+
this.hrtMeasurement = new HrtMeasurement();
|
|
21
|
+
this.parallel = optionsArg.parallel;
|
|
22
|
+
this.status = 'pending';
|
|
23
|
+
this.tapTools = new TapTools(this);
|
|
24
|
+
this.testFunction = optionsArg.testFunction;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* run the test
|
|
28
|
+
*/
|
|
29
|
+
async run(testKeyArg) {
|
|
30
|
+
this.testKey = testKeyArg;
|
|
31
|
+
const testNumber = testKeyArg + 1;
|
|
32
|
+
// Handle todo tests
|
|
33
|
+
if (this.isTodo) {
|
|
34
|
+
const todoText = this.todoReason ? `# TODO ${this.todoReason}` : '# TODO';
|
|
35
|
+
console.log(`ok ${testNumber} - ${this.description} ${todoText}`);
|
|
36
|
+
this.status = 'success';
|
|
37
|
+
this.testDeferred.resolve(this);
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
// Run test with retries
|
|
41
|
+
let lastError;
|
|
42
|
+
const maxRetries = this.tapTools.maxRetries;
|
|
43
|
+
for (let attempt = 0; attempt <= maxRetries; attempt++) {
|
|
44
|
+
this.hrtMeasurement.start();
|
|
45
|
+
try {
|
|
46
|
+
// Set up timeout if specified
|
|
47
|
+
let timeoutHandle;
|
|
48
|
+
let timeoutPromise = null;
|
|
49
|
+
if (this.timeoutMs) {
|
|
50
|
+
timeoutPromise = new Promise((_, reject) => {
|
|
51
|
+
timeoutHandle = setTimeout(() => {
|
|
52
|
+
this.status = 'timeout';
|
|
53
|
+
reject(new Error(`Test timed out after ${this.timeoutMs}ms`));
|
|
54
|
+
}, this.timeoutMs);
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
// Run the test function with potential timeout
|
|
58
|
+
const testPromise = this.testFunction(this.tapTools);
|
|
59
|
+
const testReturnValue = timeoutPromise
|
|
60
|
+
? await Promise.race([testPromise, timeoutPromise])
|
|
61
|
+
: await testPromise;
|
|
62
|
+
// Clear timeout if test completed
|
|
63
|
+
if (timeoutHandle) {
|
|
64
|
+
clearTimeout(timeoutHandle);
|
|
65
|
+
}
|
|
66
|
+
this.hrtMeasurement.stop();
|
|
67
|
+
console.log(`ok ${testNumber} - ${this.description} # time=${this.hrtMeasurement.milliSeconds}ms`);
|
|
68
|
+
this.status = 'success';
|
|
69
|
+
this.testDeferred.resolve(this);
|
|
70
|
+
this.testResultDeferred.resolve(testReturnValue);
|
|
71
|
+
return; // Success, exit retry loop
|
|
72
|
+
}
|
|
73
|
+
catch (err) {
|
|
74
|
+
this.hrtMeasurement.stop();
|
|
75
|
+
// Handle skip
|
|
76
|
+
if (err instanceof SkipError || err.name === 'SkipError') {
|
|
77
|
+
console.log(`ok ${testNumber} - ${this.description} # SKIP ${err.message.replace('Skipped: ', '')}`);
|
|
78
|
+
this.status = 'skipped';
|
|
79
|
+
this.testDeferred.resolve(this);
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
lastError = err;
|
|
83
|
+
// If we have retries left, try again
|
|
84
|
+
if (attempt < maxRetries) {
|
|
85
|
+
console.log(`# Retry ${attempt + 1}/${maxRetries} for test: ${this.description}`);
|
|
86
|
+
this.tapTools._incrementRetryCount();
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
// Final failure
|
|
90
|
+
console.log(`not ok ${testNumber} - ${this.description} # time=${this.hrtMeasurement.milliSeconds}ms`);
|
|
91
|
+
this.testDeferred.resolve(this);
|
|
92
|
+
this.testResultDeferred.resolve(err);
|
|
93
|
+
// if the test has already succeeded before
|
|
94
|
+
if (this.status === 'success') {
|
|
95
|
+
this.status = 'errorAfterSuccess';
|
|
96
|
+
console.log('!!! ALERT !!!: weird behaviour, since test has been already successfull');
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
this.status = 'error';
|
|
100
|
+
}
|
|
101
|
+
// if the test is allowed to fail
|
|
102
|
+
if (this.failureAllowed) {
|
|
103
|
+
console.log(`please note: failure allowed!`);
|
|
104
|
+
}
|
|
105
|
+
console.log(err);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFwYnVuZGxlLmNsYXNzZXMudGFwdGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3RhcGJ1bmRsZS90YXBidW5kbGUuY2xhc3Nlcy50YXB0ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFdEUsc0JBQXNCO0FBQ3RCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFTdkQsTUFBTSxPQUFPLE9BQU87SUFtQmxCOztPQUVHO0lBQ0gsWUFBWSxVQUlYO1FBaEJNLFdBQU0sR0FBWSxLQUFLLENBQUM7UUFFeEIsU0FBSSxHQUFhLEVBQUUsQ0FBQztRQUNwQixhQUFRLEdBQThCLFFBQVEsQ0FBQztRQUU5QyxpQkFBWSxHQUF5QixPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ25FLGdCQUFXLEdBQXdCLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDO1FBQzVELHVCQUFrQixHQUFnQixPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2hFLHNCQUFpQixHQUFlLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUM7UUFTckUsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUMsV0FBVyxDQUFDO1FBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxjQUFjLEVBQUUsQ0FBQztRQUMzQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUM7UUFDeEIsSUFB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
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import * as plugins from './tapbundle.plugins.js';
|
|
2
|
+
import { TapTest } from './tapbundle.classes.taptest.js';
|
|
3
|
+
export interface IPromiseFunc {
|
|
4
|
+
(): Promise<any>;
|
|
5
|
+
}
|
|
6
|
+
export declare class SkipError extends Error {
|
|
7
|
+
constructor(message: string);
|
|
8
|
+
}
|
|
9
|
+
export declare class TapTools {
|
|
10
|
+
/**
|
|
11
|
+
* the referenced TapTest
|
|
12
|
+
*/
|
|
13
|
+
private _tapTest;
|
|
14
|
+
private _retries;
|
|
15
|
+
private _retryCount;
|
|
16
|
+
testData: any;
|
|
17
|
+
private static _sharedContext;
|
|
18
|
+
private _snapshotPath;
|
|
19
|
+
private static _pathHelpers;
|
|
20
|
+
static setPathHelpers(helpers: typeof TapTools._pathHelpers): void;
|
|
21
|
+
constructor(TapTestArg: TapTest<any>);
|
|
22
|
+
/**
|
|
23
|
+
* allow failure
|
|
24
|
+
*/
|
|
25
|
+
allowFailure(): void;
|
|
26
|
+
/**
|
|
27
|
+
* skip the rest of the test
|
|
28
|
+
*/
|
|
29
|
+
skip(reason?: string): never;
|
|
30
|
+
/**
|
|
31
|
+
* conditionally skip the rest of the test
|
|
32
|
+
*/
|
|
33
|
+
skipIf(condition: boolean, reason?: string): void;
|
|
34
|
+
/**
|
|
35
|
+
* mark test as todo
|
|
36
|
+
*/
|
|
37
|
+
todo(reason?: string): void;
|
|
38
|
+
/**
|
|
39
|
+
* set the number of retries for this test
|
|
40
|
+
*/
|
|
41
|
+
retry(count: number): void;
|
|
42
|
+
/**
|
|
43
|
+
* get the current retry count
|
|
44
|
+
*/
|
|
45
|
+
get retryCount(): number;
|
|
46
|
+
/**
|
|
47
|
+
* internal: increment retry count
|
|
48
|
+
*/
|
|
49
|
+
_incrementRetryCount(): void;
|
|
50
|
+
/**
|
|
51
|
+
* get the maximum retries
|
|
52
|
+
*/
|
|
53
|
+
get maxRetries(): number;
|
|
54
|
+
/**
|
|
55
|
+
* async/await delay method
|
|
56
|
+
*/
|
|
57
|
+
delayFor(timeMilliArg: number): Promise<void>;
|
|
58
|
+
delayForRandom(timeMilliMinArg: number, timeMilliMaxArg: number): Promise<void>;
|
|
59
|
+
coloredString(...args: Parameters<typeof plugins.consolecolor.coloredString>): Promise<string>;
|
|
60
|
+
/**
|
|
61
|
+
* set a timeout for the test
|
|
62
|
+
*/
|
|
63
|
+
timeout(timeMilliArg: number): void;
|
|
64
|
+
/**
|
|
65
|
+
* wait for a timeout (used internally)
|
|
66
|
+
*/
|
|
67
|
+
waitForTimeout(timeMilliArg: number): Promise<void>;
|
|
68
|
+
returnError(throwingFuncArg: IPromiseFunc): Promise<Error>;
|
|
69
|
+
defer(): plugins.smartpromise.Deferred<unknown>;
|
|
70
|
+
cumulativeDefer(): plugins.smartpromise.CumulativeDeferred;
|
|
71
|
+
smartjson: typeof plugins.smartjson;
|
|
72
|
+
/**
|
|
73
|
+
* shared context for data sharing between tests
|
|
74
|
+
*/
|
|
75
|
+
context: {
|
|
76
|
+
get: (key: string) => any;
|
|
77
|
+
set: (key: string, value: any) => void;
|
|
78
|
+
delete: (key: string) => boolean;
|
|
79
|
+
clear: () => void;
|
|
80
|
+
};
|
|
81
|
+
/**
|
|
82
|
+
* Snapshot testing - compares output with saved snapshot
|
|
83
|
+
*/
|
|
84
|
+
matchSnapshot(value: any, snapshotName?: string): Promise<void>;
|
|
85
|
+
/**
|
|
86
|
+
* Test fixtures - create test data instances
|
|
87
|
+
*/
|
|
88
|
+
private static _fixtureData;
|
|
89
|
+
private static _fixtureFactories;
|
|
90
|
+
/**
|
|
91
|
+
* Define a fixture factory
|
|
92
|
+
*/
|
|
93
|
+
static defineFixture<T>(name: string, factory: (data?: Partial<T>) => T | Promise<T>): void;
|
|
94
|
+
/**
|
|
95
|
+
* Create a fixture instance
|
|
96
|
+
*/
|
|
97
|
+
fixture<T>(name: string, data?: Partial<T>): Promise<T>;
|
|
98
|
+
/**
|
|
99
|
+
* Factory pattern for creating multiple fixtures
|
|
100
|
+
*/
|
|
101
|
+
factory<T>(name: string): {
|
|
102
|
+
create: (data?: Partial<T>) => Promise<T>;
|
|
103
|
+
createMany: (count: number, dataOverrides?: Partial<T>[] | ((index: number) => Partial<T>)) => Promise<T[]>;
|
|
104
|
+
};
|
|
105
|
+
/**
|
|
106
|
+
* Clear all fixtures (typically called in afterEach)
|
|
107
|
+
*/
|
|
108
|
+
static cleanupFixtures(): Promise<void>;
|
|
109
|
+
}
|