public inbox for [email protected]  
help / color / mirror / Atom feed
From: Shubham Agarwal <[email protected]>
To: Dave Page <[email protected]>
Cc: Khushboo Vashi <[email protected]>
Cc: pgadmin-hackers <[email protected]>
Subject: Re: pgadmin_page functions updated
Date: Tue, 26 Jun 2018 03:45:46 -0400
Message-ID: <CAKbCA9RNS57utJJG5C073EhHf9XnTELhhGzf2G+tXqTgRxJsZg@mail.gmail.com> (raw)
In-Reply-To: <CA+OCxoxJ0DnZ1=LsDCV4aMRR8Jep3nNieng0qAE9QJjV-E6A4g@mail.gmail.com>
References: <CAKbCA9Rk0PKsMxC95MJhqK=WeDWoizDKiXBZar+uuRe42obq3Q@mail.gmail.com>
	<CAFOhELcp=g9qyFwOc_4vejbu3TRCC3a0bTYyajifNc5Z8oj7TQ@mail.gmail.com>
	<CA+OCxoxJ0DnZ1=LsDCV4aMRR8Jep3nNieng0qAE9QJjV-E6A4g@mail.gmail.com>

Hi Team,

I have modified the patch and used CSS Selector in add_server() function.

I have also tried different approaches to eliminate XPATH in click_tab()
function but failed to do so due to following reasons-:

   1. :contains() function doesnt work with CSS selector in selenium and
since in most of the anchor tags there is no specific attribute present by
which we can make the locator generic so that it can work for any tab.

   2. Tried using link_text or partial_link_text locators but since
click_tab() is a generic function which can click on any of the provided
tab name and in our case we do not have every tab having href attribute, we
have span tag as the tab as well (ex. Query tool tab) so link_text is not
the right option for it since it work only with the href attribute or
anchor tag.

I found that in such cases XPATH is the only option to continue with.

If anybody is having some another idea to achieve this using CSS Selector
than please suggest.

Thanks and Regards,
Shubham Agarwal

On Fri, Jun 15, 2018 at 4:11 AM, Dave Page <[email protected]> wrote:

>
>
> On Fri, Jun 15, 2018 at 6:32 AM, Khushboo Vashi <
> [email protected]> wrote:
>
>> Hi Shubham,
>>
>> On Thu, Jun 14, 2018 at 3:25 PM, Shubham Agarwal <
>> [email protected]> wrote:
>>
>>> Hi Team,
>>>
>>> I have modified following two functions in pgadmin_page.py :-
>>>
>>> 1. click_tab() -> Added wait till element is clickable, test cases are
>>> failing since the function attempts to click the tab which is not yet in
>>> the state to be clicked.
>>>
>>> 2. add_server() -> Replaced the sleep statement with wait till element
>>> to be clickable.
>>>
>>> Please find the attached patch.
>>>
>>> We should start using CSS selectors instead of xpath, otherwise the
>> patch works fine and also changes look good to me.
>>
>
> Yes, and we should update files as and when we touch them as part of our
> ongoing refactoring.
>
> Shubham; please go through the files your patch touches, and replace any
> xpath selectors with CSS selectors.  Aside from that, the patch looked to
> me too, and Pivotal's patch-bot seems happy with it.
>
> Thanks.
>
> --
> Dave Page
> Blog: http://pgsnake.blogspot.com
> Twitter: @pgsnake
>
> EnterpriseDB UK: http://www.enterprisedb.com
> The Enterprise PostgreSQL Company
>



-- 
Thanks & Regards,
Shubham Agarwal
EnterpriseDB Corporation

The Postgres Database Company


Attachments:

  [text/x-patch] pgadmin_page.patch (1.5K, 3-pgadmin_page.patch)
  download | inline diff:
diff --git a/web/regression/feature_utils/pgadmin_page.py b/web/regression/feature_utils/pgadmin_page.py
index 78578a2..ce9bfa3 100644
--- a/web/regression/feature_utils/pgadmin_page.py
+++ b/web/regression/feature_utils/pgadmin_page.py
@@ -60,9 +60,9 @@ class PgadminPage:
         self.fill_input_by_field_name("port", server_config['port'])
         self.fill_input_by_field_name("username", server_config['username'])
         self.fill_input_by_field_name("password", server_config['db_password'])
-        # Required sleep to avoid "fe_sendauth" password error.
-        time.sleep(0.5)
-        self.find_by_xpath("//button[contains(.,'Save')]").click()
+        WebDriverWait(self.driver, 10).until(EC.element_to_be_clickable(
+            (By.CSS_SELECTOR, "button[type='save'].btn.btn-primary")))
+        self.find_by_css_selector("button[type='save'].btn.btn-primary").click()
 
         self.find_by_xpath(
             "//*[@id='tree']//*[.='" + server_config['name'] + "']")
@@ -245,6 +245,11 @@ class PgadminPage:
         action.perform()
 
     def click_tab(self, tab_name):
+        WebDriverWait(self.driver, 10).until(EC.element_to_be_clickable(
+            (By.XPATH, "//*[contains(@class,'wcTabTop')]//"
+                       "*[contains(@class,'wcPanelTab') "
+                       "and contains(.,'" + tab_name + "')]")))
+
         tab = self.find_by_xpath("//*[contains(@class,'wcTabTop')]//"
                                  "*[contains(@class,'wcPanelTab') "
                                  "and contains(.,'" + tab_name + "')]")


view thread (6+ messages)  latest in thread

reply

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Reply to all the recipients using the --to and --cc options:
  reply via email

  To: [email protected]
  Cc: [email protected], [email protected], [email protected]
  Subject: Re: pgadmin_page functions updated
  In-Reply-To: <CAKbCA9RNS57utJJG5C073EhHf9XnTELhhGzf2G+tXqTgRxJsZg@mail.gmail.com>

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

This inbox is served by agora; see mirroring instructions
for how to clone and mirror all data and code used for this inbox