mirror of
https://github.com/pypa/pip
synced 2023-12-13 21:30:23 +01:00
59 lines
1.8 KiB
Python
59 lines
1.8 KiB
Python
import os
|
|
|
|
import pytest
|
|
from pip.compat import expanduser, get_path_uid, native_str
|
|
|
|
|
|
def test_get_path_uid():
|
|
path = os.getcwd()
|
|
assert get_path_uid(path) == os.stat(path).st_uid
|
|
|
|
|
|
@pytest.mark.skipif("not hasattr(os, 'O_NOFOLLOW')")
|
|
def test_get_path_uid_without_NOFOLLOW(monkeypatch):
|
|
monkeypatch.delattr("os.O_NOFOLLOW")
|
|
path = os.getcwd()
|
|
assert get_path_uid(path) == os.stat(path).st_uid
|
|
|
|
|
|
# Skip unconditionally on Windows, as symlinks need admin privs there
|
|
@pytest.mark.skipif("sys.platform == 'win32'")
|
|
@pytest.mark.skipif("not hasattr(os, 'symlink')")
|
|
def test_get_path_uid_symlink(tmpdir):
|
|
f = tmpdir.mkdir("symlink").join("somefile")
|
|
f.write("content")
|
|
fs = f + '_link'
|
|
os.symlink(f, fs)
|
|
with pytest.raises(OSError):
|
|
get_path_uid(fs)
|
|
|
|
|
|
@pytest.mark.skipif("not hasattr(os, 'O_NOFOLLOW')")
|
|
@pytest.mark.skipif("not hasattr(os, 'symlink')")
|
|
def test_get_path_uid_symlink_without_NOFOLLOW(tmpdir, monkeypatch):
|
|
monkeypatch.delattr("os.O_NOFOLLOW")
|
|
f = tmpdir.mkdir("symlink").join("somefile")
|
|
f.write("content")
|
|
fs = f + '_link'
|
|
os.symlink(f, fs)
|
|
with pytest.raises(OSError):
|
|
get_path_uid(fs)
|
|
|
|
|
|
def test_to_native_str_type():
|
|
some_bytes = b"test\xE9 et approuv\xC3\xE9"
|
|
some_unicode = b"test\xE9 et approuv\xE9".decode('iso-8859-15')
|
|
assert isinstance(native_str(some_bytes, True), str)
|
|
assert isinstance(native_str(some_unicode, True), str)
|
|
|
|
|
|
@pytest.mark.parametrize("home,path,expanded", [
|
|
("/Users/test", "~", "/Users/test"),
|
|
("/Users/test", "~/.cache", "/Users/test/.cache"),
|
|
# Verify that we are not affected by http://bugs.python.org/issue14768
|
|
("/", "~", "/"),
|
|
("/", "~/.cache", "/.cache"),
|
|
])
|
|
def test_expanduser(home, path, expanded, monkeypatch):
|
|
monkeypatch.setenv("HOME", home)
|
|
assert expanduser(path) == expanded
|