Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Regarding the release PR for aelf project version 1.10.0 #3596

Merged
merged 102 commits into from
Aug 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
102 commits
Select commit Hold shift + click to select a range
c68715c
Add a few things to optimize the performance, like another approach t…
eanzhao Mar 14, 2024
d13ff11
Fix test infra.
eanzhao Mar 14, 2024
a78ed5e
Remove some logs for better debug
eanzhao Mar 19, 2024
97ba152
Optimized methods of code check
eanzhao Mar 21, 2024
11bef42
Cache Chain object on ChainManager
eanzhao Mar 25, 2024
227ce39
Commit test case of feature disable service.
eanzhao Mar 26, 2024
2c6df2a
Update abp and .net version
eanzhao Apr 2, 2024
79c0c40
For stress testing.
eanzhao Apr 7, 2024
4240528
Merge .net 8 upgrade
eanzhao Apr 7, 2024
b8ba38b
Utilize Configuration Contract to store mining time and disabled feat…
eanzhao Apr 9, 2024
66becb9
Commit test case for feature disable service.
eanzhao Apr 10, 2024
11ed7c4
Improve configuration & fix test cases
eanzhao Apr 16, 2024
9e1b77a
fix .net version of feature disable test project.
eanzhao May 23, 2024
7f454eb
Merge feature/performance-tuning
eanzhao May 23, 2024
2939c92
fix .net version
eanzhao May 23, 2024
e64d004
Increase ExecutiveClearLimit from 10 to 50
David20240718 May 28, 2024
8993c67
Fix framework version.
eanzhao May 28, 2024
62d7e10
Re-impl CryptoHelper's EncryptMessage & DecryptMessage method via Bou…
eanzhao Jun 17, 2024
9babdd0
Won't perform secret sharing if it is not enabled
eanzhao Jun 18, 2024
d8833b2
Parallelize the generation of system transactions while reducing coll…
chopin-fan Jun 24, 2024
e337b4e
Add title and description filed to proposals.
eanzhao Jun 24, 2024
b37568d
Add limit to the length of title and description of proposals.
eanzhao Jun 25, 2024
0f43a56
txList(1000) -> txList(500)
chopin-fan Jun 25, 2024
54bf23d
The default value of 'limit' is set to 500.
chopin-fan Jun 25, 2024
b4c3452
Adjust mining time.
chopin-fan Jun 25, 2024
becd6c4
Adjust mining time to 90/100
chopin-fan Jun 25, 2024
decdc9b
Adjust limit to 300.
chopin-fan Jun 25, 2024
34e93e6
Adjust limit to 250
chopin-fan Jun 25, 2024
e02cb23
Reset strategyBase.
chopin-fan Jun 26, 2024
fdf61bf
Enable plugin modules, and commit web api plugin for full nodes.
eanzhao Jun 28, 2024
1cee8b9
Validate the length of ProposalDescriptionUrl field of proposals.
eanzhao Jun 28, 2024
3dbd5df
Fix judgements and add tests
eanzhao Jul 1, 2024
da843dd
Now the dpos consensus can be replaced by poa consensus via plugin me…
eanzhao Jul 3, 2024
e2d727b
Merge branch 'dev' into feature/proposal-title
eanzhao Jul 3, 2024
6ec88ef
Add plugin sources if only directory exists.
eanzhao Jul 4, 2024
6b2778a
Merge branch 'feature/plugins' of aelf:AElfProject/AElf into feature/…
eanzhao Jul 4, 2024
ed08d7a
Remove unnecessary files.
eanzhao Jul 4, 2024
c219521
Revert a few changes.
eanzhao Jul 4, 2024
cdd6db7
Merge branch 'dev' of aelf:AElfProject/AElf into feature/plugin-modules
eanzhao Jul 4, 2024
8dfa973
Merge pull request #3566 from AElfProject/feature/proposal-title
eanzhao Jul 4, 2024
29d5da2
Rollback the assembly of txList
chopin-fan Jul 8, 2024
13fb906
Change the version of protobuf to 3.27.2
chopin-fan Jul 8, 2024
1eef0a5
Adjust the style of parallelization.
chopin-fan Jul 12, 2024
78b33ad
Rollback the adjusted code.
chopin-fan Jul 17, 2024
3c1554f
Add groth16 and poseidon to whitelist.
chopin-fan Jul 18, 2024
33b0f23
Retrigger sonarqube
chopin-fan Jul 18, 2024
de76658
Merge branch 'dev' into feature/ecies
chopin-fan Jul 18, 2024
45027f0
Retrigger sonarqube
chopin-fan Jul 18, 2024
bcc764d
Retrigger sonarqube
chopin-fan Jul 18, 2024
2fb5acd
Fix method IsSecretSharingEnabled
eanzhao Jul 18, 2024
cf5aa3d
Merge branch 'dev' into feature/plugin-modules
chopin-fan Jul 18, 2024
6be7f5e
Merge pull request #3564 from AElfProject/feature/ecies
chopin-fan Jul 18, 2024
f681d58
Merge branch 'dev' into feature/plugin-modules
chopin-fan Jul 18, 2024
5069438
Merge branch 'dev' into feature/plugin-modules
JimAelf Jul 18, 2024
542043d
Merge pull request #3588 from AElfProject/feature/plugin-modules
chopin-fan Jul 18, 2024
f6a60e5
1.Add a nuget.config file
chopin-fan Jul 18, 2024
db228e8
Merge dev branch, then resolve conflicts.
chopin-fan Jul 18, 2024
1997174
Change the version of sdk to 8.0.303
chopin-fan Jul 18, 2024
2b086d1
Change version to 8.0.303 in global.json
chopin-fan Jul 18, 2024
cc7ffaa
1.Change dotnet-version to 8.0 in benchmark_action.yml
chopin-fan Jul 19, 2024
58a7833
Change version to 8.0.x in templates folder
chopin-fan Jul 19, 2024
395c89c
Change version of protobuf to 3.27.2 in build-template-window.yml
chopin-fan Jul 19, 2024
3a9a1fd
Change sdk version to 8.0.303
chopin-fan Jul 19, 2024
f77bc2f
Change version of groth16 and poseidon
chopin-fan Jul 19, 2024
77ad704
Merge remote-tracking branch 'origin/feature/performance-tuning-net8'…
chopin-fan Jul 19, 2024
509d841
Revert protoc version
chopin-fan Jul 19, 2024
15a1d3d
1.Change DOTNET_VERSION to 8.0.33
chopin-fan Jul 19, 2024
dc2f69a
Change DOTNET_VERSION to 8.0.7
chopin-fan Jul 19, 2024
1e4885d
Revert version
chopin-fan Jul 19, 2024
4942406
Change DOTNET_VERSION to 8.0.300
chopin-fan Jul 19, 2024
e32be7a
Change CAKE_VERSION to 0.37.0
chopin-fan Jul 19, 2024
c9ec1a6
Change DOTNET_VERSION to 8.0.303
chopin-fan Jul 19, 2024
ed469ba
Change sdk version to 8.0.303 in sonarqube.yaml
chopin-fan Jul 19, 2024
df42e3e
Change version of Protobuf to 3.19.4
chopin-fan Jul 19, 2024
c4170cf
Change version to 8.0.x in global.json
chopin-fan Jul 19, 2024
cd63c06
Adjust unit-test of CleanIdleExecutive_Test
chopin-fan Jul 19, 2024
48dab8a
Change version to 8.0.303 in global.json
chopin-fan Jul 19, 2024
778a952
Change version of Basic.Reference.Assemblies.Net80 to 1.5.0
chopin-fan Jul 19, 2024
6d0347b
Restore deleted lines of code.
chopin-fan Jul 19, 2024
6e906c2
Add logs to find errors
chopin-fan Jul 20, 2024
bab222c
Resolve issues with thread safety caused by parallel execution
chopin-fan Jul 20, 2024
fe82d78
Change protoc version to 3.19.4 in install_protobuf.sh
chopin-fan Jul 20, 2024
bd5099a
Add ServerServiceDefinition.BindService to whitelist
chopin-fan Jul 20, 2024
9674f81
Add whiteList
chopin-fan Jul 20, 2024
3480370
Resolve the execution timeout issue caused by using AsParallel
chopin-fan Jul 20, 2024
69835d9
Remove Parallel
chopin-fan Jul 20, 2024
dc5ea6e
Adjust wrong unit test
chopin-fan Jul 20, 2024
a6628c8
Change protoc version to 3.27.2
chopin-fan Jul 20, 2024
96ad4b1
Merge pull request #3590 from AElfProject/feature/performance-tuning-…
chopin-fan Jul 22, 2024
252338a
Cancal parallelization
chopin-fan Jul 22, 2024
698562e
Restore the GetDeterministicByteArrays method to facilitate problem d…
chopin-fan Jul 23, 2024
db20028
Use parallel
chopin-fan Jul 23, 2024
9cd1135
Add Executed block log
chopin-fan Jul 24, 2024
06d195e
Add log
chopin-fan Jul 24, 2024
02f899b
Add log
chopin-fan Jul 24, 2024
f0a06f3
Cancel parallel
chopin-fan Jul 24, 2024
aa20376
Add log
chopin-fan Jul 24, 2024
ccfa4b6
Delete log
chopin-fan Jul 24, 2024
498a64f
Cancel the whitelisting feature for groth16 and poseidon.
chopin-fan Jul 31, 2024
b750205
Merge branch 'master' into release/1.10.0
chopin-fan Jul 31, 2024
c337eda
Modify the version of groth16 and poseidon
chopin-fan Aug 1, 2024
a6ecf37
Merge remote-tracking branch 'origin/release/1.10.0' into release/1.10.0
chopin-fan Aug 1, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/benchmark_action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ jobs:
- name: Setup dotnet
uses: actions/setup-dotnet@v4
with:
dotnet-version: '6.0'
dotnet-version: '8.0'

- name: 'Download AElf build tools'
run: bash scripts/download_binary.sh
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/sonarqube.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,9 @@ jobs:
fetch-depth: 0
- uses: actions/setup-dotnet@v4
with:
dotnet-version: '7.0'
dotnet-version: '8.0'
- name: Create temporary global.json
run: echo '{"sdk":{"version":"7.0.410"}}' > ./global.json
run: echo '{"sdk":{"version":"8.0.303"}}' > ./global.json
- name: Set up JDK 17
uses: actions/setup-java@v1
with:
Expand Down
21 changes: 21 additions & 0 deletions AElf.All.sln
Original file line number Diff line number Diff line change
Expand Up @@ -379,6 +379,12 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AElf.Contracts.TestContract
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AElf.Contracts.VirtualTransactionEventContract.Tests", "test\AElf.Contracts.VirtualTransactionEventContract.Tests\AElf.Contracts.VirtualTransactionEventContract.Tests.csproj", "{6981684D-450C-412B-9082-0B0A67A679B9}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AElf.Kernel.FeatureDisable", "src\AElf.Kernel.FeatureDisable\AElf.Kernel.FeatureDisable.csproj", "{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AElf.Kernel.FeatureDisable.Tests", "test\AElf.Kernel.FeatureDisable.Tests\AElf.Kernel.FeatureDisable.Tests.csproj", "{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AElf.Kernel.FeatureDisable.Core", "src\AElf.Kernel.FeatureDisable.Core\AElf.Kernel.FeatureDisable.Core.csproj", "{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Expand Down Expand Up @@ -1089,6 +1095,18 @@ Global
{6981684D-450C-412B-9082-0B0A67A679B9}.Debug|Any CPU.Build.0 = Debug|Any CPU
{6981684D-450C-412B-9082-0B0A67A679B9}.Release|Any CPU.ActiveCfg = Release|Any CPU
{6981684D-450C-412B-9082-0B0A67A679B9}.Release|Any CPU.Build.0 = Release|Any CPU
{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E}.Debug|Any CPU.Build.0 = Debug|Any CPU
{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E}.Release|Any CPU.ActiveCfg = Release|Any CPU
{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E}.Release|Any CPU.Build.0 = Release|Any CPU
{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67}.Debug|Any CPU.Build.0 = Debug|Any CPU
{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67}.Release|Any CPU.ActiveCfg = Release|Any CPU
{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67}.Release|Any CPU.Build.0 = Release|Any CPU
{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4}.Debug|Any CPU.Build.0 = Debug|Any CPU
{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4}.Release|Any CPU.ActiveCfg = Release|Any CPU
{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
Expand Down Expand Up @@ -1280,5 +1298,8 @@ Global
{64498F8C-B827-4E1C-B5FB-4B9188C839A8} = {D3950CC9-808F-4ED8-946A-79A992F3F8EF}
{0F10B838-C363-4F55-A5BB-B7F9F80565AB} = {D3950CC9-808F-4ED8-946A-79A992F3F8EF}
{6981684D-450C-412B-9082-0B0A67A679B9} = {D3950CC9-808F-4ED8-946A-79A992F3F8EF}
{A4ACE6D2-4CF8-4B52-93C9-BB8BEC0C098E} = {90B310B4-C2DB-419E-B5EE-97FA096B62CC}
{8C0D86A4-D1A7-4B61-AC44-755F5AC75D67} = {4E54480A-D155-43ED-9736-1A5BE7957211}
{659A7C7A-44C9-424E-B4F6-D1D3656F7AD4} = {90B310B4-C2DB-419E-B5EE-97FA096B62CC}
EndGlobalSection
EndGlobal
2 changes: 1 addition & 1 deletion bench/AElf.BenchBase/AElf.BenchBase.csproj
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<IsPackable>false</IsPackable>
</PropertyGroup>

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<IsPackable>false</IsPackable>
<SkipAudit>true</SkipAudit>
</PropertyGroup>
Expand Down
2 changes: 1 addition & 1 deletion bench/AElf.Benchmark/AElf.Benchmark.csproj
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<IsPackable>false</IsPackable>
<!-- <NoWarn>0436</NoWarn>-->
<OutputType>Exe</OutputType>
Expand Down
2 changes: 1 addition & 1 deletion bench/AElf.Database.Benches/AElf.Database.Benches.csproj
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<IsPackable>false</IsPackable>
<NoWarn>xUnit1013</NoWarn>
</PropertyGroup>
Expand Down
2 changes: 1 addition & 1 deletion build.config
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
#!/usr/bin/env bash
CAKE_VERSION=0.37.0
DOTNET_VERSION=6.0.300
DOTNET_VERSION=8.0.303
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Import Project="..\..\common.props"/>

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Association</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Association is a contract that enables the creation of organizations and approvals.
Expand Down
4 changes: 3 additions & 1 deletion contract/AElf.Contracts.Association/Association.cs
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,9 @@ public override ProposalOutput GetProposal(Hash proposalId)
ToBeReleased = readyToRelease,
ApprovalCount = proposal.Approvals.Count,
RejectionCount = proposal.Rejections.Count,
AbstentionCount = proposal.Abstentions.Count
AbstentionCount = proposal.Abstentions.Count,
Title = proposal.Title,
Description = proposal.Description
};
}

Expand Down
8 changes: 8 additions & 0 deletions contract/AElf.Contracts.Association/AssociationConstants.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
namespace AElf.Contracts.Association;

public static class AssociationConstants
{
public const int MaxLengthForTitle = 255;
public const int MaxLengthForDescription = 10200;
public const int MaxLengthForProposalDescriptionUrl = 255;
}
20 changes: 18 additions & 2 deletions contract/AElf.Contracts.Association/Association_Helper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@ private Hash GenerateProposalId(CreateProposalInput input)

private Hash CreateNewProposal(CreateProposalInput input)
{
CheckCreateProposalInput(input);
var proposalId = GenerateProposalId(input);
var proposal = new ProposalInfo
{
Expand All @@ -154,16 +155,31 @@ private Hash CreateNewProposal(CreateProposalInput input)
OrganizationAddress = input.OrganizationAddress,
ProposalId = proposalId,
Proposer = Context.Sender,
ProposalDescriptionUrl = input.ProposalDescriptionUrl
ProposalDescriptionUrl = input.ProposalDescriptionUrl,
Title = input.Title,
Description = input.Description
};
Assert(Validate(proposal), "Invalid proposal.");
Assert(State.Proposals[proposalId] == null, "Proposal already exists.");
State.Proposals[proposalId] = proposal;
Context.Fire(new ProposalCreated
{
ProposalId = proposalId,
OrganizationAddress = input.OrganizationAddress
OrganizationAddress = input.OrganizationAddress,
Title = input.Title,
Description = input.Description
});
return proposalId;
}

private void CheckCreateProposalInput(CreateProposalInput input)
{
// Check the length of title
Assert(input.Title.Length <= AssociationConstants.MaxLengthForTitle, "Title is too long.");
// Check the length of description
Assert(input.Description.Length <= AssociationConstants.MaxLengthForDescription, "Description is too long.");
// Check the length of description url
Assert(input.ProposalDescriptionUrl.Length <= AssociationConstants.MaxLengthForProposalDescriptionUrl,
"Description url is too long.");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Import Project="..\..\common.props"/>

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Configuration</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Configuration is a contract used for changing configurable aspects of the chain, like for example
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,5 @@ public static class AEDPoSContractConstants
public const string SideChainShareProfitsTokenSymbol = "SHARE";
public const string PayTxFeeSymbolListName = "SymbolListToPayTxFee";
public const string PayRentalSymbolListName = "SymbolListToPayRental";
public const string SecretSharingEnabledConfigurationKey = "SecretSharingEnabled";
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ public override Empty UpdateInformationFromCrossChain(BytesValue input)
var minersKeys = consensusInformation.Round.RealTimeMinersInformation.Keys;
State.MainChainCurrentMinerList.Value = new MinerList
{
Pubkeys = { minersKeys.Select(ByteStringHelper.FromHexString) }
Pubkeys = { minersKeys.Select(k => ByteStringHelper.FromHexString(k)) }
};

return new Empty();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,11 @@
updatedRound.RealTimeMinersInformation[pubkey].ImpliedIrreversibleBlockHeight = Context.CurrentHeight;

// Update secret pieces of latest in value.
UpdateLatestSecretPieces(updatedRound, pubkey, triggerInformation);

if (IsSecretSharingEnabled())
{
UpdateLatestSecretPieces(updatedRound, pubkey, triggerInformation);
}

Check warning on line 125 in contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_GetConsensusBlockExtraData.cs

View check run for this annotation

Codecov / codecov/patch

contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_GetConsensusBlockExtraData.cs#L123-L125

Added lines #L123 - L125 were not covered by tests

// To publish Out Value.
return new AElfConsensusHeaderInformation
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@

// Update miners list.
var miners = new MinerList();
miners.Pubkeys.AddRange(nextRound.RealTimeMinersInformation.Keys.Select(ByteStringHelper.FromHexString));
miners.Pubkeys.AddRange(nextRound.RealTimeMinersInformation.Keys.Select(k => ByteStringHelper.FromHexString(k)));
if (!SetMinerList(miners, nextRound.TermNumber)) Assert(false, "Failed to update miner list.");

// Update term number lookup. (Using term number to get first round number of related term.)
Expand Down Expand Up @@ -249,7 +249,10 @@
minerInRound.ProducedBlocks = minerInRound.ProducedBlocks.Add(1);
minerInRound.ProducedTinyBlocks = minerInRound.ProducedTinyBlocks.Add(1);

PerformSecretSharing(updateValueInput, minerInRound, currentRound, _processingBlockMinerPubkey);
if (IsSecretSharingEnabled())
{
PerformSecretSharing(updateValueInput, minerInRound, currentRound, _processingBlockMinerPubkey);
}

Check warning on line 255 in contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_ProcessConsensusInformation.cs

View check run for this annotation

Codecov / codecov/patch

contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_ProcessConsensusInformation.cs#L253-L255

Added lines #L253 - L255 were not covered by tests

foreach (var tuneOrder in updateValueInput.TuneOrderInformation)
currentRound.RealTimeMinersInformation[tuneOrder.Key].FinalOrderOfNextRound = tuneOrder.Value;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
using System.Linq;
using AElf.Cryptography.SecretSharing;
using AElf.CSharp.Core;
using AElf.Sdk.CSharp;
using Google.Protobuf;
using Google.Protobuf.WellKnownTypes;

namespace AElf.Contracts.Consensus.AEDPoS;

Expand Down Expand Up @@ -49,4 +52,28 @@ private void RevealSharedInValues(Round currentRound, string publicKey)
currentRound.RealTimeMinersInformation[publicKeyOfAnotherMiner].PreviousInValue = revealedInValue;
}
}

private bool IsSecretSharingEnabled()
{
if (State.ConfigurationContract.Value == null)
{
var configurationContractAddress =
Context.GetContractAddressByName(SmartContractConstants.ConfigurationContractSystemName);
if (configurationContractAddress == null)
{
// Which means Configuration Contract hasn't been deployed yet.
return false;
}

State.ConfigurationContract.Value = configurationContractAddress;
}

var secretSharingEnabled = new BoolValue();
secretSharingEnabled.MergeFrom(State.ConfigurationContract.GetConfiguration.Call(new StringValue
{
Value = AEDPoSContractConstants.SecretSharingEnabledConfigurationKey
}).Value);

return secretSharingEnabled.Value;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
{
Pubkeys =
{
round.RealTimeMinersInformation.Keys.Select(ByteStringHelper.FromHexString)
round.RealTimeMinersInformation.Keys.Select(k => ByteStringHelper.FromHexString(k))
}
}
: new MinerList();
Expand Down Expand Up @@ -236,7 +236,7 @@
// Miners of new round are same with current round.
var miners = new MinerList();
miners.Pubkeys.AddRange(
currentRound.RealTimeMinersInformation.Keys.Select(ByteStringHelper.FromHexString));
currentRound.RealTimeMinersInformation.Keys.Select(k => ByteStringHelper.FromHexString(k)));

Check warning on line 239 in contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_ViewMethods.cs

View check run for this annotation

Codecov / codecov/patch

contract/AElf.Contracts.Consensus.AEDPoS/AEDPoSContract_ViewMethods.cs#L239

Added line #L239 was not covered by tests
newRound = miners.GenerateFirstRoundOfNewTerm(currentRound.GetMiningInterval(),
Context.CurrentBlockTime, currentRound);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Import Project="..\..\common.props" />

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Consensus.AEDPoS</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Consensus is a contract that implements AElf’s DPoS consensus protocol.</Description>
Expand Down Expand Up @@ -47,6 +47,9 @@
<ContractReference Include="..\..\protobuf\profit_contract.proto">
<Link>Protobuf\Proto\reference\profit_contract.proto</Link>
</ContractReference>
<ContractReference Include="..\..\protobuf\configuration_contract.proto">
<Link>Protobuf\Proto\reference\configuration_contract.proto</Link>
</ContractReference>
</ItemGroup>

<ItemGroup>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using AElf.Contracts.Configuration;
using AElf.Contracts.Election;
using AElf.Contracts.MultiToken;
using AElf.Contracts.Parliament;
Expand All @@ -15,4 +16,5 @@ public partial class AEDPoSContractState
internal TokenContractContainer.TokenContractReferenceState TokenContract { get; set; }
internal TokenHolderContractContainer.TokenHolderContractReferenceState TokenHolderContract { get; set; }
internal ParliamentContractContainer.ParliamentContractReferenceState ParliamentContract { get; set; }
internal ConfigurationContainer.ConfigurationReferenceState ConfigurationContract { get; set; }
}
2 changes: 1 addition & 1 deletion contract/AElf.Contracts.Consensus.AEDPoS/Types/Round.cs
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,7 @@ public MinerList GetMinerList()
{
return new MinerList
{
Pubkeys = { RealTimeMinersInformation.Keys.Select(ByteStringHelper.FromHexString) }
Pubkeys = { RealTimeMinersInformation.Keys.Select(k => ByteStringHelper.FromHexString(k)) }
};
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">
<Import Project="..\..\common.props"/>
<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.CrossChain</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>CrossChain is a contract that implements cross-chain related features, especially
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Import Project="..\..\common.props"/>

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Economic</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Economic is a contract that implements the basic functionality used to manage the economic
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Import Project="..\..\common.props"/>

<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Election</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Election is a contract that implements voting.</Description>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@ public override Empty InitialElectionContract(InitialElectionContractInput input
State.MinersCount.Value = input.MinerList.Count;
State.InitialMiners.Value = new PubkeyList
{
Value = { input.MinerList.Select(ByteStringHelper.FromHexString) }
// ReSharper disable once ConvertClosureToMethodGroup
Value = { input.MinerList.Select(m => ByteStringHelper.FromHexString(m)) }
};
foreach (var pubkey in input.MinerList)
State.CandidateInformationMap[pubkey] = new CandidateInformation
Expand Down
5 changes: 3 additions & 2 deletions contract/AElf.Contracts.Election/ViewMethods.cs
Original file line number Diff line number Diff line change
Expand Up @@ -62,15 +62,16 @@ private List<ByteString> GetVictories(List<string> currentMiners)
if (diff > 0)
{
victories =
new List<ByteString>(validCandidates.Select(ByteStringHelper.FromHexString));
new List<ByteString>(validCandidates.Select(v => ByteStringHelper.FromHexString(v)));
var backups = currentMiners.Where(k => !validCandidates.Contains(k)).ToList();
if (State.InitialMiners.Value != null)
backups.AddRange(
State.InitialMiners.Value.Value.Select(k => k.ToHex()).Where(k => !backups.Contains(k)));

victories.AddRange(backups.OrderBy(p => p)
.Take(Math.Min(diff, currentMiners.Count))
.Select(ByteStringHelper.FromHexString));
// ReSharper disable once ConvertClosureToMethodGroup
.Select(v => ByteStringHelper.FromHexString(v)));
Context.LogDebug(() => string.Join("\n", victories.Select(v => v.ToHex().Substring(0, 10)).ToList()));
return victories;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<Project Sdk="Microsoft.NET.Sdk">
<Import Project="..\..\common.props" />
<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net8.0</TargetFramework>
<PackageId>AElf.Contracts.Genesis</PackageId>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Description>Genesis is a contract that implements base functionality of the chain such as contract proposal
Expand Down
Loading
Loading