6
0
mirror of https://github.com/ChristianLight/tutor.git synced 2025-01-22 13:18:24 +00:00

chore: fix various linting warnings in f-strings and docs

This commit is contained in:
Régis Behmo 2022-02-21 11:52:46 +01:00 committed by Régis Behmo
parent a8d60d753b
commit 79f14b7e7e
3 changed files with 19 additions and 31 deletions

View File

@ -20,7 +20,7 @@ Tutor was tested with server version 1.14.1 and client 1.14.3.
Memory Memory
~~~~~~ ~~~~~~
In the following, we assume you have access to a working Kubernetes cluster. `kubectl` should use your cluster configuration by default. To launch a cluster locally, you may try out Minikube. Just follow the `official installation instructions <https://kubernetes.io/docs/setup/minikube/>`_. In the following, we assume you have access to a working Kubernetes cluster. ``kubectl`` should use your cluster configuration by default. To launch a cluster locally, you may try out Minikube. Just follow the `official installation instructions <https://kubernetes.io/docs/setup/minikube/>`__.
The Kubernetes cluster should have at least 4Gb of RAM on each node. When running Minikube, the virtual machine should have that much allocated memory. See below for an example with VirtualBox: The Kubernetes cluster should have at least 4Gb of RAM on each node. When running Minikube, the virtual machine should have that much allocated memory. See below for an example with VirtualBox:
@ -102,7 +102,7 @@ As with the :ref:`local installation <local>`, there are multiple commands to ru
tutor k8s -h tutor k8s -h
In particular, the `tutor k8s start` command restarts and reconfigures all services by running ``kubectl apply``. That means that you can delete containers, deployments or just any other kind of resources, and Tutor will re-create them automatically. You should just beware of not deleting any persistent data stored in persistent volume claims. For instance, to restart from a "blank slate", run:: In particular, the ``tutor k8s start`` command restarts and reconfigures all services by running ``kubectl apply``. That means that you can delete containers, deployments or just any other kind of resources, and Tutor will re-create them automatically. You should just beware of not deleting any persistent data stored in persistent volume claims. For instance, to restart from a "blank slate", run::
tutor k8s stop tutor k8s stop
tutor k8s start tutor k8s start
@ -133,6 +133,6 @@ Some Tutor plugins and customization procedures require that the "openedx" image
Updating docker images Updating docker images
~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~
Kubernetes does not provide a single command for updating docker images out of the box. A `commonly used trick <https://github.com/kubernetes/kubernetes/issues/33664>`_ is to modify an innocuous label on all resources:: Kubernetes does not provide a single command for updating docker images out of the box. A `commonly used trick <https://github.com/kubernetes/kubernetes/issues/33664>`__ is to modify an innocuous label on all resources::
kubectl patch -k "$(tutor config printroot)/env" --patch "{\"spec\": {\"template\": {\"metadata\": {\"labels\": {\"date\": \"`date +'%Y%m%d-%H%M%S'`\"}}}}}" kubectl patch -k "$(tutor config printroot)/env" --patch "{\"spec\": {\"template\": {\"metadata\": {\"labels\": {\"date\": \"`date +'%Y%m%d-%H%M%S'`\"}}}}}"

View File

@ -44,7 +44,7 @@ class ComposeJobRunner(jobs.BaseComposeJobRunner):
run_command += ["run", "--rm"] run_command += ["run", "--rm"]
if not utils.is_a_tty(): if not utils.is_a_tty():
run_command += ["-T"] run_command += ["-T"]
job_service_name = "{}-job".format(service) job_service_name = f"{service}-job"
return self.docker_compose( return self.docker_compose(
*run_command, *run_command,
job_service_name, job_service_name,
@ -224,9 +224,8 @@ def bindmount_command(context: BaseComposeContext, service: str, path: str) -> N
config = tutor_config.load(context.root) config = tutor_config.load(context.root)
host_path = bindmounts.create(context.job_runner(config), service, path) host_path = bindmounts.create(context.job_runner(config), service, path)
fmt.echo_info( fmt.echo_info(
"Bind-mount volume created at {}. You can now use it in all `local` and `dev` commands with the `--volume={}` option.".format( f"Bind-mount volume created at {host_path}. You can now use it in all `local` and `dev` "
host_path, path f"commands with the `--volume={path}` option."
)
) )
@ -286,12 +285,10 @@ def dc_command(context: BaseComposeContext, command: str, args: List[str]) -> No
host_bind_path = bindmounts.get_path(context.root, volume_arg) host_bind_path = bindmounts.get_path(context.root, volume_arg)
if not os.path.exists(host_bind_path): if not os.path.exists(host_bind_path):
raise TutorError( raise TutorError(
( f"Bind-mount volume directory {host_bind_path} does not exist. It must first be created "
"Bind-mount volume directory {} does not exist. It must first be created" f"with the '{bindmount_command.name}' command."
" with the '{}' command."
).format(host_bind_path, bindmount_command.name)
) )
volume_arg = "{}:{}".format(host_bind_path, volume_arg) volume_arg = f"{host_bind_path}:{volume_arg}"
volume_args += ["--volume", volume_arg] volume_args += ["--volume", volume_arg]
context.job_runner(config).docker_compose(command, *volume_args, *non_volume_args) context.job_runner(config).docker_compose(command, *volume_args, *non_volume_args)

View File

@ -45,15 +45,11 @@ def ensure_file_directory_exists(path: str) -> None:
directory = os.path.dirname(path) directory = os.path.dirname(path)
if os.path.isfile(directory): if os.path.isfile(directory):
raise exceptions.TutorError( raise exceptions.TutorError(
"Attempting to create a directory, but a file with the same name already exists: {}".format( f"Attempting to create a directory, but a file with the same name already exists: {directory}"
directory
)
) )
if os.path.isdir(path): if os.path.isdir(path):
raise exceptions.TutorError( raise exceptions.TutorError(
"Attempting to write to a file, but a directory with the same name already exists: {}".format( f"Attempting to write to a file, but a directory with the same name already exists: {directory}"
directory
)
) )
if not os.path.exists(directory): if not os.path.exists(directory):
os.makedirs(directory) os.makedirs(directory)
@ -123,7 +119,7 @@ def long_to_base64(n: int) -> str:
return _bytes return _bytes
bys = long2intarr(n) bys = long2intarr(n)
data = struct.pack("%sB" % len(bys), *bys) data = struct.pack(f"{len(bys)}B", *bys)
if not data: if not data:
data = b"\x00" data = b"\x00"
s = base64.urlsafe_b64encode(data).rstrip(b"=") s = base64.urlsafe_b64encode(data).rstrip(b"=")
@ -202,24 +198,21 @@ def execute(*command: str) -> int:
except Exception as e: except Exception as e:
p.kill() p.kill()
p.wait() p.wait()
raise exceptions.TutorError( raise exceptions.TutorError(f"Command failed: {' '.join(command)}") from e
"Command failed: {}".format(" ".join(command))
) from e
if result > 0: if result > 0:
raise exceptions.TutorError( raise exceptions.TutorError(
"Command failed with status {}: {}".format(result, " ".join(command)) f"Command failed with status {result}: {' '.join(command)}"
) )
return result return result
def check_output(*command: str) -> bytes: def check_output(*command: str) -> bytes:
click.echo(fmt.command(" ".join(command))) literal_command = " ".join(command)
click.echo(fmt.command(literal_command))
try: try:
return subprocess.check_output(command) return subprocess.check_output(command)
except Exception as e: except Exception as e:
raise exceptions.TutorError( raise exceptions.TutorError(f"Command failed: {literal_command}") from e
"Command failed: {}".format(" ".join(command))
) from e
def check_macos_docker_memory() -> None: def check_macos_docker_memory() -> None:
@ -237,7 +230,7 @@ def check_macos_docker_memory() -> None:
) )
try: try:
with open(settings_path) as fp: with open(settings_path, encoding="utf-8") as fp:
data = json.load(fp) data = json.load(fp)
memory_mib = int(data["memoryMiB"]) memory_mib = int(data["memoryMiB"])
except OSError as e: except OSError as e:
@ -264,7 +257,5 @@ def check_macos_docker_memory() -> None:
if memory_mib < 4096: if memory_mib < 4096:
raise exceptions.TutorError( raise exceptions.TutorError(
"Docker is configured to allocate {} MiB RAM, less than the recommended {} MiB".format( f"Docker is configured to allocate {memory_mib} MiB RAM, less than the recommended {4096} MiB"
memory_mib, 4096
)
) )