Comments (9)
I think if we add parallel/sequencial we should also provide a way for users to use custom monad then just Aff so it's possible for advanced users to use some custom logging, for example if we add m
param to Spec
, then _run
will have type like this:
_run
:: forall m
. Config
-> Spec' m Unit
-> (NonEmptyArray Name -> m ~> Aff)
-> Producer Event Aff (Array (Group Result))
This way someone can use ReaderT (String -> Effect Unit) Aff
as m
and in _run
use Name
as prefix of all logs, or use WriterT [String] Aff
as m
and just log everything after each test is finished/failed.
if we can provide hoistSpec :: forall m g. (m ~> g) -> Spec' m ~> Spec' g
or similar that could might also help (I was not able to write this as you can't change type of state in State
)
from purescript-spec.
Hspec has a parallel
combinator that I think you can wrap any Spec
with: https://hspec.github.io/parallel-spec-execution.html
Maybe could borrow some design from there?
Regarding logs, are you thinking of stuff printed by the code under test, rather than purescript-spec's output?
from purescript-spec.
yes spec logs just fine if you fork tests, issue is when the code under test is logging stuff
from purescript-spec.
I like the parallel
and sequential
contaminators from hspec, and will try to do similar thing instead of desribePar*
.
Tut the issue with logging still is there, I think instead of it :: String -> Aff Unit -> Spec Unit
we can do something like this:
it :: String -> WriterT String Aff Unit -> Spec Unit
or
it :: String -> ReaderT (String -> Eff Unit) Aff Unit -> Spec Unit
so you can still log to console but it has test name as prefix, or you just get log when test finishes/fails, instead of output being polluted by random strings from all parallel tests
from purescript-spec.
When it comes to logging from the code under test, I think it's a slippery slope to provide functionality in purescript-spec, and that we shouldn't implement any special support for it. Rather, we can document parallel
and note that any code that prints to the console will need to synchronize, or perhaps log to different files or with different prefixes.
from purescript-spec.
@felixmulder, any thoughts on logging?
from purescript-spec.
If ps-spec itself is not providing that then probably Spec should become be something like this:
type TestName = String
type Spec = Spec' Aff
type Spec' m t = State (Array (Group (ReaderT TestName m Unit))) t
this way one an use define there own spec:
type SpecWithCustomLoging = Spec' (ReaderT (String -> Effect Unit) Aff)
from purescript-spec.
from purescript-spec.
so i have added hoistSpec #82 and par&seq functions (like in hspec)
take a look at this example for how it can be used to for logging (nave version vs writer vs reader)
and here you can see travis logs https://travis-ci.org/purescript-spec/purescript-spec/builds/466439951#L1285
from purescript-spec.
Related Issues (20)
- Changing timeouts is too difficult HOT 1
- Pursuit docs are not up to date HOT 2
- aroundAll hook HOT 1
- Add flag to run tests in randomised order
- Spec Editor integration HOT 3
- xit HOT 2
- Report output misses last `pending` in each nested `describe`? HOT 1
- itOnly still evalutates? HOT 3
- Add warning to `*Only` HOT 1
- Better reporting for diffs HOT 1
- Use an actual bracket to handle test setup/cleanup HOT 4
- `pulp test` fails on CI HOT 1
- Version 7.3.0 is not in the package set HOT 1
- beforeAll hook and Spec Identity monad HOT 10
- Fix warning in TeamCity file HOT 2
- new Tree type is a breaking api change HOT 3
- Changes in nesting of `describe` causes unexpected changes in reporting HOT 2
- Teamcity reporter overwrites nodes when there are more then one child of a describe HOT 5
- Warning when specifying the type of a Spec HOT 7
- `consoleReporter` not reporting which test that failed when running tests in `parallel` HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from purescript-spec.