##// END OF EJS Templates
Backport PR #2126: ipcluster broken with any batch (PBS/LSF/SGE)...
Backport PR #2126: ipcluster broken with any batch (PBS/LSF/SGE) I have setup ipcluster_config.py to start with LSF: ``` c.IPClusterStart.controller_launcher_class = 'LSF' c.IPClusterStart.engine_launcher_class = 'LSF' ``` But the ipcluster command fails to start the engines: ``` ipcluster start --profile=lsf -n 10 ``` The problem is fixed if I add quotes to the launch command string ```cmd``` in ```launcher.py```. ``` diff --git a/IPython/parallel/apps/launcher.py b/IPython/parallel/apps/launcher.py index e752d2a..6035303 100644 --- a/IPython/parallel/apps/launcher.py +++ b/IPython/parallel/apps/launcher.py @@ -73,7 +73,7 @@ WINDOWS = os.name == 'nt' # Paths to the kernel apps #----------------------------------------------------------------------------- -cmd = "from IPython.parallel.apps.%s import launch_new_instance; launch_new_instance()" +cmd = "\"from IPython.parallel.apps.%s import launch_new_instance; launch_new_instance()\"" ipcluster_cmd_argv = [sys.executable, "-c", cmd % "ipclusterapp"] ```

File last commit:

r3357:581b2352
r7995:061632b4
Show More
test_wildcard.py
148 lines | 4.6 KiB | text/x-python | PythonLexer
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 """Some tests for the wildcard utilities."""
vivainio
merge all from 0.7.3 branch to trunk
r503
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 #-----------------------------------------------------------------------------
# Library imports
#-----------------------------------------------------------------------------
# Stdlib
import sys
import unittest
# Our own
from IPython.utils import wildcard
#-----------------------------------------------------------------------------
# Globals for test
#-----------------------------------------------------------------------------
vivainio
merge all from 0.7.3 branch to trunk
r503
class obj_t(object):
pass
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 root = obj_t()
l = ["arna","abel","ABEL","active","bob","bark","abbot"]
q = ["kate","loop","arne","vito","lucifer","koppel"]
vivainio
merge all from 0.7.3 branch to trunk
r503 for x in l:
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 o = obj_t()
vivainio
merge all from 0.7.3 branch to trunk
r503 setattr(root,x,o)
for y in q:
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 p = obj_t()
vivainio
merge all from 0.7.3 branch to trunk
r503 setattr(o,y,p)
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 root._apan = obj_t()
root._apan.a = 10
root._apan._a = 20
root._apan.__a = 20
root.__anka = obj_t()
root.__anka.a = 10
root.__anka._a = 20
root.__anka.__a = 20
root._APAN = obj_t()
root._APAN.a = 10
root._APAN._a = 20
root._APAN.__a = 20
root.__ANKA = obj_t()
root.__ANKA.a = 10
root.__ANKA._a = 20
root.__ANKA.__a = 20
vivainio
merge all from 0.7.3 branch to trunk
r503
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 #-----------------------------------------------------------------------------
# Test cases
#-----------------------------------------------------------------------------
vivainio
merge all from 0.7.3 branch to trunk
r503
class Tests (unittest.TestCase):
def test_case(self):
ns=root.__dict__
tests=[
("a*", ["abbot","abel","active","arna",]),
("?b*.?o*",["abbot.koppel","abbot.loop","abel.koppel","abel.loop",]),
("_a*", []),
("_*anka", ["__anka",]),
("_*a*", ["__anka",]),
]
for pat,res in tests:
res.sort()
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 a=wildcard.list_namespace(ns,"all",pat,ignore_case=False,
show_all=False).keys()
vivainio
merge all from 0.7.3 branch to trunk
r503 a.sort()
self.assertEqual(a,res)
def test_case_showall(self):
ns=root.__dict__
tests=[
("a*", ["abbot","abel","active","arna",]),
("?b*.?o*",["abbot.koppel","abbot.loop","abel.koppel","abel.loop",]),
("_a*", ["_apan"]),
("_*anka", ["__anka",]),
("_*a*", ["__anka","_apan",]),
]
for pat,res in tests:
res.sort()
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 a=wildcard.list_namespace(ns,"all",pat,ignore_case=False,
show_all=True).keys()
vivainio
merge all from 0.7.3 branch to trunk
r503 a.sort()
self.assertEqual(a,res)
def test_nocase(self):
ns=root.__dict__
tests=[
("a*", ["abbot","abel","ABEL","active","arna",]),
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 ("?b*.?o*",["abbot.koppel","abbot.loop","abel.koppel","abel.loop",
"ABEL.koppel","ABEL.loop",]),
vivainio
merge all from 0.7.3 branch to trunk
r503 ("_a*", []),
("_*anka", ["__anka","__ANKA",]),
("_*a*", ["__anka","__ANKA",]),
]
for pat,res in tests:
res.sort()
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 a=wildcard.list_namespace(ns,"all",pat,ignore_case=True,
show_all=False).keys()
vivainio
merge all from 0.7.3 branch to trunk
r503 a.sort()
self.assertEqual(a,res)
def test_nocase_showall(self):
ns=root.__dict__
tests=[
("a*", ["abbot","abel","ABEL","active","arna",]),
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 ("?b*.?o*",["abbot.koppel","abbot.loop","abel.koppel","abel.loop",
"ABEL.koppel","ABEL.loop",]),
vivainio
merge all from 0.7.3 branch to trunk
r503 ("_a*", ["_apan","_APAN"]),
("_*anka", ["__anka","__ANKA",]),
("_*a*", ["__anka","__ANKA","_apan","_APAN"]),
]
for pat,res in tests:
res.sort()
Fernando Perez
Moved old wildcard tests into proper test suite.
r2657 a=wildcard.list_namespace(ns,"all",pat,ignore_case=True,
show_all=True).keys()
vivainio
merge all from 0.7.3 branch to trunk
r503 a.sort()
self.assertEqual(a,res)
Thomas Kluyver
Test for the problem underlying issue 129.
r3261
def test_dict_attributes(self):
"""Dictionaries should be indexed by attributes, not by keys. This was
causing Github issue 129."""
ns = {"az":{"king":55}, "pq":{1:0}}
tests = [
("a*", ["az"]),
("az.k*", ["az.keys"]),
("pq.k*", ["pq.keys"])
]
for pat, res in tests:
res.sort()
a = wildcard.list_namespace(ns, "all", pat, ignore_case=False,
show_all=True).keys()
a.sort()
self.assertEqual(a, res)
Thomas Kluyver
Add test for dict_dir method in utils.wildcard
r3357
def test_dict_dir(self):
class A(object):
def __init__(self):
self.a = 1
self.b = 2
def __getattribute__(self, name):
if name=="a":
raise AttributeError
return object.__getattribute__(self, name)
a = A()
adict = wildcard.dict_dir(a)
assert "a" not in adict # change to assertNotIn method in >= 2.7
self.assertEqual(adict["b"], 2)