How to avoid a socket timeout for selenium webdriver?

前端 未结 2 1891
一生所求
一生所求 2021-01-18 19:43

I am having a complex python-selenium test suite to test a non-public webpage. In that setup I need to get the webdriver like follows:

self.driver = webdriv         


        
相关标签:
2条回答
  • 2021-01-18 19:54

    This happened to me in my Django app. The problem went away when I set DEBUG = False in my settings.py file.

    0 讨论(0)
  • 2021-01-18 19:58

    The error says it all :

      File "/usr/lib/python2.7/socket.py", line 480, in readline
        data = self._sock.recv(self._rbufsize)
    timeout: timed out
    

    Sequence of events

    Here is the sequence of events that happened :

    • Initially the error occurs at the following line in basicsuite.py file :

      self.driver = webdriver.Firefox(firefox_profile = profile, log_path = logfile)
      
    • After a series of checks finally the following method is called which fails :

      def readinto(self, b):
      """Read up to len(b) bytes into the writable buffer *b* and return
      the number of bytes read.  If the socket is non-blocking and no bytes
      are available, None is returned.
      
      If *b* is non-empty, a 0 return value indicates that the connection
      was shutdown at the other end.
      """
      self._checkClosed()
      self._checkReadable()
      if self._timeout_occurred:
          raise OSError("cannot read from timed out object")
      while True:
          try:
          return self._sock.recv_into(b)
          except timeout:
          self._timeout_occurred = True
          raise
          except error as e:
          if e.args[0] in _blocking_errnos:
              return None
          raise
      
    • The program errors out at :

      self._sock.recv(b) # where If *b* is non-empty, a 0 return value indicates that the connection was shutdown at the other end.
      

    Conclusion

    The conclusion is that the attempt to make the Connection wasn't successfull which means the initialization of the webdriver instance and further spawning of a new Mozilla Firefox Browser Session was unsuccessful.

    Analysis

    It won't be possible to conclude the real reason why timeout: timed out occured. But you can follow some of the Best Practices as follows :

    • Provide the complete name of the logfile along with the logical location of the logfile (from Project Level) as follows :

      self.driver = webdriver.Firefox(firefox_profile=profile, log_path='./Log/geckodriver.log')
      
    • Always use quit() in the tearDown() method so that the webdriver and the webclient both are properly destroyed.

    • Before starting your Test Execution, through Task Manager ensure that there are no dangling instances of GeckoDriver or Firefox process within your system.

    • Ensure that the binary versions you are using JDK, Selenium, GeckoDriver, Mozilla Firefox Browser are compatible. You can find a detailed discussion in this QA Selenium WebDriver 3.4.0 + geckodriver 0.18.0 + Firefox ?? - which combination works?

    • Clean the Project Workspace from your IDE before and after executing your Test Suite.

    • Use CCleaner tool regularly to wipe off the OS chores.

    • If the base version of Firefox Browser is too ancient, uninstall the Firefox Browser through Revo Uninstaller with Moderate Scan and install a recent GA-Released version of Firefox Browser.

    0 讨论(0)
提交回复
热议问题