Closed
Bug 1400181
Opened 7 years ago
Closed 7 years ago
Error messages prefixed with numbers, so treeherder classification doesn't find bug suggestions - drop them
Categories
(Testing :: Mochitest, defect)
Tracking
(firefox-esr52 unaffected, firefox55 unaffected, firefox56 unaffected, firefox57 fixed)
RESOLVED
FIXED
mozilla57
Tracking | Status | |
---|---|---|
firefox-esr52 | --- | unaffected |
firefox55 | --- | unaffected |
firefox56 | --- | unaffected |
firefox57 | --- | fixed |
People
(Reporter: aryx, Assigned: gbrown)
References
Details
(Keywords: regression)
Attachments
(1 file)
2.14 KB,
patch
|
ahal
:
review+
|
Details | Diff | Splinter Review |
Connection error messages started to get prefixed with a number during the last days, e.g. https://treeherder.mozilla.org/logviewer.html#?job_id=131191229&repo=autoland&lineNumber=2085
> [task 2017-09-15T05:03:22.524Z] 05:03:22 INFO - 0 ERROR Automation Error: Received unexpected exception while running application
Now Treeherder's "Failure summary" tab doesn't suggested bug 1261598 for that line anymore.
This seems to have started during the last 2 days as https://treeherder.mozilla.org/logviewer.html#?job_id=131210045&repo=autoland&lineNumber=38647 hasn't these numbers.
Comment 1•7 years ago
|
||
This is actually a Mochitest job and not Marionette. Having a look at the error message it appears only once in the tree in testing/mochitest/runtests.py. Changes to this file have been done in the last two days by Geoff via bug 1394910 and bug 1399769.
Both bugs change things around result values but not what we print out. But maybe that is connected. Geoff, do you have an idea?
Component: Marionette → Mochitest
Flags: needinfo?(gbrown)
Updated•7 years ago
|
status-firefox57:
--- → affected
Keywords: regression
Assignee | ||
Comment 2•7 years ago
|
||
It's not just error messages, but all "interior" INFO or ERROR or WARNING messages:
[task 2017-09-15T05:05:47.687Z] 05:05:47 INFO - GECKO(1214) | MEMORY STAT | vsize 912MB | residentFast 226MB | heapAllocated 86MB
[task 2017-09-15T05:05:47.691Z] 05:05:47 INFO - 5 INFO TEST-OK | browser/base/content/test/alerts/browser_notification_close.js | took 12867ms
[task 2017-09-15T05:05:48.014Z] 05:05:48 INFO - 6 INFO checking window state
[task 2017-09-15T05:05:48.151Z] 05:05:48 INFO - GECKO(1214) | --DOMWINDOW == 11 (0xda350800) [pid = 1214] [serial = 7] [outer = (nil)] [url = about:blank]
[task 2017-09-15T05:05:48.169Z] 05:05:48 INFO - 7 INFO TEST-START | browser/base/content/test/alerts/browser_notification_do_not_disturb.js
I don't think this is related to my changes, but will have a closer look.
Assignee | ||
Comment 3•7 years ago
|
||
This started with https://treeherder.mozilla.org/#/jobs?repo=mozilla-inbound&revision=e5414216229f41390263910a8ec2fb73975ba15c, bug 1371065 / bug 1399216.
:kmag -- Do you know what happened here?
Blocks: 1371065
Flags: needinfo?(gbrown) → needinfo?(kmaglione+bmo)
Comment 4•7 years ago
|
||
This looks like maybe something is going wrong with the structured log handling in the Mochitest harness.
The log from comment 0 ( https://public-artifacts.taskcluster.net/AKvlwugwRvu1XsGNp5A67g/0/public/logs/live_backing.log ) has this line:
[task 2017-09-15T05:03:22.628Z] 05:03:22 ERROR - 1 ERROR TEST-UNEXPECTED-FAIL | leakcheck | default process: missing output line for total leaks!
and the raw structured log ( https://public-artifacts.taskcluster.net/AKvlwugwRvu1XsGNp5A67g/0/public/test_info//browser-chrome-chunked_raw.log ) has this line:
{"source": "mochitest", "thread": "MainThread", "time": 1505451802627, "action": "log", "message": "TEST-UNEXPECTED-FAIL | leakcheck | default process: missing output line for total leaks!", "level": "ERROR", "pid": 1050}
Which looks sensible, so this must be breaking at the "format structured log" stage of things.
Comment 5•7 years ago
|
||
I double checked those patches and don't see anything that should have caused those changes. There are some places where I changed the structured log settings to remove 'jetpack' references, but it doesn't look like any of them should have affected other mochitest flavors.
Flags: needinfo?(kmaglione+bmo)
Assignee | ||
Comment 6•7 years ago
|
||
Thanks kmag; your changes look OK to me too, but...
Mochitest logs from before kmag's changes show
"Structured output parser in use for mochitest"
Emitted by https://dxr.mozilla.org/mozilla-central/rev/f9a5e9ed62103c84e4cde915f4d08f1ce71be83e/testing/mozharness/scripts/desktop_unittest.py#516, which is dependent on the mozharness config's "unstructured_flavors".
Current mochitest logs, with the extra numbers, do not have "Structured output parser in use for mochitest".
Comment 7•7 years ago
|
||
Oh! I think this just exposed a dumb bug in the existing mozharness code then.
kmag's changes emptied out the 'unstructured_flavors' entry for mochitest (rightfully so):
https://hg.mozilla.org/integration/mozilla-inbound/diff/f725597fa0b4/testing/mozharness/configs/unittests/linux_unittest.py#l1.32
but the check in `structured_output` does:
if not unstructured_flavors.get(suite_category) or flavor in unstructured_flavors.get(suite_category):
return False
https://dxr.mozilla.org/mozilla-central/rev/f9a5e9ed62103c84e4cde915f4d08f1ce71be83e/testing/mozharness/scripts/desktop_unittest.py#508
...and since `unstructured_flavors.get(suite_category)` is now an empty list, that will return False. That seems wrong.
Comment 8•7 years ago
|
||
Hm. Intersting. It seems to be caused by this check:
http://searchfox.org/mozilla-central/rev/2c9a5993ac40ec1db8450e3e0a85702fa291b9e2/testing/mozharness/scripts/desktop_unittest.py#507-508
since an empty array is treated as falsy.
That doesn't seem right... or at least doesn't seem intuitive... since an empty array is treated completely differently than an array with any other number of items.
Are all of the other suites listed intended to have unstructured output?
http://searchfox.org/mozilla-central/rev/2c9a5993ac40ec1db8450e3e0a85702fa291b9e2/testing/mozharness/configs/unittests/linux_unittest.py#297-304
If so, I'll just remove the `"mochitest": []` entries, which should fix the problem.
Comment 9•7 years ago
|
||
(mid-aired Ted's nearly identical comment)
Assignee | ||
Comment 10•7 years ago
|
||
ahal -- Can you confirm: Other than mochitest, are all of these unstructured?
"unstructured_flavors": {"mochitest": [],
"xpcshell": [],
"gtest": [],
"mozmill": [],
"cppunittest": [],
"jittest": [],
"mozbase": [],
},
Flags: needinfo?(ahalberstadt)
Assignee | ||
Comment 11•7 years ago
|
||
I'm pretty sure that's the case; that is,
"xpcshell": []
means "xpcshell is unstructured, regardless of flavor", and this only got confusing because there was
"mochitest": ["jetpack"]
meaning, "only jetpack mochitests are unstructured".
Assignee: nobody → gbrown
Flags: needinfo?(ahalberstadt)
Attachment #8908763 -
Flags: review?(ahalberstadt)
Comment 12•7 years ago
|
||
Comment on attachment 8908763 [details] [diff] [review]
enable structured logging support for mochitest in mozharness
Review of attachment 8908763 [details] [diff] [review]:
-----------------------------------------------------------------
Yes this looks good.
I agree this behaviour is weird and confusing. Now that none of the suites have subsuites that need to be stay unstructured, we should just turn this into a list, e.g:
unstructured_suites = ['xpcshell', 'cppunittest', ...]
But let's leave that to a follow up.
Attachment #8908763 -
Flags: review?(ahalberstadt) → review+
Comment 13•7 years ago
|
||
Pushed by gbrown@mozilla.com:
https://hg.mozilla.org/integration/mozilla-inbound/rev/8a5a46b8c9d1
Return mochitests to structured logging; r=ahal
Reporter | ||
Comment 14•7 years ago
|
||
bugherder |
Status: NEW → RESOLVED
Closed: 7 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla57
Updated•7 years ago
|
status-firefox55:
--- → unaffected
status-firefox56:
--- → unaffected
status-firefox-esr52:
--- → unaffected
You need to log in
before you can comment on or make changes to this bug.
Description
•