Closed
Bug 589668
Opened 14 years ago
Closed 13 years ago
unit test boxes should upload a screen shot after testing, on Windows
Categories
(Testing :: General, enhancement, P5)
Tracking
(firefox11 wontfix, firefox12 wontfix, firefox13 wontfix)
VERIFIED
FIXED
mozilla14
People
(Reporter: karlt, Unassigned)
References
(Blocks 2 open bugs)
Details
Attachments
(1 file, 3 obsolete files)
(deleted),
patch
|
khuey
:
review+
|
Details | Diff | Splinter Review |
+++ This bug was initially created as a clone of Bug #414049 +++
The unit test boxes sometimes have mysterious failures due to focus, which can happen if someone logs in and leaves a console window open or probably other silly things. They should upload a screenshot somewhere (linked in the log file) so we could quickly spot check for that sort of problem.
Bug 414049 added data URL screenshots for timeouts with GTK builds.
This can be extended to other platforms by adding utility programs to dump the screen to stdout in png format.
Bug 414049 references a win32 screenshot utility that could be adapted, as well as some unsuccessful attempts to use screencapture on Mac.
Updated•14 years ago
|
Summary: unit test boxes should upload a screen shot after testing → unit test boxes should upload a screen shot after testing, on Windows (and OSX) too
Version: unspecified → Trunk
Comment 1•13 years ago
|
||
There is a separate bug for OS X now.
Summary: unit test boxes should upload a screen shot after testing, on Windows (and OSX) too → unit test boxes should upload a screen shot after testing, on Windows
Comment 2•13 years ago
|
||
Might be worth looking at https://github.com/mdrasmus/boxcutter
Comment 3•13 years ago
|
||
I already wrote the code for this:
http://hg.mozilla.org/users/tmielczarek_mozilla.com/screenshot-tools
Comment 4•13 years ago
|
||
I had to undef WIN32_LEAN_AND_MEAN in the program's source because it causes a bunch of errors. I looked at windows.h and added the headers that aren't included because of lean and mean. My understanding is that WIN32_LEAN_AND_MEAN's purpose is to avoid including unnecessary headers. Since this is a support program and takes seconds to build, I don't know how important it is to figure out why this is breaking.
https://tbpl.mozilla.org/?tree=Try&rev=503fb7736731
Assignee: nobody → jhford
Status: NEW → ASSIGNED
Comment 5•13 years ago
|
||
this is having issues, specifically screenshot.exe is returning 1 even though it is taking the screenshot.
Attachment #571838 -
Attachment is obsolete: true
Comment 6•13 years ago
|
||
Shouldn't the last line of wmain be something like
return stat == Ok ? 0 : 1;
i.e. returning 0 on success?
Comment 7•13 years ago
|
||
Updated per Cameron's comment 6.
This seems to mostly work (screenshot.exe is invoked and screen shot gets saved to temp directory correctly), but the code that actually reads the PNG and tries to add it to the log seems to fail - only the first few bytes are read, and the output is "SCREENSHOT: ".
This same code works on Mac, so I'm not sure what's up. Some Windows-specific python oddity with the way we're reading the file?
Comment 8•13 years ago
|
||
Comment 9•13 years ago
|
||
Presumably the open line needs to be changed to open(imgfilename, 'rb') to open it in binary mode. It would be nice to change screenshot.cpp to accept "-" as "write to stdout", but it looks like we'd need to implement something that implements the IStream COM interface, which looks like a gigantic mess, so this is probably simpler.
Comment 10•13 years ago
|
||
I made that change and pushed a test patch (which also introduces a test timeout) to try:
https://tbpl.mozilla.org/?tree=Try&rev=074f97c43d39
Comment 11•13 years ago
|
||
The try build failed:
['c:\\talos-slave\\test\\build\\bin\\screenshot.exe'] exited with code -1073741515
Google suggests that 0xc0000135 is apparently what you get when there's a missing dependency.
Comment 12•13 years ago
|
||
Oh, it worked on Rev3 WINNT 5.1 try debug, but not Rev3 WINNT 6.1 try opt.
Updated•13 years ago
|
Attachment #572031 -
Attachment is obsolete: true
Comment 13•13 years ago
|
||
Implementing something like http://hg.mozilla.org/users/jford_mozilla.com/jhford-native-rm/file/fb3e5e394fbc/rm.cpp#l32 might be worthwhile
Updated•13 years ago
|
Whiteboard: [autoland-try: -p win32 -u mochitests]
Updated•13 years ago
|
Whiteboard: [autoland-try: -p win32 -u mochitests] → [autoland-in-queue]
Comment 14•13 years ago
|
||
Autoland Patchset:
Patches: 595260
Branch: mozilla-central => try
Destination: http://hg.mozilla.org/try/pushloghtml?changeset=fbcb125c5b6f
Try run started, revision fbcb125c5b6f. To cancel or monitor the job, see: https://tbpl.mozilla.org/?tree=Try&rev=fbcb125c5b6f
Comment 15•13 years ago
|
||
Try run for fbcb125c5b6f is complete.
Detailed breakdown of the results available here:
https://tbpl.mozilla.org/?tree=Try&rev=fbcb125c5b6f
Results (out of 14 total builds):
success: 14
Builds (or logs if builds failed) available at:
http://ftp.mozilla.org/pub/mozilla.org/firefox/try-builds/autolanduser@mozilla.com-fbcb125c5b6f
Updated•13 years ago
|
Whiteboard: [autoland-in-queue]
Comment 16•13 years ago
|
||
(In reply to Mozilla RelEng Bot from comment #15)
> https://tbpl.mozilla.org/?tree=Try&rev=fbcb125c5b6f
It built "-p all -u none" :-(
Doesn't it support a space?
Whiteboard: [autoland-try:-p win32 -u mochitests]
Updated•13 years ago
|
Whiteboard: [autoland-try:-p win32 -u mochitests] → [autoland-in-queue]
Comment 17•13 years ago
|
||
Autoland Patchset:
Patches: 595260
Branch: mozilla-central => try
Destination: http://hg.mozilla.org/try/pushloghtml?changeset=ae857c1615a3
Try run started, revision ae857c1615a3. To cancel or monitor the job, see: https://tbpl.mozilla.org/?tree=Try&rev=ae857c1615a3
Comment 18•13 years ago
|
||
Try run for ae857c1615a3 is complete.
Detailed breakdown of the results available here:
https://tbpl.mozilla.org/?tree=Try&rev=ae857c1615a3
Results (out of 26 total builds):
exception: 1
success: 24
warnings: 1
Builds (or logs if builds failed) available at:
http://ftp.mozilla.org/pub/mozilla.org/firefox/try-builds/autolanduser@mozilla.com-ae857c1615a3
Updated•13 years ago
|
Whiteboard: [autoland-in-queue]
Comment 19•13 years ago
|
||
(In reply to Mozilla RelEng Bot from comment #18)
> https://tbpl.mozilla.org/?tree=Try&rev=ae857c1615a3
Hum, it passed, but the attached patch does not include the fake timeout trigger :-|
Comment 20•13 years ago
|
||
This patch works! Just needed a USE_STATIC_LIBS=1.
https://tbpl.mozilla.org/?tree=Try&rev=11bcdbd99f43
Attachment #595260 -
Attachment is obsolete: true
Comment 21•13 years ago
|
||
Not sure who should review this (if anyone). Can we just land it?
Updated•13 years ago
|
Attachment #604605 -
Flags: review?(rcampbell)
Updated•13 years ago
|
Assignee: jhford → gavin.sharp
status-firefox11:
--- → wontfix
status-firefox12:
--- → affected
Flags: in-testsuite-
OS: All → Windows XP
Comment 22•13 years ago
|
||
I don't think it's particularly worth reviewing the screenshot.cpp code, honestly. I can review the rest (or you can get khuey or someone to review it if that would make you feel better).
Comment 23•13 years ago
|
||
Comment on attachment 604605 [details] [diff] [review]
working patch
+
+ for(UINT j = 0; j < num; ++j)
+ {
+ if( wcscmp(pImageCodecInfo[j].MimeType, format) == 0 )
+ {
+ *pClsid = pImageCodecInfo[j].Clsid;
+ free(pImageCodecInfo);
+ return j; // Success
+ }
+ }
+
geez, ted. What's up with that indent? ;)
This is landable, but I'd like this to land AFTER the merge (tomorrow, March 13, 2012).
Ping for re-review then.
Comment 24•13 years ago
|
||
also, I think you can compile your screenshotter as straight-up C and save yourself some runtime size, if you care.
Comment 25•13 years ago
|
||
(In reply to Rob Campbell [:rc] (robcee) from comment #24)
> also, I think you can compile your screenshotter as straight-up C and save
> yourself some runtime size, if you care.
sorry, disregard. Looked more closely and see the gdiplus.h #include and using namespace calls.
carry on...
Comment 26•13 years ago
|
||
(In reply to Rob Campbell [:rc] (robcee) from comment #23)
> This is landable, but I'd like this to land AFTER the merge (tomorrow, March
> 13, 2012).
>
> Ping for re-review then.
Any particular reason? This doesn't seem very risky to me. The automation-touching bits are really minor, and it's gone through a successful try run.
Comment 27•13 years ago
|
||
Serge: could you please stop micro-managing bugs? I'm quite capable of requesting review and assigning bugs to myself, so if I don't do it there's usually a reason.
Comment 28•13 years ago
|
||
(In reply to Ted Mielczarek [:ted] from comment #26)
> (In reply to Rob Campbell [:rc] (robcee) from comment #23)
> > This is landable, but I'd like this to land AFTER the merge (tomorrow, March
> > 13, 2012).
> >
> > Ping for re-review then.
>
> Any particular reason? This doesn't seem very risky to me. The
> automation-touching bits are really minor, and it's gone through a
> successful try run.
I've been burned in the past by changes to our automation that caused the tree to light up. I don't want to do it to others. I don't see any urgency to take this before the merge.
Updated•13 years ago
|
Assignee: gavin.sharp → nobody
Updated•13 years ago
|
Attachment #604605 -
Flags: review?(rcampbell) → review?(khuey)
Comment 29•13 years ago
|
||
Comment on attachment 604605 [details] [diff] [review]
working patch
when you ran this through try did you happen to cause any tests to fail?
Comment 30•13 years ago
|
||
(In reply to Rob Campbell [:rc] (robcee) from comment #29)
> when you ran this through try did you happen to cause any tests to fail?
Yes, check comment 20.
Comment 31•13 years ago
|
||
Comment on attachment 604605 [details] [diff] [review]
working patch
someone just r+ this already! :P
Attachment #604605 -
Flags: review?(ted.mielczarek)
Attachment #604605 -
Flags: review?(rcampbell)
Attachment #604605 -
Flags: review?(khuey)
Comment on attachment 604605 [details] [diff] [review]
working patch
If it works, ship it.
Attachment #604605 -
Flags: review+
Updated•13 years ago
|
Attachment #604605 -
Flags: review?(ted.mielczarek)
Attachment #604605 -
Flags: review?(rcampbell)
Comment 33•13 years ago
|
||
Target Milestone: --- → mozilla14
Comment 34•13 years ago
|
||
(In reply to Gavin Sharp (use gavin@gavinsharp.com for email) from comment #33)
> https://hg.mozilla.org/integration/mozilla-inbound/rev/84f9eb64e005
This already went into action :-)
https://tbpl.mozilla.org/php/getParsedLog.php?id=10106644&tree=Mozilla-Inbound
Rev3 WINNT 6.1 mozilla-inbound opt test mochitests-3/5 on 2012-03-15 16:06:29 PDT for push 84f9eb64e005
{
11022 ERROR TEST-UNEXPECTED-FAIL | /tests/editor/libeditor/base/tests/test_bug586662.html | Test timed out.
args: ['c:\\talos-slave\\test\\build\\bin\\screenshot.exe', 'c:\\users\\cltbld\\appdata\\local\\temp\\mozilla-test-fail_okrms0']
SCREENSHOT: data:image/png;base64,[...]
}
status-firefox13:
--- → affected
Comment 35•13 years ago
|
||
Comment on attachment 604605 [details] [diff] [review]
working patch
[Approval Request Comment]
Regression caused by (bug #): (enhancement)
User impact if declined: None, but less help to diagnose test timeouts.
Testing completed (on m-c, etc.): comment 33.
Risk to taking this patch (and alternatives if risky): None, test (harness) only.
String changes made by this patch: None.
Attachment #604605 -
Flags: approval-mozilla-beta?
Attachment #604605 -
Flags: approval-mozilla-aurora?
Comment 36•13 years ago
|
||
Status: ASSIGNED → RESOLVED
Closed: 13 years ago
Resolution: --- → FIXED
Comment 37•13 years ago
|
||
http://tinderbox.mozilla.org/showlog.cgi?log=SeaMonkey/1331928910.1331934391.22023.gz
WINNT 5.2 comm-central-trunk debug test mochitest-other on 2012/03/16 13:15:10
{
6507 ERROR TEST-UNEXPECTED-FAIL | chrome://mochitests/content/a11y/accessible/relations/test_tabbrowser.xul | Test timed out.
args: ['e:\\builds\\slave\\test\\build\\bin\\screenshot.exe', 'c:\\docume~1\\seabld\\locals~1\\temp\\mozilla-test-fail_fgfyct']
SCREENSHOT: data:image/png;base64,[...]
}
V.Fixed
Status: RESOLVED → VERIFIED
Updated•13 years ago
|
Attachment #604605 -
Flags: approval-mozilla-beta?
Attachment #604605 -
Flags: approval-mozilla-aurora?
Updated•13 years ago
|
You need to log in
before you can comment on or make changes to this bug.
Description
•