2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-22 22:58:31 +00:00

fix: remove unused nodemodules before caching

This commit is contained in:
18alantom 2024-01-18 17:44:25 +05:30
parent 683a421e43
commit 0e2e8b4da3

View File

@ -335,7 +335,7 @@ class App(AppMeta):
# Check if cache exists with gzip # Check if cache exists with gzip
if not cache_path.is_file(): if not cache_path.is_file():
return return False
app_path = self.get_app_path() app_path = self.get_app_path()
if app_path.is_dir(): if app_path.is_dir():
@ -352,28 +352,64 @@ class App(AppMeta):
return False return False
app_path = self.get_app_path() app_path = self.get_app_path()
if not app_path.is_dir() or not is_valid_app_dir(app_path): if not app_path.is_dir():
return False return False
cwd = os.getcwd() cwd = os.getcwd()
cache_path = self.get_app_cache_path(compress_artifacts) cache_path = self.get_app_cache_path(compress_artifacts)
mode = "w:gz" if compress_artifacts else "w" mode = "w:gz" if compress_artifacts else "w"
message = "Caching get-app artifacts" message = f"Caching ${self.app_name} app directory"
if compress_artifacts: if compress_artifacts:
message += " (compressed)" message += " (compressed)"
click.secho(message) click.secho(message)
self.prune_app_directory()
os.chdir(app_path.parent) os.chdir(app_path.parent)
with tarfile.open(cache_path, mode) as tar: with tarfile.open(cache_path, mode) as tar:
tar.add(app_path.name) tar.add(app_path.name)
os.chdir(cwd) os.chdir(cwd)
return True return True
def prune_app_directory(self):
app_path = self.get_app_path()
remove_unused_node_modules(app_path)
def is_valid_app_dir(app_path: Path) -> bool: def remove_unused_node_modules(app_path: Path) -> None:
# TODO: Check from content if valid frappe app root """
return True Erring a bit the side of caution; since there is no explicit way
to check if node_modules are utilized, this function checks if Vite
is being used to build the frontend code.
Since most popular Frappe apps use Vite to build their frontends,
this method should suffice.
Note: root package.json is ignored cause those usually belong to
apps that do not have a build step and so their node_modules are
utilized during runtime.
"""
for p in app_path.iterdir():
if not p.is_dir():
continue
package_json = p / "package.json"
if not package_json.is_file():
continue
node_modules = p / "node_modules"
if not node_modules.is_dir():
continue
can_delete = False
with package_json.open("r", encoding="utf-8") as f:
package_json = json.loads(f.read())
build_script = package_json.get("scripts", {}).get("build", "")
can_delete = "vite build" in build_script
if can_delete:
shutil.rmtree(node_modules)
def make_resolution_plan(app: App, bench: "Bench"): def make_resolution_plan(app: App, bench: "Bench"):