mirror of
https://github.com/openai/codex.git
synced 2026-05-23 04:24:21 +00:00
## Why Release packaging should be a staging step once release binaries have already been built and signed. The Windows release job was downloading and signing `codex-command-runner.exe` and `codex-windows-sandbox-setup.exe`, but `scripts/build_codex_package.py` still rebuilt those helpers while creating the package archives. That makes the package step slower and, more importantly, risks putting helper binaries in the archive that were produced after the signing step. Linux had the same shape for package resources: `bwrap` could be rebuilt by the package builder instead of being passed in as a prebuilt release artifact. This builds on #23752, which fixes `.tar.zst` creation when Windows runners rely on the repository DotSlash `zstd` wrapper. ## What changed - Add explicit prebuilt resource inputs to the Codex package builder: - `--bwrap-bin` - `--codex-command-runner-bin` - `--codex-windows-sandbox-setup-bin` - Make `.github/scripts/build-codex-package-archive.sh` pass resource binaries from the release output directory when they are already present. - Build Linux `bwrap` for app-server release jobs too, so app-server package creation does not invoke Cargo just to supply the package resource. - Keep macOS package creation as a no-Cargo path when `--entrypoint-bin` is provided, since macOS packages have no resource binaries. - Add unit coverage showing prebuilt macOS, Linux, and Windows package inputs result in no source-built binaries. ## Verification - `python3 -m unittest discover -s scripts/codex_package -p 'test_*.py'` - `python3 -m py_compile scripts/codex_package/*.py` - `bash -n .github/scripts/build-codex-package-archive.sh` - Dry-ran Linux and Windows package builds with fake prebuilt resources and a nonexistent Cargo path to verify the package builder did not invoke Cargo. --- [//]: # (BEGIN SAPLING FOOTER) Stack created with [Sapling](https://sapling-scm.com). Best reviewed with [ReviewStack](https://reviewstack.dev/openai/codex/pull/23759). * #23760 * __->__ #23759
46 lines
1.5 KiB
Python
46 lines
1.5 KiB
Python
#!/usr/bin/env python3
|
|
|
|
from pathlib import Path
|
|
import sys
|
|
import tempfile
|
|
import unittest
|
|
|
|
sys.path.insert(0, str(Path(__file__).resolve().parents[1]))
|
|
|
|
from codex_package.archive import resolve_zstd_command
|
|
|
|
|
|
class ResolveZstdCommandTest(unittest.TestCase):
|
|
def test_prefers_zstd_from_path(self) -> None:
|
|
def which(name: str) -> str | None:
|
|
return {"zstd": "/usr/bin/zstd", "dotslash": "/usr/bin/dotslash"}.get(name)
|
|
|
|
self.assertEqual(resolve_zstd_command(which=which), ["/usr/bin/zstd"])
|
|
|
|
def test_falls_back_to_dotslash_manifest(self) -> None:
|
|
with tempfile.TemporaryDirectory() as temp_dir:
|
|
manifest = Path(temp_dir) / "zstd"
|
|
manifest.write_text("#!/usr/bin/env dotslash\n{}\n", encoding="utf-8")
|
|
|
|
def which(name: str) -> str | None:
|
|
return {"dotslash": "/usr/bin/dotslash"}.get(name)
|
|
|
|
self.assertEqual(
|
|
resolve_zstd_command(dotslash_manifest=manifest, which=which),
|
|
["/usr/bin/dotslash", str(manifest)],
|
|
)
|
|
|
|
def test_errors_when_no_zstd_or_dotslash_manifest_is_available(self) -> None:
|
|
with tempfile.TemporaryDirectory() as temp_dir:
|
|
missing_manifest = Path(temp_dir) / "zstd"
|
|
|
|
with self.assertRaisesRegex(RuntimeError, "zstd is required"):
|
|
resolve_zstd_command(
|
|
dotslash_manifest=missing_manifest,
|
|
which=lambda _name: None,
|
|
)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main()
|