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

[camera] Remove OCMock from tests #8342

Closed

Conversation

mchudy
Copy link
Contributor

@mchudy mchudy commented Dec 23, 2024

This PR removes dependency on OCMock in unit tests and serves as a first step for full Swift migration. flutter/flutter#119109

  • Introduces wrapper protocols around AVFoundation class with default implementations and mocks
  • Replaces usages of AVFoundation classes with new protocols
  • Refactors dependency injection with FLTCamConfiguration for easier usage in tests as new protocols increased the number of dependencies required to initialize a new FLTCam instance
  • I tried to minimize changes to FLTCam to minimize the risk of introducing regressions. Splitting FLTCam into smaller classes will happen in further PRs.
  • Relying on the new protocols in some cases is cumbersome because AVFoundation methods require pointers to raw objects thus I'm sometimes keeping the underlying instance exposed which is not very elegant, I'm open to any suggestions on to how we can clean this up.

I took some inspiration from how it was done in case of the in_app_purchase package flutter/flutter#116383

Pre-launch Checklist

If you need help, consider asking for advice on the #hackers-new channel on Discord.

@mchudy mchudy force-pushed the feature/camera-ocmock-refactoring branch from 9d005b6 to 81143f5 Compare December 23, 2024 11:03
@hellohuanlin
Copy link
Contributor

Thank you for your contribution! I'm very excited about this change!

It's pretty hard to review a 3000+ LOC PR. Could you break it down to smaller pieces? Smaller PR also helps with resolving potential code conflict since this plugin is being actively developed by the community.

@@ -1,195 +1,196 @@
## NEXT

* Updates minimum supported SDK version to Flutter 3.22/Dart 3.4.
- Updates minimum supported SDK version to Flutter 3.22/Dart 3.4.
- Removes OCMock from tests.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is minimum SDK bump related to OCMock removal?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, it's not, it's been done before in a different PR.

@mchudy
Copy link
Contributor Author

mchudy commented Dec 27, 2024

@hellohuanlin I extracted two smaller PRs:

I will follow with further PRs when we get those merged as it will be tricky to keep the rest of the changes separate at this point.

auto-submit bot pushed a commit that referenced this pull request Dec 30, 2024
Smaller part extracted from #8342

- Removes OCMock from `CameraPermissionTests`
- Wraps permission methods into a new interface `FLTCameraPermissionManager`
- Introduces new protocol which wraps framework methods and can be mocked directly `FLTPermissionService`
@stuartmorgan stuartmorgan added the triage-ios Should be looked at in iOS triage label Jan 15, 2025
@mchudy mchudy closed this Jan 22, 2025
auto-submit bot pushed a commit that referenced this pull request Jan 24, 2025
…8351)

Extracted from #8342 to keep PRs smaller

- Introduces `FLTDeviceOrientationProviding` and `FLTCaptureDeviceControlling` protocols
- Removes `OCMock.h` reference from `CameraExposureTests.h` and `CameraFocusTests.h`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants