-
Notifications
You must be signed in to change notification settings - Fork 6
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
Updating cue time attributes can generate unexpected events #19
Comments
By what mechanism is it possible to update a cue I ask because I seem to recall that javascript runs single-threaded and I don't expect client javascript code to get any chance to run in the middle of the algorithm. Is there a way for them to run on separate threads without appropriate resource locks being in place, for example? |
To clarify, I mean that the 'time marches on' algorithm can run between steps 1-3, as it's typically triggered by a timer and interrupts the application thread. I do not mean that 'time marches on' can be interrupted. |
Nothing ties the "time marches on" algorithm to the event loop and I suspect all browsers run it in a separate thread in practice. Updating The spec does not say much about what needs to happen if the algorithm is already running when this happens. Is it up to implementations? Will the update be immediately taken into account? The statement "the user agent must wait for the steps to complete, and then must immediately rerun the steps" is probably meant to apply to that situation as well, meaning that the algorithm will re-run. But first run can probably still create the unexpected |
Thanks for the additional explanations @rjksmith and @tidoust . The first line in the issue says:
The trouble I have with this statement is that I think the events are entirely expected in the circumstances described, and I don't see how it can be any other way. This issue describes a race condition between a cue ending (or starting) and its end (or start) time being updated. As the time when the update is applied tends towards the time being updated (or the new time post-update), then this race condition becomes less deterministic, with actual observed behaviour likely to depend on factors beyond the control of a specification. If I've read this correctly @rjksmith you're suggesting that not everybody might realise that this issue could occur, and some folk might occasionally get caught out by it, so you want to call attention to it somewhere? What would you say? Practically speaking, I have been unable to think of any steps that could be taken either in user agent implementations or in user code to mitigate the issue. If the issue is causing a regular problem for a particular user, then presumably they have an application that sits right at the "leading edge" and is often updating cue times very close to the times being updated, perhaps because they have a very low latency system that runs "just in time". I'm not sure that advising such a user to increase the latency of their system would be what they would want to hear! |
This is something we should consider in the DataCue spec, as cues could be updated either through application script or by being updated by the UA, e.g., for in-band events. It's not clear to me whether this issue should result in a proposed change to HTML (e.g., to add an informative note), or whether it doesn't need calling out in the spec as it's expected behaviour. |
I agree. A key issue is whether a cue is generated by the app or user agent, and how to correctly handle and discriminate between those cases. I'm not proposing any changes to HTML at this stage, but am keen to ensure any changes we do propose address the proper issues. The expected behaviour for a cue is to raise one |
I think there are some unstated assumptions behind this statement, which are worth being explicit about. I think there is only one specific case in which that is the expected behaviour, which is when the associated media is played through exactly once with no pause or seek events. In any other case there will very likely be some other number of The higher level question is how well that algorithm deals with all those scenarios when the cue times themselves are also being modified. I agree there's no specific problem highlighted so far that would motivate a change to HTML, and that in proposing any changes to the Text Track Cue interface we should be careful not to introduce any such problems, or if they are unavoidable, propose a solution. |
The events are unexpected because there are circumstances in which a user cannot know whether changing a cue time attribute will generate either one or two pairs of |
Generally users don't change cue time attributes, but content providers might. Content providers can, in general, never know how many |
|
I'm thinking about this thread and realising that I feel like I'm being a bit, I don't know, snipey, picking up on seemingly minor details, so a) I probably am and b) I'm sorry about that @rjksmith . It isn't at all clear to me that there's actually anything wrong here. What is a "spurious" event seems to be in the eye of the beholder. If you imagine yourself in the position of the user agent processing all the incoming events, including those that update cue times, and those that have been generated during the course of handling events, you're just doing your job, everything's fine. None of the events is spurious, they're all just events you're required to fire. Keep on rolling. If you imagine yourself in the position of the user observing some presentational artefact of a cue, there may very occasionally be some visible strange behaviour for cues that might be subject to late changes. Looking back at the original issue text:
|
Updating the
startTime
orendTime
attributes of a cue (TextTrackCue
orDataCue
) can generate unexpectedenter
andexit
events depending on the sequence in which the steps happen.For example, if the cue
endTime
is updated to a later time just before expiry, it is possible to generate anexit
event followed by anenter
event as follows:endTime
to a later time.Running the time marches on algorithm during this process producing differing results depending on where it occurs in the sequence of steps:
exit
event is generated as the cue expires before it is updated and anenter
event will be generated when the algorithm next runs.It should be noted that both these outcomes are correct, but generating multiple
enter
andexit
events for a single cue may be unexpected behaviour and users should be made aware of this possibility in order to design their code properly.A similar issue can occur if the
startTime
of an inactive cue is updated to a later time just before it is due to start.The text was updated successfully, but these errors were encountered: