Bug 151262

Summary: WebKit should not need to modify testharness.js
Product: WebKit Reporter: youenn fablet <youennf>
Component: Tools / TestsAssignee: youenn fablet <youennf>
Status: RESOLVED FIXED    
Severity: Normal CC: ap, commit-queue, darin, lforschler
Priority: P2    
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 150332    
Attachments:
Description Flags
Patch none

youenn fablet
Reported 2015-11-13 08:56:02 PST
Currently WebKit has its own version of testharness.js. The modification is related to timeout values. It may just be better to disable testharness timeout in testharnessreport.js This will simplify further updates of testharness.js
Attachments
Patch (2.32 KB, patch)
2015-11-13 08:58 PST, youenn fablet
no flags
youenn fablet
Comment 1 2015-11-13 08:58:13 PST
Alexey Proskuryakov
Comment 2 2015-11-13 09:17:01 PST
I'm not sure if we can expect that the default timeout will suffice for us. I believe that the tests are designed to work sequentially, but we run them in parallel, which can cause almost 10x slowdown.
youenn fablet
Comment 3 2015-11-13 09:28:26 PST
(In reply to comment #2) > I'm not sure if we can expect that the default timeout will suffice for us. > I believe that the tests are designed to work sequentially, but we run them > in parallel, which can cause almost 10x slowdown. AFAICT, there are two testharness timeouts, one for each subtest and one for each file. The values modified in testharness.js only apply to the global timeout. explicit_timeout=true disables the global timeout, so this should be fine to reset those value to their default. As of the subtest timeout, by default, none is set. This is done by the author, writing something like async_test("title", {timeout: 1000}). If we want to increase these values compared to what is done currently, we can use timeout_multiplier in testharnessreport.js.
Alexey Proskuryakov
Comment 4 2015-11-13 09:33:09 PST
> AFAICT, there are two testharness timeouts, one for each subtest and one for each file. Right, what I'm saying is that per-file timeouts are likely wrong for our environment. > If we want to increase these values compared to what is done currently, we can use timeout_multiplier in testharnessreport.js. That may be OK, especially if that means that per-file timeouts are also increased.
youenn fablet
Comment 5 2015-11-13 09:41:41 PST
> That may be OK, especially if that means that per-file timeouts are also > increased. timeout_multiplier only applies to per-test timeout. This is ok since this patch disables per-file timeout by setting "explicit_timeout" to true. Doing a quick grep, it seems that a little bit more than 100 tests do set per-test timeouts.
Alexey Proskuryakov
Comment 6 2015-11-13 09:59:35 PST
So do we need to keep doing what we are doing, but also set the multiplier in addition?
youenn fablet
Comment 7 2015-11-13 10:15:23 PST
(In reply to comment #6) > So do we need to keep doing what we are doing, but also set the multiplier > in addition? First step is this patch. It should not change the testing behavior, but is just a cleaner way to integrate testharness.js. Then, we may consider using multiplier, which actually changes the testing behavior. It may be the case that a subtest is timeouting but not the whole test file. Using multiplier may make the whole test file timeouting.
Alexey Proskuryakov
Comment 8 2015-11-13 19:53:02 PST
I'm not sure if I follow. I do not object to this patch, just don't understand what we are up to.
youenn fablet
Comment 9 2015-11-14 01:20:54 PST
(In reply to comment #8) > I'm not sure if I follow. I do not object to this patch, just don't > understand what we are up to. This patch does two things: 1. Remove WebKit custom changes to testharness.js. For future syncing of testharness.js, we will no longer need to port WebKit changes to the new testharness.js. This will also allow bug 150332 which ensures that web-platform-test tests use the expected testharness.js version. 2. Update testharnessreport.js to disable testharness.js per-file timeout that would otherwise kick in before WebKit timeout due to changes done in step 1. Basically, this patch does not change anything except that it uses testharness.js/testharnessreport.js in a proper manner.
Alexey Proskuryakov
Comment 10 2015-11-14 12:05:35 PST
Let's consider a test that currently takes 15 seconds, and doesn't have a per-file timeout. It currently passes on Mac, because run-webkit-tests timeout is 30 seconds. What will keep it passing after these changes?
youenn fablet
Comment 11 2015-11-14 16:15:18 PST
(In reply to comment #10) > Let's consider a test that currently takes 15 seconds, and doesn't have a > per-file timeout. It currently passes on Mac, because run-webkit-tests > timeout is 30 seconds. > > What will keep it passing after these changes? This test will see no change as this test is not testharness.js based. A test with testharness.js currently always has a per-file js-controlled timeout, which is set to a big value. After this change, all testharness.js tests will no longer have per-test js-controlled timeouts.
WebKit Commit Bot
Comment 12 2015-11-15 08:01:51 PST
Comment on attachment 265481 [details] Patch Clearing flags on attachment: 265481 Committed r192461: <http://trac.webkit.org/changeset/192461>
WebKit Commit Bot
Comment 13 2015-11-15 08:01:54 PST
All reviewed patches have been landed. Closing bug.
Alexey Proskuryakov
Comment 14 2015-11-15 10:45:24 PST
> A test with testharness.js currently always has a per-file js-controlled timeout, which is set to a big value. In comment 9, you said that opposite - that "per-file timeout that would otherwise kick in before WebKit timeout". I still don't understand this change. It may be correct, but the explanations are self-contradicting.
youenn fablet
Comment 15 2015-11-15 11:33:27 PST
(In reply to comment #14) > > A test with testharness.js currently always has a per-file js-controlled timeout, which is set to a big value. > > In comment 9, you said that opposite - that "per-file timeout that would > otherwise kick in before WebKit timeout". I am sorry if my explanations are not clear enough, but I do not see any contradiction between c9 and c14. Here is another try. Before this patch, the situation is as follow: - testharness.js sets a per-file JS timeout of 1000 seconds (c14) - WKR sets a WK timeout of 30 seconds in debug mode - testharnessreport.js does not change testharness.js JS timeout Conclusion: - testharness.js JS timeout never kicks in After this patch, the situation can be described as follow: - testharness.js sets a per-file JS timeout of 10 seconds - WKR sets a WK timeout of 30 seconds in debug mode, hence why the JS timeout would kick (c9) in except that... - testharnessreport.js disables testharness.js JS timeout Conclusion: - testharness.js JS timeout never kicks in Is that clearer?
Alexey Proskuryakov
Comment 16 2015-11-15 13:17:16 PST
Where does the phrase "per-file timeout" come from? I don't see it in code. What this patch does is change default timeout in testharness.js, not a "per-file timeout".
youenn fablet
Comment 17 2015-11-16 02:13:35 PST
(In reply to comment #16) > Where does the phrase "per-file timeout" come from? I don't see it in code. Ah, maybe that is where the confusion comes from. This term was only coined as part of this discussion (#c4). To summarize, each testharness.js test is guarded by 3 different timeout mechanisms: 1. WTR timeout (global "per-test-file" timeout) 2. testharness.js Tests.timeout_id (global "per-test-file" timeout, default length defined by harness_timeout) 3. testharness.js Test.timeout_id ("per-test" timeout, disabled by default, can be set for each test/async_test explicitly in the html test file). What this patch does is disabling the second timeout, Tests.timeout_id. > What this patch does is change default timeout in testharness.js, not a > "per-file timeout". It does so because this patch also ensures Tests.timeout_id is always cleared during testharness setup phase.
Alexey Proskuryakov
Comment 18 2015-11-16 09:56:02 PST
> 2. testharness.js Tests.timeout_id (global "per-test-file" timeout, default length defined by harness_timeout) > 3. testharness.js Test.timeout_id ("per-test" timeout, disabled by default, can be set for each test/async_test explicitly in the html test file). What is the difference between "per-test-file" and "per-test"?
youenn fablet
Comment 19 2015-11-16 10:14:50 PST
> What is the difference between "per-test-file" and "per-test"? per-test-file means the execution of a whole HTML file. per-test means the execution of JS code inside a test() or async_test() block. As can be seen in LayputTests/streams/reference-implementation, a single HTML test file may contain several tests. Testharness.js defines Tests and Test to handle that.
youenn fablet
Comment 20 2015-11-16 10:25:17 PST
Note You need to log in before you can comment on or make changes to this bug.