summaryrefslogtreecommitdiffstats
path: root/testsuite
diff options
context:
space:
mode:
authorNarayan Desai <desai@mcs.anl.gov>2007-12-31 02:10:56 +0000
committerNarayan Desai <desai@mcs.anl.gov>2007-12-31 02:10:56 +0000
commit104a1e27cee2d5524460d26c83d3e920cd88b2e9 (patch)
tree2d5b9fac84ad048508a371541ffc41683fc08327 /testsuite
parentd017662635d02701b952a9757af3569ff1cca19d (diff)
downloadbcfg2-104a1e27cee2d5524460d26c83d3e920cd88b2e9.tar.gz
bcfg2-104a1e27cee2d5524460d26c83d3e920cd88b2e9.tar.bz2
bcfg2-104a1e27cee2d5524460d26c83d3e920cd88b2e9.zip
Add unit testing for new option parsing library (Full Coverage)
git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@4141 ce84e21b-d406-0410-9b95-82705330c041
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/TestOptions.py79
1 files changed, 79 insertions, 0 deletions
diff --git a/testsuite/TestOptions.py b/testsuite/TestOptions.py
new file mode 100644
index 000000000..9d4ed06a5
--- /dev/null
+++ b/testsuite/TestOptions.py
@@ -0,0 +1,79 @@
+import os, sys
+import Bcfg2.Options
+
+class TestOption(object):
+ def test__init(self):
+ o = Bcfg2.Options.Option('foo', False, cmd='-F')
+ try:
+ p = Bcfg2.Options.Option('foo', False, cmd='--F')
+ assert False
+ except Bcfg2.Options.OptionFailure:
+ pass
+
+ def test_parse(self):
+ o = Bcfg2.Options.Option('foo', 'test4', cmd='-F', env='TEST2',
+ odesc='bar', cf=('communication', 'password'))
+ o.parse([], ['-F', 'test'])
+ assert o.value == 'test'
+ o.parse([('-F', 'test2')], [])
+ assert o._value == 'test2'
+ os.environ['TEST2'] = 'test3'
+ o.parse([], [])
+ assert o._value == 'test3'
+ del os.environ['TEST2']
+ o.parse([], [])
+ print o._value
+ assert o._value == 'foobat'
+ o.cf = False
+ o.parse([], [])
+ assert o._value == 'test4'
+
+ def test_cook(self):
+ cooker = lambda x: 1
+ o = Bcfg2.Options.Option('foo', 'test4', cook=cooker)
+ o.parse([], [])
+ assert o.value == 1
+
+
+class TestOptionSet(object):
+ def test_buildGetopt(self):
+ opts = [('foo', Bcfg2.Options.Option('foo', 'test1', cmd='-G')),
+ ('bar', Bcfg2.Options.Option('foo', 'test2')),
+ ('baz', Bcfg2.Options.Option('foo', 'test1', cmd='-H', odesc='1'))]
+ os = Bcfg2.Options.OptionSet(opts)
+ res = os.buildGetopt()
+ assert 'H:' in res and 'G' in res and len(res) == 3
+
+ def test_parse(self):
+ opts = [('foo', Bcfg2.Options.Option('foo', 'test1', cmd='-G')),
+ ('bar', Bcfg2.Options.Option('foo', 'test2')),
+ ('baz', Bcfg2.Options.Option('foo', 'test1', cmd='-H', odesc='1'))]
+ os = Bcfg2.Options.OptionSet(opts)
+ try:
+ os.parse(['-G', '-H'])
+ assert False
+ except SystemExit:
+ pass
+ opts = [('foo', Bcfg2.Options.Option('foo', 'test1', cmd='-h')),
+ ('bar', Bcfg2.Options.Option('foo', 'test2')),
+ ('baz', Bcfg2.Options.Option('foo', 'test1', cmd='-H', odesc='1'))]
+ os2 = Bcfg2.Options.OptionSet(opts)
+ try:
+ os2.parse(['-h'])
+ assert False
+ except SystemExit:
+ pass
+
+class TestOptionParser(object):
+ def test__init(self):
+ opts = [('foo', Bcfg2.Options.Option('foo', 'test1', cmd='-h')),
+ ('bar', Bcfg2.Options.Option('foo', 'test2')),
+ ('baz', Bcfg2.Options.Option('foo', 'test1', cmd='-H', odesc='1'))]
+ os1 = Bcfg2.Options.OptionParser(opts)
+ assert Bcfg2.Options.Option.cfpath == '/etc/bcfg2.conf'
+ sys.argv = ['foo', '-C', '/usr/local/etc/bcfg2.conf']
+ os2 = Bcfg2.Options.OptionParser(opts)
+ assert Bcfg2.Options.Option.cfpath == '/usr/local/etc/bcfg2.conf'
+ sys.argv = []
+ os3 = Bcfg2.Options.OptionParser(opts)
+ assert Bcfg2.Options.Option.cfpath == '/etc/bcfg2.conf'