-
Notifications
You must be signed in to change notification settings - Fork 6
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
Fix/15322 upgrade Stories-Android to android 11 api level 30 #715
Conversation
Upgraded the following to 30 from 28 targetSdkVersion, compileSdkVersion Made tweaks to a few files mostly guard against nulls
Remove redundant permission
You can test the changes on this Pull Request by downloading the APK here. |
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.
👋 @ravishanker !
I have reviewed and tested this PR as per the instructions, it seems to work as expected, good job! 🌟
I have left a couple of minor suggestions (💡) for you to consider. I am NOT going to approve this PR for now and until we make sure that WordPress-Android
is ready as well, since it seems to me that the integration should happen at the same time. Correct me if I am wrong.
I also suggest we add @oguzkocer to the picture just to he is aware of this upcoming change.
Btw, have you tried to test this more thoroughly by integrating this branch with WordPress-Android
? I honestly didn't go that far, but it seems wise if we do so before merging this PR.
From a conversation that I had with @oguzkocer a while ago (see here) one can check out the branch in libs/stories-android
folder of WordPress-Android
. Then, if the integration works as well, we can have more confidence that there is nothing more that needs to be done for this upgrade. PS: Also, since we are upgrading two versions at once (from SDK 28
to 30
), I suggest we should be more careful with our testing here.
// if there are any external Uris in this list, copy them locally before trying to use them | ||
processExternalUris(uriList) | ||
val mediaUris = data.getStringArrayExtra(PhotoPickerActivity.EXTRA_MEDIA_URIS) | ||
if (mediaUris != null) { |
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.
Suggestion (💡): Using ?.let { ... }
instead of an if not null check it might save us a line and make this a bit more idiomatic:
PS: Same applies to setMediaUris(...)
on the ComposeLoopFrameActivity.kt
class.
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.
done
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.
👋 @ravishanker !
What I meant was the data.getStringArrayExtra(PhotoPickerActivity.EXTRA_MEDIA_URIS)?.let { ... }
equivalent, which will save a line, but please don't bother since this is totally minor, I just posted it as a nice-to-have.
😅
app/src/main/AndroidManifest.xml
Outdated
@@ -5,7 +5,6 @@ | |||
<uses-permission android:name="android.permission.INTERNET" /> | |||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> | |||
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> | |||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> |
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.
Question (❓): Are we sure about that? Why was that there is the first place?
PS: Obviously, this is just an example app
used to demonstrate that the stories
functionality works as expected, prior to integrating that with WordPress-Android
, but still, this is good to know, maybe this will be needed to be done on the main repo as well. 🤷
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.
Not sure why it was there. It could be that because there's a READ so, WRITE was added by default. It is definitely not needed here. I've it on my list to check this again on main WPAndroid and test it and remove it.
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.
Thank you @ravishanker ! 🙏
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.
👋 - this is there so others wanting to integrate the library in their projects can use the demo app as an example to be followed in their own apps, regarding what things are needed. In this sense, the <uses-permission>
tag is not strictly needed for a demo app to be built or run, but it serves a purpose that goes beyond that. That specific tag is used by Google Play to filter apps through, so it will be needed if users of the library want to publish their apps there. For reference, here's the documentation.
Also:
I've it on my list to check this again on main WPAndroid and test it and remove it
It won't affect WPAndroid, given this is only within the demo app's manifest.
Given the above reasons, please, can we get it back as it was @ravishanker ? 🙏
As a side note, I believe this change is not related to the SDK change as advertised in the PR description. I would highly encourage unrelated changes to be either explained or be kept to a different PR when possible.
@ravishanker @ParaskP7 I am currently on support rotation, so I am not supposed to review any PRs 😅 Please ping me on Slack if you are blocked and I'll do my best to unblock you.
@ParaskP7 is correct. Any stories-android library change should be tested in WPAndroid before merging the PR. We also always ping @aforcier or @cameronvoell for a review when we make a change to stories-android library and get their approval before merge. (unless it's only a tooling change)
@ravishanker We prefer not to link internal documents directly in the public repositories. There is a way to do this using a shortcode, you can see an example of how @AliSoftware does it in this PR. I personally don't link any internal documents, not even as shortcodes, and prefer to provide/duplicate the necessary information in the public space for the benefit of non-a12s, however using shortcodes is widely accepted, so it's up to you. |
Thank you for your input @oguzkocer , much appreciated, happy support rotation! 🙇 |
I've edited the PR description to use the shortcode instead. @ravishanker if you want to avoid letting links to internal docs slip in public repos in the future, I highly recommend installing our internal "GitHub Highlighter/Shorthander" tampermonkey script. You can find it by searching |
Thanks for the review @ParaskP7. I started from WPAndroid, then moved on to stories-android. I realized that, I need to fix all the dependencies starting with stories first. So, yeah, I've tested with WPAndroid. |
👋 @ravishanker !
Great, thanks for confirming that you tested this branch with PS: Then, I can approve this PR as nothing seems to be blocking. I however think that it might be better to merge than when |
👋 hello @ravishanker @ParaskP7 - let me give this one a quick round of testing before we merge 👍 |
👋 @mzorz !
💯 and many thanks! 🙇 |
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.
Thank you for taking on this task, @ravishanker !
I've smoke-tested both the demo app and WordPress-Android app with the stories-android library pointing to this branch, and using this test branch on WPAndroid (as some changes needed to be made in there as well).
- camera: taking pictures and recording videos worked as expected
- saving: both new pics and videos were composed successfully
- sourcing media: using the media picker also worked well (local media, WP media in the WP app, 3rd party app media, remote media).
- integration with Gutenberg (creating a post from zero, then editing, then editing an existing Post created on another device) seemed to work fine.
All of this using a Google Pixel 4a.
I also verified most of the changes in this PR are due to new build errors that appear from changing the targetSdk
value to 30, so that's fine.
IMPORTANT: It is worth noting that when compiling the WordPress-Android app, the stories library will take the targetSdk
and compileSdk
from the parent project so, what this really means is that when building WPAndroid if we don't perform the changes as expressed in this diff then we'd only have tested the code changes in this PR but not the actual SDK change which this PR's main aim is supposed to be cc @ravishanker . I'd only ask that we make a more thorough list of what's been tested and how next time 👍 .
So, this needs to be re-tested once the parent app (WPAndroid) is ready for the change to API level 30, before we update the commit hash of submodule /libs/stories-android
in the parent repository.
That said, let's please revert the <uses-permission>
tag removal, and we can merge afterwards
Thank you!
app/src/main/AndroidManifest.xml
Outdated
@@ -5,7 +5,6 @@ | |||
<uses-permission android:name="android.permission.INTERNET" /> | |||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> | |||
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> | |||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> |
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.
👋 - this is there so others wanting to integrate the library in their projects can use the demo app as an example to be followed in their own apps, regarding what things are needed. In this sense, the <uses-permission>
tag is not strictly needed for a demo app to be built or run, but it serves a purpose that goes beyond that. That specific tag is used by Google Play to filter apps through, so it will be needed if users of the library want to publish their apps there. For reference, here's the documentation.
Also:
I've it on my list to check this again on main WPAndroid and test it and remove it
It won't affect WPAndroid, given this is only within the demo app's manifest.
Given the above reasons, please, can we get it back as it was @ravishanker ? 🙏
As a side note, I believe this change is not related to the SDK change as advertised in the PR description. I would highly encourage unrelated changes to be either explained or be kept to a different PR when possible.
@@ -925,6 +917,15 @@ abstract class ComposeLoopFrameActivity : AppCompatActivity(), OnStoryFrameSelec | |||
} | |||
} | |||
|
|||
private fun setMediaUris(intent: Intent) { | |||
val mediaUris = intent.getStringArrayExtra(requestCodes.EXTRA_MEDIA_URIS) |
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.
Thank you for finding this opportunity to refactor 👍
Nitpick: val mediaUris
here can be removed and the expression simplified to intent.getStringArrayExtra(requestCodes.EXTRA_MEDIA_URIS)?.let {...}
, given it's only used once
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.
done, thank you
Revert WRITE_EXTERNAL_STORAGE permission
@mzorz Thank you for reviewing and testing comprehensively. 🙌 Thanks for the assurance I've reverted the permission. I removed it for testing and also AS prompting me constantly that it is redundant. I've been testing with parent WPAndroid app. I should have pushed that too, to spare you the trouble of having to make them for testing. I'll push the WPAndroid as well now. |
Thank you @ravishanker 👍 - left a comment there. In reading more about how this all fits in your migration plan paqN3M-n4-p2, I found that we might need some more thorough testing on devices running on Android 11 when targeting SDK 30. For this, TIL there's a tool we can use to force the flags needed. (see App compatibility Changes screen in Settings -> System > Advanced > Developer options > App Compatibility Changes.). With this in mind, I'll run some more tests on this PR before we proceed to merge. If you can do the same, please by all means do 👍 🙇 cc @ParaskP7 |
I've uninstalled the demo (loop) app, re-installed it, changed the flag However, I encountered a crash on WPAndroid, may be unrelated though, but created an issue here wordpress-mobile/WordPress-Android#15333 |
@mzorz I'm attempting to complete upgrade task. I've already addressed all the changes suggested. Are you able to remove this, to help me proceed with merger. Thank you 🙏 |
Could you update this branch with Also, a PR has just been merged for composite builds. Do we know how this update to SDK 30 may play together? (I haven't thought of it through deeply, so summoning here @oguzkocer just to double check whether we have a clear path to merge develop into this branch, test, then merge the PR or we need something else at this point). |
Thanks for the ping @mzorz. As long as this PR and WPAndroid counterpart are updated with latest |
Thanks @oguzkocer, Updated this PR with latest develop, it's green now. |
Thanks @mzorz, Updated this PR with latest develop and also WPAndroid PR and resolved conflicts. Once we merge this, need to update its develop-# on WPAndroid PR before merging it. |
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.
Thank you for these changes @ravishanker ! 🙌
LGTM - I'll merge and create a new release tag on the repo that can be referenced by WPAndroid
Fixes WordPress-Android#15339
Upgrade to Android 11 (API level 30)
Please see paqN3M-mr-p2 for details on mandatory requirement to upgrade to Android 11 by November 2021. Also this paqN3M-n4-p2, for details on planned approach to upgrade
NOTE: Stories is first cab off the rank for upgrade as a dependency for WPAndroid upgrade