Have one last unit test
This commit is contained in:
5
.idea/.idea.Tello Drone/.idea/contentModel.xml
generated
5
.idea/.idea.Tello Drone/.idea/contentModel.xml
generated
@@ -46,9 +46,7 @@
|
|||||||
</e>
|
</e>
|
||||||
</e>
|
</e>
|
||||||
</e>
|
</e>
|
||||||
<e p="Program.cs" t="Include" />
|
|
||||||
<e p="Tello Drone.csproj" t="IncludeRecursive" />
|
<e p="Tello Drone.csproj" t="IncludeRecursive" />
|
||||||
<e p="TestNameAttributes.cs" t="Include" />
|
|
||||||
<e p="UdpClientWrapper.cs" t="Include" />
|
<e p="UdpClientWrapper.cs" t="Include" />
|
||||||
<e p="UdpClientWrapperFactory.cs" t="Include" />
|
<e p="UdpClientWrapperFactory.cs" t="Include" />
|
||||||
</e>
|
</e>
|
||||||
@@ -58,6 +56,9 @@
|
|||||||
<e p="ConsoleLoggerTests.cs" t="Include" />
|
<e p="ConsoleLoggerTests.cs" t="Include" />
|
||||||
<e p="DroneCommandsTests.cs" t="Include" />
|
<e p="DroneCommandsTests.cs" t="Include" />
|
||||||
<e p="DroneFactoryTests.cs" t="Include" />
|
<e p="DroneFactoryTests.cs" t="Include" />
|
||||||
|
<e p="DroneTests.cs" t="Include" />
|
||||||
|
<e p="MissionCommanderTests.cs" t="Include" />
|
||||||
|
<e p="MissionListTests.cs" t="Include" />
|
||||||
<e p="obj" t="ExcludeRecursive">
|
<e p="obj" t="ExcludeRecursive">
|
||||||
<e p="Debug" t="Include">
|
<e p="Debug" t="Include">
|
||||||
<e p="netcoreapp2.2" t="Include">
|
<e p="netcoreapp2.2" t="Include">
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
using System.Dynamic;
|
|
||||||
|
|
||||||
namespace Tello_Drone
|
namespace Tello_Drone
|
||||||
{
|
{
|
||||||
public interface IUdpClientWrapperFactory
|
public interface IUdpClientWrapperFactory
|
||||||
|
|||||||
@@ -1,7 +1,3 @@
|
|||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Security.Authentication.ExtendedProtection;
|
|
||||||
|
|
||||||
namespace Tello_Drone
|
namespace Tello_Drone
|
||||||
{
|
{
|
||||||
public class MissionCommander : IMissionCommander
|
public class MissionCommander : IMissionCommander
|
||||||
@@ -15,12 +11,13 @@ namespace Tello_Drone
|
|||||||
|
|
||||||
public void RunMission(IMissions mission)
|
public void RunMission(IMissions mission)
|
||||||
{
|
{
|
||||||
SetUpDrone(3);
|
if(!SetUpDrone(3))
|
||||||
|
return;
|
||||||
mission.Run(_drone);
|
mission.Run(_drone);
|
||||||
TearDownDrone();
|
TearDownDrone();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetUpDrone(int retryCount)
|
private bool SetUpDrone(int retryCount)
|
||||||
{
|
{
|
||||||
var inCommandMode = false;
|
var inCommandMode = false;
|
||||||
while (inCommandMode != true && retryCount > 0)
|
while (inCommandMode != true && retryCount > 0)
|
||||||
@@ -28,7 +25,11 @@ namespace Tello_Drone
|
|||||||
inCommandMode = _drone.Command();
|
inCommandMode = _drone.Command();
|
||||||
retryCount--;
|
retryCount--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!inCommandMode)
|
||||||
|
return false;
|
||||||
_drone.TakeOff();
|
_drone.TakeOff();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void TearDownDrone()
|
private void TearDownDrone()
|
||||||
|
|||||||
@@ -1,10 +1,4 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Dynamic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Reflection;
|
|
||||||
using FastExpressionCompiler.LightExpression;
|
|
||||||
using ImTools;
|
|
||||||
using Tello_Drone.Missions;
|
using Tello_Drone.Missions;
|
||||||
|
|
||||||
namespace Tello_Drone
|
namespace Tello_Drone
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
namespace Tello_Drone.Missions
|
namespace Tello_Drone.Missions
|
||||||
{
|
{
|
||||||
[TestNameAttributes("Mission 2")]
|
|
||||||
public class Mission2: IMissions
|
public class Mission2: IMissions
|
||||||
{
|
{
|
||||||
public void Run(Drone drone)
|
public void Run(Drone drone)
|
||||||
{
|
{
|
||||||
|
drone.Forward(45);
|
||||||
|
drone.BackFlip();
|
||||||
|
drone.Reverse(45);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ namespace Tello_Drone.Missions
|
|||||||
drone.BackFlip();
|
drone.BackFlip();
|
||||||
drone.Left(20);
|
drone.Left(20);
|
||||||
drone.Right(20);
|
drone.Right(20);
|
||||||
|
drone.Reverse(30);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Dynamic;
|
|
||||||
using System.Security.Cryptography;
|
|
||||||
|
|
||||||
namespace Tello_Drone
|
|
||||||
{
|
|
||||||
[AttributeUsage(AttributeTargets.Class)]
|
|
||||||
public class TestNameAttributes : Attribute
|
|
||||||
{
|
|
||||||
public TestNameAttributes(string name)
|
|
||||||
{
|
|
||||||
Name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string Name { get; }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,8 +1,10 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Net.Sockets;
|
using System.Net.Sockets;
|
||||||
|
using System.Runtime.CompilerServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
|
||||||
|
[assembly: InternalsVisibleTo("TelloDroneUnitTests")]
|
||||||
namespace Tello_Drone
|
namespace Tello_Drone
|
||||||
{
|
{
|
||||||
internal class UdpClientWrapper : IUdpClientWrapper
|
internal class UdpClientWrapper : IUdpClientWrapper
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
using System.Dynamic;
|
|
||||||
|
|
||||||
namespace Tello_Drone
|
namespace Tello_Drone
|
||||||
{
|
{
|
||||||
public class UdpClientWrapperFactory : IUdpClientWrapperFactory
|
public class UdpClientWrapperFactory : IUdpClientWrapperFactory
|
||||||
|
|||||||
@@ -1,10 +1,7 @@
|
|||||||
using System;
|
|
||||||
using System.Linq.Expressions;
|
|
||||||
using Moq;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using Tello_Drone;
|
using Tello_Drone;
|
||||||
|
|
||||||
namespace Tests
|
namespace TelloDroneUnitTests
|
||||||
{
|
{
|
||||||
public class ConsoleLoggerTests
|
public class ConsoleLoggerTests
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,12 +1,8 @@
|
|||||||
|
|
||||||
using System;
|
|
||||||
using System.Net.Sockets;
|
|
||||||
using ImTools;
|
|
||||||
using Moq;
|
using Moq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using Tello_Drone;
|
using Tello_Drone;
|
||||||
|
|
||||||
namespace Tests
|
namespace TelloDroneUnitTests
|
||||||
{
|
{
|
||||||
public class DroneCommandsTests
|
public class DroneCommandsTests
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ using Moq;
|
|||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using Tello_Drone;
|
using Tello_Drone;
|
||||||
|
|
||||||
namespace Tests
|
namespace TelloDroneUnitTests
|
||||||
{
|
{
|
||||||
public class DroneFactoryTests
|
public class DroneFactoryTests
|
||||||
{
|
{
|
||||||
|
|||||||
152
TelloDroneUnitTests/DroneTests.cs
Normal file
152
TelloDroneUnitTests/DroneTests.cs
Normal file
@@ -0,0 +1,152 @@
|
|||||||
|
using System;
|
||||||
|
using System.Security.Cryptography.X509Certificates;
|
||||||
|
using Microsoft.VisualStudio.TestPlatform.Common.Utilities;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Tello_Drone;
|
||||||
|
|
||||||
|
namespace TelloDroneUnitTests
|
||||||
|
{
|
||||||
|
public class DroneTests
|
||||||
|
{
|
||||||
|
private Mock<IDroneCommands> _mockDroneCommands;
|
||||||
|
[SetUp]
|
||||||
|
public void SetUp()
|
||||||
|
{
|
||||||
|
_mockDroneCommands = new Mock<IDroneCommands>();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidForwardTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Forward(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Forward(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidReverseTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Reverse(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Reverse(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidUpTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Up(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Up(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidDownTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Down(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Down(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidLeftTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Left(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Left(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidRightTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Right(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.Right(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidFrontFlipTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.FrontFlip();
|
||||||
|
_mockDroneCommands.Verify(x => x.FrontFlip(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidBackFlipTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.BackFlip();
|
||||||
|
_mockDroneCommands.Verify(x => x.BackFlip(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidLeftFlipTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.LeftFlip();
|
||||||
|
_mockDroneCommands.Verify(x => x.LeftFlip(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void ValidRightFlipTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.RightFlip();
|
||||||
|
_mockDroneCommands.Verify(x => x.RightFlip(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void CommandTest()
|
||||||
|
{
|
||||||
|
_mockDroneCommands.Setup(x => x.Command()).Returns(true);
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
Assert.AreEqual(true, drone.Command());
|
||||||
|
_mockDroneCommands.Verify(x => x.Command(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void CommandReturnsFalse()
|
||||||
|
{
|
||||||
|
_mockDroneCommands.Setup(x => x.Command()).Returns(false);
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
Assert.AreEqual(false, drone.Command());
|
||||||
|
_mockDroneCommands.Verify(x => x.Command(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void LandTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.Land();
|
||||||
|
_mockDroneCommands.Verify(x => x.Land(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TakeOffTest()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.TakeOff();
|
||||||
|
_mockDroneCommands.Verify(x => x.TakeOff(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void InitialTakeOffTest()
|
||||||
|
{
|
||||||
|
_mockDroneCommands.Setup(x => x.InitialTakeOff()).Returns(true);
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
Assert.AreEqual(true, drone.InitialTakeOff());
|
||||||
|
_mockDroneCommands.Verify(x => x.InitialTakeOff(), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void RotateClockWise()
|
||||||
|
{
|
||||||
|
var drone = new Drone(_mockDroneCommands.Object);
|
||||||
|
drone.RotateClockWise(It.IsAny<int>());
|
||||||
|
_mockDroneCommands.Verify(x => x.RotateClockWise(It.IsAny<int>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
44
TelloDroneUnitTests/MissionCommanderTests.cs
Normal file
44
TelloDroneUnitTests/MissionCommanderTests.cs
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
using System.Threading.Tasks;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Tello_Drone;
|
||||||
|
|
||||||
|
namespace TelloDroneUnitTests
|
||||||
|
{
|
||||||
|
public class MissionCommanderTests
|
||||||
|
{
|
||||||
|
private Mock<IDroneFactory> _mockDroneFactory;
|
||||||
|
private Mock<IMissions> _mockMission;
|
||||||
|
private Mock<Drone> _mockDrone;
|
||||||
|
private Mock<IDroneCommands> _mockDroneCommands;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void SetUp()
|
||||||
|
{
|
||||||
|
_mockDroneFactory = new Mock<IDroneFactory>();
|
||||||
|
_mockMission = new Mock<IMissions>();
|
||||||
|
_mockDroneCommands = new Mock<IDroneCommands>();
|
||||||
|
_mockDrone = new Mock<Drone>(_mockDroneCommands.Object);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void RunMissionTest()
|
||||||
|
{
|
||||||
|
_mockDroneCommands.Setup(x => x.Command()).Returns(true);
|
||||||
|
_mockDroneFactory.SetupGet(x => x.CreateDrone).Returns(_mockDrone.Object);
|
||||||
|
var missionCommander = new MissionCommander(_mockDroneFactory.Object);
|
||||||
|
missionCommander.RunMission(_mockMission.Object);
|
||||||
|
_mockMission.Verify(x => x.Run(It.IsAny<Drone>()), Times.Once);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void RunMissionSetupFailed()
|
||||||
|
{
|
||||||
|
_mockDroneCommands.Setup(x => x.Command()).Returns(false);
|
||||||
|
_mockDroneFactory.SetupGet(x => x.CreateDrone).Returns(_mockDrone.Object);
|
||||||
|
var missionCommander = new MissionCommander(_mockDroneFactory.Object);
|
||||||
|
missionCommander.RunMission(_mockMission.Object);
|
||||||
|
_mockMission.Verify(x => x.Run(It.IsAny<Drone>()), Times.Never);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
30
TelloDroneUnitTests/MissionListTests.cs
Normal file
30
TelloDroneUnitTests/MissionListTests.cs
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using Microsoft.VisualStudio.TestPlatform.Common.Utilities;
|
||||||
|
using Microsoft.VisualStudio.TestPlatform.ObjectModel.Logging;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Tello_Drone;
|
||||||
|
|
||||||
|
namespace TelloDroneUnitTests
|
||||||
|
{
|
||||||
|
public class MissionListTests
|
||||||
|
{
|
||||||
|
[SetUp]
|
||||||
|
public void SetUp()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void MissionListTest()
|
||||||
|
{
|
||||||
|
var missionList = new MissionList();
|
||||||
|
for (int i = 0; i < missionList.GetMissionList().Count; i++)
|
||||||
|
{
|
||||||
|
Assert.AreEqual(typeof(string), missionList.GetMissionList()[i].Item1.GetType());
|
||||||
|
Assert.IsInstanceOf(typeof(IMissions), missionList.GetMissionList()[i].Item2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
24
TelloDroneUnitTests/UdpClientWrapperFactoryTests.cs
Normal file
24
TelloDroneUnitTests/UdpClientWrapperFactoryTests.cs
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
using System.Threading;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using Tello_Drone;
|
||||||
|
|
||||||
|
namespace TelloDroneUnitTests
|
||||||
|
{
|
||||||
|
public class UdpClientWrapperFactoryTests
|
||||||
|
{
|
||||||
|
private Mock<IConsoleLogger> _mockConsoleLogger;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void SetUp()
|
||||||
|
{
|
||||||
|
_mockConsoleLogger = new Mock<IConsoleLogger>();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void CreateTest()
|
||||||
|
{
|
||||||
|
Assert.IsInstanceOf(typeof(UdpClientWrapper), new UdpClientWrapperFactory(_mockConsoleLogger.Object).Create());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user