From 48ad39406e69688c768a386b3b88a5c7e2073d3f Mon Sep 17 00:00:00 2001 From: David Hernando Date: Wed, 18 Dec 2024 16:06:10 +0100 Subject: [PATCH 1/2] bugfix with SeigniorageAllocation parsing Signed-off-by: David Hernando --- Casper.Network.SDK/Types/SeigniorageAllocation.cs | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/Casper.Network.SDK/Types/SeigniorageAllocation.cs b/Casper.Network.SDK/Types/SeigniorageAllocation.cs index 0734890..91d5eb3 100644 --- a/Casper.Network.SDK/Types/SeigniorageAllocation.cs +++ b/Casper.Network.SDK/Types/SeigniorageAllocation.cs @@ -62,7 +62,11 @@ public override SeigniorageAllocation Read( var field = reader.GetString(); reader.Read(); if (field == "delegator_public_key") - delegatorKind = JsonSerializer.Deserialize(ref reader, options); + { + delegatorKind = reader.TokenType == JsonTokenType.String + ? new DelegatorKind() { PublicKey = PublicKey.FromHexString(reader.GetString()) } + : JsonSerializer.Deserialize(ref reader, options); + } else if (field == "validator_public_key") validatorPk = reader.GetString(); else if (field == "amount") From 3738240651c9de82f9d553f3a7d51db539dfe847 Mon Sep 17 00:00:00 2001 From: David Hernando Date: Wed, 18 Dec 2024 18:43:20 +0100 Subject: [PATCH 2/2] fix seigniorage allocation parsing. Added unit tests for v158 and v200. Signed-off-by: David Hernando --- Casper.Network.SDK.Test/StoredValueTest.cs | 44 +++++ .../TestData/seigniorage_allocation_v158.json | 71 ++++++++ .../TestData/seigniorage_allocation_v200.json | 156 ++++++++++++++++++ .../Types/SeigniorageAllocation.cs | 10 +- 4 files changed, 275 insertions(+), 6 deletions(-) create mode 100644 Casper.Network.SDK.Test/StoredValueTest.cs create mode 100644 Casper.Network.SDK.Test/TestData/seigniorage_allocation_v158.json create mode 100644 Casper.Network.SDK.Test/TestData/seigniorage_allocation_v200.json diff --git a/Casper.Network.SDK.Test/StoredValueTest.cs b/Casper.Network.SDK.Test/StoredValueTest.cs new file mode 100644 index 0000000..0954e44 --- /dev/null +++ b/Casper.Network.SDK.Test/StoredValueTest.cs @@ -0,0 +1,44 @@ +using System.IO; +using Casper.Network.SDK.Types; +using NUnit.Framework; +using JsonSerializer = System.Text.Json.JsonSerializer; + +namespace NetCasperTest +{ + public class StoredValueTest + { + [Test] + public void SeigniorageAllocationsTest_V200() + { + string json = File.ReadAllText(TestContext.CurrentContext.TestDirectory + + "/TestData/seigniorage_allocation_v200.json"); + + var storedValue = JsonSerializer.Deserialize(json); + Assert.IsNotNull(storedValue); + Assert.IsNotNull(storedValue.EraInfo); + Assert.AreEqual(20, storedValue.EraInfo.SeigniorageAllocations.Count); + Assert.IsTrue(storedValue.EraInfo.SeigniorageAllocations[0].IsDelegator); + Assert.AreEqual("018b46617b2b97e633b36530f2964b3f4c15916235910a2737e83d4fa2c7fad542", storedValue.EraInfo.SeigniorageAllocations[0].DelegatorKind.PublicKey.ToString().ToLower()); + Assert.AreEqual("01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", storedValue.EraInfo.SeigniorageAllocations[0].ValidatorPublicKey.ToString().ToLower()); + Assert.AreEqual("2515330120214391", storedValue.EraInfo.SeigniorageAllocations[0].Amount.ToString()); + Assert.IsFalse(storedValue.EraInfo.SeigniorageAllocations[1].IsDelegator); + } + + [Test] + public void SeigniorageAllocationsTest_V158() + { + string json = File.ReadAllText(TestContext.CurrentContext.TestDirectory + + "/TestData/seigniorage_allocation_v158.json"); + + var storedValue = JsonSerializer.Deserialize(json); + Assert.IsNotNull(storedValue); + Assert.IsNotNull(storedValue.EraInfo); + Assert.AreEqual(10, storedValue.EraInfo.SeigniorageAllocations.Count); + Assert.IsTrue(storedValue.EraInfo.SeigniorageAllocations[0].IsDelegator); + Assert.AreEqual("018b46617b2b97e633b36530f2964b3f4c15916235910a2737e83d4fa2c7fad542", storedValue.EraInfo.SeigniorageAllocations[0].DelegatorKind.PublicKey.ToString().ToLower()); + Assert.AreEqual("01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", storedValue.EraInfo.SeigniorageAllocations[0].ValidatorPublicKey.ToString().ToLower()); + Assert.AreEqual("4414692857142857", storedValue.EraInfo.SeigniorageAllocations[0].Amount.ToString()); + Assert.IsFalse(storedValue.EraInfo.SeigniorageAllocations[1].IsDelegator); + } + } +} \ No newline at end of file diff --git a/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v158.json b/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v158.json new file mode 100644 index 0000000..bb0b1af --- /dev/null +++ b/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v158.json @@ -0,0 +1,71 @@ +{ + "EraInfo": { + "seigniorage_allocations": [ + { + "Delegator": { + "delegator_public_key": "018b46617b2b97e633b36530f2964b3f4c15916235910a2737e83d4fa2c7fad542", + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "4414692857142857" + } + }, + { + "Validator": { + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "4585307142857143" + } + }, + { + "Delegator": { + "delegator_public_key": "0197b79d1a1351f8fb922b9f7f556d2bbfdba5105df9eaa6caa07804c703a641ed", + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "4414692857142857" + } + }, + { + "Validator": { + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "4585307142857143" + } + }, + { + "Delegator": { + "delegator_public_key": "01a5a5b7328118681638be3e06c8749609280dba4c9daf9aeb3d3464b8839b018a", + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "4414692857142857" + } + }, + { + "Validator": { + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "4585307142857143" + } + }, + { + "Delegator": { + "delegator_public_key": "0106ed45915392c02b37136618372ac8dde8e0e3b8ee6190b2ca6db539b354ede4", + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "4414692857142857" + } + }, + { + "Validator": { + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "4585307142857143" + } + }, + { + "Delegator": { + "delegator_public_key": "0184f6d260f4ee6869ddb36affe15456de6ae045278fa2f467bb677561ce0dad55", + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "4414692857142857" + } + }, + { + "Validator": { + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "4585307142857143" + } + } + ] + } +} \ No newline at end of file diff --git a/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v200.json b/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v200.json new file mode 100644 index 0000000..6b27c35 --- /dev/null +++ b/Casper.Network.SDK.Test/TestData/seigniorage_allocation_v200.json @@ -0,0 +1,156 @@ +{ + "EraInfo": { + "seigniorage_allocations": [ + { + "Delegator": { + "delegator_kind": { + "PublicKey": "018b46617b2b97e633b36530f2964b3f4c15916235910a2737e83d4fa2c7fad542" + }, + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "2515330120214391" + } + }, + { + "Validator": { + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "2728720430156545" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "018b46617b2b97e633b36530f2964b3f4c15916235910a2737e83d4fa2c7fad542" + }, + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "109303520813010" + } + }, + { + "Validator": { + "validator_public_key": "01509254f22690fbe7fb6134be574c4fbdb060dfa699964653b99753485e518ea6", + "amount": "118554941151112" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0197b79d1a1351f8fb922b9f7f556d2bbfdba5105df9eaa6caa07804c703a641ed" + }, + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "8599696498056110" + } + }, + { + "Validator": { + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "9377950843219784" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0197b79d1a1351f8fb922b9f7f556d2bbfdba5105df9eaa6caa07804c703a641ed" + }, + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "285067736921916" + } + }, + { + "Validator": { + "validator_public_key": "0190664e16a17594ed2d0e3c279c4cf5894e8db0da15e3b91c938562a1caae32ab", + "amount": "310701366981535" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "01a5a5b7328118681638be3e06c8749609280dba4c9daf9aeb3d3464b8839b018a" + }, + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "5976757455713484" + } + }, + { + "Validator": { + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "6492754998004464" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "01a5a5b7328118681638be3e06c8749609280dba4c9daf9aeb3d3464b8839b018a" + }, + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "162277940193805" + } + }, + { + "Validator": { + "validator_public_key": "01c867ff3cf1d4e4e68fc00922fdcb740304def196e223091dee62012f444b9eba", + "amount": "176125500882714" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0106ed45915392c02b37136618372ac8dde8e0e3b8ee6190b2ca6db539b354ede4" + }, + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "6111063397723576" + } + }, + { + "Validator": { + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "6660504858490961" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0106ed45915392c02b37136618372ac8dde8e0e3b8ee6190b2ca6db539b354ede4" + }, + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "183204228041446" + } + }, + { + "Validator": { + "validator_public_key": "01f58b94526d280881f79744effebc555426190950d5dfdd2f8aaf10ceaec010c6", + "amount": "199637730476608" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0184f6d260f4ee6869ddb36affe15456de6ae045278fa2f467bb677561ce0dad55" + }, + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "2170319328593039" + } + }, + { + "Validator": { + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "2366902069827651" + } + }, + { + "Delegator": { + "delegator_kind": { + "PublicKey": "0184f6d260f4ee6869ddb36affe15456de6ae045278fa2f467bb677561ce0dad55" + }, + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "217749920954248" + } + }, + { + "Validator": { + "validator_public_key": "01fed662dc7f1f7af43ad785ba07a8cc05b7a96f9ee69613cfde43bc56bec1140b", + "amount": "237377113583604" + } + } + ] + } +} \ No newline at end of file diff --git a/Casper.Network.SDK/Types/SeigniorageAllocation.cs b/Casper.Network.SDK/Types/SeigniorageAllocation.cs index 91d5eb3..77fbcdb 100644 --- a/Casper.Network.SDK/Types/SeigniorageAllocation.cs +++ b/Casper.Network.SDK/Types/SeigniorageAllocation.cs @@ -61,12 +61,10 @@ public override SeigniorageAllocation Read( { var field = reader.GetString(); reader.Read(); - if (field == "delegator_public_key") - { - delegatorKind = reader.TokenType == JsonTokenType.String - ? new DelegatorKind() { PublicKey = PublicKey.FromHexString(reader.GetString()) } - : JsonSerializer.Deserialize(ref reader, options); - } + if (field == "delegator_kind") + delegatorKind = JsonSerializer.Deserialize(ref reader, options); + else if (field == "delegator_public_key") + delegatorKind = new DelegatorKind() { PublicKey = PublicKey.FromHexString(reader.GetString()) }; else if (field == "validator_public_key") validatorPk = reader.GetString(); else if (field == "amount")