| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- using System;
- using System.Globalization;
- using System.Text;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Channels;
- using Renci.SshNet.Tests.Common;
- namespace Renci.SshNet.Tests.Classes
- {
- [TestClass]
- public class SshCommandTest_EndExecute_AsyncResultFromOtherInstance : TestBase
- {
- private Mock<ISession> _sessionMock;
- private Mock<IChannelSession> _channelSessionAMock;
- private Mock<IChannelSession> _channelSessionBMock;
- private string _commandText;
- private Encoding _encoding;
- private SshCommand _sshCommandA;
- private SshCommand _sshCommandB;
- private ArgumentException _actualException;
- private IAsyncResult _asyncResultB;
- protected override void OnInit()
- {
- base.OnInit();
- Arrange();
- Act();
- }
- private void Arrange()
- {
- _sessionMock = new Mock<ISession>(MockBehavior.Strict);
- _channelSessionAMock = new Mock<IChannelSession>(MockBehavior.Strict);
- _channelSessionBMock = new Mock<IChannelSession>(MockBehavior.Strict);
- _commandText = new Random().Next().ToString(CultureInfo.InvariantCulture);
- _encoding = Encoding.UTF8;
- _asyncResultB = null;
- var seq = new MockSequence();
- _ = _sessionMock.InSequence(seq)
- .Setup(p => p.CreateChannelSession())
- .Returns(_channelSessionAMock.Object);
- _ = _channelSessionAMock.InSequence(seq)
- .Setup(p => p.Open());
- _ = _channelSessionAMock.InSequence(seq)
- .Setup(p => p.SendExecRequest(_commandText))
- .Returns(true);
- _ = _sessionMock.InSequence(seq)
- .Setup(p => p.CreateChannelSession())
- .Returns(_channelSessionBMock.Object);
- _ = _channelSessionBMock.InSequence(seq)
- .Setup(p => p.Open());
- _ = _channelSessionBMock.InSequence(seq)
- .Setup(p => p.SendExecRequest(_commandText))
- .Returns(true);
- _sshCommandA = new SshCommand(_sessionMock.Object, _commandText, _encoding);
- _ = _sshCommandA.BeginExecute();
- _sshCommandB = new SshCommand(_sessionMock.Object, _commandText, _encoding);
- _asyncResultB = _sshCommandB.BeginExecute();
- }
- private void Act()
- {
- try
- {
- _ = _sshCommandA.EndExecute(_asyncResultB);
- Assert.Fail();
- }
- catch (ArgumentException ex)
- {
- _actualException = ex;
- }
- }
- [TestMethod]
- public void EndExecuteShouldHaveThrownArgumentException()
- {
- Assert.IsNotNull(_actualException);
- Assert.IsNull(_actualException.InnerException);
- Assert.AreEqual("asyncResult", _actualException.ParamName);
- }
- }
- }
|