Uploaded image for project: 'ZooKeeper'
  1. ZooKeeper
  2. ZOOKEEPER-510

zkpython lumps all exceptions as IOError, needs specialized exceptions for KeeperException types

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Major
    • Resolution: Fixed
    • 3.2.0
    • 3.2.2, 3.3.0
    • contrib-bindings
    • None
    • Reviewed

    Description

      The current zkpython bindings always throw "IOError("text")" exceptions, even for ZK specific exceptions such as NODEEXISTS. This makes it difficult (error prone) to handle exceptions in python code. You can't easily pickup a connection loss vs a node exists for example. Of course you could match the error string, but this seems like a bad idea imo.

      We need to add specific exception types to the python binding that map directly to KeeperException/java types. It would also be useful to include the information provided by the KeeperException (like path in some cases), etc... as part of the error thrown to the python code. Would probably be a good idea to stay as close to java api as possible wrt mapping the errors.

      Attachments

        1. ZOOKEEPER-510-incref.patch
          0.8 kB
          Henry Robinson
        2. ZOOKEEPER-510.patch
          12 kB
          Henry Robinson
        3. ZOOKEEPER-510.patch
          16 kB
          Patrick D. Hunt
        4. ZOOKEEPER-510.patch
          16 kB
          Patrick D. Hunt
        5. ZOOKEEPER-510.patch
          29 kB
          Henry Robinson

        Activity

          People

            henryr Henry Robinson
            phunt Patrick D. Hunt
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: