aboutsummaryrefslogtreecommitdiffstats
path: root/build/plugins/lib/nots
diff options
context:
space:
mode:
authorvturov <vturov@yandex-team.com>2024-03-29 18:29:15 +0300
committervturov <vturov@yandex-team.com>2024-03-29 18:40:32 +0300
commitcc0d0419d1785b914832d68319402a1bab2aebaf (patch)
treeec900f16dd7240b1e369b084566937d7e999cd75 /build/plugins/lib/nots
parentf39261a434c46274b5eaef0927ee3b2e0d95b41a (diff)
downloadydb-cc0d0419d1785b914832d68319402a1bab2aebaf.tar.gz
PR from branch users/vturov/feat/speed-up-node-modules
использовать tar при распаковке node_modules Возможность линтить синтетический проект с зависимостями dab4dcfbd7c366508c07a59f14c2be77bafdc935
Diffstat (limited to 'build/plugins/lib/nots')
-rw-r--r--build/plugins/lib/nots/package_manager/base/node_modules_bundler.py16
1 files changed, 14 insertions, 2 deletions
diff --git a/build/plugins/lib/nots/package_manager/base/node_modules_bundler.py b/build/plugins/lib/nots/package_manager/base/node_modules_bundler.py
index aae54c0be6..c632ecb24a 100644
--- a/build/plugins/lib/nots/package_manager/base/node_modules_bundler.py
+++ b/build/plugins/lib/nots/package_manager/base/node_modules_bundler.py
@@ -1,4 +1,6 @@
import os
+import sys
+import subprocess
import tarfile
from io import BytesIO
@@ -53,8 +55,16 @@ def extract_node_modules(build_root, node_modules_path, bundle_path):
:param bundle_path: tarball path
:type bundle_path: str
"""
- with tarfile.open(bundle_path) as tf:
- tf.extractall(node_modules_path)
+ os.makedirs(node_modules_path, exist_ok=True)
+ tar_unpack_cmd = ["tar", "xf", bundle_path, "-C", node_modules_path]
+ p = subprocess.run(tar_unpack_cmd, capture_output=True, text=True)
+ if p.returncode != 0:
+ if p.stdout:
+ sys.stderr.write(f"stdout:\n{p.stdout}\n")
+ if p.stderr:
+ sys.stderr.write(f"stderr:\n{p.stderr}\n")
+
+ return False
with open(os.path.join(node_modules_path, PEERS_DIR, PEERS_INDEX)) as peers_file:
peers = peers_file.read().split("\n")
@@ -64,3 +74,5 @@ def extract_node_modules(build_root, node_modules_path, bundle_path):
bundled_nm_path = build_nm_path(os.path.join(node_modules_path, PEERS_DIR, p))
nm_path = build_nm_path(os.path.join(build_root, p))
os.rename(bundled_nm_path, nm_path)
+
+ return True