From 7d60094c334d86885d40df798290c668d8640b64 Mon Sep 17 00:00:00 2001 From: Anton Trunov Date: Wed, 9 Oct 2024 13:52:30 +0400 Subject: [PATCH] fix(wrappers): non-null optional struct fields after null ones --- package.json | 2 +- src/test/e2e-emulated/contracts/structs.tact | 12 ++++++++++++ src/test/e2e-emulated/structs.spec.ts | 10 ++++++++++ yarn.lock | 8 ++++---- 4 files changed, 27 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index 7de2208f2..4b50fbd4d 100644 --- a/package.json +++ b/package.json @@ -46,7 +46,7 @@ }, "dependencies": { "@tact-lang/opcode": "^0.0.16", - "@ton/core": "0.58.1", + "@ton/core": "0.59.0", "@ton/crypto": "^3.2.0", "blockstore-core": "1.0.5", "change-case": "^4.1.2", diff --git a/src/test/e2e-emulated/contracts/structs.tact b/src/test/e2e-emulated/contracts/structs.tact index 9e979cd11..9eb01567a 100644 --- a/src/test/e2e-emulated/contracts/structs.tact +++ b/src/test/e2e-emulated/contracts/structs.tact @@ -240,6 +240,11 @@ struct Dict { m: map; } +struct OptionalFields { + nickname: String?; + avatar: String?; +} + contract StructsTester { s1: S = S {a: false, b: 21 + 21}; s2: S; @@ -921,4 +926,11 @@ contract StructsTester { get fun uintFieldsFromCell(src: Cell): UintFields { return UintFields.fromCell(src); } + + get fun optionalFields(): OptionalFields { + return OptionalFields { + nickname: null, + avatar: "non-null string", + } + } } diff --git a/src/test/e2e-emulated/structs.spec.ts b/src/test/e2e-emulated/structs.spec.ts index 9187eb0c9..614ad54b3 100644 --- a/src/test/e2e-emulated/structs.spec.ts +++ b/src/test/e2e-emulated/structs.spec.ts @@ -6,6 +6,7 @@ import { MyStruct1, MyStruct2, MyStruct3, + OptionalFields, StructsTester, UintFields, loadMyMessage1, @@ -402,5 +403,14 @@ describe("structs", () => { to: treasure.address, body: beginCell().storeDict(m).endCell(), }); + + const optionalFields: OptionalFields = { + $$type: "OptionalFields", + nickname: null, + avatar: "non-null string", + }; + expect( + await contract.getOptionalFields(), + ).toMatchObject(optionalFields); }); }); diff --git a/yarn.lock b/yarn.lock index 9d78c440c..f8f91e2c0 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1291,10 +1291,10 @@ resolved "https://registry.npmjs.org/@tact-lang/ton-jest/-/ton-jest-0.0.4.tgz" integrity sha512-FWjfiNvhMlE44ZLLL7tgmHbrszMTPMttmYiaTekf1vwFXV3uAOawM8xM9NldYaCVs9eh8840PjgISdMMUTCSCw== -"@ton/core@0.58.1": - version "0.58.1" - resolved "https://registry.npmjs.org/@ton/core/-/core-0.58.1.tgz#f6f2ecef6a7149bcd23825bfbb454f116d54363f" - integrity sha512-zydh42iT6E3U3Ky/DhTFqJMN/ycKKzbsHASY257Qr2sZn97G/MOcHFizPfMnbJJgx0H9iHX6mdyMvp1IKBVAFA== +"@ton/core@0.59.0": + version "0.59.0" + resolved "https://registry.npmjs.org/@ton/core/-/core-0.59.0.tgz#58da9fcaa58e5a0c705b63baf1e86cab6e196689" + integrity sha512-LSIkGst7BoY7fMWshejzcH0UJnoW21JGlRrW0ch+6A7Xb/7EuekxgdKym7fHxcry6OIf6FoeFg97lJ960N/Ghg== dependencies: symbol.inspect "1.0.1"