Skip to content

Conversation

@yarikoptic
Copy link
Contributor

@yarikoptic yarikoptic commented Sep 27, 2018

Closes #599
Attn: datalad/datalad#2876
TODOs:

  • Fix up possible broken tests

Demo:

$> cat demo-progress.py  
from git import RemoteProgress, Repo
import sys
url = "http://github.com/gitpython-developers/GitPython"

try:
    Repo.clone_from(url, "/dev/null")
except Exception as e:
    print("No progress - Exception %s with stderr: %r" % (e, e.stderr))

class phandler(RemoteProgress):
    def update(self, *args):
        sys.stdout.write('.')
        sys.stdout.flush()

try:
    Repo.clone_from(url, "/dev/null", progress=phandler())
except Exception as e:
    print("With progress - Exception %s with stderr: %r" % (e, e.stderr))

print("Now without exceptions")
print("Without progress")
Repo.clone_from(url, "/tmp/git-python")
print("With progress")
Repo.clone_from(url, "/tmp/git-python-progress", progress=phandler())
(dev) 1 6408.....................................:Thu 27 Sep 2018 10:17:05 AM EDT:.
(git)hopa:~deb/python-git[bf-progress-stderr2]git
$> rm -rf /tmp/git-python*; python2 demo-progress.py 
No progress - Exception Cmd('git') failed due to: exit code(128)
  cmdline: git clone -v http://github.com/gitpython-developers/GitPython /dev/null
  stderr: 'fatal: destination path '/dev/null' already exists and is not an empty directory.
' with stderr: u"fatal: destination path '/dev/null' already exists and is not an empty directory.\n"
With progress - Exception Cmd('git') failed due to: exit code(128)
  cmdline: git clone --progress -v http://github.com/gitpython-developers/GitPython /dev/null
  stderr: 'fatal: destination path '/dev/null' already exists and is not an empty directory.
' with stderr: u"fatal: destination path '/dev/null' already exists and is not an empty directory.\n"
Now without exceptions
Without progress
With progress
..........................................................................................................................................................................................................%                     (dev) 1 6409.....................................:Thu 27 Sep 2018 10:17:25 AM EDT:.
(git)hopa:~deb/python-git[bf-progress-stderr2]git
$> rm -rf /tmp/git-python*; python3 demo-progress.py 
No progress - Exception Cmd('git') failed due to: exit code(128)
  cmdline: git clone -v http://github.com/gitpython-developers/GitPython /dev/null
  stderr: 'fatal: destination path '/dev/null' already exists and is not an empty directory.
' with stderr: "fatal: destination path '/dev/null' already exists and is not an empty directory.\n"
With progress - Exception Cmd('git') failed due to: exit code(128)
  cmdline: git clone --progress -v http://github.com/gitpython-developers/GitPython /dev/null
  stderr: 'fatal: destination path '/dev/null' already exists and is not an empty directory.
' with stderr: "fatal: destination path '/dev/null' already exists and is not an empty directory.\n"
Now without exceptions
Without progress
With progress
.............................................................................................................................................................................................................%    

It is better to leave original stdout/stderr values as is (well, after decoding)
while storing them, and only add corresponding pretty printing elements while
generating a string representation.  Otherwise are two conflated and Python code
using GitPython need to know about such added formatting which actually was not
in the actual outputs
…ception

I have decided that it would be best to collect all output, not only
not parsed or error lines as is done while parsing it for progress.
This would provide more information, happen stderr includes errors spit out
during progress output etc.
Also a somewhat adhoc tune up of Exception is done to avoid passing those outputs
around etc
@yarikoptic
Copy link
Contributor Author

before I spend time addressing failing tests, I would appreciate feedback if that is the right direction

yarikoptic added a commit to yarikoptic/datalad that referenced this pull request Sep 27, 2018
yarikoptic added a commit to yarikoptic/datalad that referenced this pull request Sep 27, 2018
@Byron
Copy link
Member

Byron commented Oct 13, 2018

To me the implementation looks good! By no means I am any measure though.
Only two tests are failing which could probably be fixed in a straightforward fashion, so I would hope we can get this merged soon.

@yarikoptic
Copy link
Contributor Author

Ok, I will then look into fixing up the tests. Thanks

@Byron
Copy link
Member

Byron commented Sep 28, 2019

Thanks a lot for your contribution thus far !
I am closing this PR due to prolonged inactivity. Please feel free to reopen it in case it can proceed.

@Byron Byron closed this Sep 28, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Development

Successfully merging this pull request may close these issues.

Missing stderr in exception

2 participants