Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(561)

Unified Diff: webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm

Issue 2784243003: iOS/MacOS:Refactor metal rendering by extracting common implementation (Closed)
Patch Set: Fix build linkage Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webrtc/sdk/objc/Framework/Headers/WebRTC/RTCMTLVideoView.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm
diff --git a/webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm b/webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm
index 1d422eb09aa9b55e8a0b98414b30b9c605ea7e17..99004ea51587ce519f5acf0b7c06c0b0a0c2657c 100644
--- a/webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm
+++ b/webrtc/sdk/objc/Framework/UnitTests/RTCMTLVideoViewTests.mm
@@ -18,151 +18,170 @@
// Extension of RTCMTLVideoView for testing purposes.
@interface RTCMTLVideoView (Testing)
-@property(nonatomic, strong) id<RTCMTLRenderer> renderer;
-@property(nonatomic, strong) UIView* metalView;
-@property(atomic, strong) RTCVideoFrame* videoFrame;
+ (BOOL)isMetalAvailable;
+ (UIView*)createMetalView:(CGRect)frame;
-+ (id<RTCMTLRenderer>)createMetalRenderer;
++ (id<RTCMTLRenderer>)createNV12Renderer;
++ (id<RTCMTLRenderer>)createI420Renderer;
- (void)drawInMTKView:(id)view;
@end
@interface RTCMTLVideoViewTests : NSObject
@property(nonatomic, strong) id classMock;
@property(nonatomic, strong) id metalViewMock;
-@property(nonatomic, strong) id rendererMock;
+@property(nonatomic, strong) id rendererNV12Mock;
+@property(nonatomic, strong) id rendererI420Mock;
+@property(nonatomic, strong) id frameMock;
@end
@implementation RTCMTLVideoViewTests
@synthesize classMock = _classMock;
@synthesize metalViewMock = _metalViewMock;
-@synthesize rendererMock = _rendererMock;
+@synthesize rendererNV12Mock = _rendererNV12Mock;
+@synthesize rendererI420Mock = _rendererI420Mock;
+@synthesize frameMock = _frameMock;
- (void)setup {
self.classMock = OCMClassMock([RTCMTLVideoView class]);
-
- self.metalViewMock = OCMClassMock([RTCMTLVideoViewTests class]);
- // NOTE: OCMock doesen't provide modern syntax for -ignoringNonObjectArgs.
- [[[[self.classMock stub] ignoringNonObjectArgs] andReturn:self.metalViewMock]
- createMetalView:CGRectZero];
-
- self.rendererMock = OCMProtocolMock(@protocol(RTCMTLRenderer));
- OCMStub([self.classMock createMetalRenderer]).andReturn(self.rendererMock);
}
- (void)tearDown {
[self.classMock stopMocking];
- [self.rendererMock stopMocking];
+ [self.rendererI420Mock stopMocking];
+ [self.rendererNV12Mock stopMocking];
[self.metalViewMock stopMocking];
+ [self.frameMock stopMocking];
self.classMock = nil;
- self.rendererMock = nil;
+ self.rendererI420Mock = nil;
+ self.rendererNV12Mock = nil;
self.metalViewMock = nil;
+ self.frameMock = nil;
}
-- (void)testMetalConfigureNotExecuted {
- // when
- OCMStub([self.classMock isMetalAvailable]).andReturn(NO);
- RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] init];
+- (id)frameMockWithNativeHandle:(BOOL)hasNativeHandle {
+ id frameMock = OCMClassMock([RTCVideoFrame class]);
+ if (hasNativeHandle) {
+ OCMStub([frameMock nativeHandle]).andReturn((CVPixelBufferRef)[OCMArg anyPointer]);
+ } else {
+ OCMStub([frameMock nativeHandle]).andReturn((CVPixelBufferRef) nullptr);
+ }
+ return frameMock;
+}
- // then
- EXPECT_TRUE(realView.renderer == nil);
- EXPECT_TRUE(realView.metalView == nil);
+- (id)rendererMockWithSuccessfulSetup:(BOOL)sucess {
+ id rendererMock = OCMProtocolMock(@protocol(RTCMTLRenderer));
+ OCMStub([rendererMock addRenderingDestination:[OCMArg any]]).andReturn(sucess);
+
+ return rendererMock;
}
-- (void)testMetalConfigureExecuted {
+#pragma mark - Test cases
+- (void)testInitAssertsIfMetalUnavailabe {
// given
- OCMStub([self.classMock isMetalAvailable]).andReturn(YES);
- OCMStub([self.rendererMock addRenderingDestination:self.metalViewMock])
- .andReturn(NO);
+ OCMStub([self.classMock isMetalAvailable]).andReturn(NO);
// when
- RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] init];
-
- // then
- EXPECT_TRUE(realView.renderer == nil);
- EXPECT_TRUE(realView.metalView != nil);
+ BOOL asserts = NO;
+ @try {
+ RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] initWithFrame:CGRectZero];
+ (void)realView;
+ } @catch (NSException *ex) {
+ asserts = YES;
+ }
+
+ EXPECT_TRUE(asserts);
}
-- (void)testMetalDrawCallback {
+- (void)testRTCVideoRenderNilFrameCallback {
// given
- OCMStub([self.classMock isMetalAvailable]).andReturn(NO);
- OCMExpect([self.rendererMock drawFrame:[OCMArg any]]);
+ OCMStub([self.classMock isMetalAvailable]).andReturn(YES);
RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] init];
- realView.metalView = self.metalViewMock;
- realView.renderer = self.rendererMock;
+ self.frameMock = OCMClassMock([RTCVideoFrame class]);
+
+ [[self.frameMock reject] nativeHandle];
+ [[self.classMock reject] createNV12Renderer];
+ [[self.classMock reject] createI420Renderer];
// when
+ [realView renderFrame:nil];
[realView drawInMTKView:self.metalViewMock];
// then
- [self.rendererMock verify];
+ [self.frameMock verify];
+ [self.classMock verify];
}
-- (void)testRTCVideoRenderNilFrameCallback {
+- (void)testRTCVideoRenderFrameCallbackI420 {
// given
- OCMStub([self.classMock isMetalAvailable]).andReturn(NO);
+ OCMStub([self.classMock isMetalAvailable]).andReturn(YES);
+ self.rendererI420Mock = [self rendererMockWithSuccessfulSetup:YES];
+ self.frameMock = [self frameMockWithNativeHandle:NO];
+
+ OCMExpect([self.rendererI420Mock drawFrame:self.frameMock]);
+ OCMExpect([self.classMock createI420Renderer]).andReturn(self.rendererI420Mock);
+ [[self.classMock reject] createNV12Renderer];
+
RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] init];
// when
- [realView renderFrame:nil];
+ [realView renderFrame:self.frameMock];
+ [realView drawInMTKView:self.metalViewMock];
// then
- EXPECT_TRUE(realView.videoFrame == nil);
+ [self.rendererI420Mock verify];
+ [self.classMock verify];
}
-- (void)testRTCVideoRenderFrameCallback {
+- (void)testRTCVideoRenderFrameCallbackNV12 {
// given
- OCMStub([self.classMock isMetalAvailable]).andReturn(NO);
+ OCMStub([self.classMock isMetalAvailable]).andReturn(YES);
+ self.rendererNV12Mock = [self rendererMockWithSuccessfulSetup:YES];
+ self.frameMock = [self frameMockWithNativeHandle:YES];
+
+ OCMExpect([self.rendererNV12Mock drawFrame:self.frameMock]);
+ OCMExpect([self.classMock createNV12Renderer]).andReturn(self.rendererNV12Mock);
+ [[self.classMock reject] createI420Renderer];
+
RTCMTLVideoView *realView = [[RTCMTLVideoView alloc] init];
- id frame = OCMClassMock([RTCVideoFrame class]);
- realView.metalView = self.metalViewMock;
- realView.renderer = self.rendererMock;
- OCMExpect([self.rendererMock drawFrame:frame]);
// when
- [realView renderFrame:frame];
+ [realView renderFrame:self.frameMock];
[realView drawInMTKView:self.metalViewMock];
// then
- EXPECT_EQ(realView.videoFrame, frame);
- [self.rendererMock verify];
+ [self.rendererNV12Mock verify];
+ [self.classMock verify];
}
@end
-TEST(RTCMTLVideoViewTests, MetalConfigureNotExecuted) {
+TEST(RTCMTLVideoViewTests, InitAssertsIfMetalUnavailabe) {
RTCMTLVideoViewTests *test = [[RTCMTLVideoViewTests alloc] init];
[test setup];
- [test testMetalConfigureNotExecuted];
- [test tearDown];
-}
-
-TEST(RTCMTLVideoViewTests, MetalConfigureExecuted) {
- RTCMTLVideoViewTests *test = [[RTCMTLVideoViewTests alloc] init];
- [test setup];
- [test testMetalConfigureExecuted];
+ [test testInitAssertsIfMetalUnavailabe];
[test tearDown];
}
-TEST(RTCMTLVideoViewTests, MetalDrawCallback) {
+TEST(RTCMTLVideoViewTests, RTCVideoRenderNilFrameCallback) {
RTCMTLVideoViewTests *test = [[RTCMTLVideoViewTests alloc] init];
[test setup];
- [test testMetalDrawCallback];
+ [test testRTCVideoRenderNilFrameCallback];
[test tearDown];
}
-TEST(RTCMTLVideoViewTests, RTCVideoRenderNilFrameCallback) {
+TEST(RTCMTLVideoViewTests, RTCVideoRenderFrameCallbackI420) {
RTCMTLVideoViewTests *test = [[RTCMTLVideoViewTests alloc] init];
[test setup];
- [test testRTCVideoRenderNilFrameCallback];
+
+ [test testRTCVideoRenderFrameCallbackI420];
[test tearDown];
}
-TEST(RTCMTLVideoViewTests, RTCVideoRenderFrameCallback) {
+TEST(RTCMTLVideoViewTests, RTCVideoRenderFrameCallbackNV12) {
RTCMTLVideoViewTests *test = [[RTCMTLVideoViewTests alloc] init];
[test setup];
- [test testRTCVideoRenderFrameCallback];
+
+ [test testRTCVideoRenderFrameCallbackNV12];
[test tearDown];
}
« no previous file with comments | « webrtc/sdk/objc/Framework/Headers/WebRTC/RTCMTLVideoView.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698