-
Notifications
You must be signed in to change notification settings - Fork 30.3k
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
deps: check in gtest, add util unit test #1199
Conversation
I don't think we should build gtest unless invoking |
What @jbergstroem said, otherwise LGTM! Good job, @bnoordhuis |
Blows up on SmartOS. Looking into it. |
Updated the Makefile to build out/Release/cctest only when running |
Come to think of it, this unfortunately won't show any build/test errors with gtest until it's landed and added to test-simple/message (for the foreseeable future). If others agree, I'd be ok with "abusing" Makefile for this branch until we're happy with the result, then clean before merging. |
I'm not sure what you mean by that. |
Abuse was a poor choice of word. What I meant was letting gtest build with plain |
Re SmartOS: The problem is (was) that you built the tests twice and tried to link them; once from -all and then individually. This fixes it: diff --git deps/gtest/gtest.gyp deps/gtest/gtest.gyp
index d58d065..90388e3 100644
--- deps/gtest/gtest.gyp
+++ deps/gtest/gtest.gyp
@@ -8,7 +8,6 @@
},
'include_dirs': ['.', 'include'],
'sources': [
- 'src/gtest-all.cc',
'src/gtest-death-test.cc',
'src/gtest-filepath.cc',
'src/gtest-internal-inl.h', (also, feel free to kill that file) I'd be keen to see some different versions of Windows have a run at this before we commit. Also, is it common gtest practise to have tests live with src? I'd prefer moving them to |
Also suggesting we split building tests from running them. I'd like to build everything necessary before running it -- makes output easier to follow (this needs to be fixed for other tests as well). |
I might be running ahead of time here, but I'd suggest plugging this in from the get-go. Looks simple enough: https://github.com/kinow/gtest-tap-listener Thoughts? |
Did some minor work here: https://github.com/jbergstroem/io.js/tree/pr/1199 We need to provide TAP consumers with a bit more information about what suite is running. |
Incorporated @jbergstroem's fixups, PTAL. CI: https://jenkins-iojs.nodesource.com/view/iojs/job/iojs+any-pr+multi/414/ @jbergstroem Let me know if (and esp. how) you want attribution. |
@bnoordhuis no attribution needed; just happy to see it go in. |
@jbergstroem pointed out that Jenkins currently runs |
Looks like it needs an update to vcvars.bat in order to build the test suite on Windows. |
https://jenkins-iojs.nodesource.com/view/iojs/job/iojs+any-pr+multi/422/ Side note: I think I'm going to revert the changes to the Makefile that make cctest a separate build target. Making it a dependency of the iojs target means no one can accidentally break the C++ test suite because they forgot to run It's also consistent with the VS build (where cctest is always built) and it removes two recursive make calls from |
The test run looks ok. Good. I don't think the argument of not breaking holds -- doesn't the same apply for all javascript functionality? My opinion is that cctest belongs with I'm not super happy about how our Makefile recurses All The Things, but I don't think we should "fix" that with this PR. How about possibly doing a build-test-step that calls builds cctest, addons, doctests, etc and then clean out all the other test build dependency targets? Regardless if you insist on building cctest with the default target you have my LGTM on this. Great job; looking forward to simplifying the doc/addon test situation as well as expanding test coverage. |
The primary reason is that making it part of the main build keeps things consistent with Windows. I value consistency more than the few seconds it shaves off someone's non-test build. I reordered things a little so that cctest runs before the JS tests. They didn't run on the ARM buildbots before because the JS test suite always fails due to timeouts. PTAL. New (and hopefully final) CI: https://jenkins-iojs.nodesource.com/view/iojs/job/iojs+any-pr+multi/427/ |
Compilation order: Ok, it's a minor change but the purist in me will revisit this once the test suit grows :-) The timeout stuff will go away when we migrate to Changes and overall is LGTM. |
Check in a gypified gtest and add a simple unit test to show that the basic infrastructure is in place. PR-URL: nodejs#1199 Refs: nodejs#1193 Reviewed-By: Fedor Indutny <[email protected]> Reviewed-By: Johan Bergström <[email protected]>
Check in a gypified gtest and add a simple unit test to show that the
basic infrastructure is in place.
Refs: #1193
R=@indutny and /cc @jbergstroem
https://jenkins-iojs.nodesource.com/view/iojs/job/iojs+any-pr+multi/333/