Skip to content
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

[video_player_avfoundation] Platform view support #8237

Open
wants to merge 133 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 119 commits
Commits
Show all changes
133 commits
Select commit Hold shift + click to select a range
82d5333
Extract FVPFrameUpdater and FVPVideoPlayer from plugin file to separa…
FirentisTFW Nov 21, 2024
a2d3d9f
Add docs for FVPFrameUpdater and FVPVideoPlayer interfaces
FirentisTFW Nov 21, 2024
a74c720
Remove unused imports and #pragma statements
FirentisTFW Nov 21, 2024
9092b71
Add empty lines at the end of files
FirentisTFW Nov 21, 2024
add5719
Bump version to 2.6.4 and update changelog
FirentisTFW Nov 21, 2024
9587ad0
Move GLKit import from header file to source file
FirentisTFW Nov 21, 2024
83cec0c
Add FVPVideoPlayerPlugin_Test import to plugin file
FirentisTFW Nov 22, 2024
99123db
Fix parameter type in interface constructor
FirentisTFW Nov 22, 2024
9545fda
Separate plugin and factory classes by pragma mark
FirentisTFW Nov 25, 2024
75b5ab9
Add nullability type specifiers to FVPVideoPlayer interface
FirentisTFW Nov 25, 2024
5ec766f
Make properties not needed in header of FVPVideoPlayer private
FirentisTFW Dec 2, 2024
c958a4a
Use nonnull macro for the whole header file
FirentisTFW Dec 2, 2024
0a707a5
Make updatePlayingState private for FVPVideoPlayer
FirentisTFW Dec 2, 2024
0055ea3
Make texture registry private for FVPFrameUpdater
FirentisTFW Dec 2, 2024
717315e
Move code from Plugin_Test file to different files
FirentisTFW Dec 2, 2024
489f2a9
Make changelog description more general
FirentisTFW Dec 4, 2024
599adc8
Add a doc comment for FVPDefaultAVFactory
FirentisTFW Dec 4, 2024
513961c
Make lastKnownAvailableTime property of FVPFrameUpdater readonly
FirentisTFW Dec 4, 2024
ff11b63
Add _Test.h file for FVPVideoPlayer
FirentisTFW Dec 4, 2024
12efd58
Add FVPNativeVideoViewFactory and FVPNativeVideoView (everything in o…
FirentisTFW Nov 18, 2024
42c3724
Use platform view in Dart Code (hardcoded)
FirentisTFW Nov 18, 2024
968bbf1
Add PlatformVideoViewType enum to allow choosing between texture view…
FirentisTFW Nov 18, 2024
dc85756
Pass video view type to controller in iOS example project
FirentisTFW Nov 18, 2024
c9f27c5
Add two FVPVideoPlayer implementations - basic and texture-approach o…
FirentisTFW Nov 18, 2024
b3151e2
Split iOS native classes into multiple files
FirentisTFW Nov 19, 2024
db1a943
Only register native view factory for iOS, not MacOS
FirentisTFW Nov 19, 2024
0e3b346
Use only textue view on MacOS in example app
FirentisTFW Nov 19, 2024
6d317a5
Refactor imports
FirentisTFW Nov 19, 2024
9bace40
Allow choosing between texture view and platform view in example app
FirentisTFW Nov 19, 2024
3bf34f9
Remove redundant import
FirentisTFW Nov 19, 2024
40996c4
Add some fixme comments for later
FirentisTFW Nov 19, 2024
674f9d0
Add copyright to each native iOS file
FirentisTFW Nov 19, 2024
3806bd2
Rename viewId to playerId in params
FirentisTFW Nov 19, 2024
87e76ac
Unregister texture from registry only when using texture approach
FirentisTFW Nov 19, 2024
4d11c11
Clean up code, add more context in comments
FirentisTFW Nov 19, 2024
d4dc7e5
Fix most of existing unit tests by creating a player with texture vie…
FirentisTFW Nov 19, 2024
73564c7
Check platform view in UI test
FirentisTFW Nov 19, 2024
30f65c0
Only allow choosing between texture view and platform view in example…
FirentisTFW Nov 20, 2024
3cd5126
Only include native view files on iOS
FirentisTFW Nov 20, 2024
c96ca17
Make comments less ambiguous
FirentisTFW Nov 20, 2024
c26b210
Add unit tests for factory registration and lack of texture registrat…
FirentisTFW Nov 20, 2024
45862e3
Make viewType an optional parameter and default to textureView
FirentisTFW Nov 20, 2024
479dc37
Document new classes in native iOS code
FirentisTFW Nov 20, 2024
7fe29f7
Document VideoViewType on Dart side
FirentisTFW Nov 20, 2024
7f19bd1
Fix variable name
FirentisTFW Nov 20, 2024
f3eb9ea
Format files generated by pigeon
FirentisTFW Nov 20, 2024
a28b580
Use a class for platform view creation params
FirentisTFW Nov 20, 2024
da768fe
Remove unused param from method
FirentisTFW Nov 21, 2024
dd5637c
Fix failing unit test, prevent double factory registration
FirentisTFW Nov 21, 2024
5214aa5
Format pigeon generated file
FirentisTFW Nov 21, 2024
981eb8a
Use correct plugin key in test function
FirentisTFW Nov 21, 2024
85d5ac6
Update dartdocs and comments
FirentisTFW Nov 22, 2024
97490ae
Adjust FVPVideoPlayer interface after rebase
FirentisTFW Nov 25, 2024
fd777bd
Fix Xcode analysis issues
FirentisTFW Nov 25, 2024
bbf2efa
Split code into fiels and fix implementations to separate texture app…
FirentisTFW Nov 26, 2024
39dd125
Adjust tests to use FVPVideoPlayerTextureApproach
FirentisTFW Nov 26, 2024
ad38f1c
Make video_player platform interface backwards compatible
FirentisTFW Nov 26, 2024
fd64cbe
Bump iOS package version to 2.7.0
FirentisTFW Nov 26, 2024
5132b99
Add viewType parameter to VideoPlayerController and use it to display…
FirentisTFW Nov 26, 2024
4df6449
Improve if statements readability
FirentisTFW Nov 26, 2024
a885632
Rename textureId to playerId in onPlayerSetup
FirentisTFW Nov 26, 2024
3cb7389
Fix overriding create method from platform interface on iOS
FirentisTFW Nov 26, 2024
5dc241e
Start non-texture player ids from a high number to avoid collisions
FirentisTFW Nov 26, 2024
fe61a20
Update comments
FirentisTFW Nov 27, 2024
9c38562
Add viewType to FakeController in tests
FirentisTFW Nov 27, 2024
6705387
Use correct view type to create data source in the main package
FirentisTFW Nov 27, 2024
fe88ebf
Add unit tests for passing view type correctly
FirentisTFW Nov 27, 2024
85f088d
Throw an assertion if platform view is used on platform different tha…
FirentisTFW Nov 27, 2024
04d0e8d
Adjust example app to allow changing view type on iOS
FirentisTFW Nov 27, 2024
07874ee
Add missing doc comments
FirentisTFW Nov 27, 2024
eba2c36
Remove placeholder files which are not needed anymore
FirentisTFW Nov 27, 2024
c2defa6
Clean up player's properties after rebase
FirentisTFW Dec 4, 2024
508a212
Remove code related to platform view from the app facing package
FirentisTFW Dec 4, 2024
9a2934a
Merge branch 'main' into feature/video-player-platform-view-support
FirentisTFW Dec 5, 2024
1ee5082
Adjust interfaces after merge
FirentisTFW Dec 5, 2024
d9bb76a
Replace hyphens with asterisks in Changelog
FirentisTFW Dec 5, 2024
cea9254
Update public_header_files path for iOS
FirentisTFW Dec 5, 2024
9ef9355
Rename playersByTextureId to playersById
FirentisTFW Dec 5, 2024
120e756
Move initWithPlayerItem from the public interface to class extension
FirentisTFW Dec 5, 2024
5e8b820
Remove nullable and nonnull annotations from implementation file
FirentisTFW Dec 5, 2024
cfe51ab
Add empty lines at the end of files
FirentisTFW Dec 5, 2024
1d21f18
Improve imports
FirentisTFW Dec 5, 2024
6616a6a
Replace fixme comment with a regular comment
FirentisTFW Dec 5, 2024
a4d82b2
Update names and doc comments in platform interface
FirentisTFW Dec 5, 2024
b267d3d
Update changelogs
FirentisTFW Dec 5, 2024
b19ca86
Bump platform_interface version to 6.3.0
FirentisTFW Dec 5, 2024
f04ed06
Rename textureId to playerId in test file when using platform view
FirentisTFW Dec 5, 2024
c2117a8
Add local dependency overrides for platform interface
FirentisTFW Dec 6, 2024
e7404e3
Format generated iOS files
FirentisTFW Dec 6, 2024
d3f3873
Add native view factory import to test file
FirentisTFW Dec 6, 2024
0ca8f80
Fix iOS source files path in podspec
FirentisTFW Dec 6, 2024
5f31fc3
Add iOS include path to Package.swift
FirentisTFW Dec 6, 2024
b78b61e
Revert "Remove placeholder files which are not needed anymore"
FirentisTFW Dec 10, 2024
dbe39ba
Move header files related to platform views to the main directory
FirentisTFW Dec 10, 2024
7bbf8bf
Add TargetConditionals.h import to FVPNativeVideoView.h
FirentisTFW Dec 10, 2024
2dac440
Add TargetConditionals.h import to FVPNativeVideoViewFactory.h
FirentisTFW Dec 10, 2024
1b77376
Update doc comments for FVPVideoPlayer constructors
FirentisTFW Dec 10, 2024
277b805
Merge branch 'main' into feature/video-player-platform-view-support
FirentisTFW Dec 20, 2024
404fad2
Merge branch 'main' into feature/video-player-platform-view-support
FirentisTFW Jan 2, 2025
d2778a1
Remove dependency overrides for packages that have no other changes
FirentisTFW Jan 7, 2025
4a8d0bd
Remove redundant sentence from a comment
FirentisTFW Jan 7, 2025
b6f2e2c
Use INT_MAX as the initial non-texture player ID, and then decrement
FirentisTFW Jan 7, 2025
6702c6f
Make viewType parameter in CreationOptions non-nullable
FirentisTFW Jan 7, 2025
4d7ca15
Rename FVPVideoPlayerTextureApproach to FVPTextureBasedVideoPlayer
FirentisTFW Jan 7, 2025
7bb4de3
Remove redeclaration of view method from the interface
FirentisTFW Jan 7, 2025
f753253
Use a block instead of passing a mutable dictionary
FirentisTFW Jan 7, 2025
16fb48e
Do not use "we" in comments
FirentisTFW Jan 7, 2025
b1dd379
Inherit from NSView instead of NSWindow
FirentisTFW Jan 7, 2025
7d7121a
Do not override dealloc in FVPNativeVideoView
FirentisTFW Jan 7, 2025
3eddd81
Fix typo
FirentisTFW Jan 7, 2025
97bd780
Remove "we" from comments
FirentisTFW Jan 7, 2025
8fe7428
Fix initialization of viewType in test file
FirentisTFW Jan 7, 2025
9b7f9ad
Fix (hopefully) a flaky test - wait for the assertion to happen inste…
FirentisTFW Jan 7, 2025
cacfd26
Add back license that was removed by mistake
FirentisTFW Jan 7, 2025
576a005
Rename variables for better consistency
FirentisTFW Jan 7, 2025
b7b58e2
Do not use @synchronized when decrementing next player ID
FirentisTFW Jan 7, 2025
8a71cfa
Introduce createWithOptions method
FirentisTFW Jan 7, 2025
fe409ed
Add a todo
FirentisTFW Jan 7, 2025
057285f
Fix dartdoc
FirentisTFW Jan 7, 2025
3610b34
Remove - unnecessary casts
FirentisTFW Jan 10, 2025
93ec315
Convert static variable to an ivar
FirentisTFW Jan 10, 2025
551e2b1
Add missing newline at the end of file
FirentisTFW Jan 10, 2025
9fbc43d
Use private properties instead of ivars
FirentisTFW Jan 10, 2025
2c1f5c4
Fix textureBased condition
FirentisTFW Jan 10, 2025
f78d7da
Reuse common code in seekTo method
FirentisTFW Jan 10, 2025
65b2614
Add pragma sections to texture-based video player file
FirentisTFW Jan 10, 2025
a48f432
Merge branch 'main' into feature/video-player-platform-view-support
FirentisTFW Jan 15, 2025
2915bad
Simplfy platform interface, do not expose internal details about play…
FirentisTFW Jan 15, 2025
af1d7eb
Adjust iOS implementation to the new platform interface
FirentisTFW Jan 15, 2025
9453edc
Adjust example app's controller to the new platform interface
FirentisTFW Jan 15, 2025
37c8dab
Test playerViewTypes in iOS implementation
FirentisTFW Jan 15, 2025
4f09736
Merge branch 'main' into feature/video-player-platform-view-support
FirentisTFW Jan 15, 2025
0045c27
Adjust new test's setup after merging main
FirentisTFW Jan 15, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
## NEXT
## 2.7.0

* Adds support for platform views as an optional way of displaying a video.
* Updates minimum supported SDK version to Flutter 3.22/Dart 3.4.

## 2.6.5
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,13 @@

#import <OCMock/OCMock.h>
#import <video_player_avfoundation/AVAssetTrackUtils.h>
#import <video_player_avfoundation/FVPTextureBasedVideoPlayer_Test.h>
#import <video_player_avfoundation/FVPVideoPlayerPlugin_Test.h>
#import <video_player_avfoundation/FVPVideoPlayer_Test.h>

#if TARGET_OS_IOS
#import <video_player_avfoundation/FVPNativeVideoViewFactory.h>
#endif

// TODO(stuartmorgan): Convert to using mock registrars instead.
NSObject<FlutterPluginRegistry> *GetPluginRegistry(void) {
Expand Down Expand Up @@ -120,7 +126,7 @@ - (AVPlayerItemVideoOutput *)videoOutputWithPixelBufferAttributes:

#pragma mark -

/** Test implementation of FVPDisplayLinkFactory that returns a provided display link nstance. */
/** Test implementation of FVPDisplayLinkFactory that returns a provided display link instance. */
@interface StubFVPDisplayLinkFactory : NSObject <FVPDisplayLinkFactory>

/** This display link to return. */
Expand Down Expand Up @@ -179,17 +185,54 @@ - (void)testBlankVideoBugWithEncryptedVideoStreamAndInvertedAspectRatioBugForSom
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
XCTAssertNil(error);
XCTAssertNotNil(textureId);
FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPTextureBasedVideoPlayer *player =
(FVPTextureBasedVideoPlayer *)videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);

XCTAssertNotNil(player.playerLayer, @"AVPlayerLayer should be present.");
XCTAssertNotNil(player.playerLayer.superlayer, @"AVPlayerLayer should be added on screen.");
}

- (void)testPlayerForPlatformViewDoesNotRegisterTexture {
NSObject<FlutterTextureRegistry> *mockTextureRegistry =
OCMProtocolMock(@protocol(FlutterTextureRegistry));
NSObject<FlutterPluginRegistrar> *registrar =
[GetPluginRegistry() registrarForPlugin:@"testPlayerForPlatformViewDoesNotRegisterTexture"];
NSObject<FlutterPluginRegistrar> *partialRegistrar = OCMPartialMock(registrar);
OCMStub([partialRegistrar textures]).andReturn(mockTextureRegistry);
FVPDisplayLink *mockDisplayLink =
OCMPartialMock([[FVPDisplayLink alloc] initWithRegistrar:registrar
callback:^(){
}]);
StubFVPDisplayLinkFactory *stubDisplayLinkFactory =
[[StubFVPDisplayLinkFactory alloc] initWithDisplayLink:mockDisplayLink];
AVPlayerItemVideoOutput *mockVideoOutput = OCMPartialMock([[AVPlayerItemVideoOutput alloc] init]);
FVPVideoPlayerPlugin *videoPlayerPlugin = [[FVPVideoPlayerPlugin alloc]
initWithAVFactory:[[StubFVPAVFactory alloc] initWithPlayer:nil output:mockVideoOutput]
displayLinkFactory:stubDisplayLinkFactory
registrar:partialRegistrar];

FlutterError *initalizationError;
[videoPlayerPlugin initialize:&initalizationError];
XCTAssertNil(initalizationError);
FVPCreationOptions *create = [FVPCreationOptions
makeWithAsset:nil
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/hls/bee.m3u8"
packageName:nil
formatHint:nil
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypePlatformView];
FlutterError *createError;
[videoPlayerPlugin createWithOptions:create error:&createError];

OCMVerify(never(), [mockTextureRegistry registerTexture:[OCMArg any]]);
}

- (void)testSeekToWhilePausedStartsDisplayLinkTemporarily {
NSObject<FlutterTextureRegistry> *mockTextureRegistry =
OCMProtocolMock(@protocol(FlutterTextureRegistry));
Expand Down Expand Up @@ -217,7 +260,8 @@ - (void)testSeekToWhilePausedStartsDisplayLinkTemporarily {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/hls/bee.m3u8"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&createError];

Expand All @@ -235,9 +279,14 @@ - (void)testSeekToWhilePausedStartsDisplayLinkTemporarily {

// Seeking to a new position should start the display link temporarily.
OCMVerify([mockDisplayLink setRunning:YES]);

FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
XCTAssertEqual([player position], 1234);
FVPTextureBasedVideoPlayer *player =
(FVPTextureBasedVideoPlayer *)videoPlayerPlugin.playersById[textureId];
// Wait for the player's position to update, it shouldn't take long.
XCTestExpectation *positionExpectation =
[self expectationForPredicate:[NSPredicate predicateWithFormat:@"position == 1234"]
evaluatedWithObject:player
handler:nil];
[self waitForExpectations:@[ positionExpectation ] timeout:3.0];

// Simulate a buffer being available.
OCMStub([mockVideoOutput hasNewPixelBufferForItemTime:kCMTimeZero])
Expand Down Expand Up @@ -283,7 +332,8 @@ - (void)testInitStartsDisplayLinkTemporarily {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/hls/bee.m3u8"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&createError];

Expand All @@ -300,7 +350,8 @@ - (void)testInitStartsDisplayLinkTemporarily {
.ignoringNonObjectArgs()
.andReturn(fakeBufferRef);
// Simulate a callback from the engine to request a new frame.
FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPTextureBasedVideoPlayer *player =
(FVPTextureBasedVideoPlayer *)videoPlayerPlugin.playersById[textureId];
[player copyPixelBuffer];
// Since a frame was found, and the video is paused, the display link should be paused again.
OCMVerify([mockDisplayLink setRunning:NO]);
Expand Down Expand Up @@ -333,7 +384,8 @@ - (void)testSeekToWhilePlayingDoesNotStopDisplayLink {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/hls/bee.m3u8"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&createError];

Expand All @@ -350,7 +402,8 @@ - (void)testSeekToWhilePlayingDoesNotStopDisplayLink {
[self waitForExpectationsWithTimeout:30.0 handler:nil];
OCMVerify([mockDisplayLink setRunning:YES]);

FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPTextureBasedVideoPlayer *player =
(FVPTextureBasedVideoPlayer *)videoPlayerPlugin.playersById[textureId];
XCTAssertEqual([player position], 1234);

// Simulate a buffer being available.
Expand Down Expand Up @@ -395,7 +448,8 @@ - (void)testPauseWhileWaitingForFrameDoesNotStopDisplayLink {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/hls/bee.m3u8"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&createError];

Expand Down Expand Up @@ -423,18 +477,19 @@ - (void)testDeregistersFromPlayer {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
XCTAssertNil(error);
XCTAssertNotNil(textureId);
FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPVideoPlayer *player = videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);
AVPlayer *avPlayer = player.player;

[self keyValueObservingExpectationForObject:avPlayer keyPath:@"currentItem" expectedValue:nil];

[videoPlayerPlugin disposePlayer:textureId.integerValue error:&error];
XCTAssertEqual(videoPlayerPlugin.playersByTextureId.count, 0);
XCTAssertEqual(videoPlayerPlugin.playersById.count, 0);
XCTAssertNil(error);

[self waitForExpectationsWithTimeout:30.0 handler:nil];
Expand All @@ -455,11 +510,12 @@ - (void)testBufferingStateFromPlayer {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
XCTAssertNil(error);
XCTAssertNotNil(textureId);
FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPVideoPlayer *player = videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);
AVPlayer *avPlayer = player.player;
[avPlayer play];
Expand Down Expand Up @@ -580,7 +636,8 @@ - (void)testSeekToleranceWhenNotSeekingToEnd {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [pluginWithMockAVPlayer createWithOptions:create error:&createError];

Expand Down Expand Up @@ -618,7 +675,8 @@ - (void)testSeekToleranceWhenSeekingToEnd {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
FlutterError *createError;
NSNumber *textureId = [pluginWithMockAVPlayer createWithOptions:create error:&createError];

Expand All @@ -641,14 +699,16 @@ - (void)testSeekToleranceWhenSeekingToEnd {
[videoPlayerPlugin initialize:&error];
XCTAssertNil(error);

FVPCreationOptions *create = [FVPCreationOptions makeWithAsset:nil
uri:uri
packageName:nil
formatHint:nil
httpHeaders:@{}];
FVPCreationOptions *create =
[FVPCreationOptions makeWithAsset:nil
uri:uri
packageName:nil
formatHint:nil
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];

FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPVideoPlayer *player = videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);

XCTestExpectation *initializedExpectation = [self expectationWithDescription:@"initialized"];
Expand Down Expand Up @@ -710,12 +770,13 @@ - (void)testDoesNotCrashOnRateObservationAfterDisposal {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
XCTAssertNil(error);
XCTAssertNotNil(textureId);

FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPVideoPlayer *player = videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);
weakPlayer = player;
avPlayer = player.player;
Expand Down Expand Up @@ -764,12 +825,14 @@ - (void)testHotReloadDoesNotCrash {
uri:@"https://flutter.github.io/assets-for-api-docs/assets/videos/bee.mp4"
packageName:nil
formatHint:nil
httpHeaders:@{}];
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
XCTAssertNil(error);
XCTAssertNotNil(textureId);

FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPTextureBasedVideoPlayer *player =
(FVPTextureBasedVideoPlayer *)videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);
weakPlayer = player;

Expand All @@ -793,12 +856,34 @@ - (void)testHotReloadDoesNotCrash {
handler:nil]; // No assertions needed. Lack of crash is a success.
}

#if TARGET_OS_IOS
- (void)testNativeVideoViewFactoryRegistration {
NSObject<FlutterPluginRegistry> *registry = GetPluginRegistry();
NSObject<FlutterPluginRegistrar> *registrar =
[registry registrarForPlugin:@"testNativeVideoViewFactoryRegistration"];
id mockRegistrar = OCMPartialMock(registrar);

OCMExpect([mockRegistrar
registerViewFactory:[OCMArg isKindOfClass:[FVPNativeVideoViewFactory class]]
withId:@"plugins.flutter.dev/video_player_ios"]);
[FVPVideoPlayerPlugin registerWithRegistrar:mockRegistrar];

OCMVerifyAll(mockRegistrar);
}
#endif

- (void)testPublishesInRegistration {
NSString *pluginKey = @"TestRegistration";
NSObject<FlutterPluginRegistry> *registry = GetPluginRegistry();
NSObject<FlutterPluginRegistrar> *registrar = [registry registrarForPlugin:pluginKey];
id mockRegistrar = OCMPartialMock(registrar);
// Empty stub to pass a check in Flutter's engine (double factory registration).
// registerWithRegistrar gets called at the beginning of the test, and factory is registered
// there. Additional call would try to register the same factory another time, which would fail a
// check in the engine.
OCMStub([mockRegistrar registerViewFactory:[OCMArg any] withId:[OCMArg any]]);

[FVPVideoPlayerPlugin registerWithRegistrar:registrar];
[FVPVideoPlayerPlugin registerWithRegistrar:mockRegistrar];

id publishedValue = [registry valuePublishedByPlugin:pluginKey];

Expand All @@ -815,13 +900,15 @@ - (void)testFailedToLoadVideoEventShouldBeAlwaysSent {

[videoPlayerPlugin initialize:&error];

FVPCreationOptions *create = [FVPCreationOptions makeWithAsset:nil
uri:@""
packageName:nil
formatHint:nil
httpHeaders:@{}];
FVPCreationOptions *create =
[FVPCreationOptions makeWithAsset:nil
uri:@""
packageName:nil
formatHint:nil
httpHeaders:@{}
viewType:FVPPlatformVideoViewTypeTextureView];
NSNumber *textureId = [videoPlayerPlugin createWithOptions:create error:&error];
FVPVideoPlayer *player = videoPlayerPlugin.playersByTextureId[textureId];
FVPVideoPlayer *player = videoPlayerPlugin.playersById[textureId];
XCTAssertNotNil(player);

[self keyValueObservingExpectationForObject:(id)player.player.currentItem
Expand Down
Loading
Loading