| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- using System.Collections.Generic;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- namespace Renci.SshNet.Tests.Classes
- {
- /// <summary>
- /// * ConnectionInfo provides the following authentication methods (in order):
- /// o keyboard-interactive
- /// o password
- /// o publickey
- /// * Partial success limit is 2
- /// * Scenario:
- /// none
- /// (1=FAIL)
- /// |
- /// password
- /// (2=PARTIAL)
- /// |
- /// password
- /// (3=SUCCESS)
- /// </summary>
- [TestClass]
- public class ClientAuthenticationTest_Success_SingleList_SameAllowedAuthenticationAfterPartialSuccess : ClientAuthenticationTestBase
- {
- private int _partialSuccessLimit;
- private ClientAuthentication _clientAuthentication;
- protected override void SetupData()
- {
- _partialSuccessLimit = 2;
- }
- protected override void SetupMocks()
- {
- var seq = new MockSequence();
- SessionMock.InSequence(seq).Setup(p => p.RegisterMessage("SSH_MSG_USERAUTH_FAILURE"));
- SessionMock.InSequence(seq).Setup(p => p.RegisterMessage("SSH_MSG_USERAUTH_SUCCESS"));
- SessionMock.InSequence(seq).Setup(p => p.RegisterMessage("SSH_MSG_USERAUTH_BANNER"));
- ConnectionInfoMock.InSequence(seq).Setup(p => p.CreateNoneAuthenticationMethod())
- .Returns(NoneAuthenticationMethodMock.Object);
- /* 1 */
- NoneAuthenticationMethodMock.InSequence(seq).Setup(p => p.Authenticate(SessionMock.Object))
- .Returns(AuthenticationResult.Failure);
- ConnectionInfoMock.InSequence(seq)
- .Setup(p => p.AuthenticationMethods)
- .Returns(new List<IAuthenticationMethod>
- {
- PublicKeyAuthenticationMethodMock.Object,
- PasswordAuthenticationMethodMock.Object
- });
- NoneAuthenticationMethodMock.InSequence(seq)
- .Setup(p => p.AllowedAuthentications)
- .Returns(new[] { "password" });
- /* Enumerate supported authentication methods */
- PublicKeyAuthenticationMethodMock.InSequence(seq).Setup(p => p.Name).Returns("publickey");
- PasswordAuthenticationMethodMock.InSequence(seq).Setup(p => p.Name).Returns("password");
- /* 2 */
- PasswordAuthenticationMethodMock.InSequence(seq)
- .Setup(p => p.Authenticate(SessionMock.Object))
- .Returns(AuthenticationResult.PartialSuccess);
- PasswordAuthenticationMethodMock.InSequence(seq)
- .Setup(p => p.AllowedAuthentications)
- .Returns(new[] { "password" });
- /* Enumerate supported authentication methods */
- PublicKeyAuthenticationMethodMock.InSequence(seq).Setup(p => p.Name).Returns("publickey");
- PasswordAuthenticationMethodMock.InSequence(seq).Setup(p => p.Name).Returns("password");
- /* 3 */
- PasswordAuthenticationMethodMock.InSequence(seq)
- .Setup(p => p.Authenticate(SessionMock.Object))
- .Returns(AuthenticationResult.Success);
- SessionMock.InSequence(seq).Setup(p => p.UnRegisterMessage("SSH_MSG_USERAUTH_FAILURE"));
- SessionMock.InSequence(seq).Setup(p => p.UnRegisterMessage("SSH_MSG_USERAUTH_SUCCESS"));
- SessionMock.InSequence(seq).Setup(p => p.UnRegisterMessage("SSH_MSG_USERAUTH_BANNER"));
- }
- protected override void Arrange()
- {
- base.Arrange();
- _clientAuthentication = new ClientAuthentication(_partialSuccessLimit);
- }
- protected override void Act()
- {
- _clientAuthentication.Authenticate(ConnectionInfoMock.Object, SessionMock.Object);
- }
- }
- }
|