| Index: webrtc/sdk/objc/Framework/UnitTests/avformatmappertests.mm | 
| diff --git a/webrtc/sdk/objc/Framework/UnitTests/avformatmappertests.mm b/webrtc/sdk/objc/Framework/UnitTests/avformatmappertests.mm | 
| index deae4e35059b4f9c71d7a529ce1ee3589181781c..624eec3d6ca84f6537ad6c001e59bc424303ddb9 100644 | 
| --- a/webrtc/sdk/objc/Framework/UnitTests/avformatmappertests.mm | 
| +++ b/webrtc/sdk/objc/Framework/UnitTests/avformatmappertests.mm | 
| @@ -113,13 +113,12 @@ static cricket::VideoFormat expectedFormat = | 
|  | 
| TEST(AVFormatMapperTest, SuportedCricketFormatsWithInvalidFramerateFormats) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
|  | 
| // Valid media subtype, invalid framerate | 
| AVCaptureDeviceFormatMock* mock = | 
| [AVCaptureDeviceFormatMock invalidFpsFormat]; | 
| - | 
| -  [[[mockDevice stub] andReturn:@[ mock ]] formats]; | 
| +  OCMStub([mockDevice formats]).andReturn(@[ mock ]); | 
|  | 
| // when | 
| std::set<cricket::VideoFormat> result = | 
| @@ -131,13 +130,12 @@ TEST(AVFormatMapperTest, SuportedCricketFormatsWithInvalidFramerateFormats) { | 
|  | 
| TEST(AVFormatMapperTest, SuportedCricketFormatsWithInvalidFormats) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
|  | 
| // Invalid media subtype, valid framerate | 
| AVCaptureDeviceFormatMock* mock = | 
| [AVCaptureDeviceFormatMock invalidMediaSubtypeFormat]; | 
| - | 
| -  [[[mockDevice stub] andReturn:@[ mock ]] formats]; | 
| +  OCMStub([mockDevice formats]).andReturn(@[ mock ]); | 
|  | 
| // when | 
| std::set<cricket::VideoFormat> result = | 
| @@ -149,11 +147,11 @@ TEST(AVFormatMapperTest, SuportedCricketFormatsWithInvalidFormats) { | 
|  | 
| TEST(AVFormatMapperTest, SuportedCricketFormats) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
|  | 
| // valid media subtype, valid framerate | 
| AVCaptureDeviceFormatMock* mock = [AVCaptureDeviceFormatMock validFormat]; | 
| -  [[[mockDevice stub] andReturn:@[ mock ]] formats]; | 
| +  OCMStub([mockDevice formats]).andReturn(@[ mock ]); | 
|  | 
| // when | 
| std::set<cricket::VideoFormat> result = | 
| @@ -161,38 +159,34 @@ TEST(AVFormatMapperTest, SuportedCricketFormats) { | 
|  | 
| // then | 
| EXPECT_EQ(1u, result.size()); | 
| - | 
| // make sure the set has the expected format | 
| EXPECT_EQ(expectedFormat, *result.begin()); | 
| } | 
|  | 
| TEST(AVFormatMapperTest, MediaSubtypePreference) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
|  | 
| // valid media subtype, valid framerate | 
| AVCaptureDeviceFormatMock* mockOne = [[AVCaptureDeviceFormatMock alloc] | 
| initWithMediaSubtype:kCVPixelFormatType_420YpCbCr8BiPlanarFullRange | 
| minFps:0.0 | 
| maxFps:30.0]; | 
| - | 
| // valid media subtype, valid framerate. | 
| // This media subtype should be the preffered one. | 
| AVCaptureDeviceFormatMock* mockTwo = [[AVCaptureDeviceFormatMock alloc] | 
| initWithMediaSubtype:kCVPixelFormatType_420YpCbCr8BiPlanarVideoRange | 
| minFps:0.0 | 
| maxFps:30.0]; | 
| - | 
| -  [[[mockDevice stub] andReturnValue:@(YES)] | 
| -      lockForConfiguration:[OCMArg setTo:nil]]; | 
| -  [[mockDevice stub] unlockForConfiguration]; | 
| - | 
| -  [[[mockDevice stub] andReturn:@[ mockOne, mockTwo ]] formats]; | 
| +  OCMStub([mockDevice lockForConfiguration:[OCMArg setTo:nil]]).andReturn(YES); | 
| +  OCMStub([mockDevice unlockForConfiguration]); | 
| +  NSArray* array = @[ mockOne, mockTwo ]; | 
| +  OCMStub([mockDevice formats]).andReturn(array); | 
|  | 
| // to verify | 
| -  [[mockDevice expect] setActiveFormat:(AVCaptureDeviceFormat*)mockTwo]; | 
| -  [[mockDevice expect] | 
| -      setActiveVideoMinFrameDuration:CMTimeMake(1, kFramerate)]; | 
| +  OCMExpect([mockDevice setActiveFormat:(AVCaptureDeviceFormat*)mockTwo]); | 
| +  OCMExpect( | 
| +      [mockDevice setActiveVideoMinFrameDuration:CMTimeMake(1, kFramerate)]); | 
|  | 
| // when | 
| bool resultFormat = | 
| @@ -205,10 +199,9 @@ TEST(AVFormatMapperTest, MediaSubtypePreference) { | 
|  | 
| TEST(AVFormatMapperTest, SetFormatWhenDeviceCannotLock) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
| [[[mockDevice stub] andReturnValue:@(NO)] | 
| lockForConfiguration:[OCMArg setTo:nil]]; | 
| - | 
| [[[mockDevice stub] andReturn:@[]] formats]; | 
|  | 
| // when | 
| @@ -219,21 +212,17 @@ TEST(AVFormatMapperTest, SetFormatWhenDeviceCannotLock) { | 
| EXPECT_FALSE(resultFormat); | 
| } | 
|  | 
| -// Disabled due to failing with OCMock 3.1.5: | 
| -// https://bugs.chromium.org/p/webrtc/issues/detail?id=7137 | 
| -TEST(AVFormatMapperTest, DISABLED_SetFormatWhenFormatIsIncompatible) { | 
| +TEST(AVFormatMapperTest, SetFormatWhenFormatIsIncompatible) { | 
| // given | 
| -  id mockDevice = [OCMockObject mockForClass:[AVCaptureDevice class]]; | 
| -  [[[mockDevice stub] andReturn:@[]] formats]; | 
| -  [[[mockDevice stub] andReturnValue:@(YES)] | 
| -      lockForConfiguration:[OCMArg setTo:nil]]; | 
| - | 
| -  NSException* exception = | 
| +  id mockDevice = OCMClassMock([AVCaptureDevice class]); | 
| +  OCMStub([mockDevice formats]).andReturn(@[]); | 
| +  OCMStub([mockDevice lockForConfiguration:[OCMArg setTo:nil]]).andReturn(YES); | 
| +  NSException* testException = | 
| [NSException exceptionWithName:@"Test exception" | 
| reason:@"Raised from unit tests" | 
| userInfo:nil]; | 
| -  [[[mockDevice stub] andThrow:exception] setActiveFormat:[OCMArg any]]; | 
| -  [[mockDevice expect] unlockForConfiguration]; | 
| +  OCMStub([mockDevice setActiveFormat:[OCMArg any]]).andThrow(testException); | 
| +  OCMExpect([mockDevice unlockForConfiguration]); | 
|  | 
| // when | 
| bool resultFormat = webrtc::SetFormatForCaptureDevice(mockDevice, nil, | 
| @@ -241,5 +230,18 @@ TEST(AVFormatMapperTest, DISABLED_SetFormatWhenFormatIsIncompatible) { | 
|  | 
| // then | 
| EXPECT_FALSE(resultFormat); | 
| -  [mockDevice verify]; | 
| + | 
| +  // TODO(denicija): Remove try-catch when Chromium rolls this change: | 
| +  // https://github.com/erikdoe/ocmock/commit/de1419415581dc307045e54bfe9c98c86efea96b | 
| +  // Without it, stubbed exceptions are being re-raised on [mock verify]. | 
| +  // More information here: | 
| +  //https://github.com/erikdoe/ocmock/issues/241 | 
| +  @try { | 
| +    [mockDevice verify]; | 
| +  } @catch (NSException* exception) { | 
| +    if ([exception.reason isEqual:testException.reason]) { | 
| +      // Nothing dangerous here | 
| +      EXPECT_TRUE([exception.reason isEqualToString:exception.reason]); | 
| +    } | 
| +  } | 
| } | 
|  |