mirror of
https://github.com/ChristianLight/tutor.git
synced 2025-01-11 09:35:06 +00:00
Minor code refactoring, for naming clarity
This commit is contained in:
parent
5e626114de
commit
7eb99a3811
@ -54,7 +54,7 @@ class ConfigTests(unittest.TestCase):
|
|||||||
password1 = config1["MYSQL_ROOT_PASSWORD"]
|
password1 = config1["MYSQL_ROOT_PASSWORD"]
|
||||||
|
|
||||||
config1.pop("MYSQL_ROOT_PASSWORD")
|
config1.pop("MYSQL_ROOT_PASSWORD")
|
||||||
tutor_config.save(root, config1)
|
tutor_config.save_config_file(root, config1)
|
||||||
|
|
||||||
mock_random_string.return_value = "efgh"
|
mock_random_string.return_value = "efgh"
|
||||||
config2, _ = tutor_config.load_all(root)
|
config2, _ = tutor_config.load_all(root)
|
||||||
|
@ -58,7 +58,7 @@ def save(context, interactive, set_, unset):
|
|||||||
tutor_config.merge(config, dict(set_), force=True)
|
tutor_config.merge(config, dict(set_), force=True)
|
||||||
for key in unset:
|
for key in unset:
|
||||||
config.pop(key, None)
|
config.pop(key, None)
|
||||||
tutor_config.save(context.root, config)
|
tutor_config.save_config_file(context.root, config)
|
||||||
tutor_config.merge(config, defaults)
|
tutor_config.merge(config, defaults)
|
||||||
env.save(context.root, config)
|
env.save(context.root, config)
|
||||||
|
|
||||||
@ -78,7 +78,9 @@ def save(context, interactive, set_, unset):
|
|||||||
def render(context, extra_configs, src, dst):
|
def render(context, extra_configs, src, dst):
|
||||||
config = tutor_config.load(context.root)
|
config = tutor_config.load(context.root)
|
||||||
for extra_config in extra_configs:
|
for extra_config in extra_configs:
|
||||||
tutor_config.merge(config, tutor_config.load_file(extra_config), force=True)
|
tutor_config.merge(
|
||||||
|
config, tutor_config.load_config_file(extra_config), force=True
|
||||||
|
)
|
||||||
|
|
||||||
renderer = env.Renderer(config, [src])
|
renderer = env.Renderer(config, [src])
|
||||||
renderer.render_all_to(dst)
|
renderer.render_all_to(dst)
|
||||||
|
@ -44,7 +44,7 @@ def enable(context, plugin_names):
|
|||||||
for plugin in plugin_names:
|
for plugin in plugin_names:
|
||||||
plugins.enable(config, plugin)
|
plugins.enable(config, plugin)
|
||||||
fmt.echo_info("Plugin {} enabled".format(plugin))
|
fmt.echo_info("Plugin {} enabled".format(plugin))
|
||||||
tutor_config.save(context.root, config)
|
tutor_config.save_config_file(context.root, config)
|
||||||
fmt.echo_info(
|
fmt.echo_info(
|
||||||
"You should now re-generate your environment with `tutor config save`."
|
"You should now re-generate your environment with `tutor config save`."
|
||||||
)
|
)
|
||||||
@ -63,7 +63,7 @@ def disable(context, plugin_names):
|
|||||||
shutil.rmtree(plugin_dir)
|
shutil.rmtree(plugin_dir)
|
||||||
fmt.echo_info("Plugin {} disabled".format(plugin))
|
fmt.echo_info("Plugin {} disabled".format(plugin))
|
||||||
|
|
||||||
tutor_config.save(context.root, config)
|
tutor_config.save_config_file(context.root, config)
|
||||||
fmt.echo_info(
|
fmt.echo_info(
|
||||||
"You should now re-generate your environment with `tutor config save`."
|
"You should now re-generate your environment with `tutor config save`."
|
||||||
)
|
)
|
||||||
|
@ -87,7 +87,7 @@ def start(context, port, host):
|
|||||||
)
|
)
|
||||||
@click.pass_obj
|
@click.pass_obj
|
||||||
def configure(context, user, password):
|
def configure(context, user, password):
|
||||||
save_config(context.root, {"user": user, "password": password})
|
save_webui_config_file(context.root, {"user": user, "password": password})
|
||||||
fmt.echo_info(
|
fmt.echo_info(
|
||||||
"The web UI configuration has been updated. "
|
"The web UI configuration has been updated. "
|
||||||
"If at any point you wish to reset your username and password, "
|
"If at any point you wish to reset your username and password, "
|
||||||
@ -122,12 +122,12 @@ def check_gotty_binary(root):
|
|||||||
def load_config(root):
|
def load_config(root):
|
||||||
path = config_path(root)
|
path = config_path(root)
|
||||||
if not os.path.exists(path):
|
if not os.path.exists(path):
|
||||||
save_config(root, {"user": None, "password": None})
|
save_webui_config_file(root, {"user": None, "password": None})
|
||||||
with open(config_path(root)) as f:
|
with open(config_path(root)) as f:
|
||||||
return serialize.load(f)
|
return serialize.load(f)
|
||||||
|
|
||||||
|
|
||||||
def save_config(root, config):
|
def save_webui_config_file(root, config):
|
||||||
path = config_path(root)
|
path = config_path(root)
|
||||||
directory = os.path.dirname(path)
|
directory = os.path.dirname(path)
|
||||||
if not os.path.exists(directory):
|
if not os.path.exists(directory):
|
||||||
|
@ -14,7 +14,7 @@ def update(root):
|
|||||||
Load and save the configuration.
|
Load and save the configuration.
|
||||||
"""
|
"""
|
||||||
config, defaults = load_all(root)
|
config, defaults = load_all(root)
|
||||||
save(root, config)
|
save_config_file(root, config)
|
||||||
merge(config, defaults)
|
merge(config, defaults)
|
||||||
return config
|
return config
|
||||||
|
|
||||||
@ -53,10 +53,10 @@ def merge(config, defaults, force=False):
|
|||||||
|
|
||||||
|
|
||||||
def load_defaults():
|
def load_defaults():
|
||||||
return serialize.load(env.read("config.yml"))
|
return serialize.load(env.read_template_file("config.yml"))
|
||||||
|
|
||||||
|
|
||||||
def load_file(path):
|
def load_config_file(path):
|
||||||
with open(path) as f:
|
with open(path) as f:
|
||||||
return serialize.load(f.read())
|
return serialize.load(f.read())
|
||||||
|
|
||||||
@ -79,8 +79,7 @@ def load_user(root):
|
|||||||
if not os.path.exists(path):
|
if not os.path.exists(path):
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
with open(path) as fi:
|
config = load_config_file(path)
|
||||||
config = serialize.load(fi.read())
|
|
||||||
upgrade_obsolete(config)
|
upgrade_obsolete(config)
|
||||||
return config
|
return config
|
||||||
|
|
||||||
@ -164,16 +163,15 @@ def convert_json2yml(root):
|
|||||||
root
|
root
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
with open(json_path) as fi:
|
config = load_config_file(json_path)
|
||||||
config = json.load(fi)
|
save_config_file(root, config)
|
||||||
save(root, config)
|
|
||||||
os.remove(json_path)
|
os.remove(json_path)
|
||||||
fmt.echo_info(
|
fmt.echo_info(
|
||||||
"File config.json detected in {} and converted to config.yml".format(root)
|
"File config.json detected in {} and converted to config.yml".format(root)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def save(root, config):
|
def save_config_file(root, config):
|
||||||
path = config_path(root)
|
path = config_path(root)
|
||||||
utils.ensure_file_directory_exists(path)
|
utils.ensure_file_directory_exists(path)
|
||||||
with open(path, "w") as of:
|
with open(path, "w") as of:
|
||||||
|
16
tutor/env.py
16
tutor/env.py
@ -120,6 +120,10 @@ class Renderer:
|
|||||||
return self.__render(template)
|
return self.__render(template)
|
||||||
|
|
||||||
def render_file(self, path):
|
def render_file(self, path):
|
||||||
|
"""
|
||||||
|
Render a template file. Return the corresponding string. If it's a binary file
|
||||||
|
(as indicated by its path), return bytes.
|
||||||
|
"""
|
||||||
if is_binary_file(path):
|
if is_binary_file(path):
|
||||||
# Don't try to render binary files
|
# Don't try to render binary files
|
||||||
with open(self.find_path(path), "rb") as f:
|
with open(self.find_path(path), "rb") as f:
|
||||||
@ -205,7 +209,7 @@ def save_all_from(prefix, root, config):
|
|||||||
|
|
||||||
def write_to(content, path):
|
def write_to(content, path):
|
||||||
"""
|
"""
|
||||||
Content can be either str or bytes.
|
Write some content to a path. Content can be either str or bytes.
|
||||||
"""
|
"""
|
||||||
open_mode = "w"
|
open_mode = "w"
|
||||||
if isinstance(content, bytes):
|
if isinstance(content, bytes):
|
||||||
@ -267,17 +271,19 @@ def check_is_up_to_date(root):
|
|||||||
"\n"
|
"\n"
|
||||||
" tutor config save"
|
" tutor config save"
|
||||||
)
|
)
|
||||||
fmt.echo_alert(message.format(base_dir(root), version(root), __version__))
|
fmt.echo_alert(
|
||||||
|
message.format(base_dir(root), current_version(root), __version__)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def is_up_to_date(root):
|
def is_up_to_date(root):
|
||||||
"""
|
"""
|
||||||
Check if the currently rendered version is equal to the current tutor version.
|
Check if the currently rendered version is equal to the current tutor version.
|
||||||
"""
|
"""
|
||||||
return version(root) == __version__
|
return current_version(root) == __version__
|
||||||
|
|
||||||
|
|
||||||
def version(root):
|
def current_version(root):
|
||||||
"""
|
"""
|
||||||
Return the current environment version. If the current environment has no version,
|
Return the current environment version. If the current environment has no version,
|
||||||
return "0".
|
return "0".
|
||||||
@ -288,7 +294,7 @@ def version(root):
|
|||||||
return open(path).read().strip()
|
return open(path).read().strip()
|
||||||
|
|
||||||
|
|
||||||
def read(*path):
|
def read_template_file(*path):
|
||||||
"""
|
"""
|
||||||
Read raw content of template located at `path`.
|
Read raw content of template located at `path`.
|
||||||
"""
|
"""
|
||||||
|
@ -13,7 +13,7 @@ def update(root, interactive=True):
|
|||||||
Load and save the configuration.
|
Load and save the configuration.
|
||||||
"""
|
"""
|
||||||
config, defaults = load_all(root, interactive=interactive)
|
config, defaults = load_all(root, interactive=interactive)
|
||||||
tutor_config.save(root, config)
|
tutor_config.save_config_file(root, config)
|
||||||
tutor_config.merge(config, defaults)
|
tutor_config.merge(config, defaults)
|
||||||
return config
|
return config
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user