##// END OF EJS Templates
don't use XDG path on OS X...
MinRK -
Show More
@@ -227,13 +227,13 b' def get_home_dir(require_writable=False):'
227 227 def get_xdg_dir():
228 228 """Return the XDG_CONFIG_HOME, if it is defined and exists, else None.
229 229
230 This is only for posix (Linux,Unix,OS X, etc) systems.
230 This is only for non-OS X posix (Linux,Unix,etc.) systems.
231 231 """
232 232
233 233 env = os.environ
234 234
235 if os.name == 'posix':
236 # Linux, Unix, AIX, OS X
235 if os.name == 'posix' and sys.platform != 'darwin':
236 # Linux, Unix, AIX, etc.
237 237 # use ~/.config if empty OR not set
238 238 xdg = env.get("XDG_CONFIG_HOME", None) or os.path.join(get_home_dir(), '.config')
239 239 if xdg and _writable_dir(xdg):
@@ -93,7 +93,7 b' def setup_environment():'
93 93 each testfunction needs a pristine environment.
94 94 """
95 95 global oldstuff, platformstuff
96 oldstuff = (env.copy(), os.name, path.get_home_dir, IPython.__file__, os.getcwd())
96 oldstuff = (env.copy(), os.name, sys.platform, path.get_home_dir, IPython.__file__, os.getcwd())
97 97
98 98 if os.name == 'nt':
99 99 platformstuff = (wreg.OpenKey, wreg.QueryValueEx,)
@@ -102,7 +102,7 b' def setup_environment():'
102 102 def teardown_environment():
103 103 """Restore things that were remebered by the setup_environment function
104 104 """
105 (oldenv, os.name, path.get_home_dir, IPython.__file__, old_wd) = oldstuff
105 (oldenv, os.name, sys.platform, path.get_home_dir, IPython.__file__, old_wd) = oldstuff
106 106 os.chdir(old_wd)
107 107 reload(path)
108 108
@@ -234,7 +234,11 b' def test_get_ipython_dir_3():'
234 234 env.pop('IPYTHONDIR', None)
235 235 env['XDG_CONFIG_HOME'] = XDG_TEST_DIR
236 236 ipdir = path.get_ipython_dir()
237 nt.assert_equal(ipdir, os.path.join(XDG_TEST_DIR, "ipython"))
237 if sys.platform == "darwin":
238 expected = os.path.join("someplace", ".ipython")
239 else:
240 expected = os.path.join(XDG_TEST_DIR, "ipython")
241 nt.assert_equal(ipdir, expected)
238 242
239 243 @with_environment
240 244 def test_get_ipython_dir_4():
@@ -244,9 +248,12 b' def test_get_ipython_dir_4():'
244 248 env.pop('IPYTHON_DIR', None)
245 249 env.pop('IPYTHONDIR', None)
246 250 env['XDG_CONFIG_HOME'] = XDG_TEST_DIR
247 xdg_ipdir = os.path.join(XDG_TEST_DIR, "ipython")
248 251 ipdir = path.get_ipython_dir()
249 nt.assert_equal(ipdir, xdg_ipdir)
252 if sys.platform == "darwin":
253 expected = os.path.join(HOME_TEST_DIR, ".ipython")
254 else:
255 expected = os.path.join(XDG_TEST_DIR, "ipython")
256 nt.assert_equal(ipdir, expected)
250 257
251 258 @with_environment
252 259 def test_get_ipython_dir_5():
@@ -287,12 +294,13 b' def test_get_ipython_dir_7():'
287 294
288 295
289 296 @with_environment
290 def test_get_xdg_dir_1():
291 """test_get_xdg_dir_1, check xdg_dir"""
297 def test_get_xdg_dir_0():
298 """test_get_xdg_dir_0, check xdg_dir"""
292 299 reload(path)
293 300 path._writable_dir = lambda path: True
294 301 path.get_home_dir = lambda : 'somewhere'
295 302 os.name = "posix"
303 sys.platform = "linux2"
296 304 env.pop('IPYTHON_DIR', None)
297 305 env.pop('IPYTHONDIR', None)
298 306 env.pop('XDG_CONFIG_HOME', None)
@@ -306,6 +314,7 b' def test_get_xdg_dir_1():'
306 314 reload(path)
307 315 path.get_home_dir = lambda : HOME_TEST_DIR
308 316 os.name = "posix"
317 sys.platform = "linux2"
309 318 env.pop('IPYTHON_DIR', None)
310 319 env.pop('IPYTHONDIR', None)
311 320 env.pop('XDG_CONFIG_HOME', None)
@@ -317,14 +326,32 b' def test_get_xdg_dir_2():'
317 326 reload(path)
318 327 path.get_home_dir = lambda : HOME_TEST_DIR
319 328 os.name = "posix"
329 sys.platform = "linux2"
320 330 env.pop('IPYTHON_DIR', None)
321 331 env.pop('IPYTHONDIR', None)
322 332 env.pop('XDG_CONFIG_HOME', None)
323 333 cfgdir=os.path.join(path.get_home_dir(), '.config')
334 if not os.path.exists(cfgdir):
324 335 os.makedirs(cfgdir)
325 336
326 337 nt.assert_equal(path.get_xdg_dir(), cfgdir)
327 338
339 @with_environment
340 def test_get_xdg_dir_3():
341 """test_get_xdg_dir_3, check xdg_dir not used on OS X"""
342 reload(path)
343 path.get_home_dir = lambda : HOME_TEST_DIR
344 os.name = "posix"
345 sys.platform = "darwin"
346 env.pop('IPYTHON_DIR', None)
347 env.pop('IPYTHONDIR', None)
348 env.pop('XDG_CONFIG_HOME', None)
349 cfgdir=os.path.join(path.get_home_dir(), '.config')
350 if not os.path.exists(cfgdir):
351 os.makedirs(cfgdir)
352
353 nt.assert_equal(path.get_xdg_dir(), None)
354
328 355 def test_filefind():
329 356 """Various tests for filefind"""
330 357 f = tempfile.NamedTemporaryFile()
General Comments 0
You need to be logged in to leave comments. Login now