@fncts/test 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/TestSpec.d.ts +4 -0
- package/_cjs/api.cjs +91 -0
- package/_cjs/api.cjs.map +1 -0
- package/_cjs/control/AbstractRunnableSpec.cjs +30 -0
- package/_cjs/control/AbstractRunnableSpec.cjs.map +1 -0
- package/_cjs/control/Annotations/api.cjs +50 -0
- package/_cjs/control/Annotations/api.cjs.map +1 -0
- package/_cjs/control/Annotations/definition.cjs +27 -0
- package/_cjs/control/Annotations/definition.cjs.map +1 -0
- package/_cjs/control/Annotations/live.cjs +68 -0
- package/_cjs/control/Annotations/live.cjs.map +1 -0
- package/_cjs/control/Annotations.cjs +45 -0
- package/_cjs/control/Annotations.cjs.map +1 -0
- package/_cjs/control/Assertion/api.cjs +256 -0
- package/_cjs/control/Assertion/api.cjs.map +1 -0
- package/_cjs/control/Assertion/definition.cjs +32 -0
- package/_cjs/control/Assertion/definition.cjs.map +1 -0
- package/_cjs/control/Assertion.cjs +32 -0
- package/_cjs/control/Assertion.cjs.map +1 -0
- package/_cjs/control/AssertionIO/api.cjs +46 -0
- package/_cjs/control/AssertionIO/api.cjs.map +1 -0
- package/_cjs/control/AssertionIO/definition.cjs +37 -0
- package/_cjs/control/AssertionIO/definition.cjs.map +1 -0
- package/_cjs/control/AssertionIO.cjs +32 -0
- package/_cjs/control/AssertionIO.cjs.map +1 -0
- package/_cjs/control/DefaultRunnableSpec.cjs +30 -0
- package/_cjs/control/DefaultRunnableSpec.cjs.map +1 -0
- package/_cjs/control/DefaultTestReporter/definition.cjs +9 -0
- package/_cjs/control/DefaultTestReporter/definition.cjs.map +1 -0
- package/_cjs/control/DefaultTestReporter/render.cjs +288 -0
- package/_cjs/control/DefaultTestReporter/render.cjs.map +1 -0
- package/_cjs/control/DefaultTestReporter.cjs +32 -0
- package/_cjs/control/DefaultTestReporter.cjs.map +1 -0
- package/_cjs/control/FreeBooleanAlgebraIO/api.cjs +89 -0
- package/_cjs/control/FreeBooleanAlgebraIO/api.cjs.map +1 -0
- package/_cjs/control/FreeBooleanAlgebraIO/definition.cjs +9 -0
- package/_cjs/control/FreeBooleanAlgebraIO/definition.cjs.map +1 -0
- package/_cjs/control/FreeBooleanAlgebraIO.cjs +32 -0
- package/_cjs/control/FreeBooleanAlgebraIO.cjs.map +1 -0
- package/_cjs/control/Gen/api/array.cjs +50 -0
- package/_cjs/control/Gen/api/array.cjs.map +1 -0
- package/_cjs/control/Gen/api/char.cjs +129 -0
- package/_cjs/control/Gen/api/char.cjs.map +1 -0
- package/_cjs/control/Gen/api/conc.cjs +70 -0
- package/_cjs/control/Gen/api/conc.cjs.map +1 -0
- package/_cjs/control/Gen/api/double.cjs +82 -0
- package/_cjs/control/Gen/api/double.cjs.map +1 -0
- package/_cjs/control/Gen/api/float.cjs +55 -0
- package/_cjs/control/Gen/api/float.cjs.map +1 -0
- package/_cjs/control/Gen/api/string.cjs +102 -0
- package/_cjs/control/Gen/api/string.cjs.map +1 -0
- package/_cjs/control/Gen/api/struct.cjs +36 -0
- package/_cjs/control/Gen/api/struct.cjs.map +1 -0
- package/_cjs/control/Gen/api.cjs +369 -0
- package/_cjs/control/Gen/api.cjs.map +1 -0
- package/_cjs/control/Gen/constraints.cjs +6 -0
- package/_cjs/control/Gen/constraints.cjs.map +1 -0
- package/_cjs/control/Gen/definition.cjs +20 -0
- package/_cjs/control/Gen/definition.cjs.map +1 -0
- package/_cjs/control/Gen.cjs +136 -0
- package/_cjs/control/Gen.cjs.map +1 -0
- package/_cjs/control/Live/definition.cjs +67 -0
- package/_cjs/control/Live/definition.cjs.map +1 -0
- package/_cjs/control/Live.cjs +19 -0
- package/_cjs/control/Live.cjs.map +1 -0
- package/_cjs/control/RunnableSpec.cjs +70 -0
- package/_cjs/control/RunnableSpec.cjs.map +1 -0
- package/_cjs/control/Sample/api.cjs +244 -0
- package/_cjs/control/Sample/api.cjs.map +1 -0
- package/_cjs/control/Sample/definition.cjs +21 -0
- package/_cjs/control/Sample/definition.cjs.map +1 -0
- package/_cjs/control/Sample.cjs +32 -0
- package/_cjs/control/Sample.cjs.map +1 -0
- package/_cjs/control/Sized/api.cjs +32 -0
- package/_cjs/control/Sized/api.cjs.map +1 -0
- package/_cjs/control/Sized/definition.cjs +27 -0
- package/_cjs/control/Sized/definition.cjs.map +1 -0
- package/_cjs/control/Sized/live.cjs +42 -0
- package/_cjs/control/Sized/live.cjs.map +1 -0
- package/_cjs/control/Sized.cjs +45 -0
- package/_cjs/control/Sized.cjs.map +1 -0
- package/_cjs/control/Spec/api.cjs +525 -0
- package/_cjs/control/Spec/api.cjs.map +1 -0
- package/_cjs/control/Spec/definition.cjs +125 -0
- package/_cjs/control/Spec/definition.cjs.map +1 -0
- package/_cjs/control/Spec.cjs +32 -0
- package/_cjs/control/Spec.cjs.map +1 -0
- package/_cjs/control/SummaryBuilder.cjs +87 -0
- package/_cjs/control/SummaryBuilder.cjs.map +1 -0
- package/_cjs/control/Test.cjs +34 -0
- package/_cjs/control/Test.cjs.map +1 -0
- package/_cjs/control/TestAnnotationRenderer/api.cjs +101 -0
- package/_cjs/control/TestAnnotationRenderer/api.cjs.map +1 -0
- package/_cjs/control/TestAnnotationRenderer/definition.cjs +53 -0
- package/_cjs/control/TestAnnotationRenderer/definition.cjs.map +1 -0
- package/_cjs/control/TestAnnotationRenderer.cjs +32 -0
- package/_cjs/control/TestAnnotationRenderer.cjs.map +1 -0
- package/_cjs/control/TestAspect/api.cjs +148 -0
- package/_cjs/control/TestAspect/api.cjs.map +1 -0
- package/_cjs/control/TestAspect/definition.cjs +6 -0
- package/_cjs/control/TestAspect/definition.cjs.map +1 -0
- package/_cjs/control/TestAspect.cjs +32 -0
- package/_cjs/control/TestAspect.cjs.map +1 -0
- package/_cjs/control/TestClock/api.cjs +72 -0
- package/_cjs/control/TestClock/api.cjs.map +1 -0
- package/_cjs/control/TestClock/definition.cjs +225 -0
- package/_cjs/control/TestClock/definition.cjs.map +1 -0
- package/_cjs/control/TestClock.cjs +32 -0
- package/_cjs/control/TestClock.cjs.map +1 -0
- package/_cjs/control/TestConsole/api.cjs +64 -0
- package/_cjs/control/TestConsole/api.cjs.map +1 -0
- package/_cjs/control/TestConsole/definition.cjs +100 -0
- package/_cjs/control/TestConsole/definition.cjs.map +1 -0
- package/_cjs/control/TestConsole.cjs +32 -0
- package/_cjs/control/TestConsole.cjs.map +1 -0
- package/_cjs/control/TestEnvironment.cjs +39 -0
- package/_cjs/control/TestEnvironment.cjs.map +1 -0
- package/_cjs/control/TestExecutor.cjs +58 -0
- package/_cjs/control/TestExecutor.cjs.map +1 -0
- package/_cjs/control/TestLogger.cjs +58 -0
- package/_cjs/control/TestLogger.cjs.map +1 -0
- package/_cjs/control/TestRandom/api.cjs +125 -0
- package/_cjs/control/TestRandom/api.cjs.map +1 -0
- package/_cjs/control/TestRandom/definition.cjs +458 -0
- package/_cjs/control/TestRandom/definition.cjs.map +1 -0
- package/_cjs/control/TestRandom.cjs +32 -0
- package/_cjs/control/TestRandom.cjs.map +1 -0
- package/_cjs/control/TestRenderer/ConsoleRenderer.cjs +113 -0
- package/_cjs/control/TestRenderer/ConsoleRenderer.cjs.map +1 -0
- package/_cjs/control/TestRenderer/definition.cjs +6 -0
- package/_cjs/control/TestRenderer/definition.cjs.map +1 -0
- package/_cjs/control/TestRunner.cjs +45 -0
- package/_cjs/control/TestRunner.cjs.map +1 -0
- package/_cjs/data/AssertionData.cjs +55 -0
- package/_cjs/data/AssertionData.cjs.map +1 -0
- package/_cjs/data/AssertionResult.cjs +34 -0
- package/_cjs/data/AssertionResult.cjs.map +1 -0
- package/_cjs/data/AssertionValue/api.cjs +64 -0
- package/_cjs/data/AssertionValue/api.cjs.map +1 -0
- package/_cjs/data/AssertionValue/definition.cjs +35 -0
- package/_cjs/data/AssertionValue/definition.cjs.map +1 -0
- package/_cjs/data/AssertionValue.cjs +32 -0
- package/_cjs/data/AssertionValue.cjs.map +1 -0
- package/_cjs/data/ExecutedSpec/api.cjs +132 -0
- package/_cjs/data/ExecutedSpec/api.cjs.map +1 -0
- package/_cjs/data/ExecutedSpec/definition.cjs +58 -0
- package/_cjs/data/ExecutedSpec/definition.cjs.map +1 -0
- package/_cjs/data/ExecutedSpec.cjs +32 -0
- package/_cjs/data/ExecutedSpec.cjs.map +1 -0
- package/_cjs/data/ExecutionResult.cjs +142 -0
- package/_cjs/data/ExecutionResult.cjs.map +1 -0
- package/_cjs/data/FailureDetails.cjs +17 -0
- package/_cjs/data/FailureDetails.cjs.map +1 -0
- package/_cjs/data/FreeBooleanAlgebra/api.cjs +194 -0
- package/_cjs/data/FreeBooleanAlgebra/api.cjs.map +1 -0
- package/_cjs/data/FreeBooleanAlgebra/definition.cjs +59 -0
- package/_cjs/data/FreeBooleanAlgebra/definition.cjs.map +1 -0
- package/_cjs/data/FreeBooleanAlgebra.cjs +32 -0
- package/_cjs/data/FreeBooleanAlgebra.cjs.map +1 -0
- package/_cjs/data/GenFailureDetails.cjs +18 -0
- package/_cjs/data/GenFailureDetails.cjs.map +1 -0
- package/_cjs/data/LogLine/Fragment.cjs +94 -0
- package/_cjs/data/LogLine/Fragment.cjs.map +1 -0
- package/_cjs/data/LogLine/Line.cjs +142 -0
- package/_cjs/data/LogLine/Line.cjs.map +1 -0
- package/_cjs/data/LogLine/Message.cjs +145 -0
- package/_cjs/data/LogLine/Message.cjs.map +1 -0
- package/_cjs/data/LogLine/Style.cjs +124 -0
- package/_cjs/data/LogLine/Style.cjs.map +1 -0
- package/_cjs/data/LogLine/api.cjs +65 -0
- package/_cjs/data/LogLine/api.cjs.map +1 -0
- package/_cjs/data/LogLine.cjs +32 -0
- package/_cjs/data/LogLine.cjs.map +1 -0
- package/_cjs/data/Render/api.cjs +25 -0
- package/_cjs/data/Render/api.cjs.map +1 -0
- package/_cjs/data/Render/definition.cjs +52 -0
- package/_cjs/data/Render/definition.cjs.map +1 -0
- package/_cjs/data/Render.cjs +32 -0
- package/_cjs/data/Render.cjs.map +1 -0
- package/_cjs/data/RenderParam/api.cjs +40 -0
- package/_cjs/data/RenderParam/api.cjs.map +1 -0
- package/_cjs/data/RenderParam/definition.cjs +33 -0
- package/_cjs/data/RenderParam/definition.cjs.map +1 -0
- package/_cjs/data/RenderParam.cjs +32 -0
- package/_cjs/data/RenderParam.cjs.map +1 -0
- package/_cjs/data/Summary.cjs +20 -0
- package/_cjs/data/Summary.cjs.map +1 -0
- package/_cjs/data/TestAnnotation/api.cjs +76 -0
- package/_cjs/data/TestAnnotation/api.cjs.map +1 -0
- package/_cjs/data/TestAnnotation/definition.cjs +55 -0
- package/_cjs/data/TestAnnotation/definition.cjs.map +1 -0
- package/_cjs/data/TestAnnotation.cjs +32 -0
- package/_cjs/data/TestAnnotation.cjs.map +1 -0
- package/_cjs/data/TestAnnotationMap.cjs +51 -0
- package/_cjs/data/TestAnnotationMap.cjs.map +1 -0
- package/_cjs/data/TestArgs/definition.cjs +18 -0
- package/_cjs/data/TestArgs/definition.cjs.map +1 -0
- package/_cjs/data/TestArgs.cjs +19 -0
- package/_cjs/data/TestArgs.cjs.map +1 -0
- package/_cjs/data/TestConfig.cjs +76 -0
- package/_cjs/data/TestConfig.cjs.map +1 -0
- package/_cjs/data/TestFailure.cjs +75 -0
- package/_cjs/data/TestFailure.cjs.map +1 -0
- package/_cjs/data/TestSuccess.cjs +48 -0
- package/_cjs/data/TestSuccess.cjs.map +1 -0
- package/_cjs/data/TestTimeoutException.cjs +16 -0
- package/_cjs/data/TestTimeoutException.cjs.map +1 -0
- package/_cjs/demo.cjs +44 -0
- package/_cjs/demo.cjs.map +1 -0
- package/_cjs/util/math.cjs +673 -0
- package/_cjs/util/math.cjs.map +1 -0
- package/_mjs/api.mjs +57 -0
- package/_mjs/api.mjs.map +1 -0
- package/_mjs/control/AbstractRunnableSpec.mjs +16 -0
- package/_mjs/control/AbstractRunnableSpec.mjs.map +1 -0
- package/_mjs/control/Annotations/api.mjs +30 -0
- package/_mjs/control/Annotations/api.mjs.map +1 -0
- package/_mjs/control/Annotations/definition.mjs +13 -0
- package/_mjs/control/Annotations/definition.mjs.map +1 -0
- package/_mjs/control/Annotations/live.mjs +40 -0
- package/_mjs/control/Annotations/live.mjs.map +1 -0
- package/_mjs/control/Annotations.mjs +5 -0
- package/_mjs/control/Annotations.mjs.map +1 -0
- package/_mjs/control/Assertion/api.mjs +170 -0
- package/_mjs/control/Assertion/api.mjs.map +1 -0
- package/_mjs/control/Assertion/definition.mjs +17 -0
- package/_mjs/control/Assertion/definition.mjs.map +1 -0
- package/_mjs/control/Assertion.mjs +4 -0
- package/_mjs/control/Assertion.mjs.map +1 -0
- package/_mjs/control/AssertionIO/api.mjs +28 -0
- package/_mjs/control/AssertionIO/api.mjs.map +1 -0
- package/_mjs/control/AssertionIO/definition.mjs +23 -0
- package/_mjs/control/AssertionIO/definition.mjs.map +1 -0
- package/_mjs/control/AssertionIO.mjs +4 -0
- package/_mjs/control/AssertionIO.mjs.map +1 -0
- package/_mjs/control/DefaultRunnableSpec.mjs +15 -0
- package/_mjs/control/DefaultRunnableSpec.mjs.map +1 -0
- package/_mjs/control/DefaultTestReporter/definition.mjs +2 -0
- package/_mjs/control/DefaultTestReporter/definition.mjs.map +1 -0
- package/_mjs/control/DefaultTestReporter/render.mjs +245 -0
- package/_mjs/control/DefaultTestReporter/render.mjs.map +1 -0
- package/_mjs/control/DefaultTestReporter.mjs +4 -0
- package/_mjs/control/DefaultTestReporter.mjs.map +1 -0
- package/_mjs/control/FreeBooleanAlgebraIO/api.mjs +62 -0
- package/_mjs/control/FreeBooleanAlgebraIO/api.mjs.map +1 -0
- package/_mjs/control/FreeBooleanAlgebraIO/definition.mjs +2 -0
- package/_mjs/control/FreeBooleanAlgebraIO/definition.mjs.map +1 -0
- package/_mjs/control/FreeBooleanAlgebraIO.mjs +4 -0
- package/_mjs/control/FreeBooleanAlgebraIO.mjs.map +1 -0
- package/_mjs/control/Gen/api/array.mjs +31 -0
- package/_mjs/control/Gen/api/array.mjs.map +1 -0
- package/_mjs/control/Gen/api/char.mjs +95 -0
- package/_mjs/control/Gen/api/char.mjs.map +1 -0
- package/_mjs/control/Gen/api/conc.mjs +46 -0
- package/_mjs/control/Gen/api/conc.mjs.map +1 -0
- package/_mjs/control/Gen/api/double.mjs +60 -0
- package/_mjs/control/Gen/api/double.mjs.map +1 -0
- package/_mjs/control/Gen/api/float.mjs +41 -0
- package/_mjs/control/Gen/api/float.mjs.map +1 -0
- package/_mjs/control/Gen/api/string.mjs +72 -0
- package/_mjs/control/Gen/api/string.mjs.map +1 -0
- package/_mjs/control/Gen/api/struct.mjs +18 -0
- package/_mjs/control/Gen/api/struct.mjs.map +1 -0
- package/_mjs/control/Gen/api.mjs +288 -0
- package/_mjs/control/Gen/api.mjs.map +1 -0
- package/_mjs/control/Gen/constraints.mjs +2 -0
- package/_mjs/control/Gen/constraints.mjs.map +1 -0
- package/_mjs/control/Gen/definition.mjs +11 -0
- package/_mjs/control/Gen/definition.mjs.map +1 -0
- package/_mjs/control/Gen.mjs +14 -0
- package/_mjs/control/Gen.mjs.map +1 -0
- package/_mjs/control/Live/definition.mjs +42 -0
- package/_mjs/control/Live/definition.mjs.map +1 -0
- package/_mjs/control/Live.mjs +3 -0
- package/_mjs/control/Live.mjs.map +1 -0
- package/_mjs/control/RunnableSpec.mjs +44 -0
- package/_mjs/control/RunnableSpec.mjs.map +1 -0
- package/_mjs/control/Sample/api.mjs +195 -0
- package/_mjs/control/Sample/api.mjs.map +1 -0
- package/_mjs/control/Sample/definition.mjs +12 -0
- package/_mjs/control/Sample/definition.mjs.map +1 -0
- package/_mjs/control/Sample.mjs +4 -0
- package/_mjs/control/Sample.mjs.map +1 -0
- package/_mjs/control/Sized/api.mjs +16 -0
- package/_mjs/control/Sized/api.mjs.map +1 -0
- package/_mjs/control/Sized/definition.mjs +13 -0
- package/_mjs/control/Sized/definition.mjs.map +1 -0
- package/_mjs/control/Sized/live.mjs +25 -0
- package/_mjs/control/Sized/live.mjs.map +1 -0
- package/_mjs/control/Sized.mjs +5 -0
- package/_mjs/control/Sized.mjs.map +1 -0
- package/_mjs/control/Spec/api.mjs +449 -0
- package/_mjs/control/Spec/api.mjs.map +1 -0
- package/_mjs/control/Spec/definition.mjs +96 -0
- package/_mjs/control/Spec/definition.mjs.map +1 -0
- package/_mjs/control/Spec.mjs +4 -0
- package/_mjs/control/Spec.mjs.map +1 -0
- package/_mjs/control/SummaryBuilder.mjs +61 -0
- package/_mjs/control/SummaryBuilder.mjs.map +1 -0
- package/_mjs/control/Test.mjs +15 -0
- package/_mjs/control/Test.mjs.map +1 -0
- package/_mjs/control/TestAnnotationRenderer/api.mjs +74 -0
- package/_mjs/control/TestAnnotationRenderer/api.mjs.map +1 -0
- package/_mjs/control/TestAnnotationRenderer/definition.mjs +32 -0
- package/_mjs/control/TestAnnotationRenderer/definition.mjs.map +1 -0
- package/_mjs/control/TestAnnotationRenderer.mjs +4 -0
- package/_mjs/control/TestAnnotationRenderer.mjs.map +1 -0
- package/_mjs/control/TestAspect/api.mjs +93 -0
- package/_mjs/control/TestAspect/api.mjs.map +1 -0
- package/_mjs/control/TestAspect/definition.mjs +2 -0
- package/_mjs/control/TestAspect/definition.mjs.map +1 -0
- package/_mjs/control/TestAspect.mjs +4 -0
- package/_mjs/control/TestAspect.mjs.map +1 -0
- package/_mjs/control/TestClock/api.mjs +45 -0
- package/_mjs/control/TestClock/api.mjs.map +1 -0
- package/_mjs/control/TestClock/definition.mjs +173 -0
- package/_mjs/control/TestClock/definition.mjs.map +1 -0
- package/_mjs/control/TestClock.mjs +4 -0
- package/_mjs/control/TestClock.mjs.map +1 -0
- package/_mjs/control/TestConsole/api.mjs +41 -0
- package/_mjs/control/TestConsole/api.mjs.map +1 -0
- package/_mjs/control/TestConsole/definition.mjs +73 -0
- package/_mjs/control/TestConsole/definition.mjs.map +1 -0
- package/_mjs/control/TestConsole.mjs +4 -0
- package/_mjs/control/TestConsole.mjs.map +1 -0
- package/_mjs/control/TestEnvironment.mjs +17 -0
- package/_mjs/control/TestEnvironment.mjs.map +1 -0
- package/_mjs/control/TestExecutor.mjs +36 -0
- package/_mjs/control/TestExecutor.mjs.map +1 -0
- package/_mjs/control/TestLogger.mjs +36 -0
- package/_mjs/control/TestLogger.mjs.map +1 -0
- package/_mjs/control/TestRandom/api.mjs +87 -0
- package/_mjs/control/TestRandom/api.mjs.map +1 -0
- package/_mjs/control/TestRandom/definition.mjs +418 -0
- package/_mjs/control/TestRandom/definition.mjs.map +1 -0
- package/_mjs/control/TestRandom.mjs +4 -0
- package/_mjs/control/TestRandom.mjs.map +1 -0
- package/_mjs/control/TestRenderer/ConsoleRenderer.mjs +88 -0
- package/_mjs/control/TestRenderer/ConsoleRenderer.mjs.map +1 -0
- package/_mjs/control/TestRenderer/definition.mjs +2 -0
- package/_mjs/control/TestRenderer/definition.mjs.map +1 -0
- package/_mjs/control/TestRunner.mjs +23 -0
- package/_mjs/control/TestRunner.mjs.map +1 -0
- package/_mjs/data/AssertionData.mjs +34 -0
- package/_mjs/data/AssertionData.mjs.map +1 -0
- package/_mjs/data/AssertionResult.mjs +17 -0
- package/_mjs/data/AssertionResult.mjs.map +1 -0
- package/_mjs/data/AssertionValue/api.mjs +42 -0
- package/_mjs/data/AssertionValue/api.mjs.map +1 -0
- package/_mjs/data/AssertionValue/definition.mjs +19 -0
- package/_mjs/data/AssertionValue/definition.mjs.map +1 -0
- package/_mjs/data/AssertionValue.mjs +4 -0
- package/_mjs/data/AssertionValue.mjs.map +1 -0
- package/_mjs/data/ExecutedSpec/api.mjs +104 -0
- package/_mjs/data/ExecutedSpec/api.mjs.map +1 -0
- package/_mjs/data/ExecutedSpec/definition.mjs +40 -0
- package/_mjs/data/ExecutedSpec/definition.mjs.map +1 -0
- package/_mjs/data/ExecutedSpec.mjs +4 -0
- package/_mjs/data/ExecutedSpec.mjs.map +1 -0
- package/_mjs/data/ExecutionResult.mjs +110 -0
- package/_mjs/data/ExecutionResult.mjs.map +1 -0
- package/_mjs/data/FailureDetails.mjs +8 -0
- package/_mjs/data/FailureDetails.mjs.map +1 -0
- package/_mjs/data/FreeBooleanAlgebra/api.mjs +154 -0
- package/_mjs/data/FreeBooleanAlgebra/api.mjs.map +1 -0
- package/_mjs/data/FreeBooleanAlgebra/definition.mjs +40 -0
- package/_mjs/data/FreeBooleanAlgebra/definition.mjs.map +1 -0
- package/_mjs/data/FreeBooleanAlgebra.mjs +4 -0
- package/_mjs/data/FreeBooleanAlgebra.mjs.map +1 -0
- package/_mjs/data/GenFailureDetails.mjs +9 -0
- package/_mjs/data/GenFailureDetails.mjs.map +1 -0
- package/_mjs/data/LogLine/Fragment.mjs +65 -0
- package/_mjs/data/LogLine/Fragment.mjs.map +1 -0
- package/_mjs/data/LogLine/Line.mjs +104 -0
- package/_mjs/data/LogLine/Line.mjs.map +1 -0
- package/_mjs/data/LogLine/Message.mjs +107 -0
- package/_mjs/data/LogLine/Message.mjs.map +1 -0
- package/_mjs/data/LogLine/Style.mjs +101 -0
- package/_mjs/data/LogLine/Style.mjs.map +1 -0
- package/_mjs/data/LogLine/api.mjs +32 -0
- package/_mjs/data/LogLine/api.mjs.map +1 -0
- package/_mjs/data/LogLine.mjs +3 -0
- package/_mjs/data/LogLine.mjs.map +1 -0
- package/_mjs/data/Render/api.mjs +16 -0
- package/_mjs/data/Render/api.mjs.map +1 -0
- package/_mjs/data/Render/definition.mjs +33 -0
- package/_mjs/data/Render/definition.mjs.map +1 -0
- package/_mjs/data/Render.mjs +4 -0
- package/_mjs/data/Render.mjs.map +1 -0
- package/_mjs/data/RenderParam/api.mjs +28 -0
- package/_mjs/data/RenderParam/api.mjs.map +1 -0
- package/_mjs/data/RenderParam/definition.mjs +20 -0
- package/_mjs/data/RenderParam/definition.mjs.map +1 -0
- package/_mjs/data/RenderParam.mjs +4 -0
- package/_mjs/data/RenderParam.mjs.map +1 -0
- package/_mjs/data/Summary.mjs +11 -0
- package/_mjs/data/Summary.mjs.map +1 -0
- package/_mjs/data/TestAnnotation/api.mjs +47 -0
- package/_mjs/data/TestAnnotation/api.mjs.map +1 -0
- package/_mjs/data/TestAnnotation/definition.mjs +33 -0
- package/_mjs/data/TestAnnotation/definition.mjs.map +1 -0
- package/_mjs/data/TestAnnotation.mjs +4 -0
- package/_mjs/data/TestAnnotation.mjs.map +1 -0
- package/_mjs/data/TestAnnotationMap.mjs +33 -0
- package/_mjs/data/TestAnnotationMap.mjs.map +1 -0
- package/_mjs/data/TestArgs/definition.mjs +9 -0
- package/_mjs/data/TestArgs/definition.mjs.map +1 -0
- package/_mjs/data/TestArgs.mjs +3 -0
- package/_mjs/data/TestArgs.mjs.map +1 -0
- package/_mjs/data/TestConfig.mjs +52 -0
- package/_mjs/data/TestConfig.mjs.map +1 -0
- package/_mjs/data/TestFailure.mjs +49 -0
- package/_mjs/data/TestFailure.mjs.map +1 -0
- package/_mjs/data/TestSuccess.mjs +31 -0
- package/_mjs/data/TestSuccess.mjs.map +1 -0
- package/_mjs/data/TestTimeoutException.mjs +7 -0
- package/_mjs/data/TestTimeoutException.mjs.map +1 -0
- package/_mjs/demo.mjs +33 -0
- package/_mjs/demo.mjs.map +1 -0
- package/_mjs/util/math.mjs +604 -0
- package/_mjs/util/math.mjs.map +1 -0
- package/_src/api.ts +76 -0
- package/_src/control/AbstractRunnableSpec.ts +23 -0
- package/_src/control/Annotations/api.ts +33 -0
- package/_src/control/Annotations/definition.ts +20 -0
- package/_src/control/Annotations/live.ts +50 -0
- package/_src/control/Annotations.ts +5 -0
- package/_src/control/Assertion/api.ts +236 -0
- package/_src/control/Assertion/definition.ts +20 -0
- package/_src/control/Assertion.ts +4 -0
- package/_src/control/AssertionIO/api.ts +32 -0
- package/_src/control/AssertionIO/definition.ts +26 -0
- package/_src/control/AssertionIO.ts +4 -0
- package/_src/control/DefaultRunnableSpec.ts +12 -0
- package/_src/control/DefaultTestReporter/definition.ts +6 -0
- package/_src/control/DefaultTestReporter/render.ts +295 -0
- package/_src/control/DefaultTestReporter.ts +4 -0
- package/_src/control/FreeBooleanAlgebraIO/api.ts +67 -0
- package/_src/control/FreeBooleanAlgebraIO/definition.ts +13 -0
- package/_src/control/FreeBooleanAlgebraIO.ts +4 -0
- package/_src/control/Gen/api/array.ts +31 -0
- package/_src/control/Gen/api/char.ts +83 -0
- package/_src/control/Gen/api/conc.ts +50 -0
- package/_src/control/Gen/api/double.ts +64 -0
- package/_src/control/Gen/api/float.ts +36 -0
- package/_src/control/Gen/api/string.ts +71 -0
- package/_src/control/Gen/api/struct.ts +21 -0
- package/_src/control/Gen/api.ts +276 -0
- package/_src/control/Gen/constraints.ts +38 -0
- package/_src/control/Gen/definition.ts +9 -0
- package/_src/control/Gen.ts +15 -0
- package/_src/control/Live/definition.ts +47 -0
- package/_src/control/Live.ts +3 -0
- package/_src/control/RunnableSpec.ts +42 -0
- package/_src/control/Sample/api.ts +287 -0
- package/_src/control/Sample/definition.ts +7 -0
- package/_src/control/Sample.ts +4 -0
- package/_src/control/Sized/api.ts +14 -0
- package/_src/control/Sized/definition.ts +13 -0
- package/_src/control/Sized/live.ts +19 -0
- package/_src/control/Sized.ts +5 -0
- package/_src/control/Spec/api.ts +384 -0
- package/_src/control/Spec/definition.ts +103 -0
- package/_src/control/Spec.ts +4 -0
- package/_src/control/SummaryBuilder.ts +68 -0
- package/_src/control/Test.ts +31 -0
- package/_src/control/TestAnnotationRenderer/api.ts +75 -0
- package/_src/control/TestAnnotationRenderer/definition.ts +49 -0
- package/_src/control/TestAnnotationRenderer.ts +4 -0
- package/_src/control/TestAspect/api.ts +122 -0
- package/_src/control/TestAspect/definition.ts +3 -0
- package/_src/control/TestAspect.ts +4 -0
- package/_src/control/TestClock/api.ts +36 -0
- package/_src/control/TestClock/definition.ts +196 -0
- package/_src/control/TestClock.ts +4 -0
- package/_src/control/TestConsole/api.ts +36 -0
- package/_src/control/TestConsole/definition.ts +61 -0
- package/_src/control/TestConsole.ts +4 -0
- package/_src/control/TestEnvironment.ts +30 -0
- package/_src/control/TestExecutor.ts +54 -0
- package/_src/control/TestLogger.ts +37 -0
- package/_src/control/TestRandom/api.ts +76 -0
- package/_src/control/TestRandom/definition.ts +362 -0
- package/_src/control/TestRandom.ts +4 -0
- package/_src/control/TestRenderer/ConsoleRenderer.ts +94 -0
- package/_src/control/TestRenderer/definition.ts +7 -0
- package/_src/control/TestRunner.ts +34 -0
- package/_src/data/AssertionData.ts +33 -0
- package/_src/data/AssertionResult.ts +31 -0
- package/_src/data/AssertionValue/api.ts +48 -0
- package/_src/data/AssertionValue/definition.ts +20 -0
- package/_src/data/AssertionValue.ts +4 -0
- package/_src/data/ExecutedSpec/api.ts +96 -0
- package/_src/data/ExecutedSpec/definition.ts +37 -0
- package/_src/data/ExecutedSpec.ts +4 -0
- package/_src/data/ExecutionResult.ts +153 -0
- package/_src/data/FailureDetails.ts +13 -0
- package/_src/data/FreeBooleanAlgebra/api.ts +152 -0
- package/_src/data/FreeBooleanAlgebra/definition.ts +38 -0
- package/_src/data/FreeBooleanAlgebra.ts +4 -0
- package/_src/data/GenFailureDetails.ts +3 -0
- package/_src/data/LogLine/Fragment.ts +59 -0
- package/_src/data/LogLine/Line.ts +91 -0
- package/_src/data/LogLine/Message.ts +94 -0
- package/_src/data/LogLine/Style.ts +150 -0
- package/_src/data/LogLine/api.ts +40 -0
- package/_src/data/LogLine.ts +2 -0
- package/_src/data/Render/api.ts +18 -0
- package/_src/data/Render/definition.ts +36 -0
- package/_src/data/Render.ts +4 -0
- package/_src/data/RenderParam/api.ts +31 -0
- package/_src/data/RenderParam/definition.ts +28 -0
- package/_src/data/RenderParam.ts +4 -0
- package/_src/data/Summary.ts +4 -0
- package/_src/data/TestAnnotation/api.ts +49 -0
- package/_src/data/TestAnnotation/definition.ts +37 -0
- package/_src/data/TestAnnotation.ts +4 -0
- package/_src/data/TestAnnotationMap.ts +41 -0
- package/_src/data/TestArgs/definition.ts +7 -0
- package/_src/data/TestArgs.ts +3 -0
- package/_src/data/TestConfig.ts +47 -0
- package/_src/data/TestFailure.ts +56 -0
- package/_src/data/TestSuccess.ts +39 -0
- package/_src/data/TestTimeoutException.ts +5 -0
- package/_src/demo.ts +16 -0
- package/_src/util/math.ts +497 -0
- package/api.d.ts +21 -0
- package/control/AbstractRunnableSpec.d.ts +15 -0
- package/control/Annotations/api.d.ts +26 -0
- package/control/Annotations/definition.d.ts +20 -0
- package/control/Annotations/live.d.ts +18 -0
- package/control/Annotations.d.ts +3 -0
- package/control/Assertion/api.d.ts +81 -0
- package/control/Assertion/definition.d.ts +17 -0
- package/control/Assertion.d.ts +2 -0
- package/control/AssertionIO/api.d.ts +18 -0
- package/control/AssertionIO/definition.d.ts +18 -0
- package/control/AssertionIO.d.ts +2 -0
- package/control/DefaultRunnableSpec.d.ts +7 -0
- package/control/DefaultTestReporter/definition.d.ts +6 -0
- package/control/DefaultTestReporter/render.d.ts +23 -0
- package/control/DefaultTestReporter.d.ts +2 -0
- package/control/FreeBooleanAlgebraIO/api.d.ts +44 -0
- package/control/FreeBooleanAlgebraIO/definition.d.ts +12 -0
- package/control/FreeBooleanAlgebraIO.d.ts +2 -0
- package/control/Gen/api/array.d.ts +19 -0
- package/control/Gen/api/char.d.ts +47 -0
- package/control/Gen/api/conc.d.ts +26 -0
- package/control/Gen/api/double.d.ts +13 -0
- package/control/Gen/api/float.d.ts +7 -0
- package/control/Gen/api/string.d.ts +49 -0
- package/control/Gen/api/struct.d.ts +8 -0
- package/control/Gen/api.d.ts +169 -0
- package/control/Gen/constraints.d.ts +32 -0
- package/control/Gen/definition.d.ts +11 -0
- package/control/Gen.d.ts +10 -0
- package/control/Live/definition.d.ts +24 -0
- package/control/Live.d.ts +1 -0
- package/control/RunnableSpec.d.ts +12 -0
- package/control/Sample/api.d.ts +79 -0
- package/control/Sample/definition.d.ts +11 -0
- package/control/Sample.d.ts +2 -0
- package/control/Sized/api.d.ts +13 -0
- package/control/Sized/definition.d.ts +14 -0
- package/control/Sized/live.d.ts +9 -0
- package/control/Sized.d.ts +3 -0
- package/control/Spec/api.d.ts +159 -0
- package/control/Spec/definition.d.ts +96 -0
- package/control/Spec.d.ts +2 -0
- package/control/SummaryBuilder.d.ts +15 -0
- package/control/Test.d.ts +20 -0
- package/control/TestAnnotationRenderer/api.d.ts +42 -0
- package/control/TestAnnotationRenderer/definition.d.ts +31 -0
- package/control/TestAnnotationRenderer.d.ts +2 -0
- package/control/TestAspect/api.d.ts +23 -0
- package/control/TestAspect/definition.d.ts +2 -0
- package/control/TestAspect.d.ts +2 -0
- package/control/TestClock/api.d.ts +21 -0
- package/control/TestClock/definition.d.ts +66 -0
- package/control/TestClock.d.ts +2 -0
- package/control/TestConsole/api.d.ts +15 -0
- package/control/TestConsole/definition.d.ts +39 -0
- package/control/TestConsole.d.ts +2 -0
- package/control/TestEnvironment.d.ts +16 -0
- package/control/TestExecutor.d.ts +13 -0
- package/control/TestLogger.d.ts +25 -0
- package/control/TestRandom/api.d.ts +49 -0
- package/control/TestRandom/definition.d.ts +91 -0
- package/control/TestRandom.d.ts +2 -0
- package/control/TestRenderer/ConsoleRenderer.d.ts +15 -0
- package/control/TestRenderer/definition.d.ts +4 -0
- package/control/TestRunner.d.ts +18 -0
- package/data/AssertionData.d.ts +24 -0
- package/data/AssertionResult.d.ts +23 -0
- package/data/AssertionValue/api.d.ts +27 -0
- package/data/AssertionValue/definition.d.ts +19 -0
- package/data/AssertionValue.d.ts +2 -0
- package/data/ExecutedSpec/api.d.ts +47 -0
- package/data/ExecutedSpec/definition.d.ts +39 -0
- package/data/ExecutedSpec.d.ts +2 -0
- package/data/ExecutionResult.d.ts +59 -0
- package/data/FailureDetails.d.ts +15 -0
- package/data/FreeBooleanAlgebra/api.d.ts +81 -0
- package/data/FreeBooleanAlgebra/definition.d.ts +38 -0
- package/data/FreeBooleanAlgebra.d.ts +2 -0
- package/data/GenFailureDetails.d.ts +6 -0
- package/data/LogLine/Fragment.d.ts +46 -0
- package/data/LogLine/Line.d.ts +62 -0
- package/data/LogLine/Message.d.ts +61 -0
- package/data/LogLine/Style.d.ts +107 -0
- package/data/LogLine/api.d.ts +11 -0
- package/data/LogLine.d.ts +2 -0
- package/data/Render/api.d.ts +13 -0
- package/data/Render/definition.d.ts +31 -0
- package/data/Render.d.ts +2 -0
- package/data/RenderParam/api.d.ts +13 -0
- package/data/RenderParam/definition.d.ts +25 -0
- package/data/RenderParam.d.ts +2 -0
- package/data/Summary.d.ts +8 -0
- package/data/TestAnnotation/api.d.ts +41 -0
- package/data/TestAnnotation/definition.d.ts +20 -0
- package/data/TestAnnotation.d.ts +2 -0
- package/data/TestAnnotationMap.d.ts +12 -0
- package/data/TestArgs/definition.d.ts +7 -0
- package/data/TestArgs.d.ts +1 -0
- package/data/TestConfig.d.ts +42 -0
- package/data/TestFailure.d.ts +46 -0
- package/data/TestSuccess.d.ts +33 -0
- package/data/TestTimeoutException.d.ts +3 -0
- package/demo.d.ts +1 -0
- package/package.json +18 -0
- package/util/math.d.ts +130 -0
@@ -0,0 +1,49 @@
|
|
1
|
+
import type { TestAnnotation } from "../../data/TestAnnotation.js";
|
2
|
+
import type { TestAnnotationMap } from "../../data/TestAnnotationMap.js";
|
3
|
+
|
4
|
+
export const enum TestAnnotationRendererTag {
|
5
|
+
LeafRenderer = "LeafRenderer",
|
6
|
+
CompositeRenderer = "CompositeRenderer",
|
7
|
+
}
|
8
|
+
|
9
|
+
export class LeafRenderer {
|
10
|
+
readonly _tag = TestAnnotationRendererTag.LeafRenderer;
|
11
|
+
constructor(
|
12
|
+
readonly use: <X>(f: <V>(annotation: TestAnnotation<V>, render: (_: List<V>) => Maybe<string>) => X) => X,
|
13
|
+
) {}
|
14
|
+
|
15
|
+
run(ancestors: List<TestAnnotationMap>, child: TestAnnotationMap): List<string> {
|
16
|
+
return this.use((annotation, render) =>
|
17
|
+
render(
|
18
|
+
Cons(
|
19
|
+
child.get(annotation),
|
20
|
+
ancestors.map((map) => map.get(annotation)),
|
21
|
+
),
|
22
|
+
).match(
|
23
|
+
() => List.empty(),
|
24
|
+
(s) => Cons(s, Nil()),
|
25
|
+
),
|
26
|
+
);
|
27
|
+
}
|
28
|
+
}
|
29
|
+
|
30
|
+
export class CompositeRenderer {
|
31
|
+
readonly _tag = TestAnnotationRendererTag.CompositeRenderer;
|
32
|
+
constructor(readonly renderers: Vector<TestAnnotationRenderer>) {}
|
33
|
+
|
34
|
+
run(ancestors: List<TestAnnotationMap>, child: TestAnnotationMap): List<string> {
|
35
|
+
return this.renderers.toList.flatMap((renderer) => renderer.run(ancestors, child));
|
36
|
+
}
|
37
|
+
}
|
38
|
+
|
39
|
+
/**
|
40
|
+
* @tsplus type fncts.test.TestAnnotationRenderer
|
41
|
+
*/
|
42
|
+
export type TestAnnotationRenderer = LeafRenderer | CompositeRenderer;
|
43
|
+
|
44
|
+
/**
|
45
|
+
* @tsplus type fncts.test.TestAnnotationRendererOps
|
46
|
+
*/
|
47
|
+
export interface TestAnnotationRendererOps {}
|
48
|
+
|
49
|
+
export const TestAnnotationRenderer: TestAnnotationRendererOps = {};
|
@@ -0,0 +1,122 @@
|
|
1
|
+
import type { TestAspect } from "@fncts/test/control/TestAspect/definition";
|
2
|
+
import type { TestSuccess } from "@fncts/test/data/TestSuccess";
|
3
|
+
|
4
|
+
import { matchTag, matchTag_ } from "@fncts/base/util/pattern";
|
5
|
+
import { Console } from "@fncts/io/Console";
|
6
|
+
import { Annotations } from "@fncts/test/control/Annotations";
|
7
|
+
import { Live } from "@fncts/test/control/Live";
|
8
|
+
import { Spec, TestCase } from "@fncts/test/control/Spec";
|
9
|
+
import { TestAnnotation } from "@fncts/test/data/TestAnnotation";
|
10
|
+
import { RuntimeFailure, TestFailure } from "@fncts/test/data/TestFailure";
|
11
|
+
|
12
|
+
export type TestAspectAtLeastR<R> = TestAspect<R, never>;
|
13
|
+
|
14
|
+
export type TestAspectPoly = TestAspect<unknown, never>;
|
15
|
+
|
16
|
+
export const id: TestAspectPoly = Function.identity;
|
17
|
+
|
18
|
+
export const ignore: TestAspectAtLeastR<Has<Annotations>> = (spec) => spec.when(false);
|
19
|
+
|
20
|
+
export function perTest<R, E>(
|
21
|
+
f: <R1, E1>(test: IO<R1, TestFailure<E1>, TestSuccess>) => IO<R & R1, TestFailure<E | E1>, TestSuccess>,
|
22
|
+
): TestAspect<R, E> {
|
23
|
+
return (spec) =>
|
24
|
+
spec.transform(
|
25
|
+
matchTag(
|
26
|
+
{
|
27
|
+
Test: ({ test, annotations }) => new TestCase(f(test), annotations),
|
28
|
+
},
|
29
|
+
Function.identity,
|
30
|
+
),
|
31
|
+
);
|
32
|
+
}
|
33
|
+
|
34
|
+
export function after<R, E, A>(effect: IO<R, E, A>): TestAspect<R, E> {
|
35
|
+
return perTest<R, E>((test) =>
|
36
|
+
test.result
|
37
|
+
.zipWith(effect.catchAllCause((cause) => IO.fail(new RuntimeFailure(cause))).result, (ex0, ex1) =>
|
38
|
+
ex0.apFirst(ex1),
|
39
|
+
)
|
40
|
+
.flatMap(IO.fromExitNow),
|
41
|
+
);
|
42
|
+
}
|
43
|
+
|
44
|
+
export function around<R, E, A, R1>(before: IO<R, E, A>, after: (a: A) => IO<R1, never, any>): TestAspect<R & R1, E> {
|
45
|
+
return perTest<R & R1, E>((test) =>
|
46
|
+
before.catchAllCause((c) => IO.fail(new RuntimeFailure(c))).bracket(() => test, after),
|
47
|
+
);
|
48
|
+
}
|
49
|
+
|
50
|
+
export function aroundAll<R, E, A, R1>(
|
51
|
+
before: IO<R, E, A>,
|
52
|
+
after: (a: A) => IO<R1, never, any>,
|
53
|
+
): TestAspect<R & R1, E> {
|
54
|
+
return <R0, E0>(spec: Spec<R0, E0>) =>
|
55
|
+
Spec.scoped<R & R1 & R0, TestFailure<E | E0>, TestSuccess>(
|
56
|
+
IO.acquireRelease(before, after)
|
57
|
+
.mapError((e) => TestFailure.fail(e))
|
58
|
+
.as(spec),
|
59
|
+
);
|
60
|
+
}
|
61
|
+
|
62
|
+
export function before<R0>(effect: IO<R0, never, any>): TestAspect<R0, never> {
|
63
|
+
return perTest<R0, never>((test) => effect.apSecond(test));
|
64
|
+
}
|
65
|
+
|
66
|
+
export function beforeAll<R0, E0>(effect: IO<R0, E0, any>): TestAspect<R0, E0> {
|
67
|
+
return aroundAll(effect, () => IO.unit);
|
68
|
+
}
|
69
|
+
|
70
|
+
export const eventually = perTest((test) => test.eventually);
|
71
|
+
|
72
|
+
export function repeat<R0>(schedule: Schedule<R0, TestSuccess, any>): TestAspect<R0 & Has<Annotations>, never> {
|
73
|
+
return perTest<R0 & Has<Annotations>, never>(
|
74
|
+
<R1, E1>(
|
75
|
+
test: IO<R1, TestFailure<E1>, TestSuccess>,
|
76
|
+
): IO<R0 & R1 & Has<Annotations>, TestFailure<E1>, TestSuccess> =>
|
77
|
+
IO.environmentWithIO((r: Environment<R0 & R1 & Has<Annotations>>) =>
|
78
|
+
test
|
79
|
+
.provideEnvironment(r)
|
80
|
+
.repeat(
|
81
|
+
schedule.zipRight(
|
82
|
+
Schedule.identity<TestSuccess>().tapOutput((_) =>
|
83
|
+
Annotations.annotate(TestAnnotation.Repeated, 1).provideEnvironment(r),
|
84
|
+
),
|
85
|
+
),
|
86
|
+
),
|
87
|
+
),
|
88
|
+
);
|
89
|
+
}
|
90
|
+
|
91
|
+
export function timeoutWarning(duration: number): TestAspect<Has<Live>, any> {
|
92
|
+
return <R1, E1>(spec: Spec<R1, E1>) => {
|
93
|
+
const loop = (labels: Vector<string>, spec: Spec<R1, E1>): Spec<R1 & Has<Live>, E1> =>
|
94
|
+
matchTag_(spec.caseValue, {
|
95
|
+
Exec: ({ exec, spec }) => Spec.exec(loop(labels, spec), exec),
|
96
|
+
Labeled: ({ label, spec }) => Spec.labeled(loop(labels.append(label), spec), label),
|
97
|
+
Scoped: ({ scoped }) => Spec.scoped(scoped.map((spec) => loop(labels, spec))),
|
98
|
+
Multiple: ({ specs }) => Spec.multiple(specs.map((spec) => loop(labels, spec))),
|
99
|
+
Test: ({ test, annotations }) => Spec.test(warn(labels, test, duration), annotations),
|
100
|
+
});
|
101
|
+
|
102
|
+
return loop(Vector(), spec);
|
103
|
+
};
|
104
|
+
}
|
105
|
+
|
106
|
+
function warn<R, E>(labels: Vector<string>, test: IO<R, TestFailure<E>, TestSuccess>, duration: number) {
|
107
|
+
return test.raceWith(
|
108
|
+
Live.withLive(showWarning(labels, duration), (io) => Clock.sleep(duration) > io),
|
109
|
+
(result, fiber) => fiber.interrupt > IO.fromExitNow(result),
|
110
|
+
(_, fiber) => fiber.join,
|
111
|
+
);
|
112
|
+
}
|
113
|
+
|
114
|
+
function showWarning(labels: Vector<string>, duration: number) {
|
115
|
+
return Live.Live(Console.print(renderWarning(labels, duration)));
|
116
|
+
}
|
117
|
+
|
118
|
+
function renderWarning(labels: Vector<string>, duration: number) {
|
119
|
+
return `Test ${labels.join(
|
120
|
+
" - ",
|
121
|
+
)} has taken more than ${duration} milliseconds to execute. If this is not expected, consider using TestAspect.timeout to timeout runaway tests for faster diagnostics`;
|
122
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import { IOEnv } from "@fncts/io/IOEnv";
|
2
|
+
import { Annotations } from "@fncts/test/control/Annotations";
|
3
|
+
import { Live } from "@fncts/test/control/Live";
|
4
|
+
import { Data, Start, TestClock } from "@fncts/test/control/TestClock/definition";
|
5
|
+
|
6
|
+
/**
|
7
|
+
* @tsplus static fncts.test.TestClockOps make
|
8
|
+
*/
|
9
|
+
export function make(data: Data): Layer<Has<Live> & Has<Annotations>, never, Has<TestClock>> {
|
10
|
+
return Layer.scoped(
|
11
|
+
IO.gen(function* (_) {
|
12
|
+
const live = yield* _(IO.service(Live.Tag));
|
13
|
+
const annotations = yield* _(IO.service(Annotations.Tag));
|
14
|
+
const ref = yield* _(Ref.make(data));
|
15
|
+
const synchronized = yield* _(Ref.Synchronized.make(Start));
|
16
|
+
const test = yield* _(
|
17
|
+
IO.acquireRelease(IO.succeed(new TestClock(ref, live, annotations, synchronized)), (tc) => tc.warningDone),
|
18
|
+
);
|
19
|
+
yield* _(IOEnv.services.locallyScopedWith((_) => _.add(test, TestClock.Tag)));
|
20
|
+
return test;
|
21
|
+
}),
|
22
|
+
TestClock.Tag,
|
23
|
+
);
|
24
|
+
}
|
25
|
+
|
26
|
+
/**
|
27
|
+
* @tsplus static fncts.test.TestClockOps Live
|
28
|
+
*/
|
29
|
+
export const live: Layer<Has<Live> & Has<Annotations>, never, Has<TestClock>> = TestClock.make(new Data(0, Nil()));
|
30
|
+
|
31
|
+
/**
|
32
|
+
* @tsplus static fncts.test.TestClockOps adjust
|
33
|
+
*/
|
34
|
+
export function adjust(duration: number): IO<Has<TestClock>, never, void> {
|
35
|
+
return IO.serviceWithIO((service: TestClock) => service.adjust(duration), TestClock.Tag);
|
36
|
+
}
|
@@ -0,0 +1,196 @@
|
|
1
|
+
import type { FiberStatus } from "@fncts/io/FiberStatus";
|
2
|
+
import type { Annotations } from "@fncts/test/control/Annotations";
|
3
|
+
import type { Live } from "@fncts/test/control/Live";
|
4
|
+
|
5
|
+
import { matchTag } from "@fncts/base/util/pattern";
|
6
|
+
import { Console } from "@fncts/io/Console";
|
7
|
+
import { TestAnnotation } from "@fncts/test/data/TestAnnotation";
|
8
|
+
|
9
|
+
export class Data {
|
10
|
+
constructor(readonly duration: number, readonly sleeps: List<readonly [number, Future<never, void>]>) {}
|
11
|
+
}
|
12
|
+
|
13
|
+
export class Sleep {
|
14
|
+
constructor(readonly duration: number, readonly promise: Future<never, void>, readonly fiberId: FiberId) {}
|
15
|
+
}
|
16
|
+
|
17
|
+
interface Start {
|
18
|
+
readonly _tag: "Start";
|
19
|
+
}
|
20
|
+
|
21
|
+
interface Pending {
|
22
|
+
readonly _tag: "Pending";
|
23
|
+
readonly fiber: Fiber<never, void>;
|
24
|
+
}
|
25
|
+
|
26
|
+
interface Done {
|
27
|
+
readonly _tag: "Done";
|
28
|
+
}
|
29
|
+
|
30
|
+
type WarningData = Start | Pending | Done;
|
31
|
+
|
32
|
+
export const Start: WarningData = { _tag: "Start" };
|
33
|
+
|
34
|
+
export const Pending = (fiber: Fiber<never, void>): WarningData => ({ _tag: "Pending", fiber });
|
35
|
+
|
36
|
+
export const Done: WarningData = { _tag: "Done" };
|
37
|
+
|
38
|
+
const warning =
|
39
|
+
"Warning: A test is using time, but is not advancing the test clock, " +
|
40
|
+
"which may result in the test hanging. Use TestClock.adjust to " +
|
41
|
+
"manually advance the time.";
|
42
|
+
|
43
|
+
/**
|
44
|
+
* @tsplus static fncts.test.TestClockOps Tag
|
45
|
+
*/
|
46
|
+
export const TestClockTag = Tag<TestClock>();
|
47
|
+
|
48
|
+
/**
|
49
|
+
* @tsplus type fncts.test.TestClock
|
50
|
+
* @tsplus companion fncts.test.TestClockOps
|
51
|
+
*/
|
52
|
+
export class TestClock extends Clock {
|
53
|
+
constructor(
|
54
|
+
readonly clockState: Ref<Data>,
|
55
|
+
readonly live: Live,
|
56
|
+
readonly annotations: Annotations,
|
57
|
+
readonly warningState: Ref.Synchronized<WarningData>,
|
58
|
+
) {
|
59
|
+
super();
|
60
|
+
}
|
61
|
+
sleep = (ms: number) => {
|
62
|
+
const self = this;
|
63
|
+
return IO.gen(function* (_) {
|
64
|
+
const promise = yield* _(Future.make<never, void>());
|
65
|
+
const wait = yield* _(
|
66
|
+
self.clockState.modify((data) => {
|
67
|
+
const end = data.duration + ms;
|
68
|
+
if (end > data.duration) {
|
69
|
+
return [true, new Data(data.duration, data.sleeps.prepend([end, promise]))];
|
70
|
+
} else {
|
71
|
+
return [false, data];
|
72
|
+
}
|
73
|
+
}),
|
74
|
+
);
|
75
|
+
yield* _(
|
76
|
+
IO.defer(() => {
|
77
|
+
if (wait) {
|
78
|
+
return self.warningStart > promise.await;
|
79
|
+
} else {
|
80
|
+
return promise.succeed(undefined) > IO.unit;
|
81
|
+
}
|
82
|
+
}),
|
83
|
+
);
|
84
|
+
});
|
85
|
+
};
|
86
|
+
|
87
|
+
currentTime = this.clockState.get.map((data) => data.duration);
|
88
|
+
|
89
|
+
adjust(duration: number): UIO<void> {
|
90
|
+
return this.warningDone > this.run((d) => d + duration);
|
91
|
+
}
|
92
|
+
|
93
|
+
setDate(date: Date): UIO<void> {
|
94
|
+
return this.setTime(date.getTime());
|
95
|
+
}
|
96
|
+
|
97
|
+
setTime(time: number): UIO<void> {
|
98
|
+
return this.warningDone > this.run((_) => time);
|
99
|
+
}
|
100
|
+
|
101
|
+
sleeps = this.clockState.get.map((data) => data.sleeps.map(([_]) => _));
|
102
|
+
|
103
|
+
get supervizedFibers(): UIO<HashSet<Fiber.Runtime<any, any>>> {
|
104
|
+
return IO.descriptorWith((descriptor) =>
|
105
|
+
this.annotations.get(TestAnnotation.Fibers).flatMap((_) =>
|
106
|
+
_.match(
|
107
|
+
(_) => IO.succeed(HashSet.makeDefault()),
|
108
|
+
(fibers) =>
|
109
|
+
IO.foreach(fibers, (ref) => ref.get)
|
110
|
+
.map((_) => _.foldLeft(HashSet.makeDefault<Fiber.Runtime<any, any>>(), (s0, s1) => s0.union(s1)))
|
111
|
+
.map((set) => set.filter((f) => !Equatable.strictEquals(f.id, descriptor.id))),
|
112
|
+
),
|
113
|
+
),
|
114
|
+
);
|
115
|
+
}
|
116
|
+
|
117
|
+
private get freeze(): IO<unknown, void, HashMap<FiberId, FiberStatus>> {
|
118
|
+
return this.supervizedFibers.flatMap((fibers) =>
|
119
|
+
IO.foldLeft(fibers, HashMap.makeDefault<FiberId, FiberStatus>(), (map, fiber) =>
|
120
|
+
fiber.status.flatMap((status) => {
|
121
|
+
switch (status._tag) {
|
122
|
+
case "Done": {
|
123
|
+
return IO.succeed(map.set(fiber.id, status));
|
124
|
+
}
|
125
|
+
case "Suspended": {
|
126
|
+
return IO.succeed(map.set(fiber.id, status));
|
127
|
+
}
|
128
|
+
default: {
|
129
|
+
return IO.fail(undefined);
|
130
|
+
}
|
131
|
+
}
|
132
|
+
}),
|
133
|
+
),
|
134
|
+
);
|
135
|
+
}
|
136
|
+
|
137
|
+
private get delay(): UIO<void> {
|
138
|
+
return this.live.provide(Clock.sleep(5));
|
139
|
+
}
|
140
|
+
|
141
|
+
private get awaitSuspended(): UIO<void> {
|
142
|
+
return this.suspended
|
143
|
+
.zipWith(this.live.provide(Clock.sleep(10)) > this.suspended, Equatable.strictEquals)
|
144
|
+
.filterOrFail(Function.identity, (): void => undefined).eventually.asUnit;
|
145
|
+
}
|
146
|
+
|
147
|
+
private run(f: (duration: number) => number): UIO<void> {
|
148
|
+
return (
|
149
|
+
this.awaitSuspended >
|
150
|
+
this.clockState.modify((data) => {
|
151
|
+
const end = f(data.duration);
|
152
|
+
const sorted = data.sleeps.sortWith(([x], [y]) => Number.Ord.compare_(x, y));
|
153
|
+
return sorted.head
|
154
|
+
.flatMap(([duration, promise]) =>
|
155
|
+
duration <= end
|
156
|
+
? Just([Just([end, promise] as const), new Data(duration, sorted.unsafeTail)] as const)
|
157
|
+
: Nothing(),
|
158
|
+
)
|
159
|
+
.getOrElse([Nothing(), new Data(end, data.sleeps)] as const);
|
160
|
+
})
|
161
|
+
).flatMap((_) =>
|
162
|
+
_.match(
|
163
|
+
() => IO.unit,
|
164
|
+
([end, promise]) => promise.succeed(undefined) > IO.yieldNow > this.run(() => end),
|
165
|
+
),
|
166
|
+
);
|
167
|
+
}
|
168
|
+
|
169
|
+
private get suspended(): IO<unknown, void, HashMap<FiberId, FiberStatus>> {
|
170
|
+
return this.freeze.zip(this.delay > this.freeze).flatMap(([first, last]) => {
|
171
|
+
if (Equatable.strictEquals(first, last)) {
|
172
|
+
return IO.succeedNow(first);
|
173
|
+
} else {
|
174
|
+
return IO.failNow(undefined);
|
175
|
+
}
|
176
|
+
});
|
177
|
+
}
|
178
|
+
|
179
|
+
warningDone: UIO<void> = this.warningState.updateJustIO(
|
180
|
+
matchTag({
|
181
|
+
Start: () => Just(IO(Done)),
|
182
|
+
Pending: ({ fiber }) => Just(fiber.interrupt.as(Done)),
|
183
|
+
Done: () => Nothing(),
|
184
|
+
}),
|
185
|
+
);
|
186
|
+
|
187
|
+
private warningStart: UIO<void> = this.warningState.updateJustIO(
|
188
|
+
matchTag(
|
189
|
+
{
|
190
|
+
Start: () =>
|
191
|
+
Just(this.live.provide(Clock.sleep(5000) > Console.print(warning)).interruptible.fork.map(Pending)),
|
192
|
+
},
|
193
|
+
() => Nothing<IO<unknown, never, WarningData>>(),
|
194
|
+
),
|
195
|
+
);
|
196
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import { Console } from "@fncts/io/Console";
|
2
|
+
import { IOEnv } from "@fncts/io/IOEnv";
|
3
|
+
import { Live } from "@fncts/test/control/Live";
|
4
|
+
import { ConsoleData } from "@fncts/test/control/TestConsole/definition";
|
5
|
+
import { TestConsole } from "@fncts/test/control/TestConsole/definition";
|
6
|
+
|
7
|
+
/**
|
8
|
+
* @tsplus static fncts.test.TestConsoleOps make
|
9
|
+
*/
|
10
|
+
export function make(data: ConsoleData, debug = true): Layer<Has<Live>, never, Has<TestConsole>> {
|
11
|
+
return Layer.scopedEnvironment(
|
12
|
+
IO.serviceWithIO(
|
13
|
+
(live) =>
|
14
|
+
IO.gen(function* (_) {
|
15
|
+
const ref = yield* _(Ref.make(data));
|
16
|
+
const debugRef = yield* _(FiberRef.make(debug));
|
17
|
+
const test = new TestConsole(ref, live, debugRef);
|
18
|
+
yield* _(IOEnv.services.locallyScopedWith((_) => _.add(test, Console.Tag)));
|
19
|
+
return Environment.empty.add(test, TestConsole.Tag);
|
20
|
+
}),
|
21
|
+
Live.Tag,
|
22
|
+
),
|
23
|
+
);
|
24
|
+
}
|
25
|
+
|
26
|
+
/**
|
27
|
+
* @tsplus static fncts.test.TestConsoleOps Live
|
28
|
+
*/
|
29
|
+
export const live = TestConsole.make(
|
30
|
+
new ConsoleData({
|
31
|
+
input: Vector.empty(),
|
32
|
+
output: Vector.empty(),
|
33
|
+
errOutput: Vector.empty(),
|
34
|
+
debugOutput: Vector.empty(),
|
35
|
+
}),
|
36
|
+
);
|
@@ -0,0 +1,61 @@
|
|
1
|
+
import type { Console } from "@fncts/io/Console";
|
2
|
+
import type { Live } from "@fncts/test/control/Live";
|
3
|
+
|
4
|
+
import { showWithOptions } from "@fncts/base/typeclass/Showable";
|
5
|
+
|
6
|
+
export class ConsoleData extends CaseClass<{
|
7
|
+
readonly input: Vector<string>;
|
8
|
+
readonly output: Vector<string>;
|
9
|
+
readonly errOutput: Vector<string>;
|
10
|
+
readonly debugOutput: Vector<string>;
|
11
|
+
}> {}
|
12
|
+
|
13
|
+
/**
|
14
|
+
* @tsplus type fncts.test.TestConsole
|
15
|
+
* @tsplus companion fncts.test.TestConsoleOps
|
16
|
+
*/
|
17
|
+
export class TestConsole implements Console {
|
18
|
+
constructor(readonly consoleState: Ref<ConsoleData>, readonly live: Live, readonly debugState: FiberRef<boolean>) {}
|
19
|
+
show(...input: ReadonlyArray<unknown>): UIO<void> {
|
20
|
+
return this.consoleState.update((data) =>
|
21
|
+
data.copy({
|
22
|
+
output: data.output.concat(
|
23
|
+
input.foldLeft(Vector.empty(), (b, a) => b.append(showWithOptions(a, { colors: false }))),
|
24
|
+
),
|
25
|
+
}),
|
26
|
+
);
|
27
|
+
}
|
28
|
+
print(line: string): UIO<void> {
|
29
|
+
return this.consoleState.update((data) =>
|
30
|
+
data.copy({
|
31
|
+
output: data.output.append(`${line}\n`),
|
32
|
+
}),
|
33
|
+
);
|
34
|
+
}
|
35
|
+
error(line: string): UIO<void> {
|
36
|
+
return this.consoleState.update((data) =>
|
37
|
+
data.copy({
|
38
|
+
errOutput: data.errOutput.append(`${line}\n`),
|
39
|
+
}),
|
40
|
+
);
|
41
|
+
}
|
42
|
+
clearInput = this.consoleState.update((data) => data.copy({ input: Vector.empty() }));
|
43
|
+
clearOutput = this.consoleState.update((data) => data.copy({ output: Vector.empty() }));
|
44
|
+
output = this.consoleState.get.map((data) => data.output);
|
45
|
+
errOutput = this.consoleState.get.map((data) => data.errOutput);
|
46
|
+
debugOutput = this.consoleState.get.map((data) => data.debugOutput);
|
47
|
+
feedLines(...lines: ReadonlyArray<string>): UIO<void> {
|
48
|
+
return this.consoleState.update((data) => data.copy({ input: data.input.concat(Vector.from(lines)) }));
|
49
|
+
}
|
50
|
+
silent<R, E, A>(io: IO<R, E, A>): IO<R, E, A> {
|
51
|
+
return this.debugState.locally(false)(io);
|
52
|
+
}
|
53
|
+
debug<R, E, A>(io: IO<R, E, A>): IO<R, E, A> {
|
54
|
+
return this.debugState.locally(true)(io);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
/**
|
59
|
+
* @tsplus static fncts.test.TestConsoleOps Tag
|
60
|
+
*/
|
61
|
+
export const TestConsoleTag = Tag<TestConsole>();
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import type { Console } from "@fncts/io/Console";
|
2
|
+
|
3
|
+
import { IOEnv } from "@fncts/io/IOEnv";
|
4
|
+
import { Annotations } from "@fncts/test/control/Annotations";
|
5
|
+
import { Live } from "@fncts/test/control/Live";
|
6
|
+
import { Sized } from "@fncts/test/control/Sized";
|
7
|
+
import { TestClock } from "@fncts/test/control/TestClock";
|
8
|
+
import { TestConsole } from "@fncts/test/control/TestConsole";
|
9
|
+
import { TestRandom } from "@fncts/test/control/TestRandom";
|
10
|
+
import { TestConfig } from "@fncts/test/data/TestConfig";
|
11
|
+
|
12
|
+
export type TestEnvironment = Has<Annotations> &
|
13
|
+
Has<Live> &
|
14
|
+
Has<Sized> &
|
15
|
+
Has<TestClock> &
|
16
|
+
Has<TestConfig> &
|
17
|
+
Has<TestRandom> &
|
18
|
+
Has<Clock> &
|
19
|
+
Has<Random> &
|
20
|
+
Has<Console> &
|
21
|
+
Has<TestConsole>;
|
22
|
+
|
23
|
+
export const LiveTestEnvironment: Layer<IOEnv, never, TestEnvironment> = Annotations.Live.and(Live.Default)
|
24
|
+
.and(Sized.Live(100))
|
25
|
+
.and(TestConfig.Live({ repeats: 100, retries: 100, samples: 200, shrinks: 1000 }))
|
26
|
+
.and(TestRandom.Deterministic)
|
27
|
+
.andTo(TestClock.Live)
|
28
|
+
.andTo(TestConsole.Live);
|
29
|
+
|
30
|
+
export const TestEnvironment = IOEnv.Live.to(LiveTestEnvironment);
|
@@ -0,0 +1,54 @@
|
|
1
|
+
import type { TestFailure } from "../data/TestFailure.js";
|
2
|
+
import type { TestSuccess } from "../data/TestSuccess.js";
|
3
|
+
import type { Annotated, Annotations } from "./Annotations.js";
|
4
|
+
import type { Spec, SpecCase } from "./Spec.js";
|
5
|
+
import type { ExecutionStrategy } from "@fncts/base/data/ExecutionStrategy";
|
6
|
+
|
7
|
+
import { matchTag_ } from "@fncts/base/util/pattern";
|
8
|
+
|
9
|
+
import { ExecutedSpec } from "../data/ExecutedSpec.js";
|
10
|
+
import { TestAnnotationMap } from "../data/TestAnnotationMap.js";
|
11
|
+
import { RuntimeFailure } from "../data/TestFailure.js";
|
12
|
+
|
13
|
+
export interface TestExecutor<R> {
|
14
|
+
readonly run: <E>(spec: Spec<R & Has<Annotations>, E>, defExec: ExecutionStrategy) => UIO<ExecutedSpec<E>>;
|
15
|
+
readonly environment: Layer<unknown, never, R>;
|
16
|
+
}
|
17
|
+
|
18
|
+
export function defaultTestExecutor<R>(
|
19
|
+
env: Layer<unknown, never, R & Has<Annotations>>,
|
20
|
+
): TestExecutor<R & Has<Annotations>> {
|
21
|
+
return {
|
22
|
+
run: <E>(spec: Spec<R & Has<Annotations>, E>, defExec: ExecutionStrategy): UIO<ExecutedSpec<E>> =>
|
23
|
+
spec.annotated
|
24
|
+
.provideLayer(env)
|
25
|
+
.foreachExec(
|
26
|
+
(cause): UIO<Annotated<Either<TestFailure<E>, TestSuccess>>> =>
|
27
|
+
cause.failureOrCause.match(
|
28
|
+
([failure, annotations]) => IO.succeedNow([Either.left(failure), annotations]),
|
29
|
+
(cause) => IO.succeedNow([Either.left(new RuntimeFailure(cause)), TestAnnotationMap.empty]),
|
30
|
+
),
|
31
|
+
([success, annotations]): UIO<Annotated<Either<TestFailure<E>, TestSuccess>>> =>
|
32
|
+
IO.succeedNow([Either.right(success), annotations]),
|
33
|
+
defExec,
|
34
|
+
)
|
35
|
+
.scoped.flatMap(
|
36
|
+
(s) =>
|
37
|
+
s.foldScoped(
|
38
|
+
(spec: SpecCase<unknown, never, Annotated<Either<TestFailure<E>, TestSuccess>>, ExecutedSpec<E>>) =>
|
39
|
+
matchTag_(spec, {
|
40
|
+
Exec: ({ spec }) => IO.succeedNow(spec),
|
41
|
+
Labeled: ({ label, spec }) => IO.succeedNow(ExecutedSpec.labeled(spec, label)),
|
42
|
+
Scoped: ({ scoped }) => scoped,
|
43
|
+
Multiple: ({ specs }) => IO.succeedNow(ExecutedSpec.multiple(specs)),
|
44
|
+
Test: ({ test, annotations }) =>
|
45
|
+
test.map(([result, dynamicAnnotations]) =>
|
46
|
+
ExecutedSpec.test(result, annotations.combine(dynamicAnnotations)),
|
47
|
+
),
|
48
|
+
}),
|
49
|
+
defExec,
|
50
|
+
).scoped,
|
51
|
+
),
|
52
|
+
environment: env,
|
53
|
+
};
|
54
|
+
}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { Console } from "@fncts/io/Console";
|
2
|
+
|
3
|
+
/**
|
4
|
+
* @tsplus type fncts.test.TestLogger
|
5
|
+
* @tsplus companion fncts.test.TestLoggerOps
|
6
|
+
*/
|
7
|
+
export abstract class TestLogger {
|
8
|
+
abstract logLine(line: string): UIO<void>;
|
9
|
+
}
|
10
|
+
|
11
|
+
/**
|
12
|
+
* @tsplus static fncts.test.TestLoggerOps Tag
|
13
|
+
*/
|
14
|
+
export const TestLoggerTag = Tag<TestLogger>();
|
15
|
+
|
16
|
+
/**
|
17
|
+
* @tsplus static fncts.test.TestLoggerOps fromConsole
|
18
|
+
*/
|
19
|
+
export const fromConsole: Layer<unknown, never, Has<TestLogger>> = Layer.fromIO(
|
20
|
+
IO.consoleWith((console) =>
|
21
|
+
IO.succeedNow(
|
22
|
+
new (class extends TestLogger {
|
23
|
+
logLine(line: string): UIO<void> {
|
24
|
+
return console.print(line);
|
25
|
+
}
|
26
|
+
})(),
|
27
|
+
),
|
28
|
+
),
|
29
|
+
TestLogger.Tag,
|
30
|
+
);
|
31
|
+
|
32
|
+
/**
|
33
|
+
* @tsplus static fncts.test.TestLoggerOps logLine
|
34
|
+
*/
|
35
|
+
export function logLine(line: string): URIO<Has<TestLogger>, void> {
|
36
|
+
return IO.serviceWithIO((testLogger) => testLogger.logLine(line), TestLogger.Tag);
|
37
|
+
}
|