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

feat(onboarding): Present Terms to users upgrading from v1 or those who need to accept updated Terms #21487

Merged
merged 3 commits into from
Oct 23, 2024

Conversation

ilmotta
Copy link
Contributor

@ilmotta ilmotta commented Oct 23, 2024

Fixes #21113

Summary

This PR is 99% identical to #21124. We are cherry-picking from the 2.30 release branch revision d45eb5e and applying to the status-go and status-mobile develop branches in preparation for the 2.31 release.

Related status-go PR: status-im/status-go#5977

We will update the release branches once the develop branches are merged.

Steps to test

Steps to test are identical to the original PR #21124.

I re-tested and everything seems to work as well as in 2.30, where the original PR was already tested. I tested a scenario that's difficult for a QA to test, where I simulated a user who had Status v2 installed, had already accepted the Terms, then I forced a new migration in status-go to simulate an update to the Terms, and finally checked the user would need to re-accept terms before proceeding.

status: ready

@ilmotta ilmotta self-assigned this Oct 23, 2024
@@ -17,6 +18,15 @@
(fn [{:keys [customization-color]}]
(or customization-color constants/profile-default-color)))

;; A profile can only be created without accepting terms in Status v1. In Status
Copy link
Contributor Author

Choose a reason for hiding this comment

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

I was confused by my own comment in the original commit, so after cherry-picking I reworded things a bit and renamed the subscription.

@status-im-auto
Copy link
Member

status-im-auto commented Oct 23, 2024

Jenkins Builds

Commit #️⃣ Finished (UTC) Duration Platform Result
✔️ 61ac890 #1 2024-10-23 03:27:29 ~5 min tests 📄log
✔️ 61ac890 #1 2024-10-23 03:30:59 ~9 min android-e2e 🤖apk 📲
✔️ 61ac890 #1 2024-10-23 03:31:23 ~9 min android 🤖apk 📲
✔️ 61ac890 #1 2024-10-23 03:31:36 ~10 min ios 📱ipa 📲
✔️ 61ac890 #2 2024-10-23 10:52:56 ~9 min android 🤖apk 📲
✔️ c47f317 #2 2024-10-23 14:17:17 ~4 min tests 📄log
✔️ c47f317 #2 2024-10-23 14:20:12 ~7 min android-e2e 🤖apk 📲
✔️ c47f317 #3 2024-10-23 14:21:42 ~9 min android 🤖apk 📲
✔️ c47f317 #2 2024-10-23 14:22:34 ~10 min ios 📱ipa 📲

@pavloburykh pavloburykh self-assigned this Oct 23, 2024
@status-im-auto
Copy link
Member

75% of end-end tests have passed

Total executed tests: 8
Failed tests: 2
Expected to fail tests: 0
Passed tests: 6
IDs of failed tests: 703133,702843 

Failed tests (2)

Click to expand
  • Rerun failed tests

  • Class TestCommunityOneDeviceMerged:

    1. test_restore_multiaccount_with_waku_backup_remove_switch, id: 703133

    # STEP: Check that removed user is not shown in the list anymore
    Device 1: Wait for element `Button` for max 30s and click when it is available

    critical/chats/test_public_chat_browsing.py:240: in test_restore_multiaccount_with_waku_backup_remove_switch
        self.sign_in.show_profiles_button.wait_and_click()
    ../views/base_element.py:100: in wait_and_click
        self.wait_for_visibility_of_element(sec)
    ../views/base_element.py:147: in wait_for_visibility_of_element
        raise TimeoutException(
     Device 1: Button by accessibility id:`show-profiles` is not found on the screen after wait_for_visibility_of_element
    



    Device sessions

    Class TestCommunityMultipleDeviceMerged:

    1. test_community_message_edit, id: 702843

    Device 2: Find Text by xpath: //android.view.ViewGroup[@content-desc='chat-item']//android.widget.TextView[contains(@text,'https://status.app/c/')]
    Device 2: Wait for element Button for max 120s and click when it is available

    Test setup failed: critical/chats/test_public_chat_browsing.py:350: in prepare_devices
        self.community_2.join_community()
    ../views/chat_view.py:420: in join_community
        self.join_button.wait_and_click(120)
    ../views/base_element.py:100: in wait_and_click
        self.wait_for_visibility_of_element(sec)
    ../views/base_element.py:147: in wait_for_visibility_of_element
        raise TimeoutException(
     Device 2: Button by accessibility id:`show-request-to-join-screen-button` is not found on the screen after wait_for_visibility_of_element
    



    Device sessions

    Passed tests (6)

    Click to expand

    Class TestOneToOneChatMultipleSharedDevicesNewUi:

    1. test_1_1_chat_non_latin_messages_stack_update_profile_photo, id: 702745
    Device sessions

    Class TestWalletMultipleDevice:

    1. test_wallet_send_asset_from_drawer, id: 727230
    2. test_wallet_send_eth, id: 727229

    Class TestWalletOneDevice:

    1. test_wallet_add_remove_regular_account, id: 727231
    2. test_wallet_balance_mainnet, id: 740490

    Class TestCommunityOneDeviceMerged:

    1. test_community_copy_and_paste_message_in_chat_input, id: 702742
    Device sessions

    @status-im-auto
    Copy link
    Member

    75% of end-end tests have passed

    Total executed tests: 8
    Failed tests: 2
    Expected to fail tests: 0
    Passed tests: 6
    
    IDs of failed tests: 703133,702843 
    

    Failed tests (2)

    Click to expand
  • Rerun failed tests

  • Class TestCommunityMultipleDeviceMerged:

    1. test_community_message_edit, id: 702843

    Device 2: Find `Text` by `xpath`: `//android.view.ViewGroup[@content-desc='chat-item']//android.widget.TextView[contains(@text,'https://status.app/c/')]`
    Device 2: Wait for element `Button` for max 120s and click when it is available

    Test setup failed: critical/chats/test_public_chat_browsing.py:350: in prepare_devices
        self.community_2.join_community()
    ../views/chat_view.py:420: in join_community
        self.join_button.wait_and_click(120)
    ../views/base_element.py:100: in wait_and_click
        self.wait_for_visibility_of_element(sec)
    ../views/base_element.py:147: in wait_for_visibility_of_element
        raise TimeoutException(
     Device 2: Button by accessibility id:`show-request-to-join-screen-button` is not found on the screen after wait_for_visibility_of_element
    



    Device sessions

    Class TestCommunityOneDeviceMerged:

    1. test_restore_multiaccount_with_waku_backup_remove_switch, id: 703133

    # STEP: Check that removed user is not shown in the list anymore
    Device 1: Wait for element Button for max 30s and click when it is available

    critical/chats/test_public_chat_browsing.py:240: in test_restore_multiaccount_with_waku_backup_remove_switch
        self.sign_in.show_profiles_button.wait_and_click()
    ../views/base_element.py:100: in wait_and_click
        self.wait_for_visibility_of_element(sec)
    ../views/base_element.py:147: in wait_for_visibility_of_element
        raise TimeoutException(
     Device 1: Button by accessibility id:`show-profiles` is not found on the screen after wait_for_visibility_of_element
    



    Device sessions

    Passed tests (6)

    Click to expand

    Class TestOneToOneChatMultipleSharedDevicesNewUi:

    1. test_1_1_chat_non_latin_messages_stack_update_profile_photo, id: 702745
    Device sessions

    Class TestWalletOneDevice:

    1. test_wallet_add_remove_regular_account, id: 727231
    2. test_wallet_balance_mainnet, id: 740490

    Class TestCommunityOneDeviceMerged:

    1. test_community_copy_and_paste_message_in_chat_input, id: 702742
    Device sessions

    Class TestWalletMultipleDevice:

    1. test_wallet_send_asset_from_drawer, id: 727230
    2. test_wallet_send_eth, id: 727229

    @pavloburykh
    Copy link
    Contributor

    pavloburykh commented Oct 23, 2024

    @ilmotta thanks for the PR. Please take a look at the issue below

    ISSUE 1 Terms screen appears after removing one of the existing Profiles despite terms have been already accepted before

    Steps:

    1. Create Profile A
    2. Close and reopen the app
    3. Create Profile B
    4. Close and reopen the app
    5. Go to Profiles list screen
    6. Remove Profile A
    7. Close and reopen the app
    8. Observe which screen is displayed after app reopening

    Actual result: Terms screen is displayed despite terms have been already accepted.

    telegram-cloud-document-2-5244689624340649849.mp4

    @ilmotta
    Copy link
    Contributor Author

    ilmotta commented Oct 23, 2024

    Thank you for promptly testing @pavloburykh 💯

    Unfortunately this is the behavior by "design" in the code. It's a known shortcoming of the implementation in status-go. The state about whether the user accepted the terms is stored in the first profile ever created. If you created two profiles, but deleted the first one, then the incorrect screen will appear. If you remove profile B instead of A, it work correctly because the state would still be stored in the local db by status-go.

    In release 2.32 we will make same pretty significant simplifications to onboarding. One of the changes under consideration is to remove this mandatory checkbox and use something like "By proceeding you agree with the terms" and possibly removing this extra screen saying "Explore new Status" because most users would have migrated from v1 anyway (according to app stores). It will be a matter of aligning with legal too, so let's see. Right now we can minimize our efforts regarding the privacy policy and terms of use UX because we may change everything soon.

    For now I would say this is a minor limitation we can live with until 2.32 is published.

    What do you think?

    @pavloburykh
    Copy link
    Contributor

    What do you think?

    Agree @ilmotta! PR is ready for merge. Thank you!

    This commit is essentially a cherry-pick from
    d45eb5e.
    
    We now show the onboarding intro requesting the user to accept the Terms of Use
    & Privacy Policy with the new button "Explore the new Status".
    
    status-go PR status-im/status-go#5977
    
    In practice, this means:
    
    - Users coming from Status v1 who had at least one profile will see the modified
    onboarding intro screen and will need to accept the terms to proceed.
    - Users who already installed v2, are upgrading, and Status has a privacy policy
    changes will need to accept the terms to proceed.
    
    Areas that may be impacted
    
    - Onboarding
    
    Steps to test:
    
    The criteria used during development:
    
    1. Given that user Alice had installed v1 and had one or more profiles.
    2. When she installs v2 and opens it, she sees the new onboarding intro and must
       agree to the terms to enable the button "Explore the new Status".
    3. After pressing the button, she can login as usual in any of her profiles.
    
    1. Given that user Alice already upgraded from v1 and accepted the terms.
    2. When she reopens the app she does not need to accept terms again and can
       immediately sign-in with any of her profiles.
    
    1. Given that user Alice already upgraded from v1 and accepted the terms.
    2. When she deletes all profiles, she sees the onboarding intro for users who
       have not upgraded, i.e. she has to agree to terms and she sees the usual two
       buttons "Create profile" and "Sync or recover profile".
    
    1. Given that user Alice never installed Status.
    2. When she installs v2, she sees the normal onboarding intro screen, where she
       has to accept the terms and she sees two buttons "Create profile" and "Sync
       or recover profile".
    3. When she reopens the app, she doesn't see anymore the screen to accept terms.
    @ilmotta ilmotta force-pushed the ilmotta/present-terms-when-they-changed branch from 61ac890 to c47f317 Compare October 23, 2024 14:12
    @ilmotta ilmotta merged commit e1abe5c into develop Oct 23, 2024
    5 checks passed
    @ilmotta ilmotta deleted the ilmotta/present-terms-when-they-changed branch October 23, 2024 14:26
    ilmotta added a commit that referenced this pull request Oct 23, 2024
    …ho need to accept updated Terms (#21487)
    
    Cherry-pick d45eb5e.
    
    Fixes #21113
    
    Related status-go PR: status-im/status-go#5977
    ilmotta added a commit that referenced this pull request Oct 23, 2024
    …ho need to accept updated Terms (#21487)
    
    Cherry-pick d45eb5e.
    
    Fixes #21113
    
    Related status-go PR: status-im/status-go#5977
    @pavloburykh
    Copy link
    Contributor

    pavloburykh commented Nov 4, 2024

    Hey @ilmotta! Also, it turned out that Terms screen is appearing for synced account.

    ISSUE 2 Terms screen appears after syncing the account

    Steps:

    1. Generate sync QR on Device A
    2. Scan QR by Device B to sync the devices
    3. Wait until sync is complete
    4. Close and reopen the app on Device B

    Actual result: user needs accept Terms

    telegram-cloud-document-2-5280758248591349646.mp4

    @pavloburykh
    Copy link
    Contributor

    @ilmotta how do you think, do we want to fix ISSUE 1 and ISSUE 2 or we will leave it as it is. In case we want to fix it, I can combine and log them in one separate issue.

    @ilmotta
    Copy link
    Contributor Author

    ilmotta commented Nov 4, 2024

    @ilmotta how do you think, do we want to fix ISSUE 1 and ISSUE 2 or we will leave it as it is. In case we want to fix it, I can combine and log them in one separate issue.

    @pavloburykh, ISSUE 2 is new to me, and it's an unfortunate bug we will have to live with in 2.31 (the bug should exist in 2.30 (?) because we basically cherry-picked).

    But to answer your question, onboarding simplifications have been defined and the user won't have to accept the checkbox (per screenshot). This means the existing (2.30 & 2.31) solution won't work well in 2.32 and we'll need to adjust. The business problem is: how do we tell the user the Terms of Service or Privacy Policy changed between releases? I believe whatever we do we will do in the least obtrusive way and the simplest way, therefore different than 2.30 & 2.31.

    Long story short, I think we shouldn't fix ISSUE 1 or ISSUE 2 now, but they will be attacked/solved in 2.32 once we define & implement what I shared above. I even have the impression we might completely remove the code from this PR (and from status-go), but let's see.

    @pavloburykh
    Copy link
    Contributor

    (the bug should exist in 2.30 (?)

    Yes. it exists in 2.30, wondering how we (QAs) have missed it.
    Thanks for the answer @ilmotta Then, let's wait for implementing onboarding simplification.

    @ilmotta
    Copy link
    Contributor Author

    ilmotta commented Dec 9, 2024

    (the bug should exist in 2.30 (?)

    Yes. it exists in 2.30, wondering how we (QAs) have missed it. Thanks for the answer @ilmotta Then, let's wait for implementing onboarding simplification.

    @pavloburykh I didn't forget about this issue :) But in 2.32 we will go with what we have right now and not cause further modifications because the onboarding simplifications are still in progress. In release 2.33 we will likely have time to get back to this issue. My intuition tells me we will just remove the entire feature because users of 2.32+ will accept the terms implicitly.

    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
    Projects
    Status: DONE
    Development

    Successfully merging this pull request may close these issues.

    Show Privacy Policy and Terms modal for upgraded users
    5 participants