@aerokit/sdk 12.82.0 → 12.85.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.
@@ -21,47 +21,134 @@ __export(junit_exports, {
21
21
  assertFalse: () => assertFalse,
22
22
  assertNotEquals: () => assertNotEquals,
23
23
  assertTrue: () => assertTrue,
24
+ clearResults: () => clearResults,
24
25
  fail: () => fail,
26
+ getResults: () => getResults,
27
+ getResultsSummary: () => getResultsSummary,
28
+ storeResults: () => storeResults,
25
29
  test: () => test
26
30
  });
27
31
  module.exports = __toCommonJS(junit_exports);
28
- const Assert = Java.type("org.junit.Assert");
32
+ var import_http = require("@aerokit/sdk/http");
33
+ const Assertions = Java.type("org.junit.jupiter.api.Assertions");
34
+ const TestResultsService = Java.type("org.eclipse.dirigible.components.ide.junit.service.TestResultsService");
35
+ const ArrayList = Java.type("java.util.ArrayList");
36
+ const TestResult = Java.type("org.eclipse.dirigible.components.ide.junit.domain.TestResult");
37
+ class TestResultCollector {
38
+ results = [];
39
+ currentTest = null;
40
+ haveFailedTests = false;
41
+ hasFailedTests() {
42
+ return this.haveFailedTests;
43
+ }
44
+ recordTestStart(name) {
45
+ this.currentTest = { name, startTime: (/* @__PURE__ */ new Date()).getTime() };
46
+ }
47
+ recordTestComplete(status, error) {
48
+ if (!this.currentTest) return;
49
+ const result = {
50
+ name: this.currentTest.name,
51
+ status,
52
+ duration: (/* @__PURE__ */ new Date()).getTime() - this.currentTest.startTime,
53
+ timestamp: (/* @__PURE__ */ new Date()).getTime()
54
+ };
55
+ if (error) {
56
+ result.error = error.message;
57
+ result.stackTrace = error.stackTrace;
58
+ }
59
+ this.results.push(result);
60
+ this.currentTest = null;
61
+ if (status === "failed" || error) {
62
+ this.haveFailedTests = true;
63
+ }
64
+ }
65
+ getResults() {
66
+ return [...this.results];
67
+ }
68
+ storeResults() {
69
+ const resultsList = new ArrayList();
70
+ this.results.forEach((e) => resultsList.add(new TestResult(e.name, e.status, e.duration, e.error, e.stackTrace, e.timestamp)));
71
+ TestResultsService.get().storeResults(resultsList);
72
+ import_http.Response.sendRedirect("/services/web/ide-junit-results/junit-results");
73
+ }
74
+ getSummary() {
75
+ const results = this.results;
76
+ const total = results.length;
77
+ const passed = results.filter((r) => r.status === "passed").length;
78
+ const failed = results.filter((r) => r.status === "failed").length;
79
+ const skipped = results.filter((r) => r.status === "skipped").length;
80
+ const duration = results.reduce((sum, r) => sum + r.duration, 0);
81
+ return { total, passed, failed, skipped, duration };
82
+ }
83
+ clearResults() {
84
+ this.results = [];
85
+ this.currentTest = null;
86
+ this.haveFailedTests = false;
87
+ }
88
+ }
89
+ const resultCollector = new TestResultCollector();
29
90
  function test(name, testFn) {
30
- globalThis.test(name, testFn);
91
+ resultCollector.recordTestStart(name);
92
+ if (resultCollector.hasFailedTests()) {
93
+ resultCollector.recordTestComplete("skipped");
94
+ console.log(`- Skipping test "${name}" due to previous failures`);
95
+ } else {
96
+ try {
97
+ testFn();
98
+ resultCollector.recordTestComplete("passed");
99
+ } catch (error) {
100
+ resultCollector.recordTestComplete("failed", {
101
+ message: error?.message || String(error),
102
+ stackTrace: error?.stack
103
+ });
104
+ }
105
+ }
31
106
  }
32
107
  function assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined) {
33
108
  if (arguments.length === 3) {
34
- Assert.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);
109
+ Assertions.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);
35
110
  } else {
36
- Assert.assertEquals(messageOrExpected, expectedOrActual);
111
+ Assertions.assertEquals(messageOrExpected, expectedOrActual);
37
112
  }
38
113
  }
39
114
  function assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined) {
40
115
  if (arguments.length === 3) {
41
- Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);
116
+ Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);
42
117
  } else {
43
- Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual);
118
+ Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual);
44
119
  }
45
120
  }
46
121
  function assertTrue(messageOrCondition, conditionOrUndefined) {
47
122
  if (arguments.length === 2) {
48
- Assert.assertTrue(messageOrCondition, conditionOrUndefined);
123
+ Assertions.assertTrue(messageOrCondition, conditionOrUndefined);
49
124
  } else {
50
- Assert.assertTrue(messageOrCondition);
125
+ Assertions.assertTrue(messageOrCondition);
51
126
  }
52
127
  }
53
128
  function assertFalse(messageOrCondition, conditionOrUndefined) {
54
129
  if (arguments.length === 2) {
55
- Assert.assertFalse(messageOrCondition, conditionOrUndefined);
130
+ Assertions.assertFalse(messageOrCondition, conditionOrUndefined);
56
131
  } else {
57
- Assert.assertFalse(messageOrCondition);
132
+ Assertions.assertFalse(messageOrCondition);
58
133
  }
59
134
  }
60
135
  function fail(message) {
61
136
  if (message) {
62
- Assert.fail(message);
137
+ Assertions.fail(message);
63
138
  } else {
64
- Assert.fail();
139
+ Assertions.fail();
65
140
  }
66
141
  }
67
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/junit/junit.ts"],
  "sourcesContent": ["/**\n * @module junit/junit\n * @package @aerokit/sdk/junit\n * @name JUnit\n * @overview\n * \n * The JUnit module provides a set of utility functions for defining tests and performing assertions, wrapping the native JUnit Assertions for use in TypeScript/JavaScript tests. It allows developers to write test cases in a familiar format while leveraging the powerful assertion capabilities of JUnit, making it easier to validate code behavior and ensure correctness.\n * \n * ### Key Features:\n * - **Test Definition**: The `test` function allows developers to define individual test cases with a descriptive name and a function containing the test logic.\n * - **Assertions**: Functions such as `assertEquals`, `assertNotEquals`, `assertTrue`, `assertFalse`, and `fail` provide a variety of assertion methods to validate conditions and compare values within tests.\n * \n * ### Use Cases:\n * - **Unit Testing**: These utilities are primarily used for writing unit tests to verify the functionality of individual components or functions in isolation.\n * - **Integration Testing**: They can also be used in integration tests to validate the behavior of multiple components working together, ensuring that they interact correctly.\n * \n * ### Example Usage:\n * ```ts\n * import { test, assertEquals, assertTrue } from \"@aerokit/sdk/junit\";\n * \n * test(\"should add two numbers correctly\", () => {\n *     const result = add(2, 3);\n *     assertEquals(5, result);\n * });\n * \n * test(\"should return true for valid input\", () => {\n *     const isValid = validateInput(\"valid input\");\n *     assertTrue(isValid);\n * });\n * ```\n */\n\nconst Assert = Java.type('org.junit.Assert');\n\n/**\n * Defines a test case.\n *\n * @param name The name of the test case.\n * @param testFn The function containing the test logic and assertions.\n */\nexport function test(name: string, testFn: () => void) {\n    // Calls the global test runner function provided by the SDK environment.\n    (globalThis as any).test(name, testFn);\n}\n\n/**\n * Asserts that two objects or primitive values are equal.\n *\n * @template T The type of the values being compared.\n * @param expected The expected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertEquals<T>(expected: T, actual: T): void\nexport function assertEquals<T>(message: string, expected: T, actual: T): void\nexport function assertEquals<T>(messageOrExpected?: string | T, expectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assert.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);\n    } else {\n        Assert.assertEquals(messageOrExpected, expectedOrActual);\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are not equal.\n *\n * @template T The type of the values being compared.\n * @param unexpected The unexpected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertNotEquals<T>(unexpected: T, actual: T): void\nexport function assertNotEquals<T>(message: string, unexpected: T, actual: T): void\nexport function assertNotEquals<T>(messageOrUnexpected?: string | T, unexpectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);\n    } else {\n        Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual);\n    }\n}\n\n/**\n * Asserts that a condition is true.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertTrue(condition: boolean): void\nexport function assertTrue(message: string, condition: boolean): void\nexport function assertTrue(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assert.assertTrue(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assert.assertTrue(messageOrCondition);\n    }\n}\n\n/**\n * Asserts that a condition is false.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertFalse(condition: boolean): void\nexport function assertFalse(message: string, condition: boolean): void\nexport function assertFalse(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assert.assertFalse(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assert.assertFalse(messageOrCondition);\n    }\n}\n\n/**\n * Fails a test immediately.\n *\n * @param message Optional message to display indicating the reason for the failure.\n */\nexport function fail(): void\nexport function fail(message: string): void\nexport function fail(message?: string): void {\n    if (message) {\n        Assert.fail(message);\n    } else {\n        Assert.fail();\n    }\n}"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAgCA,MAAM,SAAS,KAAK,KAAK,kBAAkB;AAQpC,SAAS,KAAK,MAAc,QAAoB;AAEnD,EAAC,WAAmB,KAAK,MAAM,MAAM;AACzC;AAYO,SAAS,aAAgB,mBAAgC,kBAAsB,mBAA6B;AAC/G,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,aAAa,mBAAmB,kBAAkB,iBAAiB;AAAA,EAC9E,OAAO;AACH,WAAO,aAAa,mBAAmB,gBAAgB;AAAA,EAC3D;AACJ;AAYO,SAAS,gBAAmB,qBAAkC,oBAAwB,mBAA6B;AACtH,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,gBAAgB,qBAAqB,oBAAoB,iBAAiB;AAAA,EACrF,OAAO;AACH,WAAO,gBAAgB,qBAAqB,kBAAkB;AAAA,EAClE;AACJ;AAUO,SAAS,WAAW,oBAAuC,sBAAsC;AACpG,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,WAAW,oBAAoB,oBAAoB;AAAA,EAC9D,OAAO;AACH,WAAO,WAAW,kBAAkB;AAAA,EACxC;AACJ;AAUO,SAAS,YAAY,oBAAuC,sBAAsC;AACrG,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,YAAY,oBAAoB,oBAAoB;AAAA,EAC/D,OAAO;AACH,WAAO,YAAY,kBAAkB;AAAA,EACzC;AACJ;AASO,SAAS,KAAK,SAAwB;AACzC,MAAI,SAAS;AACT,WAAO,KAAK,OAAO;AAAA,EACvB,OAAO;AACH,WAAO,KAAK;AAAA,EAChB;AACJ;",
  "names": []
}

142
+ function getResults() {
143
+ return resultCollector.getResults();
144
+ }
145
+ function getResultsSummary() {
146
+ return resultCollector.getSummary();
147
+ }
148
+ function clearResults() {
149
+ resultCollector.clearResults();
150
+ }
151
+ function storeResults() {
152
+ resultCollector.storeResults();
153
+ }
154
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/junit/junit.ts"],
  "sourcesContent": ["/**\n * @module junit/junit\n * @package @aerokit/sdk/junit\n * @name JUnit\n * @overview\n * \n * The JUnit module provides a set of utility functions for defining tests and performing assertions, wrapping the native JUnit Assertions for use in TypeScript/JavaScript tests. It allows developers to write test cases in a familiar format while leveraging the powerful assertion capabilities of JUnit, making it easier to validate code behavior and ensure correctness.\n * \n * ### Key Features:\n * - **Test Definition**: The `test` function allows developers to define individual test cases with a descriptive name and a function containing the test logic.\n * - **Assertions**: Functions such as `assertEquals`, `assertNotEquals`, `assertTrue`, `assertFalse`, and `fail` provide a variety of assertion methods to validate conditions and compare values within tests.\n * - **Result Tracking**: Test results are automatically captured and can be retrieved via the results API.\n * \n * ### Use Cases:\n * - **Unit Testing**: These utilities are primarily used for writing unit tests to verify the functionality of individual components or functions in isolation.\n * - **Integration Testing**: They can also be used in integration tests to validate the behavior of multiple components working together, ensuring that they interact correctly.\n * \n * ### Example Usage:\n * ```ts\n * import { test, assertEquals, assertTrue, storeResults } from \"@aerokit/sdk/junit\";\n * \n * test(\"should add two numbers correctly\", () => {\n *     const result = 2 + 3;\n *     assertEquals(5, result);\n * });\n * \n * test(\"should return true for valid input\", () => {\n *     const isValid = false; // Replace with actual validation logic\n *     assertTrue(isValid);\n * });\n * \n * // After running tests, store results for later retrieval\n * storeResults();\n * ```\n */\n\nimport { Response } from '@aerokit/sdk/http';\n\nconst Assertions = Java.type('org.junit.jupiter.api.Assertions');\nconst TestResultsService = Java.type('org.eclipse.dirigible.components.ide.junit.service.TestResultsService');\nconst ArrayList = Java.type('java.util.ArrayList');\nconst TestResult = Java.type('org.eclipse.dirigible.components.ide.junit.domain.TestResult');\n\n// Test Result Tracking\ninterface TestResult {\n    name: string;\n    status: 'passed' | 'failed' | 'skipped';\n    duration: number;\n    error?: string;\n    stackTrace?: string;\n    timestamp: number;\n}\n\nclass TestResultCollector {\n    private results: TestResult[] = [];\n    private currentTest: { name: string; startTime: number } | null = null;\n    private haveFailedTests: boolean = false;\n\n    public hasFailedTests(): boolean {\n        return this.haveFailedTests;\n    }\n\n    public recordTestStart(name: string): void {\n        this.currentTest = { name, startTime: new Date().getTime() };\n    }\n\n    public recordTestComplete(status: 'passed' | 'failed' | 'skipped', error?: { message: string; stackTrace?: string }): void {\n        if (!this.currentTest) return;\n\n        const result: TestResult = {\n            name: this.currentTest.name,\n            status,\n            duration: new Date().getTime() - this.currentTest.startTime,\n            timestamp: new Date().getTime(),\n        };\n\n        if (error) {\n            result.error = error.message;\n            result.stackTrace = error.stackTrace;\n        }\n\n        this.results.push(result);\n        this.currentTest = null;\n\n        if (status === 'failed' || error) {\n            this.haveFailedTests = true;\n        }\n    }\n\n    public getResults(): TestResult[] {\n        return [...this.results];\n    }\n\n    public storeResults(): void {\n        const resultsList = new ArrayList();\n        this.results.forEach(e => resultsList.add(new TestResult(e.name, e.status, e.duration, e.error, e.stackTrace, e.timestamp)));\n        TestResultsService.get().storeResults(resultsList);\n        Response.sendRedirect('/services/web/ide-junit-results/junit-results');\n    }\n\n    public getSummary(): {\n        total: number;\n        passed: number;\n        failed: number;\n        skipped: number;\n        duration: number;\n    } {\n        const results = this.results;\n        const total = results.length;\n        const passed = results.filter(r => r.status === 'passed').length;\n        const failed = results.filter(r => r.status === 'failed').length;\n        const skipped = results.filter(r => r.status === 'skipped').length;\n        const duration = results.reduce((sum, r) => sum + r.duration, 0);\n\n        return { total, passed, failed, skipped, duration };\n    }\n\n    public clearResults(): void {\n        this.results = [];\n        this.currentTest = null;\n        this.haveFailedTests = false;\n    }\n}\n\nconst resultCollector = new TestResultCollector();\n\n/**\n * Defines a test case.\n *\n * @param name The name of the test case.\n * @param testFn The function containing the test logic and assertions.\n */\nexport function test(name: string, testFn: () => void) {\n    resultCollector.recordTestStart(name);\n    if (resultCollector.hasFailedTests()) {\n        resultCollector.recordTestComplete('skipped');\n        console.log(`- Skipping test \"${name}\" due to previous failures`);\n    } else {\n        try {\n            testFn();\n            resultCollector.recordTestComplete('passed');\n        } catch (error: any) {\n            resultCollector.recordTestComplete('failed', {\n                message: error?.message || String(error),\n                stackTrace: error?.stack,\n            });\n        }\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are equal.\n *\n * @template T The type of the values being compared.\n * @param expected The expected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertEquals<T>(expected: T, actual: T): void\nexport function assertEquals<T>(message: string, expected: T, actual: T): void\nexport function assertEquals<T>(messageOrExpected?: string | T, expectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assertions.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);\n    } else {\n        Assertions.assertEquals(messageOrExpected, expectedOrActual);\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are not equal.\n *\n * @template T The type of the values being compared.\n * @param unexpected The unexpected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertNotEquals<T>(unexpected: T, actual: T): void\nexport function assertNotEquals<T>(message: string, unexpected: T, actual: T): void\nexport function assertNotEquals<T>(messageOrUnexpected?: string | T, unexpectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);\n    } else {\n        Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual);\n    }\n}\n\n/**\n * Asserts that a condition is true.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertTrue(condition: boolean): void\nexport function assertTrue(message: string, condition: boolean): void\nexport function assertTrue(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assertions.assertTrue(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assertions.assertTrue(messageOrCondition);\n    }\n}\n\n/**\n * Asserts that a condition is false.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertFalse(condition: boolean): void\nexport function assertFalse(message: string, condition: boolean): void\nexport function assertFalse(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assertions.assertFalse(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assertions.assertFalse(messageOrCondition);\n    }\n}\n\n/**\n * Fails a test immediately.\n *\n * @param message Optional message to display indicating the reason for the failure.\n */\nexport function fail(): void\nexport function fail(message: string): void\nexport function fail(message?: string): void {\n    if (message) {\n        Assertions.fail(message);\n    } else {\n        Assertions.fail();\n    }\n}\n\n/**\n * Retrieves all test results collected during this session.\n *\n * @returns An array of test results.\n */\nexport function getResults(): Array<{\n    name: string;\n    status: 'passed' | 'failed' | 'skipped';\n    duration: number;\n    error?: string;\n    stackTrace?: string;\n    timestamp: number;\n}> {\n    return resultCollector.getResults();\n}\n\n/**\n * Retrieves a summary of test execution.\n *\n * @returns An object containing counts and total duration.\n */\nexport function getResultsSummary(): {\n    total: number;\n    passed: number;\n    failed: number;\n    skipped: number;\n    duration: number;\n} {\n    return resultCollector.getSummary();\n}\n\n/**\n * Clears all collected test results.\n */\nexport function clearResults(): void {\n    resultCollector.clearResults();\n}\n\n/**\n * Clears all collected test results.\n */\nexport function storeResults(): void {\n    resultCollector.storeResults();\n}"],
  "mappings": "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",
  "names": []
}

@@ -9,6 +9,7 @@
9
9
  * ### Key Features:
10
10
  * - **Test Definition**: The `test` function allows developers to define individual test cases with a descriptive name and a function containing the test logic.
11
11
  * - **Assertions**: Functions such as `assertEquals`, `assertNotEquals`, `assertTrue`, `assertFalse`, and `fail` provide a variety of assertion methods to validate conditions and compare values within tests.
12
+ * - **Result Tracking**: Test results are automatically captured and can be retrieved via the results API.
12
13
  *
13
14
  * ### Use Cases:
14
15
  * - **Unit Testing**: These utilities are primarily used for writing unit tests to verify the functionality of individual components or functions in isolation.
@@ -16,17 +17,20 @@
16
17
  *
17
18
  * ### Example Usage:
18
19
  * ```ts
19
- * import { test, assertEquals, assertTrue } from "@aerokit/sdk/junit";
20
+ * import { test, assertEquals, assertTrue, storeResults } from "@aerokit/sdk/junit";
20
21
  *
21
22
  * test("should add two numbers correctly", () => {
22
- * const result = add(2, 3);
23
+ * const result = 2 + 3;
23
24
  * assertEquals(5, result);
24
25
  * });
25
26
  *
26
27
  * test("should return true for valid input", () => {
27
- * const isValid = validateInput("valid input");
28
+ * const isValid = false; // Replace with actual validation logic
28
29
  * assertTrue(isValid);
29
30
  * });
31
+ *
32
+ * // After running tests, store results for later retrieval
33
+ * storeResults();
30
34
  * ```
31
35
  */
32
36
  /**
@@ -79,3 +83,36 @@ export declare function assertFalse(message: string, condition: boolean): void;
79
83
  */
80
84
  export declare function fail(): void;
81
85
  export declare function fail(message: string): void;
86
+ /**
87
+ * Retrieves all test results collected during this session.
88
+ *
89
+ * @returns An array of test results.
90
+ */
91
+ export declare function getResults(): Array<{
92
+ name: string;
93
+ status: 'passed' | 'failed' | 'skipped';
94
+ duration: number;
95
+ error?: string;
96
+ stackTrace?: string;
97
+ timestamp: number;
98
+ }>;
99
+ /**
100
+ * Retrieves a summary of test execution.
101
+ *
102
+ * @returns An object containing counts and total duration.
103
+ */
104
+ export declare function getResultsSummary(): {
105
+ total: number;
106
+ passed: number;
107
+ failed: number;
108
+ skipped: number;
109
+ duration: number;
110
+ };
111
+ /**
112
+ * Clears all collected test results.
113
+ */
114
+ export declare function clearResults(): void;
115
+ /**
116
+ * Clears all collected test results.
117
+ */
118
+ export declare function storeResults(): void;
@@ -1,48 +1,135 @@
1
- const Assert = Java.type("org.junit.Assert");
1
+ import { Response } from "@aerokit/sdk/http";
2
+ const Assertions = Java.type("org.junit.jupiter.api.Assertions");
3
+ const TestResultsService = Java.type("org.eclipse.dirigible.components.ide.junit.service.TestResultsService");
4
+ const ArrayList = Java.type("java.util.ArrayList");
5
+ const TestResult = Java.type("org.eclipse.dirigible.components.ide.junit.domain.TestResult");
6
+ class TestResultCollector {
7
+ results = [];
8
+ currentTest = null;
9
+ haveFailedTests = false;
10
+ hasFailedTests() {
11
+ return this.haveFailedTests;
12
+ }
13
+ recordTestStart(name) {
14
+ this.currentTest = { name, startTime: (/* @__PURE__ */ new Date()).getTime() };
15
+ }
16
+ recordTestComplete(status, error) {
17
+ if (!this.currentTest) return;
18
+ const result = {
19
+ name: this.currentTest.name,
20
+ status,
21
+ duration: (/* @__PURE__ */ new Date()).getTime() - this.currentTest.startTime,
22
+ timestamp: (/* @__PURE__ */ new Date()).getTime()
23
+ };
24
+ if (error) {
25
+ result.error = error.message;
26
+ result.stackTrace = error.stackTrace;
27
+ }
28
+ this.results.push(result);
29
+ this.currentTest = null;
30
+ if (status === "failed" || error) {
31
+ this.haveFailedTests = true;
32
+ }
33
+ }
34
+ getResults() {
35
+ return [...this.results];
36
+ }
37
+ storeResults() {
38
+ const resultsList = new ArrayList();
39
+ this.results.forEach((e) => resultsList.add(new TestResult(e.name, e.status, e.duration, e.error, e.stackTrace, e.timestamp)));
40
+ TestResultsService.get().storeResults(resultsList);
41
+ Response.sendRedirect("/services/web/ide-junit-results/junit-results");
42
+ }
43
+ getSummary() {
44
+ const results = this.results;
45
+ const total = results.length;
46
+ const passed = results.filter((r) => r.status === "passed").length;
47
+ const failed = results.filter((r) => r.status === "failed").length;
48
+ const skipped = results.filter((r) => r.status === "skipped").length;
49
+ const duration = results.reduce((sum, r) => sum + r.duration, 0);
50
+ return { total, passed, failed, skipped, duration };
51
+ }
52
+ clearResults() {
53
+ this.results = [];
54
+ this.currentTest = null;
55
+ this.haveFailedTests = false;
56
+ }
57
+ }
58
+ const resultCollector = new TestResultCollector();
2
59
  function test(name, testFn) {
3
- globalThis.test(name, testFn);
60
+ resultCollector.recordTestStart(name);
61
+ if (resultCollector.hasFailedTests()) {
62
+ resultCollector.recordTestComplete("skipped");
63
+ console.log(`- Skipping test "${name}" due to previous failures`);
64
+ } else {
65
+ try {
66
+ testFn();
67
+ resultCollector.recordTestComplete("passed");
68
+ } catch (error) {
69
+ resultCollector.recordTestComplete("failed", {
70
+ message: error?.message || String(error),
71
+ stackTrace: error?.stack
72
+ });
73
+ }
74
+ }
4
75
  }
5
76
  function assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined) {
6
77
  if (arguments.length === 3) {
7
- Assert.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);
78
+ Assertions.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);
8
79
  } else {
9
- Assert.assertEquals(messageOrExpected, expectedOrActual);
80
+ Assertions.assertEquals(messageOrExpected, expectedOrActual);
10
81
  }
11
82
  }
12
83
  function assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined) {
13
84
  if (arguments.length === 3) {
14
- Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);
85
+ Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);
15
86
  } else {
16
- Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual);
87
+ Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual);
17
88
  }
18
89
  }
19
90
  function assertTrue(messageOrCondition, conditionOrUndefined) {
20
91
  if (arguments.length === 2) {
21
- Assert.assertTrue(messageOrCondition, conditionOrUndefined);
92
+ Assertions.assertTrue(messageOrCondition, conditionOrUndefined);
22
93
  } else {
23
- Assert.assertTrue(messageOrCondition);
94
+ Assertions.assertTrue(messageOrCondition);
24
95
  }
25
96
  }
26
97
  function assertFalse(messageOrCondition, conditionOrUndefined) {
27
98
  if (arguments.length === 2) {
28
- Assert.assertFalse(messageOrCondition, conditionOrUndefined);
99
+ Assertions.assertFalse(messageOrCondition, conditionOrUndefined);
29
100
  } else {
30
- Assert.assertFalse(messageOrCondition);
101
+ Assertions.assertFalse(messageOrCondition);
31
102
  }
32
103
  }
33
104
  function fail(message) {
34
105
  if (message) {
35
- Assert.fail(message);
106
+ Assertions.fail(message);
36
107
  } else {
37
- Assert.fail();
108
+ Assertions.fail();
38
109
  }
39
110
  }
111
+ function getResults() {
112
+ return resultCollector.getResults();
113
+ }
114
+ function getResultsSummary() {
115
+ return resultCollector.getSummary();
116
+ }
117
+ function clearResults() {
118
+ resultCollector.clearResults();
119
+ }
120
+ function storeResults() {
121
+ resultCollector.storeResults();
122
+ }
40
123
  export {
41
124
  assertEquals,
42
125
  assertFalse,
43
126
  assertNotEquals,
44
127
  assertTrue,
128
+ clearResults,
45
129
  fail,
130
+ getResults,
131
+ getResultsSummary,
132
+ storeResults,
46
133
  test
47
134
  };
48
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/junit/junit.ts"],
  "sourcesContent": ["/**\n * @module junit/junit\n * @package @aerokit/sdk/junit\n * @name JUnit\n * @overview\n * \n * The JUnit module provides a set of utility functions for defining tests and performing assertions, wrapping the native JUnit Assertions for use in TypeScript/JavaScript tests. It allows developers to write test cases in a familiar format while leveraging the powerful assertion capabilities of JUnit, making it easier to validate code behavior and ensure correctness.\n * \n * ### Key Features:\n * - **Test Definition**: The `test` function allows developers to define individual test cases with a descriptive name and a function containing the test logic.\n * - **Assertions**: Functions such as `assertEquals`, `assertNotEquals`, `assertTrue`, `assertFalse`, and `fail` provide a variety of assertion methods to validate conditions and compare values within tests.\n * \n * ### Use Cases:\n * - **Unit Testing**: These utilities are primarily used for writing unit tests to verify the functionality of individual components or functions in isolation.\n * - **Integration Testing**: They can also be used in integration tests to validate the behavior of multiple components working together, ensuring that they interact correctly.\n * \n * ### Example Usage:\n * ```ts\n * import { test, assertEquals, assertTrue } from \"@aerokit/sdk/junit\";\n * \n * test(\"should add two numbers correctly\", () => {\n *     const result = add(2, 3);\n *     assertEquals(5, result);\n * });\n * \n * test(\"should return true for valid input\", () => {\n *     const isValid = validateInput(\"valid input\");\n *     assertTrue(isValid);\n * });\n * ```\n */\n\nconst Assert = Java.type('org.junit.Assert');\n\n/**\n * Defines a test case.\n *\n * @param name The name of the test case.\n * @param testFn The function containing the test logic and assertions.\n */\nexport function test(name: string, testFn: () => void) {\n    // Calls the global test runner function provided by the SDK environment.\n    (globalThis as any).test(name, testFn);\n}\n\n/**\n * Asserts that two objects or primitive values are equal.\n *\n * @template T The type of the values being compared.\n * @param expected The expected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertEquals<T>(expected: T, actual: T): void\nexport function assertEquals<T>(message: string, expected: T, actual: T): void\nexport function assertEquals<T>(messageOrExpected?: string | T, expectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assert.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);\n    } else {\n        Assert.assertEquals(messageOrExpected, expectedOrActual);\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are not equal.\n *\n * @template T The type of the values being compared.\n * @param unexpected The unexpected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertNotEquals<T>(unexpected: T, actual: T): void\nexport function assertNotEquals<T>(message: string, unexpected: T, actual: T): void\nexport function assertNotEquals<T>(messageOrUnexpected?: string | T, unexpectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);\n    } else {\n        Assert.assertNotEquals(messageOrUnexpected, unexpectedOrActual);\n    }\n}\n\n/**\n * Asserts that a condition is true.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertTrue(condition: boolean): void\nexport function assertTrue(message: string, condition: boolean): void\nexport function assertTrue(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assert.assertTrue(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assert.assertTrue(messageOrCondition);\n    }\n}\n\n/**\n * Asserts that a condition is false.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertFalse(condition: boolean): void\nexport function assertFalse(message: string, condition: boolean): void\nexport function assertFalse(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assert.assertFalse(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assert.assertFalse(messageOrCondition);\n    }\n}\n\n/**\n * Fails a test immediately.\n *\n * @param message Optional message to display indicating the reason for the failure.\n */\nexport function fail(): void\nexport function fail(message: string): void\nexport function fail(message?: string): void {\n    if (message) {\n        Assert.fail(message);\n    } else {\n        Assert.fail();\n    }\n}"],
  "mappings": "AAgCA,MAAM,SAAS,KAAK,KAAK,kBAAkB;AAQpC,SAAS,KAAK,MAAc,QAAoB;AAEnD,EAAC,WAAmB,KAAK,MAAM,MAAM;AACzC;AAYO,SAAS,aAAgB,mBAAgC,kBAAsB,mBAA6B;AAC/G,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,aAAa,mBAAmB,kBAAkB,iBAAiB;AAAA,EAC9E,OAAO;AACH,WAAO,aAAa,mBAAmB,gBAAgB;AAAA,EAC3D;AACJ;AAYO,SAAS,gBAAmB,qBAAkC,oBAAwB,mBAA6B;AACtH,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,gBAAgB,qBAAqB,oBAAoB,iBAAiB;AAAA,EACrF,OAAO;AACH,WAAO,gBAAgB,qBAAqB,kBAAkB;AAAA,EAClE;AACJ;AAUO,SAAS,WAAW,oBAAuC,sBAAsC;AACpG,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,WAAW,oBAAoB,oBAAoB;AAAA,EAC9D,OAAO;AACH,WAAO,WAAW,kBAAkB;AAAA,EACxC;AACJ;AAUO,SAAS,YAAY,oBAAuC,sBAAsC;AACrG,MAAI,UAAU,WAAW,GAAG;AACxB,WAAO,YAAY,oBAAoB,oBAAoB;AAAA,EAC/D,OAAO;AACH,WAAO,YAAY,kBAAkB;AAAA,EACzC;AACJ;AASO,SAAS,KAAK,SAAwB;AACzC,MAAI,SAAS;AACT,WAAO,KAAK,OAAO;AAAA,EACvB,OAAO;AACH,WAAO,KAAK;AAAA,EAChB;AACJ;",
  "names": []
}

135
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/junit/junit.ts"],
  "sourcesContent": ["/**\n * @module junit/junit\n * @package @aerokit/sdk/junit\n * @name JUnit\n * @overview\n * \n * The JUnit module provides a set of utility functions for defining tests and performing assertions, wrapping the native JUnit Assertions for use in TypeScript/JavaScript tests. It allows developers to write test cases in a familiar format while leveraging the powerful assertion capabilities of JUnit, making it easier to validate code behavior and ensure correctness.\n * \n * ### Key Features:\n * - **Test Definition**: The `test` function allows developers to define individual test cases with a descriptive name and a function containing the test logic.\n * - **Assertions**: Functions such as `assertEquals`, `assertNotEquals`, `assertTrue`, `assertFalse`, and `fail` provide a variety of assertion methods to validate conditions and compare values within tests.\n * - **Result Tracking**: Test results are automatically captured and can be retrieved via the results API.\n * \n * ### Use Cases:\n * - **Unit Testing**: These utilities are primarily used for writing unit tests to verify the functionality of individual components or functions in isolation.\n * - **Integration Testing**: They can also be used in integration tests to validate the behavior of multiple components working together, ensuring that they interact correctly.\n * \n * ### Example Usage:\n * ```ts\n * import { test, assertEquals, assertTrue, storeResults } from \"@aerokit/sdk/junit\";\n * \n * test(\"should add two numbers correctly\", () => {\n *     const result = 2 + 3;\n *     assertEquals(5, result);\n * });\n * \n * test(\"should return true for valid input\", () => {\n *     const isValid = false; // Replace with actual validation logic\n *     assertTrue(isValid);\n * });\n * \n * // After running tests, store results for later retrieval\n * storeResults();\n * ```\n */\n\nimport { Response } from '@aerokit/sdk/http';\n\nconst Assertions = Java.type('org.junit.jupiter.api.Assertions');\nconst TestResultsService = Java.type('org.eclipse.dirigible.components.ide.junit.service.TestResultsService');\nconst ArrayList = Java.type('java.util.ArrayList');\nconst TestResult = Java.type('org.eclipse.dirigible.components.ide.junit.domain.TestResult');\n\n// Test Result Tracking\ninterface TestResult {\n    name: string;\n    status: 'passed' | 'failed' | 'skipped';\n    duration: number;\n    error?: string;\n    stackTrace?: string;\n    timestamp: number;\n}\n\nclass TestResultCollector {\n    private results: TestResult[] = [];\n    private currentTest: { name: string; startTime: number } | null = null;\n    private haveFailedTests: boolean = false;\n\n    public hasFailedTests(): boolean {\n        return this.haveFailedTests;\n    }\n\n    public recordTestStart(name: string): void {\n        this.currentTest = { name, startTime: new Date().getTime() };\n    }\n\n    public recordTestComplete(status: 'passed' | 'failed' | 'skipped', error?: { message: string; stackTrace?: string }): void {\n        if (!this.currentTest) return;\n\n        const result: TestResult = {\n            name: this.currentTest.name,\n            status,\n            duration: new Date().getTime() - this.currentTest.startTime,\n            timestamp: new Date().getTime(),\n        };\n\n        if (error) {\n            result.error = error.message;\n            result.stackTrace = error.stackTrace;\n        }\n\n        this.results.push(result);\n        this.currentTest = null;\n\n        if (status === 'failed' || error) {\n            this.haveFailedTests = true;\n        }\n    }\n\n    public getResults(): TestResult[] {\n        return [...this.results];\n    }\n\n    public storeResults(): void {\n        const resultsList = new ArrayList();\n        this.results.forEach(e => resultsList.add(new TestResult(e.name, e.status, e.duration, e.error, e.stackTrace, e.timestamp)));\n        TestResultsService.get().storeResults(resultsList);\n        Response.sendRedirect('/services/web/ide-junit-results/junit-results');\n    }\n\n    public getSummary(): {\n        total: number;\n        passed: number;\n        failed: number;\n        skipped: number;\n        duration: number;\n    } {\n        const results = this.results;\n        const total = results.length;\n        const passed = results.filter(r => r.status === 'passed').length;\n        const failed = results.filter(r => r.status === 'failed').length;\n        const skipped = results.filter(r => r.status === 'skipped').length;\n        const duration = results.reduce((sum, r) => sum + r.duration, 0);\n\n        return { total, passed, failed, skipped, duration };\n    }\n\n    public clearResults(): void {\n        this.results = [];\n        this.currentTest = null;\n        this.haveFailedTests = false;\n    }\n}\n\nconst resultCollector = new TestResultCollector();\n\n/**\n * Defines a test case.\n *\n * @param name The name of the test case.\n * @param testFn The function containing the test logic and assertions.\n */\nexport function test(name: string, testFn: () => void) {\n    resultCollector.recordTestStart(name);\n    if (resultCollector.hasFailedTests()) {\n        resultCollector.recordTestComplete('skipped');\n        console.log(`- Skipping test \"${name}\" due to previous failures`);\n    } else {\n        try {\n            testFn();\n            resultCollector.recordTestComplete('passed');\n        } catch (error: any) {\n            resultCollector.recordTestComplete('failed', {\n                message: error?.message || String(error),\n                stackTrace: error?.stack,\n            });\n        }\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are equal.\n *\n * @template T The type of the values being compared.\n * @param expected The expected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertEquals<T>(expected: T, actual: T): void\nexport function assertEquals<T>(message: string, expected: T, actual: T): void\nexport function assertEquals<T>(messageOrExpected?: string | T, expectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assertions.assertEquals(messageOrExpected, expectedOrActual, actualOrUndefined);\n    } else {\n        Assertions.assertEquals(messageOrExpected, expectedOrActual);\n    }\n}\n\n/**\n * Asserts that two objects or primitive values are not equal.\n *\n * @template T The type of the values being compared.\n * @param unexpected The unexpected value.\n * @param actual The actual value.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertNotEquals<T>(unexpected: T, actual: T): void\nexport function assertNotEquals<T>(message: string, unexpected: T, actual: T): void\nexport function assertNotEquals<T>(messageOrUnexpected?: string | T, unexpectedOrActual?: T, actualOrUndefined?: T): void {\n    if (arguments.length === 3) {\n        Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual, actualOrUndefined);\n    } else {\n        Assertions.assertNotEquals(messageOrUnexpected, unexpectedOrActual);\n    }\n}\n\n/**\n * Asserts that a condition is true.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertTrue(condition: boolean): void\nexport function assertTrue(message: string, condition: boolean): void\nexport function assertTrue(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assertions.assertTrue(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assertions.assertTrue(messageOrCondition);\n    }\n}\n\n/**\n * Asserts that a condition is false.\n *\n * @param condition The condition to test.\n * @param message Optional message to display if the assertion fails.\n */\nexport function assertFalse(condition: boolean): void\nexport function assertFalse(message: string, condition: boolean): void\nexport function assertFalse(messageOrCondition?: string | boolean, conditionOrUndefined?: boolean): void {\n    if (arguments.length === 2) {\n        Assertions.assertFalse(messageOrCondition, conditionOrUndefined);\n    } else {\n        Assertions.assertFalse(messageOrCondition);\n    }\n}\n\n/**\n * Fails a test immediately.\n *\n * @param message Optional message to display indicating the reason for the failure.\n */\nexport function fail(): void\nexport function fail(message: string): void\nexport function fail(message?: string): void {\n    if (message) {\n        Assertions.fail(message);\n    } else {\n        Assertions.fail();\n    }\n}\n\n/**\n * Retrieves all test results collected during this session.\n *\n * @returns An array of test results.\n */\nexport function getResults(): Array<{\n    name: string;\n    status: 'passed' | 'failed' | 'skipped';\n    duration: number;\n    error?: string;\n    stackTrace?: string;\n    timestamp: number;\n}> {\n    return resultCollector.getResults();\n}\n\n/**\n * Retrieves a summary of test execution.\n *\n * @returns An object containing counts and total duration.\n */\nexport function getResultsSummary(): {\n    total: number;\n    passed: number;\n    failed: number;\n    skipped: number;\n    duration: number;\n} {\n    return resultCollector.getSummary();\n}\n\n/**\n * Clears all collected test results.\n */\nexport function clearResults(): void {\n    resultCollector.clearResults();\n}\n\n/**\n * Clears all collected test results.\n */\nexport function storeResults(): void {\n    resultCollector.storeResults();\n}"],
  "mappings": "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",
  "names": []
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aerokit/sdk",
3
- "version": "12.82.0",
3
+ "version": "12.85.0",
4
4
  "description": "Unified TypeScript SDK for modern cloud platforms.",
5
5
  "scripts": {
6
6
  "clean": "rm -rf dist",