From f7b285284618e252994ec93c6feb9d9cec85435d Mon Sep 17 00:00:00 2001 From: John Sirois Date: Fri, 3 Mar 2023 22:14:19 -0800 Subject: [PATCH] Guard against racing sdist builds. Narrow the search for a result build artifact to "*.whl" files to avoid any racing work directories that may be present when collecting the wheel build artifact. Fixes #2078 --- pex/resolver.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pex/resolver.py b/pex/resolver.py index 403abecf3..608376301 100644 --- a/pex/resolver.py +++ b/pex/resolver.py @@ -5,6 +5,7 @@ from __future__ import absolute_import import functools +import glob import hashlib import itertools import os @@ -311,7 +312,7 @@ def dist_dir(self): def finalize_build(self): # type: () -> InstallRequest self._atomic_dir.finalize() - wheels = os.listdir(self.dist_dir) + wheels = glob.glob(os.path.join(self.dist_dir, "*.whl")) if len(wheels) != 1: raise AssertionError( "Build of {request} produced {count} artifacts; expected 1:\n{actual}".format( @@ -323,8 +324,7 @@ def finalize_build(self): ), ) ) - wheel = wheels[0] - wheel_path = os.path.join(self.dist_dir, wheel) + wheel_path = wheels[0] if self.request.target.is_foreign: wheel_tags = CompatibilityTags.from_wheel(wheel_path) if not self.request.target.supported_tags.compatible_tags(wheel_tags): @@ -339,7 +339,7 @@ def finalize_build(self): project_name=project_name_and_version.project_name, version=project_name_and_version.version, eol=os.linesep, - wheel=wheel, + wheel=os.path.basename(wheel_path), sdist=os.path.basename(self.request.source_path), target=self.request.target.render_description(), )