##// END OF EJS Templates
Add tests and fix some issues...
Add tests and fix some issues Tests taken from #6360

File last commit:

r15218:639f40c3
r17782:b70c50fc
Show More
test_loader.py
396 lines | 11.3 KiB | text/x-python | PythonLexer
Brian Granger
Work on Application and loader testing.
r2187 # encoding: utf-8
"""
Tests for IPython.config.loader
Authors:
* Brian Granger
* Fernando Perez (design help)
"""
#-----------------------------------------------------------------------------
MinRK
AttributeError no longer raised on missing config
r12798 # Copyright (C) 2008 The IPython Development Team
Brian Granger
Work on Application and loader testing.
r2187 #
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
import os
MinRK
test that config objects are pickleable
r13448 import pickle
MinRK
fix handling of unicode in KV loader...
r4162 import sys
Matthias BUSSONNIER
allow to load config from json file...
r13771 import json
Brian Granger
Work on Application and loader testing.
r2187 from tempfile import mkstemp
from unittest import TestCase
MinRK
fix handling of unicode in KV loader...
r4162 from nose import SkipTest
Matthias BUSSONNIER
allow to load config from json file...
r13771 import nose.tools as nt
MinRK
fix handling of unicode in KV loader...
r4162
MinRK
aliases match flag pattern ('-' as wordsep, not '_')...
r4214
Brian Granger
Massive refactoring of of the core....
r2245 from IPython.config.loader import (
Config,
MinRK
test getattr / getitem behavior in Config...
r13470 LazyConfigValue,
Brian Granger
Added KeyValueConfigLoader with tests.
r3786 PyFileConfigLoader,
Matthias BUSSONNIER
allow to load config from json file...
r13771 JSONFileConfigLoader,
Brian Granger
Added KeyValueConfigLoader with tests.
r3786 KeyValueConfigLoader,
Brian Granger
Massive refactoring of of the core....
r2245 ArgParseConfigLoader,
MinRK
fix type=str->unicode in argparse kv loader...
r4830 KVArgParseConfigLoader,
MinRK
test getattr / getitem behavior in Config...
r13470 ConfigError,
Brian Granger
Massive refactoring of of the core....
r2245 )
Brian Granger
Work on Application and loader testing.
r2187
#-----------------------------------------------------------------------------
# Actual tests
#-----------------------------------------------------------------------------
pyfile = """
Fernando Perez
Fix failing config test: https://bugs.launchpad.net/ipython/+bug/503731...
r2394 c = get_config()
Brian Granger
Added KeyValueConfigLoader with tests.
r3786 c.a=10
c.b=20
c.Foo.Bar.value=10
Thomas Kluyver
Fix config loader test for Python 3.
r4762 c.Foo.Bam.value=list(range(10)) # list() is just so it's the same on Python 3
Brian Granger
Added KeyValueConfigLoader with tests.
r3786 c.D.C.value='hi there'
Brian Granger
Work on Application and loader testing.
r2187 """
Matthias BUSSONNIER
allow to load config from json file...
r13771 json1file = """
{
"version": 1,
"a": 10,
"b": 20,
"Foo": {
"Bam": {
"value": [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
},
"Bar": {
"value": 10
}
},
"D": {
"C": {
"value": "hi there"
}
}
}
"""
Brian Granger
Work on Application and loader testing.
r2187
Matthias BUSSONNIER
allow to load config from json file...
r13771 # should not load
json2file = """
{
"version": 2
}
"""
import logging
log = logging.getLogger('devnull')
log.setLevel(0)
class TestFileCL(TestCase):
def _check_conf(self, config):
self.assertEqual(config.a, 10)
self.assertEqual(config.b, 20)
self.assertEqual(config.Foo.Bar.value, 10)
self.assertEqual(config.Foo.Bam.value, list(range(10)))
self.assertEqual(config.D.C.value, 'hi there')
def test_python(self):
Fernando Perez
Progress towards getting the test suite in shape again....
r2392 fd, fname = mkstemp('.py')
Brian Granger
Work on Application and loader testing.
r2187 f = os.fdopen(fd, 'w')
f.write(pyfile)
f.close()
Brian Granger
Minor changes to a few files to reflect design discussion.
r2198 # Unlink the file
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = PyFileConfigLoader(fname, log=log)
Brian Granger
Work on Application and loader testing.
r2187 config = cl.load_config()
Matthias BUSSONNIER
allow to load config from json file...
r13771 self._check_conf(config)
def test_json(self):
fd, fname = mkstemp('.json')
f = os.fdopen(fd, 'w')
f.write(json1file)
f.close()
# Unlink the file
cl = JSONFileConfigLoader(fname, log=log)
config = cl.load_config()
self._check_conf(config)
def test_v2raise(self):
fd, fname = mkstemp('.json')
f = os.fdopen(fd, 'w')
f.write(json2file)
f.close()
# Unlink the file
cl = JSONFileConfigLoader(fname, log=log)
with nt.assert_raises(ValueError):
cl.load_config()
Brian Granger
Work on Application and loader testing.
r2187
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 class MyLoader1(ArgParseConfigLoader):
MinRK
use cfg._merge instead of update in loader...
r4606 def _add_arguments(self, aliases=None, flags=None):
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 p = self.parser
p.add_argument('-f', '--foo', dest='Global.foo', type=str)
p.add_argument('-b', dest='MyClass.bar', type=int)
p.add_argument('-n', dest='n', action='store_true')
p.add_argument('Global.bam', type=str)
class MyLoader2(ArgParseConfigLoader):
MinRK
use cfg._merge instead of update in loader...
r4606 def _add_arguments(self, aliases=None, flags=None):
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 subparsers = self.parser.add_subparsers(dest='subparser_name')
subparser1 = subparsers.add_parser('1')
subparser1.add_argument('-x',dest='Global.x')
subparser2 = subparsers.add_parser('2')
subparser2.add_argument('y')
Brian Granger
Work on the config system....
r2500
Brian Granger
Work on Application and loader testing.
r2187 class TestArgParseCL(TestCase):
def test_basic(self):
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 cl = MyLoader1()
Brian Granger
Work on Application and loader testing.
r2187 config = cl.load_config('-f hi -b 10 -n wow'.split())
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.Global.foo, 'hi')
self.assertEqual(config.MyClass.bar, 10)
self.assertEqual(config.n, True)
self.assertEqual(config.Global.bam, 'wow')
Brian Granger
Work on the config system....
r2500 config = cl.load_config(['wow'])
Thomas Kluyver
Fix tests for config
r13374 self.assertEqual(list(config.keys()), ['Global'])
self.assertEqual(list(config.Global.keys()), ['bam'])
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.Global.bam, 'wow')
Brian Granger
Work on Application and loader testing.
r2187
def test_add_arguments(self):
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 cl = MyLoader2()
Brian Granger
Work on Application and loader testing.
r2187 config = cl.load_config('2 frobble'.split())
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.subparser_name, '2')
self.assertEqual(config.y, 'frobble')
Brian Granger
Work on Application and loader testing.
r2187 config = cl.load_config('1 -x frobble'.split())
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.subparser_name, '1')
self.assertEqual(config.Global.x, 'frobble')
Brian Granger
Massive refactoring of of the core....
r2245
Brian Granger
Work on the config system....
r2500 def test_argv(self):
Brian Granger
Refactored the command line config system and other aspects of config....
r2501 cl = MyLoader1(argv='-f hi -b 10 -n wow'.split())
Brian Granger
Work on the config system....
r2500 config = cl.load_config()
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.Global.foo, 'hi')
self.assertEqual(config.MyClass.bar, 10)
self.assertEqual(config.n, True)
self.assertEqual(config.Global.bam, 'wow')
Brian Granger
Work on the config system....
r2500
Brian Granger
Added KeyValueConfigLoader with tests.
r3786 class TestKeyValueCL(TestCase):
MinRK
fix type=str->unicode in argparse kv loader...
r4830 klass = KeyValueConfigLoader
Brian Granger
Added KeyValueConfigLoader with tests.
r3786
def test_basic(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
disallow no-prefix `ipython foo=bar` argument style....
r4197 argv = ['--'+s.strip('c.') for s in pyfile.split('\n')[2:-1]]
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.a, 10)
self.assertEqual(config.b, 20)
self.assertEqual(config.Foo.Bar.value, 10)
Thomas Kluyver
Fix tests for config
r13374 self.assertEqual(config.Foo.Bam.value, list(range(10)))
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.D.C.value, 'hi there')
MinRK
allow extra_args in applications
r3958
MinRK
expand '~' with path.expanduser in KVLoader...
r5189 def test_expanduser(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
expand '~' with path.expanduser in KVLoader...
r5189 argv = ['--a=~/1/2/3', '--b=~', '--c=~/', '--d="~/"']
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.a, os.path.expanduser('~/1/2/3'))
self.assertEqual(config.b, os.path.expanduser('~'))
self.assertEqual(config.c, os.path.expanduser('~/'))
self.assertEqual(config.d, '~/')
MinRK
expand '~' with path.expanduser in KVLoader...
r5189
MinRK
allow extra_args in applications
r3958 def test_extra_args(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
config = cl.load_config(['--a=5', 'b', '--c=10', 'd'])
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(cl.extra_args, ['b', 'd'])
self.assertEqual(config.a, 5)
self.assertEqual(config.c, 10)
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(['--', '--a=5', '--c=10'])
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(cl.extra_args, ['--a=5', '--c=10'])
MinRK
fix handling of unicode in KV loader...
r4162
def test_unicode_args(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
disallow no-prefix `ipython foo=bar` argument style....
r4197 argv = [u'--a=épsîlön']
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.a, u'épsîlön')
MinRK
fix handling of unicode in KV loader...
r4162
def test_unicode_bytes_args(self):
MinRK
disallow no-prefix `ipython foo=bar` argument style....
r4197 uarg = u'--a=é'
MinRK
fix handling of unicode in KV loader...
r4162 try:
barg = uarg.encode(sys.stdin.encoding)
except (TypeError, UnicodeEncodeError):
raise SkipTest("sys.stdin.encoding can't handle 'é'")
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
config = cl.load_config([barg])
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.a, u'é')
MinRK
fix type=str->unicode in argparse kv loader...
r4830
def test_unicode_alias(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
fix type=str->unicode in argparse kv loader...
r4830 argv = [u'--a=épsîlön']
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv, aliases=dict(a='A.a'))
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.A.a, u'épsîlön')
MinRK
fix type=str->unicode in argparse kv loader...
r4830
Brian Granger
Added KeyValueConfigLoader with tests.
r3786
MinRK
fix type=str->unicode in argparse kv loader...
r4830 class TestArgParseKVCL(TestKeyValueCL):
klass = KVArgParseConfigLoader
Brian Granger
Added new tests for config.loader and configurable.
r3791
MinRK
expand '~' with path.expanduser in KVLoader...
r5189 def test_expanduser2(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
expand '~' with path.expanduser in KVLoader...
r5189 argv = ['-a', '~/1/2/3', '--b', "'~/1/2/3'"]
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv, aliases=dict(a='A.a', b='A.b'))
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.A.a, os.path.expanduser('~/1/2/3'))
self.assertEqual(config.A.b, '~/1/2/3')
MinRK
expand '~' with path.expanduser in KVLoader...
r5189
MinRK
use eval for command-line args instead of exec...
r6757 def test_eval(self):
Matthias BUSSONNIER
allow to load config from json file...
r13771 cl = self.klass(log=log)
MinRK
use eval for command-line args instead of exec...
r6757 argv = ['-c', 'a=5']
Matthias BUSSONNIER
allow to load config from json file...
r13771 config = cl.load_config(argv, aliases=dict(c='A.c'))
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(config.A.c, u"a=5")
MinRK
use eval for command-line args instead of exec...
r6757
Brian Granger
Massive refactoring of of the core....
r2245 class TestConfig(TestCase):
def test_setget(self):
c = Config()
c.a = 10
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c.a, 10)
self.assertEqual('b' in c, False)
Brian Granger
Massive refactoring of of the core....
r2245
def test_auto_section(self):
c = Config()
MinRK
test getattr / getitem behavior in Config...
r13470 self.assertNotIn('A', c)
assert not c._has_section('A')
Brian Granger
Massive refactoring of of the core....
r2245 A = c.A
A.foo = 'hi there'
MinRK
test getattr / getitem behavior in Config...
r13470 self.assertIn('A', c)
assert c._has_section('A')
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c.A.foo, 'hi there')
Brian Granger
Massive refactoring of of the core....
r2245 del c.A
MinRK
test getattr / getitem behavior in Config...
r13470 self.assertEqual(c.A, Config())
Brian Granger
Massive refactoring of of the core....
r2245
def test_merge_doesnt_exist(self):
c1 = Config()
c2 = Config()
c2.bar = 10
c2.Foo.bar = 10
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c1.Foo.bar, 10)
self.assertEqual(c1.bar, 10)
Brian Granger
Massive refactoring of of the core....
r2245 c2.Bar.bar = 10
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c1.Bar.bar, 10)
Brian Granger
Massive refactoring of of the core....
r2245
def test_merge_exists(self):
c1 = Config()
c2 = Config()
c1.Foo.bar = 10
c1.Foo.bam = 30
c2.Foo.bar = 20
c2.Foo.wow = 40
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c1.Foo.bam, 30)
self.assertEqual(c1.Foo.bar, 20)
self.assertEqual(c1.Foo.wow, 40)
Brian Granger
Massive refactoring of of the core....
r2245 c2.Foo.Bam.bam = 10
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c1.Foo.Bam.bam, 10)
Brian Granger
Massive refactoring of of the core....
r2245
def test_deepcopy(self):
c1 = Config()
c1.Foo.bar = 10
c1.Foo.bam = 30
c1.a = 'asdf'
c1.b = range(10)
import copy
c2 = copy.deepcopy(c1)
Bradley M. Froehle
s/assertEquals/assertEqual/
r7874 self.assertEqual(c1, c2)
Bradley M. Froehle
s/assert_/assertTrue/
r7876 self.assertTrue(c1 is not c2)
self.assertTrue(c1.Foo is not c2.Foo)
Brian Granger
Massive refactoring of of the core....
r2245
def test_builtin(self):
c1 = Config()
MinRK
update config builtins test
r11265 c1.format = "json"
MinRK
test Config objects from dicts
r10870
def test_fromdict(self):
c1 = Config({'Foo' : {'bar' : 1}})
self.assertEqual(c1.Foo.__class__, Config)
self.assertEqual(c1.Foo.bar, 1)
MinRK
make Config.merge a public method...
r10873 def test_fromdictmerge(self):
MinRK
test Config objects from dicts
r10870 c1 = Config()
c2 = Config({'Foo' : {'bar' : 1}})
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
MinRK
test Config objects from dicts
r10870 self.assertEqual(c1.Foo.__class__, Config)
self.assertEqual(c1.Foo.bar, 1)
MinRK
make Config.merge a public method...
r10873 def test_fromdictmerge2(self):
MinRK
test Config objects from dicts
r10870 c1 = Config({'Foo' : {'baz' : 2}})
c2 = Config({'Foo' : {'bar' : 1}})
MinRK
make Config.merge a public method...
r10873 c1.merge(c2)
MinRK
test Config objects from dicts
r10870 self.assertEqual(c1.Foo.__class__, Config)
self.assertEqual(c1.Foo.bar, 1)
self.assertEqual(c1.Foo.baz, 2)
MinRK
AttributeError no longer raised on missing config
r12798 self.assertNotIn('baz', c2.Foo)
MinRK
add tests for container extension methods in config
r12929
def test_contains(self):
c1 = Config({'Foo' : {'baz' : 2}})
c2 = Config({'Foo' : {'bar' : 1}})
self.assertIn('Foo', c1)
self.assertIn('Foo.baz', c1)
self.assertIn('Foo.bar', c2)
self.assertNotIn('Foo.bar', c1)
MinRK
test that config objects are pickleable
r13448 def test_pickle_config(self):
cfg = Config()
cfg.Foo.bar = 1
pcfg = pickle.dumps(cfg)
cfg2 = pickle.loads(pcfg)
self.assertEqual(cfg2, cfg)
MinRK
test getattr / getitem behavior in Config...
r13470
def test_getattr_section(self):
cfg = Config()
self.assertNotIn('Foo', cfg)
Foo = cfg.Foo
assert isinstance(Foo, Config)
self.assertIn('Foo', cfg)
def test_getitem_section(self):
cfg = Config()
self.assertNotIn('Foo', cfg)
Foo = cfg['Foo']
assert isinstance(Foo, Config)
self.assertIn('Foo', cfg)
def test_getattr_not_section(self):
cfg = Config()
self.assertNotIn('foo', cfg)
foo = cfg.foo
assert isinstance(foo, LazyConfigValue)
self.assertIn('foo', cfg)
MinRK
don't allow LazyConfigValue on private names...
r15218 def test_getattr_private_missing(self):
cfg = Config()
self.assertNotIn('_repr_html_', cfg)
with self.assertRaises(AttributeError):
_ = cfg._repr_html_
self.assertNotIn('_repr_html_', cfg)
self.assertEqual(len(cfg), 0)
MinRK
test getattr / getitem behavior in Config...
r13470 def test_getitem_not_section(self):
cfg = Config()
self.assertNotIn('foo', cfg)
foo = cfg['foo']
assert isinstance(foo, LazyConfigValue)
self.assertIn('foo', cfg)
MinRK
copy values in Config.merge
r13471
def test_merge_copies(self):
c = Config()
c2 = Config()
c2.Foo.trait = []
c.merge(c2)
c2.Foo.trait.append(1)
self.assertIsNot(c.Foo, c2.Foo)
self.assertEqual(c.Foo.trait, [])
self.assertEqual(c2.Foo.trait, [1])
MinRK
add tests for container extension methods in config
r12929