chore: Update check-wheel-size.py to read MAX_SIZE_MB from env (#8103)
This commit is contained in:
parent
855c262a6b
commit
ccd7207191
@ -1,36 +1,43 @@
|
|||||||
import os
|
import os
|
||||||
|
import sys
|
||||||
import zipfile
|
import zipfile
|
||||||
|
|
||||||
MAX_SIZE_MB = 250
|
# Read the VLLM_MAX_SIZE_MB environment variable, defaulting to 250 MB
|
||||||
|
VLLM_MAX_SIZE_MB = int(os.environ.get('VLLM_MAX_SIZE_MB', 250))
|
||||||
|
|
||||||
|
|
||||||
def print_top_10_largest_files(zip_file):
|
def print_top_10_largest_files(zip_file):
|
||||||
|
"""Print the top 10 largest files in the given zip file."""
|
||||||
with zipfile.ZipFile(zip_file, 'r') as z:
|
with zipfile.ZipFile(zip_file, 'r') as z:
|
||||||
file_sizes = [(f, z.getinfo(f).file_size) for f in z.namelist()]
|
file_sizes = [(f, z.getinfo(f).file_size) for f in z.namelist()]
|
||||||
file_sizes.sort(key=lambda x: x[1], reverse=True)
|
file_sizes.sort(key=lambda x: x[1], reverse=True)
|
||||||
for f, size in file_sizes[:10]:
|
for f, size in file_sizes[:10]:
|
||||||
print(f"{f}: {size/(1024*1024)} MBs uncompressed.")
|
print(f"{f}: {size / (1024 * 1024):.2f} MBs uncompressed.")
|
||||||
|
|
||||||
|
|
||||||
def check_wheel_size(directory):
|
def check_wheel_size(directory):
|
||||||
|
"""Check the size of .whl files in the given directory."""
|
||||||
for root, _, files in os.walk(directory):
|
for root, _, files in os.walk(directory):
|
||||||
for f in files:
|
for file_name in files:
|
||||||
if f.endswith(".whl"):
|
if file_name.endswith(".whl"):
|
||||||
wheel_path = os.path.join(root, f)
|
wheel_path = os.path.join(root, file_name)
|
||||||
wheel_size = os.path.getsize(wheel_path)
|
wheel_size_mb = os.path.getsize(wheel_path) / (1024 * 1024)
|
||||||
wheel_size_mb = wheel_size / (1024 * 1024)
|
if wheel_size_mb > VLLM_MAX_SIZE_MB:
|
||||||
if wheel_size_mb > MAX_SIZE_MB:
|
print(f"Not allowed: Wheel {wheel_path} is larger "
|
||||||
print(
|
f"({wheel_size_mb:.2f} MB) than the limit "
|
||||||
f"Wheel {wheel_path} is too large ({wheel_size_mb} MB) "
|
f"({VLLM_MAX_SIZE_MB} MB).")
|
||||||
f"compare to the allowed size ({MAX_SIZE_MB} MB).")
|
|
||||||
print_top_10_largest_files(wheel_path)
|
print_top_10_largest_files(wheel_path)
|
||||||
return 1
|
return 1
|
||||||
else:
|
else:
|
||||||
print(f"Wheel {wheel_path} is within the allowed size "
|
print(f"Wheel {wheel_path} is within the allowed size "
|
||||||
f"({wheel_size_mb} MB).")
|
f"({wheel_size_mb:.2f} MB).")
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
import sys
|
if len(sys.argv) < 2:
|
||||||
sys.exit(check_wheel_size(sys.argv[1]))
|
print("Usage: python check-wheel-size.py <directory>")
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
directory = sys.argv[1]
|
||||||
|
sys.exit(check_wheel_size(directory))
|
13
Dockerfile
13
Dockerfile
@ -108,10 +108,17 @@ RUN --mount=type=cache,target=/root/.cache/ccache \
|
|||||||
python3 setup.py bdist_wheel --dist-dir=dist --py-limited-api=cp38; \
|
python3 setup.py bdist_wheel --dist-dir=dist --py-limited-api=cp38; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# check the size of the wheel, we cannot upload wheels larger than 100MB
|
# Check the size of the wheel if RUN_WHEEL_CHECK is true
|
||||||
COPY .buildkite/check-wheel-size.py check-wheel-size.py
|
COPY .buildkite/check-wheel-size.py check-wheel-size.py
|
||||||
RUN python3 check-wheel-size.py dist
|
# Default max size of the wheel is 250MB
|
||||||
|
ARG VLLM_MAX_SIZE_MB=250
|
||||||
|
ENV VLLM_MAX_SIZE_MB=$VLLM_MAX_SIZE_MB
|
||||||
|
ARG RUN_WHEEL_CHECK=true
|
||||||
|
RUN if [ "$RUN_WHEEL_CHECK" = "true" ]; then \
|
||||||
|
python3 check-wheel-size.py dist; \
|
||||||
|
else \
|
||||||
|
echo "Skipping wheel size check."; \
|
||||||
|
fi
|
||||||
#################### EXTENSION Build IMAGE ####################
|
#################### EXTENSION Build IMAGE ####################
|
||||||
|
|
||||||
#################### DEV IMAGE ####################
|
#################### DEV IMAGE ####################
|
||||||
|
Loading…
x
Reference in New Issue
Block a user