-
-
Notifications
You must be signed in to change notification settings - Fork 6.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
console.log does not output when running tests #2441
Comments
Just tested this using repl.it: https://repl.it/EwfT/0 Good news is it works as expected and console.log outputs. I attempted downgrading my jest version to 17.0.3, was still seeing the same issues. Installed |
Thanks for reporting this, but that's a duplicate of #2166 and happens on Node 6 too. |
@thisissami it seems like your test or code isn't running then. Jest's test suite passes on node 4 and node 6 which makes sure console printing works fine and we are working on a fix for 7.3. |
@cpojer - My tests pass/fail properly - just |
If it was working earlier today for you and isn't any more, you must have made an update or broken something yourself. We didn't publish a Jest release in two weeks. |
ok so the only thing that's changed in my test code is that i've added a multiline comment after the code that's supposed to run (as a reference for myself). I'll see if removing that makes a difference. |
@cpojer I don't know what to say, I don't see anything wrong in my test code but nothing is being outputted to stdout:
The test fails, as expected, so I know it's working. My config in
Jest ran totally normally, no extra flags attached. Same issue with Jest v17 & 18. |
I haven't changed any files other than this one in the entire afternoon. I've just been getting to understand how |
It seems like you updated to node 7.3. We have some fixes up for that. Please note this issue tracker is not a help forum; use stackoverflow for questions :) |
I am using node v4.4.7, and as far as I'm concerned - not having anything show up to stdout when using |
@cpojer Fairly certain you guys have a bug here. Having 3 tests run (as in 3 different files with Having just 1 test run (AKA me renaming I'm gonna keep running a second arbitrary test so that I see the output I need, so I'm good for my own personal needs - but this should be addressed imo, assuming it's reproducable elsewhere. |
The test suite of Jest tests this behavior on node 4, node 6 and node 7.3. It works for 4 and 6 but was broken in 7.3. I'm fixing this for node 7.3 and will publish a new release of Jest shortly: #2464 If Jest's own test suite using node 4 fails for you, then something is likely wrong with your setup. |
Cloning the repository and giving it a try now. |
Everything passed except for these 3 tests. Not sure what implications that might have. You have all the info of what the errors related to console.log that I'm having are, as well as the image below. If that isn't a bug in jest, then so be it. Seems weird to me though that doing nothing but following the guides would result in a scenario where I can't see my logs when only running one test file. |
These just indicate you don't have mercurial (hg) installed, unrelated to your issue. It seems like the test suite passes for you and as said; we explicitly test for the logging behavior in the test suite so it must be something going wrong with your code or setup. |
Ok cool - thanks for your feedback. Do you have any inkling as to what could be causing it to work when there are multiple files but not when there is only 1? If there's no obvious "oh this sometimes causes an issue like that" that comes to your mind - no worries, I'll just ensure that there's always at least 2 files running. :) |
I am experiencing the same issue, console.log is not outputting for me now (and it previously was about an hour ago). I'm using node 6.9.1 and also enabling the --forceExit flag. When I do not have this flag enabled, the console.log output appears. However, I have another test script that utilizes the --forceExit flag and console.log appears, so I cannot say that the --forceExit flag is causing this behaviour. As @thisissami is doing, I experience the logging issue only when I try to test a single file. |
I was having the same issue, but found that it was due to running jest via jest-cli (jest.runCLI) within gulpfile.js and it was swallowing the output of console.log. If I run jest directly I see the console output. |
I'm now having seeing some funky behaviour, which I cannot isolate to a simple test case yet, otherwise I'd file a new issue.
jest v18.1.0 Since I cannot isolate this in a simple test, I'm guessing it has something to do with running an more complex asynchronous test. |
Upgrade jest-cli since it was not logging stdout under node 7.4 Apparently there was a bug that was recently fixed to be compatible with Node v7. jestjs/jest#2441
I'm getting the same issue, I wonder if it's output overwriting other output. Occasionally I'll see something like this: It's like one process outputted an error (failed prop types) but it just gets written right over by the test output logs. More: And sometimes if I Versions |
@davidgilbertson does it happen on v18.1? |
I've tried I can't pick any particular pattern, but some things that have happened (I have a
Could it be that all the errors thrown by missing props causes this issue? I have to keep |
Not working for me either (jest 19.0.1, node 5.12). Interestingly it does work on another project with same setup. Not sure how to debug Jest tests so being able to see some console messages would be quite important I think. |
Have you tried using the jest flag |
The |
I will try. The slightly unnerving thing is that in the same project some console log statements are being output on the console, some aren't. Unfortunately the ones I tried to add where a test case is failing doesn't get output (I tried to add everywhere in the test case, in the unit tested, etc to no avail). So I don't actually think this can be down to a flag, as the behaviour is not concise. It's a react native project, following standard layout btw. |
None of this seems to help. The --bail flag just stops other tests from being run (the offending one is last one anyway in my case), and --runInBands doesn't seem to have any observable difference. Jest does run the updated files btw, so if I insert a console.log statement, the error stack trace shows the error coming from the updated line number. It's just the console log doesn't happen. Since it's hard/impossible to debug these tests in a browser (pls correct me if this is not the case) console.log is absolutely vital to fix some issues in the tests. |
I've tried everything in this thread and still can't see output for console.log. --runInBand does not solve the problem for me. Using node@12 and latest jest. Debugging with web dev is hard enough, it would be really useful if I could at least print to the screen to see why my unit test is failing |
@u84six have you tried my solution? Cheers |
@ivandosreisandrade what happens is that if there's an error in the code (like referencing an undefined value), it won't print out, even if the console.log call is before the error. If everything in the test passes, then I'll see the log. That kind of behavior makes it totally useless for debugging. |
@ivandosreisandrade what does your package.json look like? I'm trying to follow this: npm test -- --runInBand -t "My Test Name" But I have it setup like this in my package.json "test:unit": "jest --verbose" You'd think that with the --verbose flag, it would allow a console.log to get through, but I still can't get console.log to work. So frustrating! |
@u84six this is my packadge.json
|
Your testMatch allows either |
It's not relevant to the cause 🤷♂️ |
I am unsure as to why the issue is closed. So here is my node version - 13.12.10, npm -6.14.4 Here is a basic test with mock-fs
I am unsure as to why this happens. Is this because of the event-loop where the console.log is made to considered to be processed in the nextTick() only after the execution of test specs. Apologies to bringing this up, but it rather seems tedious to debug every single test case, rather than just do a console o/p and check the req data. |
Because you have to return your filePromisy promise to jest so it knows when your test is done - your issue has nothing to do with this one. |
I got around this issue for debugging purposes by simply putting whatever I wanted to log into a temporary |
What worked for me on Node 8: const util = require('util')
const myLogger = util.debuglog('myloggername')
myLogger('foobar') And start jest with the debugger flag: NODE_DEBUG=myloggername npm test -t "My Test Name" |
I was seeing console logs appear sporadically when watching a single test. Sometimes I would see all logs, other times none, and other times I would see some of them but not all of them. Each time the test ran I would see something different. 😒
https://jestjs.io/docs/en/configuration#verbose-boolean Related StackOverflow thread: https://stackoverflow.com/questions/48695717/console-log-statements-output-nothing-at-all-in-jest |
jest doesn't handle logging well on multiple levels. it should
that's it. not complicated really. |
My guess is, they're capturing the console logs because they're trying to get asynchronous output to print in a sane order when running tests. The problem is that if this logging code doesn't work for a user, in their environment, they're pretty much hosed.
I stopped using jest years ago, because I couldn't reliably get console output when debugging tests, i matter what suggestions I followed in this thread.
The moral of the story is, don't mess with the global console. EVER. If you want to provide a logger that can be turned on or off great do that. I'll use it if I want. But the global console should not be interfered with.
Get Outlook for iOS<https://aka.ms/o0ukef>
…________________________________
From: earonesty <[email protected]>
Sent: Wednesday, August 12, 2020 12:33:23 PM
To: facebook/jest <[email protected]>
Cc: Chris Grimes <[email protected]>; Mention <[email protected]>
Subject: Re: [facebook/jest] console.log does not output when running tests (#2441)
jest doesn't handle logging well on multiple levels. it should capture logs and show them on failure by default, have an option to show none at all, and have an option to show all. that's it.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub<#2441 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AAFCNBK5MQEA6AJHEC52ZWDSALG6HANCNFSM4C2VWUXQ>.
|
@halis I've used Jest on and off for about four years and this has always been a problem. The result is that Jest tests are quite difficult to debug. My sense is that Jest's main play is to be happy to break expected behaviour & semantics now and then if it drastically improves the testing experience. Things like the autohoisting of Is that a bad thing? Clearly not necessarily, as Jest is enormously successful. But I do think Jest has the capacity to surprise you once in a while. I'm pretty sure 90% of Jest users have no idea their code is AST-transformed to hoist mock calls, for example. |
WHAT |
Try using |
You can use https://nodejs.org/api/process.html#process_a_note_on_process_i_o |
I've been struggling with this again today and the |
I was struggling with the same issue, logs weren't showing when a test failed. I managed to get my |
I want to add myupvote to this and support what @halis has written above: Never ever mess with the global console. I know that what jest is doing may seem "logical" if you are a real expert in coding of parallel runing asynchrounous TDD test code. But most jest users will be confused, where their log outputs are. See [1] [2] [3] ... Catching console.log() in asynchrounous test is a nice idea for parallel running tests as a configuration option. But it shouldn't be the default. |
I'm 2 weeks into learning react and ran into this issue. I wanted to share my solution as none of the suggestions above worked for me (neither
It's crude and ugly, but it works for debugging test code I've written. Here's the output I get:
|
@badiozam The problem with that approach is that it only works for logs in the test functions themselves, i.e. that have the require statement in their closures. The code under test won't have access to that scope, unless it's written in an IOC style allowing you to manually pass the logger in. What we really want is a reliable, synchronous, unbuffered output to stderr and stdout. It seems like |
@jbreckmckye yeah I agree, and I'm surprised that it's not easily available in such a widely used package and platform. We spent quite a bit of time trying to get it to work with We did indeed end up with the scenario you pointed out above and the code under test wouldn't output anything, even though the test code would. Our solution was to just explicitly include the import statement in that code as well. Desperate times indeed, but since our app ships with all log output stripped out anyway, it was a relatively easy choice to make. Here's a sample of that which worked for us:
|
Shouldn't this issue be reopened? Does not look solved yet, even though the long discussion. IMHO this issue is the main one that keeps popping out every time and that limits productivity, working with Jest. There are so many suggested solutions but not a consistent/confirmed one. Why not to add a FAQ and provide a streamlined solution recommended by the authors? |
…jest#2441 while trying to make these work. !@#$%^&*-jest!)
I could it by using |
This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs. |
Do you want to request a feature or report a bug?
Report a bug.
What is the current behavior?
Calling
console.log
using the default testEnvironment ofjsdom
doesn't print to stdout.If the current behavior is a bug, please provide the steps to reproduce and either a repl.it demo through https://repl.it/languages/jest or a minimal repository on GitHub that we can
yarn install
andyarn test
.yarn test
testEnvironment
Jest configuration setting tonode
yarn test
What is the expected behavior?
I would expect to have console.log always output while my tests are running.
Please provide your exact Jest configuration and mention your Jest, node, yarn/npm version and operating system.
See
package.json
andyarn.lock
in the repo for package versions. I'm running node 7.3.0 and yarn 0.18.1The text was updated successfully, but these errors were encountered: