diff --git a/CHANGELOG.md b/CHANGELOG.md index 84e5a6f9bb..0b0486fec4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,25 @@ Detailed changelog for Perry. See CLAUDE.md for concise summaries. +## v0.5.1114 — test(parity): specify expected exit code for three intentional-throw expected-output tests + +`run_parity_tests.sh` compares an expected-output test's process exit code +against `test-parity/expected-exit/.txt`, defaulting to `0` when that +file is absent. Three Perry-specific expected-output tests intentionally end by +throwing a `TypeError` (verifying spec behavior) — their committed +`test-parity/expected/.txt` snapshots already capture the thrown error — +but they had no `expected-exit` entry, so the harness expected exit `0` while +Perry (correctly, matching `node --experimental-strip-types`) exits `1`. That +made all three report a false parity failure even though Perry's output and +exit already match Node. + +Adds `test-parity/expected-exit/{test_issue_462_nullish_property_access, +test_issue_510_primitive_method_typeerror, +test_decorators_replacement_unsupported}.txt` each containing `1`. Verified each +now passes via `./run_parity_tests.sh --filter `. No runtime/compiler +change — Perry's behavior was already correct; this only corrects the harness's +expected exit code for these three throw-on-purpose cases. + ## v0.5.1113 — fix(inline): #945 restore scalar method inlining for PutValueSet constructors #4126 ("assignment PutValue descriptor semantics") changed `this.field = x` diff --git a/CLAUDE.md b/CLAUDE.md index 58783e503e..b9692d68c8 100644 --- a/CLAUDE.md +++ b/CLAUDE.md @@ -8,7 +8,7 @@ This file provides guidance to Claude Code (claude.ai/code) when working with co Perry is a native TypeScript compiler written in Rust that compiles TypeScript source code directly to native executables. It uses SWC for TypeScript parsing and LLVM for code generation. -**Current Version:** 0.5.1113 +**Current Version:** 0.5.1114 ## TypeScript Parity Status diff --git a/Cargo.lock b/Cargo.lock index 39cb93f51a..40943432c2 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5022,7 +5022,7 @@ checksum = "9b4f627cb1b25917193a259e49bdad08f671f8d9708acfd5fe0a8c1455d87220" [[package]] name = "perry" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "base64", @@ -5077,14 +5077,14 @@ dependencies = [ [[package]] name = "perry-api-manifest" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "serde", ] [[package]] name = "perry-audio-miniaudio" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "cc", "libc", @@ -5092,7 +5092,7 @@ dependencies = [ [[package]] name = "perry-codegen" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "log", @@ -5107,7 +5107,7 @@ dependencies = [ [[package]] name = "perry-codegen-arkts" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-hir", @@ -5116,7 +5116,7 @@ dependencies = [ [[package]] name = "perry-codegen-glance" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-hir", @@ -5124,7 +5124,7 @@ dependencies = [ [[package]] name = "perry-codegen-js" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-dispatch", @@ -5134,7 +5134,7 @@ dependencies = [ [[package]] name = "perry-codegen-swiftui" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-hir", @@ -5143,7 +5143,7 @@ dependencies = [ [[package]] name = "perry-codegen-wasm" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "base64", @@ -5156,7 +5156,7 @@ dependencies = [ [[package]] name = "perry-codegen-wear-tiles" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-hir", @@ -5164,7 +5164,7 @@ dependencies = [ [[package]] name = "perry-container-compose" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "async-trait", @@ -5193,7 +5193,7 @@ dependencies = [ [[package]] name = "perry-diagnostics" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "serde", "serde_json", @@ -5201,7 +5201,7 @@ dependencies = [ [[package]] name = "perry-dispatch" -version = "0.5.1113" +version = "0.5.1114" [[package]] name = "perry-doc-fixture-my-bindings" @@ -5212,7 +5212,7 @@ dependencies = [ [[package]] name = "perry-doc-tests" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "clap", @@ -5227,14 +5227,14 @@ dependencies = [ [[package]] name = "perry-ext-ads" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", ] [[package]] name = "perry-ext-argon2" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "argon2", "perry-ffi", @@ -5242,7 +5242,7 @@ dependencies = [ [[package]] name = "perry-ext-axios" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "reqwest", @@ -5251,7 +5251,7 @@ dependencies = [ [[package]] name = "perry-ext-bcrypt" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "bcrypt", "perry-ffi", @@ -5259,7 +5259,7 @@ dependencies = [ [[package]] name = "perry-ext-better-sqlite3" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "rusqlite", @@ -5267,7 +5267,7 @@ dependencies = [ [[package]] name = "perry-ext-cheerio" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "scraper", @@ -5275,7 +5275,7 @@ dependencies = [ [[package]] name = "perry-ext-commander" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "perry-runtime", @@ -5283,7 +5283,7 @@ dependencies = [ [[package]] name = "perry-ext-cron" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "chrono", "cron", @@ -5293,7 +5293,7 @@ dependencies = [ [[package]] name = "perry-ext-dayjs" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "chrono", "perry-ffi", @@ -5301,7 +5301,7 @@ dependencies = [ [[package]] name = "perry-ext-decimal" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "rust_decimal", @@ -5309,7 +5309,7 @@ dependencies = [ [[package]] name = "perry-ext-dotenv" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "serde_json", @@ -5317,7 +5317,7 @@ dependencies = [ [[package]] name = "perry-ext-ethers" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "rand 0.8.6", @@ -5325,7 +5325,7 @@ dependencies = [ [[package]] name = "perry-ext-events" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "perry-runtime", @@ -5333,14 +5333,14 @@ dependencies = [ [[package]] name = "perry-ext-exponential-backoff" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", ] [[package]] name = "perry-ext-fastify" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "bytes", "http-body-util", @@ -5357,7 +5357,7 @@ dependencies = [ [[package]] name = "perry-ext-fetch" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lazy_static", "perry-ffi", @@ -5369,7 +5369,7 @@ dependencies = [ [[package]] name = "perry-ext-http" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lazy_static", "perry-ext-http-server", @@ -5382,7 +5382,7 @@ dependencies = [ [[package]] name = "perry-ext-http-server" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "bytes", "h2", @@ -5403,7 +5403,7 @@ dependencies = [ [[package]] name = "perry-ext-ioredis" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lazy_static", "perry-ffi", @@ -5413,7 +5413,7 @@ dependencies = [ [[package]] name = "perry-ext-jsonwebtoken" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "jsonwebtoken", @@ -5424,7 +5424,7 @@ dependencies = [ [[package]] name = "perry-ext-lru-cache" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lru", "perry-ffi", @@ -5432,7 +5432,7 @@ dependencies = [ [[package]] name = "perry-ext-moment" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "chrono", "perry-ffi", @@ -5440,7 +5440,7 @@ dependencies = [ [[package]] name = "perry-ext-mongodb" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "bson", "futures-util", @@ -5452,7 +5452,7 @@ dependencies = [ [[package]] name = "perry-ext-mysql2" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "chrono", "perry-ffi", @@ -5462,7 +5462,7 @@ dependencies = [ [[package]] name = "perry-ext-nanoid" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "nanoid", "perry-ffi", @@ -5471,7 +5471,7 @@ dependencies = [ [[package]] name = "perry-ext-net" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "perry-runtime", @@ -5483,7 +5483,7 @@ dependencies = [ [[package]] name = "perry-ext-nodemailer" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lettre", "perry-ffi", @@ -5493,7 +5493,7 @@ dependencies = [ [[package]] name = "perry-ext-pdf" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "printpdf", @@ -5501,7 +5501,7 @@ dependencies = [ [[package]] name = "perry-ext-pg" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "sqlx", @@ -5510,7 +5510,7 @@ dependencies = [ [[package]] name = "perry-ext-ratelimit" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "governor", "perry-ffi", @@ -5518,7 +5518,7 @@ dependencies = [ [[package]] name = "perry-ext-sharp" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "image", @@ -5527,14 +5527,14 @@ dependencies = [ [[package]] name = "perry-ext-slugify" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", ] [[package]] name = "perry-ext-streams" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "lazy_static", "perry-ffi", @@ -5543,7 +5543,7 @@ dependencies = [ [[package]] name = "perry-ext-uuid" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "uuid", @@ -5551,7 +5551,7 @@ dependencies = [ [[package]] name = "perry-ext-validator" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ffi", "regex", @@ -5561,7 +5561,7 @@ dependencies = [ [[package]] name = "perry-ext-ws" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "futures-util", "lazy_static", @@ -5573,7 +5573,7 @@ dependencies = [ [[package]] name = "perry-ext-zlib" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "brotli", "flate2", @@ -5582,7 +5582,7 @@ dependencies = [ [[package]] name = "perry-ffi" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "dashmap 6.2.1", "once_cell", @@ -5591,7 +5591,7 @@ dependencies = [ [[package]] name = "perry-hir" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-api-manifest", @@ -5608,7 +5608,7 @@ dependencies = [ [[package]] name = "perry-parser" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-diagnostics", @@ -5620,7 +5620,7 @@ dependencies = [ [[package]] name = "perry-runtime" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "base64", @@ -5647,7 +5647,7 @@ dependencies = [ [[package]] name = "perry-stdlib" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "aes 0.8.4", "aes-gcm", @@ -5731,7 +5731,7 @@ dependencies = [ [[package]] name = "perry-transform" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "perry-hir", @@ -5741,7 +5741,7 @@ dependencies = [ [[package]] name = "perry-types" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "anyhow", "thiserror 1.0.69", @@ -5749,14 +5749,14 @@ dependencies = [ [[package]] name = "perry-ui" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "perry-ui-model", ] [[package]] name = "perry-ui-android" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "itoa", @@ -5773,7 +5773,7 @@ dependencies = [ [[package]] name = "perry-ui-geisterhand" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "rand 0.8.6", "serde", @@ -5783,7 +5783,7 @@ dependencies = [ [[package]] name = "perry-ui-gtk4" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "cairo-rs", @@ -5806,7 +5806,7 @@ dependencies = [ [[package]] name = "perry-ui-ios" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "block2", @@ -5822,7 +5822,7 @@ dependencies = [ [[package]] name = "perry-ui-macos" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "block2", @@ -5837,7 +5837,7 @@ dependencies = [ [[package]] name = "perry-ui-model" -version = "0.5.1113" +version = "0.5.1114" [[package]] name = "perry-ui-test" @@ -5845,11 +5845,11 @@ version = "0.1.0" [[package]] name = "perry-ui-testkit" -version = "0.5.1113" +version = "0.5.1114" [[package]] name = "perry-ui-tvos" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "block2", @@ -5865,7 +5865,7 @@ dependencies = [ [[package]] name = "perry-ui-visionos" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "block2", @@ -5881,7 +5881,7 @@ dependencies = [ [[package]] name = "perry-ui-watchos" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "block2", "libc", @@ -5894,7 +5894,7 @@ dependencies = [ [[package]] name = "perry-ui-windows" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "libc", @@ -5910,7 +5910,7 @@ dependencies = [ [[package]] name = "perry-updater" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "base64", "ed25519-dalek", @@ -5924,7 +5924,7 @@ dependencies = [ [[package]] name = "perry-wasm-host" -version = "0.5.1113" +version = "0.5.1114" dependencies = [ "wasmi", ] diff --git a/Cargo.toml b/Cargo.toml index 753da2f4c3..76dbb857a8 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -193,7 +193,7 @@ codegen-units = 16 opt-level = "s" # Optimize for size in stdlib [workspace.package] -version = "0.5.1113" +version = "0.5.1114" edition = "2021" license = "MIT" repository = "https://github.com/PerryTS/perry" diff --git a/test-parity/expected-exit/test_decorators_replacement_unsupported.txt b/test-parity/expected-exit/test_decorators_replacement_unsupported.txt new file mode 100644 index 0000000000..56a6051ca2 --- /dev/null +++ b/test-parity/expected-exit/test_decorators_replacement_unsupported.txt @@ -0,0 +1 @@ +1 \ No newline at end of file diff --git a/test-parity/expected-exit/test_issue_462_nullish_property_access.txt b/test-parity/expected-exit/test_issue_462_nullish_property_access.txt new file mode 100644 index 0000000000..56a6051ca2 --- /dev/null +++ b/test-parity/expected-exit/test_issue_462_nullish_property_access.txt @@ -0,0 +1 @@ +1 \ No newline at end of file diff --git a/test-parity/expected-exit/test_issue_510_primitive_method_typeerror.txt b/test-parity/expected-exit/test_issue_510_primitive_method_typeerror.txt new file mode 100644 index 0000000000..56a6051ca2 --- /dev/null +++ b/test-parity/expected-exit/test_issue_510_primitive_method_typeerror.txt @@ -0,0 +1 @@ +1 \ No newline at end of file