Skip to content

Commit

Permalink
Fix handling of file_not_found errors
Browse files Browse the repository at this point in the history
Fixes: #496

Signed-off-by: Daniel J Walsh <[email protected]>
  • Loading branch information
rhatdan committed Dec 3, 2024
1 parent bbf73a4 commit 7d89322
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 12 deletions.
2 changes: 1 addition & 1 deletion docs/ramalama.1.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ Running in containers eliminates the need for users to configure the host system

RamaLama pulls AI Models from model registries. Starting a chatbot or a rest API service from a simple single command. Models are treated similarly to how Podman and Docker treat container images.

When both Podman and Docker are installed, RamaLama defaults to Podman, The `RAMALAMA_CONTAINER_ENGINE=docker` environment variable can override this behavior. When neither are installed RamaLama attempts to run the model with software on the local system.
When both Podman and Docker are installed, RamaLama defaults to Podman, The `RAMALAMA_CONTAINER_ENGINE=docker` environment variable can override this behaviour. When neither are installed RamaLama attempts to run the model with software on the local system.

Note:

Expand Down
26 changes: 15 additions & 11 deletions ramalama/model.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,17 +21,17 @@


file_not_found = """\
RamaLama requires the "%s" command to be installed on the host when running with --nocontainer.
RamaLama is designed to run AI Models inside of containers, where "%s" is already installed.
Either install a package containing the "%s" command or run the workload inside of a container.
"""
RamaLama requires the "%{cmd}s" command to be installed on the host when running with --nocontainer.
RamaLama is designed to run AI Models inside of containers, where "%{cmd}s" is already installed.
Either install a package containing the "%{cmd}s" command or run the workload inside of a container.
%{error}s"""

file_not_found_in_container = """\
RamaLama requires the "%s" command to be installed inside of the container.
RamaLama requires the "%{cmd}s" command to be installed inside of the container.
RamaLama requires the server application be installed in the container images.
Either install a package containing the "%s" command in the container or run
Either install a package containing the "%{cmd}s" command in the container or run
with the default RamaLama image.
"""
%{error}s"""


class Model:
Expand Down Expand Up @@ -295,8 +295,10 @@ def run(self, args):
exec_cmd(exec_args, args.debug, debug=args.debug)
except FileNotFoundError as e:
if in_container():
raise NotImplementedError(file_not_found_in_container % (exec_args[0], str(e).strip("'")))
raise NotImplementedError(file_not_found % (exec_args[0], exec_args[0], exec_args[0], str(e).strip("'")))
raise NotImplementedError(
file_not_found_in_container % {"cmd": exec_args[0], "error": str(e).strip("'")}
)
raise NotImplementedError(file_not_found % {"cmd": exec_args[0], "error": str(e).strip("'")})

def serve(self, args):
if hasattr(args, "name") and args.name:
Expand Down Expand Up @@ -355,8 +357,10 @@ def serve(self, args):
exec_cmd(exec_args, debug=args.debug)
except FileNotFoundError as e:
if in_container():
raise NotImplementedError(file_not_found_in_container % (exec_args[0], str(e).strip("'")))
raise NotImplementedError(file_not_found % (exec_args[0], exec_args[0], exec_args[0], str(e).strip("'")))
raise NotImplementedError(
file_not_found_in_container % {"cmd": exec_args[0], "error": str(e).strip("'")}
)
raise NotImplementedError(file_not_found % {"cmd": exec_args[0], "error": str(e).strip("'")})

def quadlet(self, model, args, exec_args):
quadlet = Quadlet(model, args, exec_args)
Expand Down

0 comments on commit 7d89322

Please sign in to comment.