Skip to content
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

Out of Scope Variable in Exception Block in constants.py #2283

Closed
wants to merge 9 commits into from
24 changes: 20 additions & 4 deletions mslib/msui/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,17 +34,33 @@
# ToDo refactor to generic functions, keep only constants
HOME = os.path.expanduser(f"~{os.path.sep}")
MSUI_CONFIG_PATH = os.getenv("MSUI_CONFIG_PATH", os.path.join(HOME, ".config", "msui"))
_fs = None
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This doesn't solve the issue. Now it is possible that .makedirs is called on None.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please remove this _fs = None line, it should not be necessary.

if '://' in MSUI_CONFIG_PATH:
try:
_fs = fs.open_fs(MSUI_CONFIG_PATH)
except fs.errors.CreateFailed:
_fs.makedirs(MSUI_CONFIG_PATH)
_fs = fs.open_fs(fs.path.dirname(MSUI_CONFIG_PATH))
Copy link
Member

@ReimarBauer ReimarBauer Mar 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

look at the idea in the issue. There should be only one attempt for the fs.errors.CreateFailed because it could be a remote system,

and it would be good to have a test for describing the problem and evaluating the fix by that

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not convinced that fs.path.dirname is correct there. For the default value of ~/.config/msui defined above this would open ~/.config, which seems wrong to me.

except fs.opener.errors.UnsupportedProtocol:
logging.error('FS url "%s" not supported', MSUI_CONFIG_PATH)
except fs.errors.DirectoryExists:
logging.warning('Directory "%s" already exists', MSUI_CONFIG_PATH)
except fs.errors.CreateFailed:
try:
_fs = fs.open_fs(fs.path.dirname(MSUI_CONFIG_PATH))
_fs.makedirs(fs.path.basename(MSUI_CONFIG_PATH))
except fs.errors.DirectoryExists:
logging.warning('Directory "%s" already exists', MSUI_CONFIG_PATH)
except fs.opener.errors.UnsupportedProtocol:
logging.error('FS url "%s" not supported', MSUI_CONFIG_PATH)
except Exception as e:
logging.error('Failed to create directory "%s": %s', MSUI_CONFIG_PATH, e)
else:
_dir = os.path.expanduser(MSUI_CONFIG_PATH)
if not os.path.exists(_dir):
os.makedirs(_dir)
try:
os.makedirs(_dir)
except FileExistsError:
logging.warning('Directory "%s" already exists', MSUI_CONFIG_PATH)
except Exception as e:
logging.error('Failed to create directory "%s": %s', MSUI_CONFIG_PATH, e)

GRAVATAR_DIR_PATH = fs.path.join(MSUI_CONFIG_PATH, "gravatars")

Expand Down
Loading