Skip to content

Commit

Permalink
Add convert to bool if string or number receive for boolean value
Browse files Browse the repository at this point in the history
  • Loading branch information
danielailie committed Aug 6, 2024
1 parent a86346c commit d445b1f
Show file tree
Hide file tree
Showing 4 changed files with 62 additions and 6 deletions.
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 1,6 @@
{
"name": "@multiversx/sdk-core",
"version": "13.2.2",
"version": "13.2.3",
"description": "MultiversX SDK for JavaScript and TypeScript",
"main": "out/index.js",
"types": "out/index.d.js",
Expand Down Expand Up @@ -58,4 58,4 @@
"bignumber.js": "^9.0.1",
"protobufjs": "^7.2.6"
}
}
}
57 changes: 56 additions & 1 deletion src/smartcontracts/nativeSerializer.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 169,7 @@ describe("test native serializer", () => {
assert.deepEqual(typedValues[1].valueOf(), [Buffer.from("a"), Buffer.from("b"), Buffer.from("c")]);
});

it("should should handle optionals in a strict manner (but it does not)", async () => {
it("should handle optionals in a strict manner (but it does not)", async () => {
const endpoint = AbiRegistry.create({
endpoints: [
{
Expand Down Expand Up @@ -610,4 610,59 @@ describe("test native serializer", () => {
variadic: false,
});
});

it.only("should accept a mixed of values for boolen type", async () => {
const endpoint = AbiRegistry.create({
endpoints: [
{
name: "foo",
inputs: [
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
{
type: "bool",
},
],
outputs: [],
},
],
}).getEndpoint("foo");

let typedValues = NativeSerializer.nativeToTypedValues(
[true, "true", "TRUE", 1, false, "false", "falseString", 0, 5],
endpoint,
);

assert.deepEqual(typedValues[0].valueOf(), true);
assert.deepEqual(typedValues[1].valueOf(), true);
assert.deepEqual(typedValues[2].valueOf(), true);
assert.deepEqual(typedValues[3].valueOf(), true);
assert.deepEqual(typedValues[4].valueOf(), false);
assert.deepEqual(typedValues[5].valueOf(), false);
assert.deepEqual(typedValues[6].valueOf(), false);
assert.deepEqual(typedValues[7].valueOf(), false);
assert.deepEqual(typedValues[8].valueOf(), false);
});
});
3 changes: 2 additions & 1 deletion src/smartcontracts/nativeSerializer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -296,7 296,8 @@ export namespace NativeSerializer {
return new AddressValue(convertNativeToAddress(native, errorContext));
}
if (type instanceof BooleanType) {
return new BooleanValue(native);
const boolValue = native.toString().toLowerCase() === "true" || native.toString() === "1";
return new BooleanValue(boolValue);
}
if (type instanceof TokenIdentifierType) {
return new TokenIdentifierValue(convertNativeToString(native, errorContext));
Expand Down

0 comments on commit d445b1f

Please sign in to comment.