Skip to content

Commit

Permalink
Merge branch 'master' into add/builders/transaction
Browse files Browse the repository at this point in the history
  • Loading branch information
NGDAdmin authored Sep 27, 2024
2 parents 68469d9 + d6ed5a5 commit 8afada7
Show file tree
Hide file tree
Showing 3 changed files with 87 additions and 3 deletions.
18 changes: 16 additions & 2 deletions src/Neo/Ledger/HeaderCache.cs
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,26 @@ public Header this[uint index]
/// <summary>
/// Gets the number of elements in the cache.
/// </summary>
public int Count => headers.Count;
public int Count
{
get
{
readerWriterLock.EnterReadLock();
try
{
return headers.Count;
}
finally
{
readerWriterLock.ExitReadLock();
}
}
}

/// <summary>
/// Indicates whether the cache is full.
/// </summary>
public bool Full => headers.Count >= 10000;
public bool Full => Count >= 10000;

/// <summary>
/// Gets the last <see cref="Header"/> in the cache. Or <see langword="null"/> if the cache is empty.
Expand Down
2 changes: 1 addition & 1 deletion src/Plugins/RpcServer/RpcError.cs
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ public class RpcError
public static readonly RpcError AlreadyInPool = new(-503, "Already in pool");
public static readonly RpcError InsufficientNetworkFee = new(-504, "Insufficient network fee");
public static readonly RpcError PolicyFailed = new(-505, "Policy check failed");
public static readonly RpcError InvalidScript = new(-509, "Invalid transaction script");
public static readonly RpcError InvalidScript = new(-506, "Invalid transaction script");
public static readonly RpcError InvalidAttribute = new(-507, "Invalid transaction attribute");
public static readonly RpcError InvalidSignature = new(-508, "Invalid signature");
public static readonly RpcError InvalidSize = new(-509, "Invalid inventory size");
Expand Down
70 changes: 70 additions & 0 deletions tests/Neo.UnitTests/Ledger/UT_HeaderCache.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
// Copyright (C) 2015-2024 The Neo Project.
//
// UT_HeaderCache.cs file belongs to the neo project and is free
// software distributed under the MIT software license, see the
// accompanying file LICENSE in the main directory of the
// repository or http://www.opensource.org/licenses/mit-license.php
// for more details.
//
// Redistribution and use in source and binary forms with or without
// modifications are permitted.

using FluentAssertions;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Neo.Ledger;
using Neo.Network.P2P.Payloads;
using System;

namespace Neo.UnitTests.Ledger
{
[TestClass]
public class UT_HeaderCache
{
[TestMethod]
public void TestHeaderCache()
{
var cache = new HeaderCache();
var header = new Header();
header.Index = 1;
cache.Add(header);

var got = cache[1];
got.Should().NotBeNull();
got.Index.Should().Be(1);

var count = cache.Count;
count.Should().Be(1);

var full = cache.Full;
full.Should().BeFalse();

var last = cache.Last;
last.Should().NotBeNull();
last.Index.Should().Be(1);

got = cache[2];
got.Should().BeNull();

// enumerate
var enumerator = cache.GetEnumerator();
enumerator.MoveNext().Should().BeTrue();
enumerator.Current.Index.Should().Be(1);
enumerator.MoveNext().Should().BeFalse();

var removed = cache.TryRemoveFirst(out header);
removed.Should().BeTrue();

count = cache.Count;
count.Should().Be(0);

full = cache.Full;
full.Should().BeFalse();

last = cache.Last;
last.Should().BeNull();

got = cache[1];
got.Should().BeNull();
}
}
}

0 comments on commit 8afada7

Please sign in to comment.