test-bad-extension.t
163 lines
| 7.2 KiB
| text/troff
|
Tads3Lexer
/ tests / test-bad-extension.t
Pulkit Goyal
|
r45109 | #require no-chg | ||
Yuya Nishihara
|
r41032 | $ filterlog () { | ||
> sed -e 's!^[0-9/]* [0-9:]* ([0-9]*)>!YYYY/MM/DD HH:MM:SS (PID)>!' | ||||
> } | ||||
Bryan O'Sullivan
|
r31957 | ensure that failing ui.atexit handlers report sensibly | ||
$ cat > $TESTTMP/bailatexit.py <<EOF | ||||
> from mercurial import util | ||||
> def bail(): | ||||
> raise RuntimeError('ui.atexit handler exception') | ||||
> | ||||
> def extsetup(ui): | ||||
> ui.atexit(bail) | ||||
> EOF | ||||
$ hg -q --config extensions.bailatexit=$TESTTMP/bailatexit.py \ | ||||
> help help | ||||
r40382 | hg help [-eck] [-s PLATFORM] [TOPIC] | |||
Bryan O'Sullivan
|
r31957 | |||
show help for a given topic or a help overview | ||||
error in exit handlers: | ||||
Traceback (most recent call last): | ||||
r48651 | File "*/mercurial/dispatch.py", line *, in _runexithandlers (glob) (no-pyoxidizer !) | |||
File "mercurial.dispatch", line *, in _runexithandlers (glob) (pyoxidizer !) | ||||
Bryan O'Sullivan
|
r31957 | func(*args, **kwargs) | ||
File "$TESTTMP/bailatexit.py", line *, in bail (glob) | ||||
raise RuntimeError('ui.atexit handler exception') | ||||
RuntimeError: ui.atexit handler exception | ||||
[255] | ||||
$ rm $TESTTMP/bailatexit.py | ||||
another bad extension | ||||
Martin Geisler
|
r11858 | $ echo 'raise Exception("bit bucket overflow")' > badext.py | ||
Simon Farnsworth
|
r28083 | $ abspathexc=`pwd`/badext.py | ||
$ cat >baddocext.py <<EOF | ||||
> """ | ||||
> baddocext is bad | ||||
> """ | ||||
> EOF | ||||
$ abspathdoc=`pwd`/baddocext.py | ||||
Martin Geisler
|
r11858 | |||
Yuya Nishihara
|
r23172 | $ cat <<EOF >> $HGRCPATH | ||
> [extensions] | ||||
> gpg = | ||||
> hgext.gpg = | ||||
Simon Farnsworth
|
r28083 | > badext = $abspathexc | ||
> baddocext = $abspathdoc | ||||
Yuya Nishihara
|
r23172 | > badext2 = | ||
> EOF | ||||
Martin Geisler
|
r11858 | |||
timeless@mozdev.org
|
r26239 | $ hg -q help help 2>&1 |grep extension | ||
r49183 | *** failed to import extension "badext" from $TESTTMP/badext.py: bit bucket overflow | |||
r49239 | *** failed to import extension "badext2": No module named 'badext2' (py3 !) | |||
Yuya Nishihara
|
r25364 | |||
show traceback | ||||
Augie Fackler
|
r40273 | $ hg -q help help --traceback 2>&1 | egrep ' extension|^Exception|Traceback|ImportError|ModuleNotFound' | ||
r49183 | *** failed to import extension "badext" from $TESTTMP/badext.py: bit bucket overflow | |||
Yuya Nishihara
|
r25364 | Traceback (most recent call last): | ||
Exception: bit bucket overflow | ||||
r49239 | *** failed to import extension "badext2": No module named 'badext2' (py3 !) | |||
Yuya Nishihara
|
r25364 | Traceback (most recent call last): | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext.badext2' (py36 !) | ||||
Martijn Pieters
|
r40299 | Traceback (most recent call last): (py3 !) | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext3rd.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext3rd.badext2' (py36 !) | ||||
Martijn Pieters
|
r40299 | Traceback (most recent call last): (py3 !) | ||
Ian Moody
|
r43461 | ImportError: No module named 'badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'badext2' (py36 !) | ||||
Yuya Nishihara
|
r25364 | |||
Jun Wu
|
r28155 | names of extensions failed to load can be accessed via extensions.notloaded() | ||
$ cat <<EOF > showbadexts.py | ||||
Yuya Nishihara
|
r32337 | > from mercurial import commands, extensions, registrar | ||
Jun Wu
|
r28155 | > cmdtable = {} | ||
Yuya Nishihara
|
r32337 | > command = registrar.command(cmdtable) | ||
Pulkit Goyal
|
r33097 | > @command(b'showbadexts', norepo=True) | ||
Jun Wu
|
r28155 | > def showbadexts(ui, *pats, **opts): | ||
Augie Fackler
|
r40222 | > ui.write(b'BADEXTS: %s\n' % b' '.join(sorted(extensions.notloaded()))) | ||
Jun Wu
|
r28155 | > EOF | ||
$ hg --config extensions.badexts=showbadexts.py showbadexts 2>&1 | grep '^BADEXTS' | ||||
BADEXTS: badext badext2 | ||||
Gregory Szorc
|
r39148 | #if no-extraextensions | ||
Boris Feld
|
r38750 | show traceback for ImportError of hgext.name if devel.debug.extensions is set | ||
Yuya Nishihara
|
r25364 | |||
Boris Feld
|
r38750 | $ (hg help help --traceback --debug --config devel.debug.extensions=yes 2>&1) \ | ||
timeless@mozdev.org
|
r26239 | > | grep -v '^ ' \ | ||
Yuya Nishihara
|
r41032 | > | filterlog \ | ||
> | egrep 'extension..[^p]|^Exception|Traceback|ImportError|^YYYY|not import|ModuleNotFound' | ||||
YYYY/MM/DD HH:MM:SS (PID)> loading extensions | ||||
YYYY/MM/DD HH:MM:SS (PID)> - processing 5 entries | ||||
YYYY/MM/DD HH:MM:SS (PID)> - loading extension: gpg | ||||
YYYY/MM/DD HH:MM:SS (PID)> > gpg extension loaded in * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - validating extension tables: gpg | ||||
YYYY/MM/DD HH:MM:SS (PID)> - invoking registered callbacks: gpg | ||||
YYYY/MM/DD HH:MM:SS (PID)> > callbacks completed in * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - loading extension: badext | ||||
r49183 | *** failed to import extension "badext" from $TESTTMP/badext.py: bit bucket overflow | |||
Yuya Nishihara
|
r25364 | Traceback (most recent call last): | ||
Exception: bit bucket overflow | ||||
Yuya Nishihara
|
r41032 | YYYY/MM/DD HH:MM:SS (PID)> - loading extension: baddocext | ||
YYYY/MM/DD HH:MM:SS (PID)> > baddocext extension loaded in * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - validating extension tables: baddocext | ||||
YYYY/MM/DD HH:MM:SS (PID)> - invoking registered callbacks: baddocext | ||||
YYYY/MM/DD HH:MM:SS (PID)> > callbacks completed in * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - loading extension: badext2 | ||||
YYYY/MM/DD HH:MM:SS (PID)> - could not import hgext.badext2 (No module named *badext2*): trying hgext3rd.badext2 (glob) | ||||
Yuya Nishihara
|
r25364 | Traceback (most recent call last): | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext.badext2' (py36 !) | ||||
Yuya Nishihara
|
r41032 | YYYY/MM/DD HH:MM:SS (PID)> - could not import hgext3rd.badext2 (No module named *badext2*): trying badext2 (glob) | ||
Pierre-Yves David
|
r28541 | Traceback (most recent call last): | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext.badext2' (py36 !) | ||||
Martijn Pieters
|
r40299 | Traceback (most recent call last): (py3 !) | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext3rd.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext3rd.badext2' (py36 !) | ||||
r49239 | *** failed to import extension "badext2": No module named 'badext2' (py3 !) | |||
Yuya Nishihara
|
r25364 | Traceback (most recent call last): | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext.badext2' (py36 !) | ||||
Martijn Pieters
|
r40299 | Traceback (most recent call last): (py3 !) | ||
Ian Moody
|
r43461 | ImportError: No module named 'hgext3rd.badext2' (py3 no-py36 !) | ||
ModuleNotFoundError: No module named 'hgext3rd.badext2' (py36 !) | ||||
Martijn Pieters
|
r40299 | Traceback (most recent call last): (py3 !) | ||
Ian Moody
|
r43461 | ModuleNotFoundError: No module named 'badext2' (py36 !) | ||
ImportError: No module named 'badext2' (py3 no-py36 !) | ||||
Yuya Nishihara
|
r41032 | YYYY/MM/DD HH:MM:SS (PID)> > loaded 2 extensions, total time * (glob) | ||
YYYY/MM/DD HH:MM:SS (PID)> - loading configtable attributes | ||||
YYYY/MM/DD HH:MM:SS (PID)> - executing uisetup hooks | ||||
YYYY/MM/DD HH:MM:SS (PID)> - running uisetup for gpg | ||||
YYYY/MM/DD HH:MM:SS (PID)> > uisetup for gpg took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - running uisetup for baddocext | ||||
YYYY/MM/DD HH:MM:SS (PID)> > uisetup for baddocext took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> > all uisetup took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - executing extsetup hooks | ||||
YYYY/MM/DD HH:MM:SS (PID)> - running extsetup for gpg | ||||
YYYY/MM/DD HH:MM:SS (PID)> > extsetup for gpg took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - running extsetup for baddocext | ||||
YYYY/MM/DD HH:MM:SS (PID)> > extsetup for baddocext took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> > all extsetup took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - executing remaining aftercallbacks | ||||
YYYY/MM/DD HH:MM:SS (PID)> > remaining aftercallbacks completed in * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> - loading extension registration objects | ||||
YYYY/MM/DD HH:MM:SS (PID)> > extension registration object loading took * (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> > extension baddocext take a total of * to load (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> > extension gpg take a total of * to load (glob) | ||||
YYYY/MM/DD HH:MM:SS (PID)> extension loading complete | ||||
Gregory Szorc
|
r39148 | #endif | ||
Simon Farnsworth
|
r28083 | |||
confirm that there's no crash when an extension's documentation is bad | ||||
$ hg help --keyword baddocext | ||||
r49183 | *** failed to import extension "badext" from $TESTTMP/badext.py: bit bucket overflow | |||
r49239 | *** failed to import extension "badext2": No module named 'badext2' (py3 !) | |||
Simon Farnsworth
|
r28083 | Topics: | ||
extensions Using Additional Features | ||||