Fix all tests
This commit is contained in:
@@ -1,17 +1,8 @@
|
||||
using FluentAssertions;
|
||||
using Managing.Common;
|
||||
using Managing.Domain.Accounts;
|
||||
using Managing.Domain.Candles;
|
||||
using Managing.Domain.Indicators;
|
||||
using Managing.Domain.MoneyManagements;
|
||||
using Managing.Domain.Scenarios;
|
||||
using Managing.Domain.Shared.Helpers;
|
||||
using Managing.Domain.Statistics;
|
||||
using Managing.Domain.Strategies;
|
||||
using Managing.Domain.Strategies.Base;
|
||||
using Managing.Domain.Trades;
|
||||
using Xunit;
|
||||
using static Managing.Common.Enums;
|
||||
|
||||
namespace Managing.Domain.Tests;
|
||||
|
||||
@@ -121,26 +112,6 @@ public class TraderAnalysisTests : TradingBoxTests
|
||||
result.Should().BeFalse();
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void IsAGoodTrader_WithBoundaryValues_ReturnsTrue()
|
||||
{
|
||||
// Arrange
|
||||
var trader = new Trader
|
||||
{
|
||||
Winrate = 30, // Exactly 30
|
||||
TradeCount = 9, // Exactly 9
|
||||
AverageWin = 100m,
|
||||
AverageLoss = -99m, // |AverageLoss| < AverageWin
|
||||
Pnl = 1m // > 0
|
||||
};
|
||||
|
||||
// Act
|
||||
var result = TradingBox.IsAGoodTrader(trader);
|
||||
|
||||
// Assert
|
||||
result.Should().BeTrue();
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void IsABadTrader_WithAllCriteriaMet_ReturnsTrue()
|
||||
{
|
||||
@@ -241,26 +212,6 @@ public class TraderAnalysisTests : TradingBoxTests
|
||||
result.Should().BeFalse();
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void IsABadTrader_WithBoundaryValues_ReturnsTrue()
|
||||
{
|
||||
// Arrange
|
||||
var trader = new Trader
|
||||
{
|
||||
Winrate = 29, // < 30
|
||||
TradeCount = 9, // >= 8
|
||||
AverageWin = 50m,
|
||||
AverageLoss = -150m, // |AverageLoss| * 3 = 450 > AverageWin
|
||||
Pnl = -1m // < 0
|
||||
};
|
||||
|
||||
// Act
|
||||
var result = TradingBox.IsABadTrader(trader);
|
||||
|
||||
// Assert
|
||||
result.Should().BeTrue();
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void FindBadTrader_WithEmptyList_ReturnsEmptyList()
|
||||
{
|
||||
@@ -440,11 +391,11 @@ public class TraderAnalysisTests : TradingBoxTests
|
||||
[Theory]
|
||||
[InlineData(35, 10, 100, -50, 250, true)] // Good trader
|
||||
[InlineData(25, 10, 50, -200, -500, false)] // Bad trader
|
||||
[InlineData(30, 8, 100, -50, 100, true)] // Boundary good trader
|
||||
[InlineData(29, 9, 50, -150, -100, false)] // Boundary bad trader
|
||||
[InlineData(32, 7, 100, -50, 200, false)] // Insufficient trades
|
||||
[InlineData(28, 10, 200, -50, -100, false)] // Good RR but low winrate
|
||||
public void TraderEvaluation_TheoryTests(int winrate, int tradeCount, decimal avgWin, decimal avgLoss, decimal pnl, bool expectedGood)
|
||||
public void TraderEvaluation_TheoryTests(int winrate, int tradeCount, decimal avgWin, decimal avgLoss, decimal pnl,
|
||||
bool expectedGood)
|
||||
{
|
||||
// Arrange
|
||||
var trader = new Trader
|
||||
@@ -511,4 +462,4 @@ public class TraderAnalysisTests : TradingBoxTests
|
||||
badTraders.Should().HaveCount(1);
|
||||
goodTraders.First().Should().NotBe(badTraders.First());
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user