[tor-commits] [bridgedb/master] Refactor scripts/bridgedb to use the new options and runner.
isis at torproject.org
isis at torproject.org
Sun Jan 12 06:06:30 UTC 2014
commit 831a778b054cf6425de953bb86eeae3be69ceac1
Author: Isis Lovecruft <isis at torproject.org>
Date: Tue Oct 15 14:08:14 2013 +0000
Refactor scripts/bridgedb to use the new options and runner.
---
scripts/bridgedb | 54 +++++++++++++++++++++++++++++++++---------------------
1 file changed, 33 insertions(+), 21 deletions(-)
diff --git a/scripts/bridgedb b/scripts/bridgedb
index 8e8800b..0e20cd9 100644
--- a/scripts/bridgedb
+++ b/scripts/bridgedb
@@ -1,31 +1,43 @@
#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+#
+# This file is part of BridgeDB, a Tor bridge distribution system.
+#
+# :authors: Isis Lovecruft 0xA3ADB67A2CDB8B35 <isis at torproject.org>
+# please also see AUTHORS file
+# :copyright: (c) 2007-2013, The Tor Project, Inc.
+# (c) 2007-2013, all entities within the AUTHORS file
+# :license: 3-clause BSD, see included LICENSE for information
+
+from __future__ import print_function
import bridgedb
+import os
import sys
-if len(sys.argv) == 1:
- from bridgedb import Main
- Main.run()
-else:
- if sys.argv[1] in ('test', 'coverage'):
- import os
- from twisted.scripts import trial
+from bridgedb import runner
+from bridgedb import opt
- if sys.argv[1] == 'coverage':
- run_python_coverage = True
- # Hack to set the PYTHONPATH:
- sys.path[:] = map(os.path.abspath, sys.path)
- sys.path.insert(0, os.path.abspath(os.getcwd()))
+options = opt.parseOptions()
- if run_python_coverage:
- from coverage import coverage
- cov = coverage()
- cov.start()
+if options.subCommand is not None:
+ # Hack to set the PYTHONPATH:
+ sys.path[:] = map(os.path.abspath, sys.path)
+ sys.path.insert(0, os.path.abspath(os.getcwd()))
+ sys.path.insert(0, os.path.abspath(os.path.join(os.getcwd(), '../lib')))
- sys.argv = ['trial', 'bridgedb']
- trial.run()
+ if 'descriptors' in options.subOptions:
+ runner.generateDescriptors(options.subOptions['descriptors'])
- if run_python_coverage:
- cov.stop()
- cov.html_report('.coverage-results')
+ if options.subCommand == 'test':
+ if options.subOptions['trial']:
+ runner.runTrial(options.subOptions)
+ if options.subOptions['unittests']:
+ runner.runTests(options.subOptions)
+ sys.exit()
+
+# If no suboption was given, just run bridgedb:
+else:
+ from bridgedb import Main
+ Main.run(options)
More information about the tor-commits
mailing list