xunit.ts 0.13.1 → 1.0.3

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 (175) hide show
  1. package/.editorconfig +26 -0
  2. package/.eslintrc.json +37 -0
  3. package/README.md +2 -1
  4. package/SECURITY.md +11 -0
  5. package/cli.ts +6 -5
  6. package/dist/cli.js +2 -1
  7. package/dist/cli.js.map +1 -1
  8. package/dist/src/Assertions/Contains.js +1 -1
  9. package/dist/src/Assertions/Contains.js.map +1 -1
  10. package/dist/src/Assertions/Count.js.map +1 -1
  11. package/dist/src/Assertions/Defined.js +2 -2
  12. package/dist/src/Assertions/Defined.js.map +1 -1
  13. package/dist/src/Assertions/DoesNotContain.js +1 -1
  14. package/dist/src/Assertions/DoesNotContain.js.map +1 -1
  15. package/dist/src/Assertions/DoesNotThrow.js +2 -2
  16. package/dist/src/Assertions/DoesNotThrow.js.map +1 -1
  17. package/dist/src/Assertions/Empty.js +1 -1
  18. package/dist/src/Assertions/Empty.js.map +1 -1
  19. package/dist/src/Assertions/Equal.js +2 -2
  20. package/dist/src/Assertions/Equal.js.map +1 -1
  21. package/dist/src/Assertions/False.js +1 -1
  22. package/dist/src/Assertions/False.js.map +1 -1
  23. package/dist/src/Assertions/InstanceOf.d.ts +1 -1
  24. package/dist/src/Assertions/InstanceOf.d.ts.map +1 -1
  25. package/dist/src/Assertions/InstanceOf.js +1 -1
  26. package/dist/src/Assertions/InstanceOf.js.map +1 -1
  27. package/dist/src/Assertions/NotEmpty.js +2 -2
  28. package/dist/src/Assertions/NotEmpty.js.map +1 -1
  29. package/dist/src/Assertions/NotEqual.js +2 -2
  30. package/dist/src/Assertions/NotEqual.js.map +1 -1
  31. package/dist/src/Assertions/NotNull.js +2 -2
  32. package/dist/src/Assertions/NotNull.js.map +1 -1
  33. package/dist/src/Assertions/Null.js +1 -1
  34. package/dist/src/Assertions/Null.js.map +1 -1
  35. package/dist/src/Assertions/StringContains.d.ts.map +1 -1
  36. package/dist/src/Assertions/StringContains.js +2 -2
  37. package/dist/src/Assertions/StringContains.js.map +1 -1
  38. package/dist/src/Assertions/StringDoesNotContain.d.ts.map +1 -1
  39. package/dist/src/Assertions/StringDoesNotContain.js +1 -1
  40. package/dist/src/Assertions/StringDoesNotContain.js.map +1 -1
  41. package/dist/src/Assertions/StringDoesNotEndWith.d.ts.map +1 -1
  42. package/dist/src/Assertions/StringDoesNotEndWith.js +4 -2
  43. package/dist/src/Assertions/StringDoesNotEndWith.js.map +1 -1
  44. package/dist/src/Assertions/StringDoesNotStartWith.d.ts.map +1 -1
  45. package/dist/src/Assertions/StringDoesNotStartWith.js +1 -1
  46. package/dist/src/Assertions/StringDoesNotStartWith.js.map +1 -1
  47. package/dist/src/Assertions/StringEndsWith.d.ts.map +1 -1
  48. package/dist/src/Assertions/StringEndsWith.js +4 -2
  49. package/dist/src/Assertions/StringEndsWith.js.map +1 -1
  50. package/dist/src/Assertions/StringStartsWith.d.ts.map +1 -1
  51. package/dist/src/Assertions/StringStartsWith.js +1 -1
  52. package/dist/src/Assertions/StringStartsWith.js.map +1 -1
  53. package/dist/src/Assertions/Throws.js +1 -1
  54. package/dist/src/Assertions/Throws.js.map +1 -1
  55. package/dist/src/Assertions/True.js +1 -1
  56. package/dist/src/Assertions/True.js.map +1 -1
  57. package/dist/src/Assertions/Undefined.js +1 -1
  58. package/dist/src/Assertions/Undefined.js.map +1 -1
  59. package/dist/src/Assertions/index.d.ts +22 -22
  60. package/dist/src/Assertions/index.d.ts.map +1 -1
  61. package/dist/src/Assertions/index.js.map +1 -1
  62. package/dist/src/CLI.d.ts +4 -1
  63. package/dist/src/CLI.d.ts.map +1 -1
  64. package/dist/src/CLI.js +10 -8
  65. package/dist/src/CLI.js.map +1 -1
  66. package/dist/src/Factory.d.ts +5 -4
  67. package/dist/src/Factory.d.ts.map +1 -1
  68. package/dist/src/Factory.js +4 -4
  69. package/dist/src/Factory.js.map +1 -1
  70. package/dist/src/Framework/ResultType.d.ts.map +1 -1
  71. package/dist/src/Framework/ResultType.js.map +1 -1
  72. package/dist/src/Framework/Test.d.ts.map +1 -1
  73. package/dist/src/Framework/Test.js.map +1 -1
  74. package/dist/src/Framework/TestName.d.ts.map +1 -1
  75. package/dist/src/Framework/TestName.js.map +1 -1
  76. package/dist/src/Framework/TestResult.d.ts.map +1 -1
  77. package/dist/src/Framework/TestResult.js.map +1 -1
  78. package/dist/src/Framework/TestSuite.d.ts +1 -1
  79. package/dist/src/Framework/TestSuite.d.ts.map +1 -1
  80. package/dist/src/Framework/TestSuite.js.map +1 -1
  81. package/dist/src/Framework/TestSuiteResults.d.ts +1 -1
  82. package/dist/src/Framework/TestSuiteResults.d.ts.map +1 -1
  83. package/dist/src/Framework/TestSuiteResults.js.map +1 -1
  84. package/dist/src/IO/FileSystem.d.ts +2 -2
  85. package/dist/src/IO/FileSystem.d.ts.map +1 -1
  86. package/dist/src/IO/FileSystem.js +6 -6
  87. package/dist/src/IO/FileSystem.js.map +1 -1
  88. package/dist/src/IO/Output.d.ts.map +1 -1
  89. package/dist/src/IO/Output.js.map +1 -1
  90. package/dist/src/Reporters/ConsoleReporter.d.ts.map +1 -1
  91. package/dist/src/Reporters/ConsoleReporter.js +8 -7
  92. package/dist/src/Reporters/ConsoleReporter.js.map +1 -1
  93. package/dist/src/Reporters/FileReporter.d.ts.map +1 -1
  94. package/dist/src/Reporters/FileReporter.js +1 -0
  95. package/dist/src/Reporters/FileReporter.js.map +1 -1
  96. package/dist/src/Reporters/JUnitReporter.d.ts +2 -2
  97. package/dist/src/Reporters/JUnitReporter.d.ts.map +1 -1
  98. package/dist/src/Reporters/JUnitReporter.js +7 -7
  99. package/dist/src/Reporters/JUnitReporter.js.map +1 -1
  100. package/dist/src/Reporters/ResultReporter.d.ts +3 -3
  101. package/dist/src/Reporters/ResultReporter.d.ts.map +1 -1
  102. package/dist/src/Reporters/SonarReporter.d.ts +2 -2
  103. package/dist/src/Reporters/SonarReporter.d.ts.map +1 -1
  104. package/dist/src/Reporters/SonarReporter.js +16 -16
  105. package/dist/src/Reporters/SonarReporter.js.map +1 -1
  106. package/dist/src/Reporters/XMLReporter.d.ts.map +1 -1
  107. package/dist/src/Reporters/XMLReporter.js.map +1 -1
  108. package/dist/src/Runners/Runner.d.ts +3 -3
  109. package/dist/src/Runners/Runner.d.ts.map +1 -1
  110. package/dist/src/Runners/Runner.js +5 -5
  111. package/dist/src/Runners/Runner.js.map +1 -1
  112. package/dist/src/Runners/TestRunner.d.ts +4 -4
  113. package/dist/src/Runners/TestRunner.d.ts.map +1 -1
  114. package/dist/src/Runners/TestRunner.js +10 -9
  115. package/dist/src/Runners/TestRunner.js.map +1 -1
  116. package/dist/src/Runners/TestSuiteLoader.d.ts +3 -3
  117. package/dist/src/Runners/TestSuiteLoader.d.ts.map +1 -1
  118. package/dist/src/Runners/TestSuiteLoader.js +15 -15
  119. package/dist/src/Runners/TestSuiteLoader.js.map +1 -1
  120. package/dist/src/Runners/TestSuiteRunner.d.ts +5 -5
  121. package/dist/src/Runners/TestSuiteRunner.d.ts.map +1 -1
  122. package/dist/src/Runners/TestSuiteRunner.js +1 -1
  123. package/dist/src/Runners/TestSuiteRunner.js.map +1 -1
  124. package/dist/xunit.d.ts +3 -3
  125. package/dist/xunit.d.ts.map +1 -1
  126. package/dist/xunit.js.map +1 -1
  127. package/icon.svg +82 -0
  128. package/logo.svg +154 -0
  129. package/package.json +43 -35
  130. package/sonar-project.properties +1 -1
  131. package/src/Assertions/Contains.ts +10 -10
  132. package/src/Assertions/Count.ts +11 -11
  133. package/src/Assertions/Defined.ts +11 -11
  134. package/src/Assertions/DoesNotContain.ts +11 -11
  135. package/src/Assertions/DoesNotThrow.ts +13 -13
  136. package/src/Assertions/Empty.ts +11 -11
  137. package/src/Assertions/Equal.ts +12 -12
  138. package/src/Assertions/False.ts +11 -11
  139. package/src/Assertions/InstanceOf.ts +13 -13
  140. package/src/Assertions/NotEmpty.ts +11 -11
  141. package/src/Assertions/NotEqual.ts +12 -12
  142. package/src/Assertions/NotNull.ts +11 -11
  143. package/src/Assertions/Null.ts +11 -11
  144. package/src/Assertions/StringContains.ts +12 -12
  145. package/src/Assertions/StringDoesNotContain.ts +12 -12
  146. package/src/Assertions/StringDoesNotEndWith.ts +14 -12
  147. package/src/Assertions/StringDoesNotStartWith.ts +12 -12
  148. package/src/Assertions/StringEndsWith.ts +14 -12
  149. package/src/Assertions/StringStartsWith.ts +12 -12
  150. package/src/Assertions/Throws.ts +11 -11
  151. package/src/Assertions/True.ts +11 -11
  152. package/src/Assertions/Undefined.ts +12 -12
  153. package/src/Assertions/index.ts +45 -45
  154. package/src/CLI.ts +85 -84
  155. package/src/Factory.ts +25 -25
  156. package/src/Framework/ResultType.ts +4 -4
  157. package/src/Framework/Test.ts +6 -6
  158. package/src/Framework/TestName.ts +7 -7
  159. package/src/Framework/TestResult.ts +3 -2
  160. package/src/Framework/TestSuite.ts +18 -18
  161. package/src/Framework/TestSuiteResults.ts +17 -16
  162. package/src/IO/FileSystem.ts +28 -29
  163. package/src/IO/Output.ts +21 -20
  164. package/src/Reporters/ConsoleReporter.ts +88 -87
  165. package/src/Reporters/FileReporter.ts +29 -29
  166. package/src/Reporters/JUnitReporter.ts +80 -80
  167. package/src/Reporters/ResultReporter.ts +20 -12
  168. package/src/Reporters/SonarReporter.ts +86 -86
  169. package/src/Reporters/XMLReporter.ts +6 -6
  170. package/src/Runners/Runner.ts +21 -21
  171. package/src/Runners/TestRunner.ts +34 -32
  172. package/src/Runners/TestSuiteLoader.ts +41 -40
  173. package/src/Runners/TestSuiteRunner.ts +27 -26
  174. package/tsconfig.json +26 -24
  175. package/xunit.ts +6 -6
package/package.json CHANGED
@@ -1,36 +1,44 @@
1
1
  {
2
- "name": "xunit.ts",
3
- "version": "0.13.1",
4
- "description": "A unit testing framework for TypeScript, following standard xUnit patterns",
5
- "main": "dist/xunit.js",
6
- "author": "ecoAPM LLC",
7
- "license": "MIT",
8
- "dependencies": {
9
- "colors": "1.4.0",
10
- "command-line-args": "5.2.0",
11
- "command-line-usage": "6.1.1",
12
- "lodash.isequal": "4.5.0",
13
- "typescript": "4.3.5",
14
- "xml": "1.0.1"
15
- },
16
- "devDependencies": {
17
- "@microsoft/tsdoc": "0.13.2",
18
- "@types/command-line-args": "5.2.0",
19
- "@types/command-line-usage": "5.0.2",
20
- "@types/lodash.isequal": "4.5.5",
21
- "@types/node": "16.6.0",
22
- "@types/xml": "1.0.6",
23
- "notosans": "4.0.1",
24
- "ts-mockito": "2.6.1",
25
- "ts-node": "10.2.0"
26
- },
27
- "scripts": {
28
- "clean": "rm -rf dist",
29
- "build": "tsc",
30
- "test": "node dist/cli.js dist/tests",
31
- "tsdoc": "cp -r node_modules/notosans/noto.css node_modules/notosans/dist docs/assets && ts-node tsdoc.ts"
32
- },
33
- "bin": {
34
- "xunit": "dist/cli.js"
35
- }
36
- }
2
+ "name": "xunit.ts",
3
+ "version": "1.0.3",
4
+ "description": "A unit testing framework for TypeScript, following standard xUnit patterns",
5
+ "main": "dist/xunit.js",
6
+ "author": "ecoAPM LLC",
7
+ "homepage": "https://github.com/ecoAPM/xunit.ts",
8
+ "bugs": "https://github.com/ecoAPM/xunit.ts/issues",
9
+ "license": "MIT",
10
+ "dependencies": {
11
+ "colors": "1.4.0",
12
+ "command-line-args": "5.2.0",
13
+ "command-line-usage": "6.1.1",
14
+ "lodash.isequal": "4.5.0",
15
+ "xml": "1.0.1"
16
+ },
17
+ "devDependencies": {
18
+ "@microsoft/tsdoc": "0.13.2",
19
+ "@types/command-line-args": "5.2.0",
20
+ "@types/command-line-usage": "5.0.2",
21
+ "@types/lodash.isequal": "4.5.5",
22
+ "@types/node": "17.0.4",
23
+ "@types/xml": "1.0.7",
24
+ "@typescript-eslint/eslint-plugin": "5.8.0",
25
+ "@typescript-eslint/parser": "5.8.0",
26
+ "eslint": "8.5.0",
27
+ "notosans": "5.0.0",
28
+ "ts-mockito": "2.6.1",
29
+ "ts-node": "10.4.0",
30
+ "typescript": "4.5.4"
31
+ },
32
+ "peerDependencies": {
33
+ "typescript": "^4.0.0"
34
+ },
35
+ "scripts": {
36
+ "clean": "rm -rf dist",
37
+ "build": "tsc",
38
+ "test": "node dist/cli.js dist/tests",
39
+ "tsdoc": "cp -r node_modules/notosans/* docs/assets && ts-node tsdoc.ts"
40
+ },
41
+ "bin": {
42
+ "xunit": "dist/cli.js"
43
+ }
44
+ }
@@ -1,6 +1,6 @@
1
1
  sonar.organization=ecoapm
2
2
  sonar.projectKey=ecoAPM_xunit.ts
3
- sonar.sources=src
3
+ sonar.sources=src,TSDoc
4
4
  sonar.tests=tests
5
5
  sonar.testExecutionReportPaths=sonar.xml
6
6
  sonar.javascript.lcov.reportPaths=coverage/lcov.info
@@ -2,10 +2,10 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an array contains a given element
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if array `haystack` contains an element with a value of `needle`
8
- *
8
+ *
9
9
  * Fails if array `haystack` does not contain an element with a value of `needle`
10
10
  *
11
11
  * @param needle the element to find
@@ -16,13 +16,13 @@ import { AssertionError } from "assert";
16
16
  * this.assert.contains(needle, haystack);
17
17
  */
18
18
  export default function Contains<T>(needle: T, haystack: ReadonlyArray<T>, message?: string) {
19
- if(haystack.includes(needle)) {
20
- return;
21
- }
19
+ if (haystack.includes(needle)) {
20
+ return;
21
+ }
22
22
 
23
- throw new AssertionError({
24
- message: message || 'Expected array containing expression, but array did not contain expression',
25
- expected: needle,
26
- actual: haystack
27
- });
23
+ throw new AssertionError({
24
+ message: message || "Expected array containing expression, but array did not contain expression",
25
+ expected: needle,
26
+ actual: haystack
27
+ });
28
28
  }
@@ -2,27 +2,27 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an array contains a certain number of elements
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `array` contains `expected` number of elements
8
- *
8
+ *
9
9
  * Fails if `array` does not contain `expected` number of elements
10
10
  *
11
11
  * @param expected the number of array elements expected
12
12
  * @param array the array to check the length of
13
13
  * @param message (optional) message to display on failure
14
- *
14
+ *
15
15
  * @example
16
16
  * this.assert.count(expected, array);
17
17
  */
18
18
  export default function Count(expected: number, array: ReadonlyArray<any>, message?: string) {
19
- if(array.length === expected) {
20
- return;
21
- }
19
+ if (array.length === expected) {
20
+ return;
21
+ }
22
22
 
23
- throw new AssertionError({
24
- message: message || `Expected array with ${expected} elements, but array had ${array.length} elements`,
25
- expected: expected,
26
- actual: array.length
27
- });
23
+ throw new AssertionError({
24
+ message: message || `Expected array with ${expected} elements, but array had ${array.length} elements`,
25
+ expected: expected,
26
+ actual: array.length
27
+ });
28
28
  }
@@ -2,26 +2,26 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a value is defined (any value other than `undefined`)
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `expression` does not evaluate to `undefined`
8
- *
8
+ *
9
9
  * Fails if `expression` evaluates to `undefined`
10
10
  *
11
11
  * @param expression the value to check
12
12
  * @param message (optional) message to display on failure
13
- *
13
+ *
14
14
  * @example
15
15
  * this.assert.defined(expression);
16
16
  */
17
17
  export default function Defined(expression: any, message?: string) {
18
- if(expression !== undefined) {
19
- return;
20
- }
18
+ if (expression !== undefined) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be defined, but expression is undefined',
24
- expected: '(not undefined expression)',
25
- actual: expression
26
- });
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be defined, but expression is undefined",
24
+ expected: "(not undefined expression)",
25
+ actual: expression
26
+ });
27
27
  }
@@ -2,27 +2,27 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an array does not contain a given element
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if array `haystack` does not contain an element with a value of `needle`
8
- *
8
+ *
9
9
  * Fails if array `haystack` contains an element with a value of `needle`
10
10
  *
11
11
  * @param needle the element to find
12
12
  * @param haystack the array to search
13
13
  * @param message (optional) message to display on failure
14
- *
14
+ *
15
15
  * @example
16
16
  * this.assert.doesNotContain(needle, haystack);
17
17
  */
18
18
  export default function DoesNotContain<T>(needle: T, haystack: ReadonlyArray<T>, message?: string) {
19
- if(!haystack.includes(needle)) {
20
- return;
21
- }
19
+ if (!haystack.includes(needle)) {
20
+ return;
21
+ }
22
22
 
23
- throw new AssertionError({
24
- message: message || 'Expected array not containing expression, but array contained expression',
25
- expected: needle,
26
- actual: haystack
27
- });
23
+ throw new AssertionError({
24
+ message: message || "Expected array not containing expression, but array contained expression",
25
+ expected: needle,
26
+ actual: haystack
27
+ });
28
28
  }
@@ -2,27 +2,27 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an expression does not throw an error/exception
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if calling `expression` does not throw an error/exception
8
- *
8
+ *
9
9
  * Fails if calling `expression` throws an error/exception
10
10
  *
11
11
  * @param expression the expression to run
12
12
  * @param message (optional) message to display on failure
13
- *
13
+ *
14
14
  * @example
15
15
  * this.assert.doesNotThrow(() => expression);
16
16
  */
17
17
  export default function DoesNotThrow(expression: () => any, message?: string) {
18
- try {
19
- expression();
20
- return;
21
- } catch (exception) {
22
- throw new AssertionError({
23
- message: message || 'Expected expression to not throw exception, but expression did throw exception',
24
- expected: '(no exception)',
25
- actual: exception
26
- });
27
- }
18
+ try {
19
+ expression();
20
+ return;
21
+ } catch (exception) {
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to not throw exception, but expression did throw exception",
24
+ expected: "(no exception)",
25
+ actual: exception
26
+ });
27
+ }
28
28
  }
@@ -2,26 +2,26 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an array is empty
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `array` contains zero elements
8
- *
8
+ *
9
9
  * Fails if `array` contains any elements
10
10
  *
11
11
  * @param array the array to check
12
12
  * @param message (optional) message to display on failure
13
- *
13
+ *
14
14
  * @example
15
15
  * this.assert.empty(array);
16
16
  */
17
17
  export default function Empty(array: ReadonlyArray<any>, message?: string) {
18
- if(array.length === 0) {
19
- return;
20
- }
18
+ if (array.length === 0) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be empty, but expression was not empty',
24
- expected: [],
25
- actual: array
26
- })
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be empty, but expression was not empty",
24
+ expected: [],
25
+ actual: array
26
+ });
27
27
  }
@@ -1,14 +1,14 @@
1
1
  import { AssertionError } from "assert";
2
- import equal from 'lodash.isequal';
2
+ import equal from "lodash.isequal";
3
3
 
4
4
  /**
5
5
  * Asserts that two values are equal
6
- *
6
+ *
7
7
  * @remarks
8
8
  * Passes if `actual` and `expected` evaluate to equal values
9
- *
9
+ *
10
10
  * Fails if `actual` and `expected` do not evaluate to equal values
11
- *
11
+ *
12
12
  * @param expected the expected value
13
13
  * @param actual the actual value
14
14
  * @param message (optional) message to display on failure
@@ -17,13 +17,13 @@ import equal from 'lodash.isequal';
17
17
  * this.assert.equal(expected, actual);
18
18
  */
19
19
  export default function Equal(expected: any, actual: any, message?: string) {
20
- if(equal(actual, expected)) {
21
- return;
22
- }
20
+ if (equal(actual, expected)) {
21
+ return;
22
+ }
23
23
 
24
- throw new AssertionError({
25
- message: message || 'Expected expressions to be equal, but expressions are not equal',
26
- expected: expected,
27
- actual: actual,
28
- });
24
+ throw new AssertionError({
25
+ message: message || "Expected expressions to be equal, but expressions are not equal",
26
+ expected: expected,
27
+ actual: actual,
28
+ });
29
29
  }
@@ -2,12 +2,12 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a given value is equal to `false`
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `expression` evaluates to `false`
8
- *
8
+ *
9
9
  * Fails if `expression` does not evaluate to `false`
10
- *
10
+ *
11
11
  * @param expression the value to check
12
12
  * @param message (optional) message to display on failure
13
13
  *
@@ -15,13 +15,13 @@ import { AssertionError } from "assert";
15
15
  * this.assert.false(expression);
16
16
  */
17
17
  export default function False(expression: any, message?: string) {
18
- if(expression === false) {
19
- return;
20
- }
18
+ if (expression === false) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be false, but expression is not false',
24
- expected: false,
25
- actual: expression
26
- });
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be false, but expression is not false",
24
+ expected: false,
25
+ actual: expression
26
+ });
27
27
  }
@@ -2,27 +2,27 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a value is an instance of a certain type
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `object`'s type matches `type`
8
- *
9
- * Fails if `object`'s type does not match `type`
8
+ *
9
+ * Fails if `object`'s type does not match `type`
10
10
  *
11
11
  * @param type the expected type of the value
12
12
  * @param expression the value to check
13
13
  * @param message (optional) message to display on failure
14
- *
14
+ *
15
15
  * @example
16
16
  * this.assert.instanceOf(type, object);
17
17
  */
18
- export default function InstanceOf<T>(type: any, expression: any, message?: string) {
19
- if (expression instanceof type) {
20
- return;
21
- }
18
+ export default function InstanceOf(type: any, expression: any, message?: string) {
19
+ if (expression instanceof type) {
20
+ return;
21
+ }
22
22
 
23
- throw new AssertionError({
24
- message: message || `Expected expression of type, but was ${typeof expression}`,
25
- expected: type,
26
- actual: typeof expression
27
- })
23
+ throw new AssertionError({
24
+ message: message || `Expected expression of type, but was ${typeof expression}`,
25
+ expected: type.name,
26
+ actual: typeof expression
27
+ });
28
28
  }
@@ -2,26 +2,26 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that an array is not empty
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `array` contains any elements
8
- *
8
+ *
9
9
  * Fails if `array` contains zero elements
10
10
  *
11
11
  * @param array the array to check
12
12
  * @param message (optional) message to display on failure
13
- *
13
+ *
14
14
  * @example
15
15
  * this.assert.notEmpty(array);
16
16
  */
17
17
  export default function NotEmpty(array: ReadonlyArray<any>, message?: string) {
18
- if(array.length > 0) {
19
- return;
20
- }
18
+ if (array.length > 0) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be not empty, but expression was empty',
24
- expected: '(non-empty expression)',
25
- actual: array
26
- })
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be not empty, but expression was empty",
24
+ expected: "(non-empty expression)",
25
+ actual: array
26
+ });
27
27
  }
@@ -1,14 +1,14 @@
1
1
  import { AssertionError } from "assert";
2
- import equal from 'lodash.isequal';
2
+ import equal from "lodash.isequal";
3
3
 
4
4
  /**
5
5
  * Asserts that two values are not equal
6
- *
6
+ *
7
7
  * @remarks
8
8
  * Passes if `actual` and `expected` do not evaluate to equal values
9
- *
9
+ *
10
10
  * Fails if `actual` and `expected` evaluate to equal values
11
- *
11
+ *
12
12
  * @param expected the expected value
13
13
  * @param actual the actual value
14
14
  * @param message (optional) message to display on failure
@@ -17,13 +17,13 @@ import equal from 'lodash.isequal';
17
17
  * this.assert.notEqual(expected, actual);
18
18
  */
19
19
  export default function NotEqual(expected: any, actual: any, message?: string) {
20
- if(!equal(actual, expected)) {
21
- return;
22
- }
20
+ if (!equal(actual, expected)) {
21
+ return;
22
+ }
23
23
 
24
- throw new AssertionError({
25
- message: message || 'Expected expressions to be not equal, but expressions are equal',
26
- expected: expected,
27
- actual: actual,
28
- });
24
+ throw new AssertionError({
25
+ message: message || "Expected expressions to be not equal, but expressions are equal",
26
+ expected: expected,
27
+ actual: actual,
28
+ });
29
29
  }
@@ -2,12 +2,12 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a value is not `null`
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `expression` does not evaluate to `null`
8
- *
8
+ *
9
9
  * Fails if `expression` evaluates to `null`
10
- *
10
+ *
11
11
  * @param expression the value to check
12
12
  * @param message (optional) message to display on failure
13
13
  *
@@ -15,13 +15,13 @@ import { AssertionError } from "assert";
15
15
  * this.assert.notNull(expression);
16
16
  */
17
17
  export default function NotNull(expression: any, message?: string) {
18
- if(expression !== null) {
19
- return;
20
- }
18
+ if (expression !== null) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be not null, but expression is null',
24
- expected: '(non-null expression)',
25
- actual: expression
26
- });
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be not null, but expression is null",
24
+ expected: "(non-null expression)",
25
+ actual: expression
26
+ });
27
27
  }
@@ -2,12 +2,12 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a value is `null`
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `expression` evaluates to `null`
8
- *
8
+ *
9
9
  * Fails if `expression` does not evaluate to `null`
10
- *
10
+ *
11
11
  * @param expression the value to check
12
12
  * @param message (optional) message to display on failure
13
13
  *
@@ -15,13 +15,13 @@ import { AssertionError } from "assert";
15
15
  * this.assert.null(expression);
16
16
  */
17
17
  export default function Null(expression: any, message?: string) {
18
- if(expression === null) {
19
- return;
20
- }
18
+ if (expression === null) {
19
+ return;
20
+ }
21
21
 
22
- throw new AssertionError({
23
- message: message || 'Expected expression to be null, but expression is not null',
24
- expected: null,
25
- actual: expression
26
- });
22
+ throw new AssertionError({
23
+ message: message || "Expected expression to be null, but expression is not null",
24
+ expected: null,
25
+ actual: expression
26
+ });
27
27
  }
@@ -2,27 +2,27 @@ import { AssertionError } from "assert";
2
2
 
3
3
  /**
4
4
  * Asserts that a string contains a given substring
5
- *
5
+ *
6
6
  * @remarks
7
7
  * Passes if `needle` is a substring of `haystack`
8
- *
8
+ *
9
9
  * Fails if `needle` is not a substring of `haystack`
10
10
  *
11
11
  * @param needle the substring to find
12
12
  * @param haystack the string to search
13
13
  * @param message (optional) message to display on failure
14
- *
14
+ *
15
15
  * @example
16
16
  * this.assert.stringContains(needle, haystack);
17
17
  */
18
- export default function StringContains(needle: string, haystack: string|null, message?: string) {
19
- if(haystack !== undefined && haystack !== null && haystack.indexOf(needle) !== -1) {
20
- return;
21
- }
18
+ export default function StringContains(needle: string, haystack: string | null, message?: string) {
19
+ if (haystack !== undefined && haystack !== null && haystack.indexOf(needle) > -1) {
20
+ return;
21
+ }
22
22
 
23
- throw new AssertionError({
24
- message: message || 'Expected string containing expression, but string did not contain expression',
25
- expected: needle,
26
- actual: haystack
27
- });
23
+ throw new AssertionError({
24
+ message: message || "Expected string containing expression, but string did not contain expression",
25
+ expected: needle,
26
+ actual: haystack
27
+ });
28
28
  }