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

Restructure wallet-connect namespaces #21167

Merged
merged 11 commits into from
Sep 10, 2024

Conversation

clauxx
Copy link
Member

@clauxx clauxx commented Sep 3, 2024

fixes #21166

Summary

Following the initial WalletConnect implementation and the rush to release, a restructuring became necessary to stabilize the future development of the feature.

Review notes

There are no functional changes other than the namespace names (which cause formatting changes sometimes) and moving of functions into different namespaces.

Testing notes

Need to make sure the main flows work as expected, as all the wallet-connect code was touched. There are no functional changes though, so things should work as they did before.

Platforms

  • Android
  • iOS

Areas that maybe impacted

Functional
  • wallet connect

status: ready

@status-im-auto
Copy link
Member

status-im-auto commented Sep 3, 2024

Jenkins Builds

Click to see older builds (19)
Commit #️⃣ Finished (UTC) Duration Platform Result
ebd43f5 #1 2024-09-03 07:54:08 ~2 min tests 📄log
✔️ ebd43f5 #1 2024-09-03 07:58:48 ~7 min android-e2e 🤖apk 📲
✔️ ebd43f5 #1 2024-09-03 07:59:14 ~8 min android 🤖apk 📲
✔️ ebd43f5 #1 2024-09-03 08:02:49 ~11 min ios 📱ipa 📲
ba25780 #2 2024-09-03 09:02:08 ~3 min tests 📄log
✔️ ba25780 #2 2024-09-03 09:07:11 ~8 min android-e2e 🤖apk 📲
✔️ ba25780 #2 2024-09-03 09:07:39 ~8 min android 🤖apk 📲
✔️ ba25780 #2 2024-09-03 09:10:02 ~11 min ios 📱ipa 📲
✔️ 03472fa #3 2024-09-03 10:23:48 ~4 min tests 📄log
✔️ 03472fa #3 2024-09-03 10:27:45 ~8 min android-e2e 🤖apk 📲
✔️ 03472fa #3 2024-09-03 10:28:09 ~9 min android 🤖apk 📲
✔️ 03472fa #3 2024-09-03 10:30:17 ~11 min ios 📱ipa 📲
✔️ 83cbb86 #4 2024-09-03 10:53:13 ~5 min tests 📄log
✔️ 83cbb86 #4 2024-09-03 10:57:00 ~8 min android-e2e 🤖apk 📲
✔️ 83cbb86 #4 2024-09-03 10:57:26 ~9 min android 🤖apk 📲
✔️ 83cbb86 #4 2024-09-03 11:01:05 ~12 min ios 📱ipa 📲
91831e3 #5 2024-09-09 16:39:39 ~2 min tests 📄log
✔️ 91831e3 #5 2024-09-09 16:45:27 ~8 min android-e2e 🤖apk 📲
✔️ 91831e3 #5 2024-09-09 16:45:53 ~8 min android 🤖apk 📲
Commit #️⃣ Finished (UTC) Duration Platform Result
✔️ d87d8f6 #6 2024-09-09 16:53:08 ~4 min tests 📄log
✔️ d87d8f6 #6 2024-09-09 16:56:43 ~8 min android-e2e 🤖apk 📲
✔️ d87d8f6 #6 2024-09-09 16:57:09 ~9 min android 🤖apk 📲
d87d8f6 #7 2024-09-09 17:20:08 ~1 min ios 📄log
✔️ d87d8f6 #8 2024-09-09 18:37:22 ~14 min ios 📱ipa 📲
✔️ bb548da #7 2024-09-10 12:47:21 ~4 min tests 📄log
✔️ bb548da #7 2024-09-10 12:51:01 ~8 min android-e2e 🤖apk 📲
✔️ bb548da #7 2024-09-10 12:51:30 ~9 min android 🤖apk 📲
✔️ bb548da #9 2024-09-10 12:56:09 ~13 min ios 📱ipa 📲

Copy link
Contributor

@mohsen-ghafouri mohsen-ghafouri left a comment

Choose a reason for hiding this comment

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

Overall looks good to me. Thank you for the amazing work 🚀

@clauxx
Copy link
Member Author

clauxx commented Sep 3, 2024

@status-im/mobile-qa ready for testing

@status-im-auto
Copy link
Member

86% of end-end tests have passed

Total executed tests: 7
Failed tests: 1
Expected to fail tests: 0
Passed tests: 6
IDs of failed tests: 702843 

Failed tests (1)

Click to expand
  • Rerun failed tests

  • Class TestCommunityMultipleDeviceMerged:

    1. test_community_message_edit, id: 702843

    Device 1: Find `Text` by `xpath`: `//android.view.ViewGroup[@content-desc='chat-item']//android.widget.TextView[contains(@text,'Message BEFORE edit')]`
    Device 1: Long press on `Text` until expected element is shown

    critical/chats/test_public_chat_browsing.py:373: in test_community_message_edit
        self.channel_1.edit_message_in_chat(message_before_edit, message_after_edit)
    ../views/chat_view.py:1015: in edit_message_in_chat
        self.chat_element_by_text(message_to_edit).message_body.long_press_until_element_is_shown(element)
    ../views/base_element.py:331: in long_press_until_element_is_shown
        action.long_press(element).release().perform()
    ../../../../status-app-prs-rerun@tmp/venv/lib/python3.10/site-packages/appium/webdriver/common/touch_action.py:174: in perform
        self._driver.execute(Command.TOUCH_ACTION, params)
    ../../../../status-app-prs-rerun@tmp/venv/lib/python3.10/site-packages/selenium/webdriver/remote/webdriver.py:345: in execute
        self.error_handler.check_response(response)
    ../../../../status-app-prs-rerun@tmp/venv/lib/python3.10/site-packages/appium/webdriver/errorhandler.py:122: in check_response
        raise exception_class(msg=message, stacktrace=format_stacktrace(stacktrace))
     The element 'By.xpath: //android.view.ViewGroup[@content-desc='chat-item']//android.widget.TextView[contains(@text,'Message BEFORE edit')]' is not linked to the same object in DOM anymore; For documentation on this error, please visit: https://www.selenium.dev/documentation/webdriver/troubleshooting/errors#stale-element-reference-exception
    E   Stacktrace:
    E   io.appium.uiautomator2.common.exceptions.StaleElementReferenceException: The element 'By.xpath: //android.view.ViewGroup[@content-desc='chat-item']//android.widget.TextView[contains(@text,'Message BEFORE edit')]' is not linked to the same object in DOM anymore
    E   	at io.appium.uiautomator2.model.ElementsCache.restore(ElementsCache.java:122)
    E   	at io.appium.uiautomator2.model.ElementsCache.get(ElementsCache.java:153)
    E   	at io.appium.uiautomator2.handler.Location.safeHandle(Location.java:23)
    E   	at io.appium.uiautomator2.handler.request.SafeRequestHandler.handle(SafeRequestHandler.java:59)
    E   	at io.appium.uiautomator2.server.AppiumServlet.handleRequest(AppiumServlet.java:277)
    E   	at io.appium.uiautomator2.server.AppiumServlet.handleHttpRequest(AppiumServlet.java:271)
    E   	at io.appium.uiautomator2.http.ServerHandler.channelRead(ServerHandler.java:68)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:366)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:352)
    E   	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:345)
    E   	at io.netty.handler.codec.MessageToMessageDecoder.channelRead(MessageToMessageDecoder.java:102)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:366)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:352)
    E   	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:345)
    E   	at io.netty.channel.CombinedChannelDuplexHandler$DelegatingChannelHandlerContext.fireChannelRead(CombinedChannelDuplexHandler.java:435)
    E   	at io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:293)
    E   	at io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:267)
    E   	at io.netty.channel.CombinedChannelDuplexHandler.channelRead(CombinedChannelDuplexHandler.java:250)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:366)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:352)
    E   	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:345)
    E   	at io.netty.handler.timeout.IdleStateHandler.channelRead(IdleStateHandler.java:266)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:366)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:352)
    E   	at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:345)
    E   	at io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1294)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:366)
    E   	at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:352)
    E   	at io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:911)
    E   	at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:131)
    E   	at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:611)
    E   	at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:552)
    E   	at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:466)
    E   	at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:438)
    E   	at io.netty.util.concurrent.SingleThreadEventExecutor$2.run(SingleThreadEventExecutor.java:140)
    E   	at io.netty.util.concurrent.DefaultThreadFactory$DefaultRunnableDecorator.run(DefaultThreadFactory.java:144)
    E   	at java.lang.Thread.run(Thread.java:1012)
    



    Device sessions

    Passed tests (6)

    Click to expand

    Class TestWalletMultipleDevice:

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

    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
    Device sessions

    Class TestCommunityOneDeviceMerged:

    1. test_community_copy_and_paste_message_in_chat_input, id: 702742
    Device sessions

    2. test_restore_multiaccount_with_waku_backup_remove_switch, id: 703133
    Device sessions

    @pavloburykh pavloburykh self-assigned this Sep 6, 2024
    @pavloburykh
    Copy link
    Contributor

    pavloburykh commented Sep 6, 2024

    @clauxx thanks for the PR. Please, take a look at the issue

    ISSUE 1 No account is selected by default in connection modal

    Steps:

    1. Scan wallet connect QR via universal scanner
    2. See if account is selected within connection modal

    Actual result: no account selected.

    photo_2024-09-06 13 43 45

    Expected result: default account should be selected

    @mohsen-ghafouri
    Copy link
    Contributor

    I will take a look to this issue

    @mohsen-ghafouri mohsen-ghafouri self-assigned this Sep 9, 2024
    mohsen-ghafouri added a commit that referenced this pull request Sep 9, 2024
    @mohsen-ghafouri mohsen-ghafouri force-pushed the cl-restructure-wallet-connect branch from 83cbb86 to 91831e3 Compare September 9, 2024 16:36
    mohsen-ghafouri added a commit that referenced this pull request Sep 9, 2024
    @mohsen-ghafouri mohsen-ghafouri force-pushed the cl-restructure-wallet-connect branch from 91831e3 to d87d8f6 Compare September 9, 2024 16:47
    @mohsen-ghafouri
    Copy link
    Contributor

    Hey @mariia-skrypnyk could you please test again. thanks

    @mariia-skrypnyk
    Copy link

    Hi @mohsen-ghafouri !
    Thanks for your fix. Accounts could be changed successfully!

    I see one more issue relates to account selection:

    ISSUE 2: user is navigated to Wallet Account without a connection

    Steps:

    1. Login to app
    2. Choose Account 1
    3. Tap on WC icon
    4. Scan QR code from test daap https://react-app.walletconnect.com/
    5. Choose Account 2 within connection modal
    6. Tap connect

    Actual result:

    User is redirected to Wallet account connection screen on Account 1 without a connection:

    IMG_2330.MP4

    Expected result:

    User should be redirected to Wallet account connection of chosen Account 2.

    Design with navigation example is here https://www.figma.com/design/mLyiYPXqu8KetdQONOlZpV/dApp-Interactions?node-id=47-29943&node-type=frame&t=YPrT5xiOglqRZdyE-0

    @mohsen-ghafouri
    Copy link
    Contributor

    mohsen-ghafouri commented Sep 10, 2024

    Thank you @mariia-skrypnyk for checking this, could you please check if it's related to this PR or a general issue on dev, if so we can handle it in a follow up issue, as current PR is big enough to merge.

    also i'm not sure when user exactly is in this account we should let they change the selection or not.

    @mariia-skrypnyk
    Copy link

    Thank you @mariia-skrypnyk for checking this, could you please check if it's related to this PR or a general issue on dev, if so we can handle it in a follow up issue, as current PR is big enough to merge.

    also i'm not sure when user exactly is in this account we should let they change the selection or not.

    Thanks @mohsen-ghafouri !

    This behaviour also exist on nightly.
    I rerun tests and let you know.

    @status-im-auto
    Copy link
    Member

    57% of end-end tests have passed

    Total executed tests: 7
    Failed tests: 3
    Expected to fail tests: 0
    Passed tests: 4
    
    IDs of failed tests: 703133,727229,702843 
    

    Failed tests (3)

    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:346: 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 TestWalletMultipleDevice:

    1. test_wallet_send_eth, id: 727229

    Device 2: Find Text by xpath: //android.view.ViewGroup[@content-desc='container']/android.widget.TextView[@text='Ether']/../android.widget.TextView[3]
    Device 2: Text is 0.05289 ETH

    critical/test_wallet.py:159: in test_wallet_send_eth
        self.errors.verify_no_errors()
    base_test_case.py:191: in verify_no_errors
        pytest.fail('\n '.join([self.errors.pop(0) for _ in range(len(self.errors))]))
     Sender balance is not updated on Etherscan, it is 0.4334 but expected to be 0.4335
    



    Class TestCommunityOneDeviceMerged:

    1. test_restore_multiaccount_with_waku_backup_remove_switch, id: 703133

    Device 1: Find Button by accessibility id: show-profiles
    Device 1: Tap on found: Button

    critical/chats/test_public_chat_browsing.py:243: in test_restore_multiaccount_with_waku_backup_remove_switch
        self.errors.verify_no_errors()
    base_test_case.py:191: in verify_no_errors
        pytest.fail('\n '.join([self.errors.pop(0) for _ in range(len(self.errors))]))
     zQ3...dWXh5 was not restored as a contact from waku backup!
    E    zQ3...Vacac was not restored as a contact from waku backup!
    E    admin_open was not restored from waku-backup!!
    E    member_open was not restored from waku-backup!!
    E    admin_closed was not restored from waku-backup!!
    E    member_closed was not restored from waku-backup!!
    



    Device sessions

    Passed tests (4)

    Click to expand

    Class TestWalletMultipleDevice:

    1. test_wallet_send_asset_from_drawer, id: 727230

    Class TestCommunityOneDeviceMerged:

    1. test_community_copy_and_paste_message_in_chat_input, id: 702742
    Device sessions

    Class TestWalletOneDevice:

    1. test_wallet_add_remove_regular_account, id: 727231
    Device sessions

    Class TestOneToOneChatMultipleSharedDevicesNewUi:

    1. test_1_1_chat_non_latin_messages_stack_update_profile_photo, id: 702745
    Device sessions

    @churik
    Copy link
    Member

    churik commented Sep 10, 2024

    Failed tests are not related to PR, ready to merge

    thanks @mariia-skrypnyk and @mohsen-ghafouri

    @status-im-auto
    Copy link
    Member

    67% of end-end tests have passed

    Total executed tests: 3
    Failed tests: 1
    Expected to fail tests: 0
    Passed tests: 2
    
    IDs of failed tests: 702843 
    

    Failed tests (1)

    Click to expand
  • Rerun failed tests

  • Class TestCommunityMultipleDeviceMerged:

    1. test_community_message_edit, id: 702843

    Device 2: Looking for a message by text: Message AFTER edit 2 (Edited)
    Device 2: Find `ChatElementByText` by `xpath`: `//*[starts-with(@text,'Message AFTER edit 2 (Edited)')]/ancestor::android.view.ViewGroup[@content-desc='chat-item']`

    critical/chats/test_public_chat_browsing.py:378: in test_community_message_edit
        self.channel_2.set_reaction(message_text_after_edit)
    ../views/chat_view.py:1053: in set_reaction
        self.chat_element_by_text(message).long_press_until_element_is_shown(element)
    ../views/base_element.py:327: in long_press_until_element_is_shown
        element = self.find_element()
    ../views/chat_view.py:116: in find_element
        self.wait_for_visibility_of_element(20)
    ../views/base_element.py:147: in wait_for_visibility_of_element
        raise TimeoutException(
     Device 2: ChatElementByText by xpath:`//*[starts-with(@text,'Message AFTER edit 2 (Edited)')]/ancestor::android.view.ViewGroup[@content-desc='chat-item']` is not found on the screen after wait_for_visibility_of_element
    



    Device sessions

    Passed tests (2)

    Click to expand

    Class TestCommunityOneDeviceMerged:

    1. test_restore_multiaccount_with_waku_backup_remove_switch, id: 703133
    Device sessions

    Class TestWalletMultipleDevice:

    1. test_wallet_send_eth, id: 727229

    @mohsen-ghafouri mohsen-ghafouri force-pushed the cl-restructure-wallet-connect branch from d87d8f6 to bb548da Compare September 10, 2024 12:42
    @mohsen-ghafouri mohsen-ghafouri merged commit 9135e91 into develop Sep 10, 2024
    6 checks passed
    @mohsen-ghafouri mohsen-ghafouri deleted the cl-restructure-wallet-connect branch September 10, 2024 12:59
    @mohsen-ghafouri
    Copy link
    Contributor

    mohsen-ghafouri commented Sep 10, 2024

    Hi @mariia-skrypnyk, I created this issue #21243 for ISSUE 2

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

    Successfully merging this pull request may close these issues.

    Restructure wallet-connect namespaces
    8 participants