-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Editor: Post contains local changes even when the user doesn't modify the post #13169
Comments
Looks related to the ticket opened a few days ago in the gb-mobile repo: wordpress-mobile/gutenberg-mobile#2714 |
Thanks for the info, I've missed that. They look similar, however, I haven't even need to scroll + this issue isn't about autosave but about save on exit. Having said all that there is a pretty high chance these two tickets are related. |
Since you're also @mchowning doing groundskeeping this week, is it ok if I'll leave this to you? |
I have spent some time investigating this, and it appears to be due to certain blocks having outdated or otherwise unexpected (but valid) formatting in the post content. I (obviously) still need to do some more investigation into this, and I do plan to follow-up on this. |
I suspect this may be related to wordpress-mobile/gutenberg-mobile#894. |
A note which might be useful - I noticed the EditorFragment.getTitleOrContentChanged() is invoked when you open a post. It's also interesting that it is invoked on the same post every time you open it (even if you open it after it already has the "local changes" label). |
Removed my assignment because I'm not going to have time to get back to this in the near future. |
Apologies, I added that last comment to the wrong issue. @malinajirka can you help me with prioritization on this one? Should it stay medium? |
I managed to reproduce the reported behaviour in smaller post. Starting from a post with content from the first revision of this gist you can observe the content loop between two states (check the revisions).
localchanges.mp4 |
Looked into this issue a bit and just wanted to confirm that starting from the steps reported by Antonis here, I was able to get the same two states loop. Also in my case to trigger the loop, the on opening I was trying to have some more debug into the GB editor to get a better understanding but had some issue with my local setup to get Metro up without crashing the app (it then disappear so this is why I'm pretty sure it was an issue with my setup only 🤷 , but run out of time in the end). |
I investigated this issue some and wanted to capture what I noticed so far. I was able to reproduce the issue with a subset of the content shared in #13169 (comment). Reproducible Post HTML<!-- wp:spacer {"height":90} -->
<div style="height:90px" aria-hidden="true" class="wp-block-spacer"></div>
<!-- /wp:spacer -->
<!-- wp:preformatted -->
<pre class="wp-block-preformatted"><br>coding is fun</pre>
<!-- /wp:preformatted -->
<!-- wp:preformatted -->
<pre class="wp-block-preformatted"><br>coding is fun</pre>
<!-- /wp:preformatted --> I observed similar changes to the block markup as referenced before, namely the jump between I have been unable to identify why parsing the |
Hi @dcalhoun 👋 😄 Great job reproducing with a subset of content.
In your debugging screenshot, is the content going "back and forth" between those representations (i.e. would explain Antonis's observations about triggering local changes in a "loop")?
The differences in |
I think this is because of Aztec-Android. There are a number of changes like this that it makes to content (i.e., if you pass an html string into the fromHtml method and then immediately call toHtml, you will not always get back the exact same string because Aztec tries to clean up the input. There has been some talk of trying to create a simplified version of Aztec for use with Gutenberg, and I think that's our best chance to address these issues. I think that without a separate version of Aztec for Gutenberg, it will be very difficult to fix these issues without causing regressions in the classic editor. Changes I Observed When Web Blocks Were Viewed on WPAndroidI did some testing of this last year, and I feel like I wrote this down publicly somewhere, but I can't find it now, so here are the changes I saw that would occur:
|
@mkevins no, I did not observe multiple "back and forth" switches. I only observed the swap oddity with
@mchowning great point. I am unable to reproduce the same issue in WPiOS, so it would make sense to be related to Aztec-Android.
You may be right that a simplified Aztec is the most straightforward approach. Avoiding regressions in the Classic editor would be difficult. |
This was also reported in 4347487-zen
User has Google Pixel 2 XL, WPAndroid 18.4-rc-2 |
I was able to verify that this is still an issue (during groundskeeping rotation). After login and site selection, I am navigated directly into the editor, then back-out without making any changes. I see the "local changes" in the post list, plus I see a dialog warning upon logout. See pbxNRc-1fJ-p2#comment-3049 for steps to recreate and dialog. |
I have been investigating this issue as part of groundskeeping, and have confirmed that in some cases, the issue only occurs after interacting with a particular block, and in other cases, merely opening existing content is enough to have it marked "dirty" or locally changed. I have also observed that there are some differences with the behavior depending on whether the post is in a draft state or a published state, but I have not yet found the root cause of those differences. It seems this issue can actually have many underlying causes, so in order to better understand the data flow that may lead to this, I examined the control flow graph from the point of view of the flowchart LR
A[setIsLocallyChanged]
B["PostRestClient:326\n(sets to false)"] --> A
C["PostUtils:573\n(sets to true)"] --> A
style C fill:orange,color:black
D["SavePostToDbUserCase:43\n(sets to true)"] --> A
style D fill:orange,color:black
E["UploadService:607\n(sets to true)"] --> A
style E fill:orange,color:black
F["UploadService:633\n(sets to true)"] --> A
style F fill:orange,color:black
G["UploadService:657\n(sets to true)"] --> A
style G fill:orange,color:black
To get a sense of breadth and scope, we can work backwards from there (also giving clues about other areas that can affect this, such as media uploads): flowchart RL
A[setIsLocallyChanged]
H[preparePostForPublish] --"!post.isLocalDraft()"--> C["PostUtils:573"] --> A
I["savePostToDb\n[if postRepository.postHasChanges()]"] --"!post.isLocalDraft()" --> D["SavePostToDbUserCase:43"] --> A
J[updatePostWithNewFeatureImg] --> E["UploadService:607"] --> A
K[updatePostWithMediaUrl] --"!post.isLocalDraft"--> F["UploadService:633"] --> A
L[updatePostWithFailedMedia] --"!post.isLocalDraft"--> G["UploadService:657"] --> A
A deeper traversal expands the graph even further, revealing quite a bit of complexity potentially underlying this issue (I have colored orange the flow discovered while debugging with the example content from this comment): flowchart RL
A[setIsLocallyChanged]
style A fill:orange,color:black
B["preparePostForPublish\n (in PostUtils)"] --> A
G[PostUtilsWrapper:44] --> B
H[UploadService:321] --> B
I[UploadUtils:453] --> B
C["savePostToDb\n (in SavePostToDbUserCase)"] ==> A
style C fill:orange,color:black
J[PostListMainViewModel:314] --> C
K[StorePostViewModel:82] --> C
L[StorePostViewModel:111] ==> C
style L fill:orange,color:black
M[SaveInitialPostUseCase:33] --> C
N[StoryComposerViewModel:164] --> C
O[StoryMediaSaveUploadBridge] --> C
D["updatePostWithNewFeatureImg\n (in UploadService)"] --> A
P["UploadService:474\n(updatePostWithCurrentlyCompletedUploads)"] --> D
E["updatePostWithMediaUrl\n (in UploadService)"] --> A
Q["UploadService:476\n(updatePostWithCurrentlyCompletedUploads)"] --> E
F["updatePostWithFailedMedia\n in (UploadService)"] --> A
R["UploadService:496\n(updatePostWithCurrentlyFailedUploads)"] --> F
What is perplexing to me, though, is that I did not consistently encounter this (I seemed to encounter it more frequently on a published post, though, than a draft post in my testing). I also wonder why we are saving to the local db when there are no changes to be saved. So, I also began investigating the Gutenberg side of this issue, and found that upon initializing, the autosave function is called at least twice, though the content did not change, which seems slightly suspicious to me. However, I did not observe this function invocation after tapping a block, although such an action often seemed to result in the locally changed flag being set. I agree with previous conclusions that Aztec improvements will help resolve this issue, and I found that a recent fix has landed for resolving a similar issue regarding parsing and serialization representation differences. Given the complexity of possible sources / causes, I'm hopeful the above diagrams can be useful in resolving this completely. Ultimately, I believe these will reveal the issue to be that of multiple sources of truth (content string diff or an independent boolean flag), and fixing that without regression(s) (i.e. breaking different assumptions) in other areas may require a view of the bigger picture. |
Expected behavior
When I open a post in the gutenberg editor and I close it I expect the post won't contain any local changes.
Actual behavior
When I open a post in the gutenebrg editor and I close it the post contains local changes.
Steps to reproduce the behavior
Tested on [device], Android [version], WPAndroid [version]
Emulator API 29
cc @mchowning you recently played with saving/exiting editor
cc @planarvoid you also have context. Would you have time to look into it during groundskeeping?
The text was updated successfully, but these errors were encountered: