-
Notifications
You must be signed in to change notification settings - Fork 7.5k
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
Monkeypatch canPlayType on Android 4.0+ for HLS #1084
Merged
Merged
Changes from all commits
Commits
Show all changes
14 commits
Select commit
Hold shift + click to select a range
e35083b
Monkeypatch canPlayType on Android 4.0+ for HLS
gkatsev 252ad3f
be case insensitive
gkatsev 5381f70
+ vjs.Html5.{patchCanPlayType,unpatchCanPlayType}
gkatsev 86c3f94
fix up jshint errors
gkatsev f86e073
Switch HTMLVideoElement to constructor reference
gkatsev 817253b
Also, switch out HTMLVideoElement to constructor reference in tests
gkatsev 0c856ce
call unpatchCanPlayType after tests
gkatsev f1d2aef
Don't assume only mimetype available for matching
gkatsev fef6282
remove unused var
gkatsev 75bd76f
return the patched function from unpatchCanPlayType
gkatsev 94ec725
update for IE8 and fixup stupid tests
gkatsev d21019a
add existence test for patch and unpatch methods
gkatsev e2a1cac
fix typo for unpatchCanPlayType
gkatsev e39557e
Always unpatch canPlayType.
gkatsev File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -38,3 +38,59 @@ test('should re-link the player if the tech is moved', function(){ | |
|
||
strictEqual(player, tech.el()['player']); | ||
}); | ||
|
||
test('patchCanPlayType and unpatchCanPlayType are available on Html5 object', function() { | ||
ok(vjs.Html5.patchCanPlayType, 'patchCanPlayType is available'); | ||
ok(vjs.Html5.unpatchCanPlayType, 'unpatchCanPlayType is available'); | ||
}); | ||
|
||
test('patchCanPlayType patches canplaytype with our function, conditionally', function() { | ||
var oldAV = vjs.ANDROID_VERSION, | ||
video = document.createElement('video'), | ||
canPlayType = vjs.TEST_VID.constructor.prototype.canPlayType, | ||
patchedCanPlayType, | ||
unpatchedCanPlayType; | ||
|
||
vjs.ANDROID_VERSION = 4.0; | ||
vjs.Html5.patchCanPlayType(); | ||
|
||
notStrictEqual(video.canPlayType, canPlayType, 'original canPlayType and patched canPlayType should not be equal'); | ||
|
||
patchedCanPlayType = video.canPlayType; | ||
unpatchedCanPlayType = vjs.Html5.unpatchCanPlayType(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. unpatchedCanPlayType isn't currently used |
||
|
||
strictEqual(canPlayType, vjs.TEST_VID.constructor.prototype.canPlayType, 'original canPlayType and unpatched canPlayType should be equal'); | ||
strictEqual(patchedCanPlayType, unpatchedCanPlayType, 'patched canPlayType and function returned from unpatch are equal'); | ||
|
||
vjs.ANDROID_VERSION = oldAV; | ||
vjs.Html5.unpatchCanPlayType(); | ||
}); | ||
|
||
test('should return maybe for HLS urls on Android 4.0 or above', function() { | ||
var oldAV = vjs.ANDROID_VERSION, | ||
video = document.createElement('video'); | ||
|
||
vjs.ANDROID_VERSION = 4.0; | ||
vjs.Html5.patchCanPlayType(); | ||
|
||
strictEqual(video.canPlayType('application/x-mpegurl'), 'maybe', 'android version 4.0 or above should be a maybe for x-mpegurl'); | ||
strictEqual(video.canPlayType('application/x-mpegURL'), 'maybe', 'android version 4.0 or above should be a maybe for x-mpegURL'); | ||
strictEqual(video.canPlayType('application/vnd.apple.mpegurl'), 'maybe', 'android version 4.0 or above should be a maybe for vnd.apple.mpegurl'); | ||
strictEqual(video.canPlayType('application/vnd.apple.mpegURL'), 'maybe', 'android version 4.0 or above should be a maybe for vnd.apple.mpegurl'); | ||
|
||
vjs.ANDROID_VERSION = oldAV; | ||
vjs.Html5.unpatchCanPlayType(); | ||
}); | ||
|
||
test('should return a maybe for mp4 on OLD ANDROID', function() { | ||
var isOldAndroid = vjs.IS_OLD_ANDROID, | ||
video = document.createElement('video'); | ||
|
||
vjs.IS_OLD_ANDROID = true; | ||
vjs.Html5.patchCanPlayType(); | ||
|
||
strictEqual(video.canPlayType('video/mp4'), 'maybe', 'old android should return a maybe for video/mp4'); | ||
|
||
vjs.IS_OLD_ANDROID = isOldAndroid; | ||
vjs.Html5.unpatchCanPlayType(); | ||
}); |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@gkatsev are these meant to check that the functions exist after minifying?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
um... yes. Though, I guess would we want to check that it as a string so it doesn't get minified since we want those functions exported?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I typically do that in the api.js file, though I guess a string key would do the same thing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could move this test there if you think it would be a better place for them.