From 77a9924e774f2f1116f2e0a7ee53fc2c126c434e Mon Sep 17 00:00:00 2001 From: Wouter Vanden Hove Date: Sun, 12 Mar 2023 02:56:41 +0100 Subject: [PATCH 1/3] blacken codebase --- HISTORY.txt | 14 ++++++------- ipdb/__init__.py | 6 +++--- ipdb/__main__.py | 50 +++++++++++++++++++++++++++----------------- pyproject.toml | 4 ++++ tests/test_config.py | 27 ++++++++++++------------ tests/test_import.py | 4 ++-- tests/test_opts.py | 34 +++++++++++++++--------------- 7 files changed, 78 insertions(+), 61 deletions(-) diff --git a/HISTORY.txt b/HISTORY.txt index 74d2830..62b0a1f 100644 --- a/HISTORY.txt +++ b/HISTORY.txt @@ -4,7 +4,7 @@ Changelog 0.13.14 (unreleased) -------------------- -- Nothing changed yet. +- Run ``black`` on ipdb-codebase with line-length 88. [WouterVH] 0.13.13 (2023-03-09) @@ -145,7 +145,7 @@ Changelog 0.12.1 (2019-07-26) ------------------- -- Fix --help +- Fix --help [native-api] @@ -185,7 +185,7 @@ Changelog - Ask IPython which debugger class to use. Closes https://github.com/gotcha/ipdb/issues/105 - [gnebehay, JBKahn] + [gnebehay, JBKahn] - ipdb.set_trace() does not ignore context arg anymore. Closes https://github.com/gotcha/ipdb/issues/93. @@ -339,7 +339,7 @@ Changelog ---------------- - Add setuptools ``console_scripts`` entry point. - [akrito, gotcha] + [akrito, gotcha] - Nose support. Closes https://github.com/gotcha/ipdb/issues/8 @@ -360,12 +360,12 @@ Changelog Closes https://github.com/gotcha/ipdb/issues/1 [gotcha] -- Fixed errors when exiting with "q". +- Fixed errors when exiting with "q". [gotcha] - Allow use of ``python -m ipdb mymodule.py``. - Python 2.7 only. - Closes https://github.com/gotcha/ipdb/issues/3 + Python 2.7 only. + Closes https://github.com/gotcha/ipdb/issues/3 [gotcha] - Fixed post_mortem when the traceback is None. diff --git a/ipdb/__init__.py b/ipdb/__init__.py index 75e8fed..65cc3b4 100644 --- a/ipdb/__init__.py +++ b/ipdb/__init__.py @@ -4,8 +4,8 @@ # Redistributable under the revised BSD license # https://opensource.org/licenses/BSD-3-Clause -from ipdb.__main__ import set_trace, post_mortem, pm, run, iex # noqa +from ipdb.__main__ import set_trace, post_mortem, pm, run, iex # noqa from ipdb.__main__ import runcall, runeval, launch_ipdb_on_exception # noqa -from ipdb.stdout import sset_trace, spost_mortem, spm # noqa -from ipdb.stdout import slaunch_ipdb_on_exception # noqa +from ipdb.stdout import sset_trace, spost_mortem, spm # noqa +from ipdb.stdout import slaunch_ipdb_on_exception # noqa diff --git a/ipdb/__main__.py b/ipdb/__main__.py index fb1cd1c..c4b649a 100644 --- a/ipdb/__main__.py +++ b/ipdb/__main__.py @@ -10,12 +10,13 @@ from decorator import contextmanager -__version__ = '0.13.14.dev0' +__version__ = "0.13.14.dev0" from IPython import get_ipython from IPython.core.debugger import BdbQuit_excepthook from IPython.terminal.ipapp import TerminalIPythonApp from IPython.terminal.embed import InteractiveShellEmbed + try: import configparser except: @@ -75,7 +76,7 @@ def set_trace(frame=None, context=None, cond=True): if frame is None: frame = sys._getframe().f_back p = _init_pdb(context).set_trace(frame) - if p and hasattr(p, 'shell'): + if p and hasattr(p, "shell"): p.shell.restore_sys_module_state() @@ -110,7 +111,7 @@ def readline(self): try: return self.__next__() except StopIteration: - return '' + return "" # Python 2.7 (Newer dot versions) def next(self): @@ -170,21 +171,24 @@ def get_config(): parser.filepath = filepath # Users are expected to put an [ipdb] section # only if they use setup.cfg - if filepath.endswith('setup.cfg'): + if filepath.endswith("setup.cfg"): with open(filepath) as f: parser.remove_section("ipdb") read_func(f) # To use on pyproject.toml, put [tool.ipdb] section - elif filepath.endswith('pyproject.toml'): + elif filepath.endswith("pyproject.toml"): try: import tomllib + file_mode = "rb" except ImportError: try: import tomli as tomllib + file_mode = "rb" except ImportError: import toml as tomllib + file_mode = "r" with open(filepath, file_mode) as f: toml_file = tomllib.load(f) @@ -242,7 +246,8 @@ def launch_ipdb_on_exception(): iex = launch_ipdb_on_exception() -_usage = """\ +_usage = ( + """\ usage: python -m ipdb [-m] [-c command] ... pyfile [arg] ... Debug the Python program given by pyfile. @@ -257,7 +262,9 @@ def launch_ipdb_on_exception(): Option -m is available only in Python 3.7 and later. -ipdb version %s.""" % __version__ +ipdb version %s.""" + % __version__ +) def main(): @@ -268,35 +275,36 @@ def main(): try: from pdb import Restart except ImportError: + class Restart(Exception): pass if sys.version_info >= (3, 7): - opts, args = getopt.getopt(sys.argv[1:], 'mhc:', ['help', 'command=']) + opts, args = getopt.getopt(sys.argv[1:], "mhc:", ["help", "command="]) else: - opts, args = getopt.getopt(sys.argv[1:], 'hc:', ['help', 'command=']) + opts, args = getopt.getopt(sys.argv[1:], "hc:", ["help", "command="]) commands = [] run_as_module = False for opt, optarg in opts: - if opt in ['-h', '--help']: + if opt in ["-h", "--help"]: print(_usage) sys.exit() - elif opt in ['-c', '--command']: + elif opt in ["-c", "--command"]: commands.append(optarg) - elif opt in ['-m']: + elif opt in ["-m"]: run_as_module = True if not args: print(_usage) sys.exit(2) - mainpyfile = args[0] # Get script filename + mainpyfile = args[0] # Get script filename if not run_as_module and not os.path.exists(mainpyfile): - print('Error:', mainpyfile, 'does not exist') + print("Error:", mainpyfile, "does not exist") sys.exit(1) - sys.argv = args # Hide "pdb.py" from argument list + sys.argv = args # Hide "pdb.py" from argument list # Replace pdb's dir with script's dir in front of module search path. if not run_as_module: @@ -310,6 +318,7 @@ class Restart(Exception): while 1: try: import pdb as stdlib_pdb + if hasattr(stdlib_pdb.Pdb, "_run"): # Looks like Pdb from Python 3.11+ if run_as_module: @@ -329,7 +338,7 @@ class Restart(Exception): print("\t" + " ".join(sys.argv[1:])) except SystemExit: # In most cases SystemExit does not warrant a post-mortem session. - print("The program exited via sys.exit(). Exit status: ", end='') + print("The program exited via sys.exit(). Exit status: ", end="") print(sys.exc_info()[1]) except: traceback.print_exc() @@ -337,9 +346,12 @@ class Restart(Exception): print("Running 'cont' or 'step' will restart the program") t = sys.exc_info()[2] pdb.interaction(None, t) - print("Post mortem debugger finished. The " + mainpyfile + - " will be restarted") + print( + "Post mortem debugger finished. The " + + mainpyfile + + " will be restarted" + ) -if __name__ == '__main__': +if __name__ == "__main__": main() diff --git a/pyproject.toml b/pyproject.toml index b1e1a46..b9a8d87 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,2 +1,6 @@ [build-system] requires = ["setuptools"] + + +[tool.black] +line-length = 88 diff --git a/tests/test_config.py b/tests/test_config.py index 4a44f85..e4fc7e7 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -198,12 +198,13 @@ def test_env_nodef_nosetup(self): os.unlink(self.default_filename) os.unlink(self.pyproject_filename) os.remove(self.setup_filename) - with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, - HOME=self.tmpd): + with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, HOME=self.tmpd): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.env_context, cfg.getint("ipdb", "context")) - self.assertRaises(configparser.NoOptionError, cfg.getboolean, "ipdb", "version") + self.assertRaises( + configparser.NoOptionError, cfg.getboolean, "ipdb", "version" + ) def test_noenv_def_nosetup(self): """ @@ -243,8 +244,7 @@ def test_env_cwd(self): os.chdir(self.tmpd) # setUp is already set to restore us to our pre-testing cwd os.unlink(self.pyproject_filename) os.remove(self.setup_filename) - with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, - HOME=self.tmpd): + with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, HOME=self.tmpd): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.env_context, cfg.getint("ipdb", "context")) @@ -258,8 +258,7 @@ def test_env_def_nosetup(self): """ os.unlink(self.pyproject_filename) os.remove(self.setup_filename) - with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, - HOME=self.tmpd): + with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, HOME=self.tmpd): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.env_context, cfg.getint("ipdb", "context")) @@ -277,7 +276,9 @@ def test_noenv_def_setup(self): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.default_context, cfg.getint("ipdb", "context")) - self.assertRaises(configparser.NoOptionError, cfg.getboolean, "ipdb", "version") + self.assertRaises( + configparser.NoOptionError, cfg.getboolean, "ipdb", "version" + ) def test_noenv_nodef_setup(self): """ @@ -301,8 +302,7 @@ def test_env_def_setup(self): Result: load $IPDB_CONFIG """ os.unlink(self.pyproject_filename) - with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, - HOME=self.tmpd): + with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, HOME=self.tmpd): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.env_context, cfg.getint("ipdb", "context")) @@ -316,12 +316,13 @@ def test_env_nodef_setup(self): """ os.unlink(self.default_filename) os.unlink(self.pyproject_filename) - with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, - HOME=self.tmpd): + with ModifiedEnvironment(IPDB_CONFIG=self.env_filename, HOME=self.tmpd): cfg = get_config() self.assertEqual(["ipdb"], cfg.sections()) self.assertEqual(self.env_context, cfg.getint("ipdb", "context")) - self.assertRaises(configparser.NoOptionError, cfg.getboolean, "ipdb", "version") + self.assertRaises( + configparser.NoOptionError, cfg.getboolean, "ipdb", "version" + ) def test_noenv_def_setup(self): """ diff --git a/tests/test_import.py b/tests/test_import.py index 7178d63..72bc193 100644 --- a/tests/test_import.py +++ b/tests/test_import.py @@ -8,13 +8,13 @@ class ImportTest(unittest.TestCase): - def test_import(self): from ipdb import set_trace, post_mortem, pm, iex, run, runcall, runeval + set_trace # please pyflakes post_mortem # please pyflakes pm # please pyflakes - iex # please pyflakes + iex # please pyflakes run # please pyflakes runcall # please pyflakes runeval # please pyflakes diff --git a/tests/test_opts.py b/tests/test_opts.py index 6365d57..160fabd 100644 --- a/tests/test_opts.py +++ b/tests/test_opts.py @@ -17,10 +17,10 @@ from ipdb.__main__ import main -@patch('ipdb.__main__._get_debugger_cls') +@patch("ipdb.__main__._get_debugger_cls") class OptsTest(unittest.TestCase): def set_argv(self, *argv): - argv_patch = patch('ipdb.__main__.sys.argv', argv) + argv_patch = patch("ipdb.__main__.sys.argv", argv) argv_patch.start() self.addCleanup(argv_patch.stop) @@ -28,10 +28,10 @@ def set_argv(self, *argv): sys.version_info[0] == 3 and sys.version_info[1] >= 11, ">3.11 requires different test", ) - @patch('ipdb.__main__.sys.version_info', (3, 7)) + @patch("ipdb.__main__.sys.version_info", (3, 7)) def test_debug_module_script(self, get_debugger_cls): - module_name = 'my_buggy_module' - self.set_argv('ipdb', '-m', module_name) + module_name = "my_buggy_module" + self.set_argv("ipdb", "-m", module_name) main() @@ -42,10 +42,10 @@ def test_debug_module_script(self, get_debugger_cls): sys.version_info[0] == 3 and sys.version_info[1] >= 11, ">3.11 requires different test", ) - @patch('ipdb.__main__.os.path.exists') + @patch("ipdb.__main__.os.path.exists") def test_debug_script(self, exists, get_debugger_cls): - script_name = 'my_buggy_script' - self.set_argv('ipdb', script_name) + script_name = "my_buggy_script" + self.set_argv("ipdb", script_name) main() @@ -57,8 +57,8 @@ def test_debug_script(self, exists, get_debugger_cls): "<3.11 requires different test", ) def test_debug_module_script_3_11(self, get_debugger_cls): - module_name = 'my_buggy_module_3_11' - self.set_argv('ipdb', '-m', module_name) + module_name = "my_buggy_module_3_11" + self.set_argv("ipdb", "-m", module_name) main() @@ -69,10 +69,10 @@ def test_debug_module_script_3_11(self, get_debugger_cls): sys.version_info[0] != 3 or sys.version_info[1] < 11, "<3.11 requires different test", ) - @patch('ipdb.__main__.os.path.exists') + @patch("ipdb.__main__.os.path.exists") def test_debug_script_3_11(self, exists, get_debugger_cls): - script_name = 'my_buggy_script_3_11' - self.set_argv('ipdb', script_name) + script_name = "my_buggy_script_3_11" + self.set_argv("ipdb", script_name) main() @@ -80,13 +80,13 @@ def test_debug_script_3_11(self, exists, get_debugger_cls): debugger._run.assert_called_once_with(os.path.join(os.getcwd(), script_name)) def test_option_m_fallback_on_py36(self, get_debugger_cls): - self.set_argv('ipdb', '-m', 'my.module') - with patch('ipdb.__main__.sys.version_info', (3, 6)): + self.set_argv("ipdb", "-m", "my.module") + with patch("ipdb.__main__.sys.version_info", (3, 6)): with self.assertRaises(GetoptError): main() - with patch('ipdb.__main__.sys.version_info', (3, 7)): - self.set_argv('ipdb', '-m', 'my.module') + with patch("ipdb.__main__.sys.version_info", (3, 7)): + self.set_argv("ipdb", "-m", "my.module") try: main() except GetoptError: From 63796e991601bcabca09a4964e659ae7d5c10c44 Mon Sep 17 00:00:00 2001 From: Wouter Vanden Hove Date: Mon, 13 Mar 2023 13:45:51 +0100 Subject: [PATCH 2/3] add ipython-profile support (#1) * add ipython-profile support * add tests to fetch ipytohn_profiler from config --------- Co-authored-by: Wouter Vanden Hove --- HISTORY.txt | 4 ++ README.rst | 21 ++++++++ ipdb/__main__.py | 38 +++++++++++++-- tests/test_config.py | 113 +++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 171 insertions(+), 5 deletions(-) diff --git a/HISTORY.txt b/HISTORY.txt index 62b0a1f..b0a35be 100644 --- a/HISTORY.txt +++ b/HISTORY.txt @@ -4,6 +4,10 @@ Changelog 0.13.14 (unreleased) -------------------- +- Add ipython_profile support. We can now run ipdb with a non-default + ipython-profile by setting an environment-variable ``IPDB_IPYTHON_PROFILE`` + or by setting ``ipython_profile`` in the config. [WouterVH] + - Run ``black`` on ipdb-codebase with line-length 88. [WouterVH] diff --git a/README.rst b/README.rst index 96f6882..8a5fff0 100644 --- a/README.rst +++ b/README.rst @@ -120,6 +120,27 @@ Or you can use ``iex`` as a function decorator to launch ipdb if an exception is Using ``from future import print_function`` for Python 3 compat implies dropping Python 2.5 support. Use ``ipdb<=0.8`` with 2.5. + +Using a non-default ipython-profile +----------------------------------- +By default ``ipdb`` will instantiate an ipython-session loaded with the default profile called ``default``. +You can set a non-default profile by setting the environment variable ``IPDB_IPYTON_PROFILE``: + +.. code-block:: bash + + export IPDB_IPYTON_PROFILE="ipdb" + +Or by setting in ``pyproject.toml``: + +.. code-block:: toml + + [tool.ipdb] + ipython_profile = "ipdb" + +This should correspond with a profile-directory ``profile_ipdb```in your ``IPYTHON_HOME``. +If this profile-directory does not exist, we fall back to the default profile. + + Issues with ``stdout`` ---------------------- diff --git a/ipdb/__main__.py b/ipdb/__main__.py index c4b649a..56376f9 100644 --- a/ipdb/__main__.py +++ b/ipdb/__main__.py @@ -13,7 +13,10 @@ __version__ = "0.13.14.dev0" from IPython import get_ipython +from IPython.core.application import ProfileDir from IPython.core.debugger import BdbQuit_excepthook +from IPython.core.profiledir import ProfileDirError +from IPython.paths import get_ipython_dir from IPython.terminal.ipapp import TerminalIPythonApp from IPython.terminal.embed import InteractiveShellEmbed @@ -23,20 +26,30 @@ import ConfigParser as configparser -def _get_debugger_cls(): +def _get_debugger_cls(ipython_profile="default"): shell = get_ipython() if shell is None: # Not inside IPython # Build a terminal app in order to force ipython to load the # configuration - ipapp = TerminalIPythonApp() + ipython_dir = get_ipython_dir() + try: + profile_dir = ProfileDir.find_profile_dir_by_name( + ipython_dir=ipython_dir, + name=ipython_profile, + ) + except ProfileDirError: # fallback to default-profile + profile_dir = ProfileDir.find_profile_dir_by_name( + ipython_dir=ipython_dir, + ) + ipapp = TerminalIPythonApp(profile_dir=profile_dir) + # Avoid output (banner, prints) ipapp.interact = False ipapp.initialize(["--no-term-title"]) shell = ipapp.shell else: # Running inside IPython - # Detect if embed shell or not and display a message if isinstance(shell, InteractiveShellEmbed): sys.stderr.write( @@ -49,10 +62,17 @@ def _get_debugger_cls(): return shell.debugger_cls -def _init_pdb(context=None, commands=[]): +def _init_pdb(context=None, ipython_profile=None, commands=[]): if context is None: context = os.getenv("IPDB_CONTEXT_SIZE", get_context_from_config()) - debugger_cls = _get_debugger_cls() + + if ipython_profile is None: + ipython_profile = os.getenv( + "IPDB_IPYTHON_PROFILE", get_ipython_profile_from_config() + ) + + debugger_cls = _get_debugger_cls(ipython_profile=ipython_profile) + try: p = debugger_cls(context=context) except TypeError: @@ -94,6 +114,14 @@ def get_context_from_config(): ) +def get_ipython_profile_from_config(): + parser = get_config() + try: + return parser.get("ipdb", "ipython_profile") + except (configparser.NoSectionError, configparser.NoOptionError): + return "default" + + class ConfigFile(object): """ Filehandle wrapper that adds a "[ipdb]" section to the start of a config diff --git a/tests/test_config.py b/tests/test_config.py index e4fc7e7..2d5ff4a 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -16,6 +16,7 @@ from ipdb.__main__ import ( get_config, get_context_from_config, + get_ipython_profile_from_config, ) @@ -137,6 +138,22 @@ def test_noenv_nodef_nosetup_pyproject(self): self.assertEqual(self.pyproject_context, cfg.getint("ipdb", "context")) self.assertRaises(configparser.NoOptionError, cfg.get, "ipdb", "version") + def test_noenv_nodef_nosetup_pyproject(self): + """ + Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, + setup.cfg does not exist, pyproject.toml exists + Result: load pyproject.toml + """ + os.unlink(self.env_filename) + os.unlink(self.default_filename) + os.remove(self.setup_filename) + with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): + cfg = get_config() + # breakpoint() + self.assertEqual(["ipdb"], cfg.sections()) + self.assertEqual(self.pyproject_context, cfg.getint("ipdb", "context")) + self.assertRaises(configparser.NoOptionError, cfg.get, "ipdb", "version") + def test_env_nodef_setup_pyproject(self): """ Setup: $IPDB_CONFIG is set, $HOME/.ipdb does not exist, @@ -382,3 +399,99 @@ def test_noenv_nodef_invalid_setup(self): pass else: self.fail("Expected TomlDecodeError from invalid config file") + + +class get_ipython_profile_from_config_TestCase(unittest.TestCase): + """ + Test cases for function `get_ipython_profile_from_config`. + """ + + def setUp(self): + """ + Set fixtures for this test case. + """ + set_config_files_fixture(self) + + def test_missing_key_setup(self): + """ + Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, + setup.cfg does not exist, pyproject.toml content is invalid. + Result: Propagate exception from `get_config`. + """ + os.unlink(self.env_filename) + os.unlink(self.default_filename) + os.unlink(self.setup_filename) + write_lines_to_file( + self.pyproject_filename, + ["[tool.ipdb]"], + ) + + try: + from tomllib import TOMLDecodeError + except ImportError: + try: + from tomli import TOMLDecodeError + except ImportError: + from toml.decoder import TomlDecodeError as TOMLDecodeError + + with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): + profile_name = get_ipython_profile_from_config() + assert profile_name == "default" + + def test_default_profile_setup(self): + """ + Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, + setup.cfg does not exist, pyproject.toml content is invalid. + Result: Propagate exception from `get_config`. + """ + os.unlink(self.env_filename) + os.unlink(self.default_filename) + os.unlink(self.setup_filename) + write_lines_to_file( + self.pyproject_filename, + [ + "[tool.ipdb]", + "ipython_profile = 'default'", + ], + ) + + try: + from tomllib import TOMLDecodeError + except ImportError: + try: + from tomli import TOMLDecodeError + except ImportError: + from toml.decoder import TomlDecodeError as TOMLDecodeError + + with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): + profile_name = get_ipython_profile_from_config() + assert profile_name == "default" + + def test_non_existing_profile_setup(self): + """ + Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, + setup.cfg does not exist, pyproject.toml content is invalid. + Result: Propagate exception from `get_config`. + """ + os.unlink(self.env_filename) + os.unlink(self.default_filename) + os.unlink(self.setup_filename) + write_lines_to_file( + self.pyproject_filename, + [ + "[tool.ipdb]", + "ipython_profile = 'foo'", + ], + ) + + try: + from tomllib import TOMLDecodeError + except ImportError: + try: + from tomli import TOMLDecodeError + except ImportError: + from toml.decoder import TomlDecodeError as TOMLDecodeError + + with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): + profile_name = get_ipython_profile_from_config() + assert profile_name == "foo" From 9726ed851315eb69a3dcfca025b359d339cab796 Mon Sep 17 00:00:00 2001 From: Wouter Vanden Hove Date: Fri, 31 Mar 2023 10:05:26 +0200 Subject: [PATCH 3/3] add ipython-profile support (#2) * add ipython-profile support * add tests to fetch ipytohn_profiler from config * cleanup profile-tests --------- Co-authored-by: Wouter Vanden Hove --- tests/test_config.py | 45 +++++++++----------------------------------- 1 file changed, 9 insertions(+), 36 deletions(-) diff --git a/tests/test_config.py b/tests/test_config.py index 2d5ff4a..4ae06b6 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -412,37 +412,27 @@ def setUp(self): """ set_config_files_fixture(self) - def test_missing_key_setup(self): + def test_missing_profile_setup(self): """ - Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, - setup.cfg does not exist, pyproject.toml content is invalid. - Result: Propagate exception from `get_config`. + Setup: pyproject.toml has no [tool.ipdb]-section. """ os.unlink(self.env_filename) os.unlink(self.default_filename) os.unlink(self.setup_filename) write_lines_to_file( self.pyproject_filename, - ["[tool.ipdb]"], + "" ) - try: - from tomllib import TOMLDecodeError - except ImportError: - try: - from tomli import TOMLDecodeError - except ImportError: - from toml.decoder import TomlDecodeError as TOMLDecodeError - with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): profile_name = get_ipython_profile_from_config() assert profile_name == "default" def test_default_profile_setup(self): """ - Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, - setup.cfg does not exist, pyproject.toml content is invalid. - Result: Propagate exception from `get_config`. + Setup: pyproject.toml has a [tool.ipdb]-section + with the ipython_profile explicitly set to 'default'. + """ os.unlink(self.env_filename) os.unlink(self.default_filename) @@ -455,23 +445,14 @@ def test_default_profile_setup(self): ], ) - try: - from tomllib import TOMLDecodeError - except ImportError: - try: - from tomli import TOMLDecodeError - except ImportError: - from toml.decoder import TomlDecodeError as TOMLDecodeError - with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): profile_name = get_ipython_profile_from_config() assert profile_name == "default" - def test_non_existing_profile_setup(self): + def test_non_default_profile_setup(self): """ - Setup: $IPDB_CONFIG unset, $HOME/.ipdb does not exist, - setup.cfg does not exist, pyproject.toml content is invalid. - Result: Propagate exception from `get_config`. + Setup: pyproject.toml has a [tool.ipdb]-section + with the ipython_profile explicitly set to a non-default. """ os.unlink(self.env_filename) os.unlink(self.default_filename) @@ -484,14 +465,6 @@ def test_non_existing_profile_setup(self): ], ) - try: - from tomllib import TOMLDecodeError - except ImportError: - try: - from tomli import TOMLDecodeError - except ImportError: - from toml.decoder import TomlDecodeError as TOMLDecodeError - with ModifiedEnvironment(IPDB_CONFIG=None, HOME=self.tmpd): profile_name = get_ipython_profile_from_config() assert profile_name == "foo"