-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Consolidate process cwd() "null" return value across all platforms #2238
Labels
Comments
psutil/psutil/tests/test_contracts.py Line 457 in b070015
|
giampaolo
added a commit
that referenced
this issue
Apr 16, 2023
Signed-off-by: Giampaolo Rodola <g.rodola@gmail.com>
giampaolo
added a commit
that referenced
this issue
Apr 17, 2023
giampaolo
added a commit
that referenced
this issue
Apr 17, 2023
ddelange
added a commit
to ddelange/psutil
that referenced
this issue
Apr 21, 2023
* 'master' of https://github.com/giampaolo/psutil: (22 commits) use glob.glob() in setup.py OSX / refact: get rid of process_info.c (giampaolo#2243) OSX C refact: reconstruct _psutil_osx.c to preserve history OSX: rename psutil/_psutil_osx.c to arch/osx/proc.c to preserve GIT history OSX big C refactoring (giampaolo#2242) fix failing users() test; update HISTORY; give CREDITS to @0-wiz-0 for giampaolo#2241 win C refact: reconstruct _psutil_windows.c trying to preserve history rename _psutil_windows.c -> proc.c Win, C, refact: move proc funcs into proc.c file BSD big refact: move proc funcs in new proc.c file Fix build on NetBSD due to missing .h include. (giampaolo#2241) Win, C, refact: move boot_time() and users() in new sys.c Windows / refact: new sensors.c file C refact: remove useless cmdline / cwd / environ layers. Call direct functions pre release Add CI testing for OpenBSD and NetBSD (giampaolo#2240) Fix giampaolo#2239 / proc name(): don't fail with ZombieProcess on cmdline() giampaolo#2238: passed wrong value to Py_BuildValue fix giampaolo#2238 if cwd() cannot be determined always return "" instead of None Fix giampaolo#2237, OpenBSD, cwd(): return None instead of FileNotFoundError ...
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
There are cases where
Process.cwd()
cannot be determined, but not due a permission error (AccessDenied
). Sometimes the kernel simply returns a "null" information and there's nothing we can do about it. Some other times like in #2237 the kernel returns ENOENT because perhaps the directory no longer exists, and again, we're forced to return a "null" value (this time I opted forNone
).When such cases occur, psutil sometimes returns
None
, some other times an empty string. Perhaps even worse, none of this is documented. Such cases should be consolidated (either returnNone
or empty string everywhere) and documented.Because the native type returned
cwd()
is a string, I'm more keen on returning an empty string everywhere rather thanNone
.The text was updated successfully, but these errors were encountered: