| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- using System;
- using System.IO;
- using Microsoft.VisualStudio.TestTools.UnitTesting;
- using Moq;
- using Renci.SshNet.Common;
- using Renci.SshNet.Sftp;
- namespace Renci.SshNet.Tests.Classes.Sftp
- {
- [TestClass]
- public class SftpFileStreamTest_Read_ReadMode_NoDataInReaderBufferAndReadMoreBytesFromServerThanCount : SftpFileStreamTestBase
- {
- private string _path;
- private SftpFileStream _target;
- private byte[] _handle;
- private uint _bufferSize;
- private uint _readBufferSize;
- private uint _writeBufferSize;
- private int _actual;
- private byte[] _buffer;
- private byte[] _serverData;
- private int _numberOfBytesToWriteToReadBuffer;
- private int _numberOfBytesToRead;
- protected override void SetupData()
- {
- base.SetupData();
- var random = new Random();
- _path = random.Next().ToString();
- _handle = GenerateRandom(5, random);
- _bufferSize = (uint)random.Next(1, 1000);
- _readBufferSize = 20;
- _writeBufferSize = 500;
- _numberOfBytesToRead = 20;
- _buffer = new byte[_numberOfBytesToRead];
- _numberOfBytesToWriteToReadBuffer = 10; // should be less than _readBufferSize
- _serverData = GenerateRandom(_numberOfBytesToRead + _numberOfBytesToWriteToReadBuffer, random);
- }
- protected override void SetupMocks()
- {
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.RequestOpen(_path, Flags.Read, false))
- .Returns(_handle);
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.CalculateOptimalReadLength(_bufferSize))
- .Returns(_readBufferSize);
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.CalculateOptimalWriteLength(_bufferSize, _handle))
- .Returns(_writeBufferSize);
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.IsOpen)
- .Returns(true);
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.RequestRead(_handle, 0UL, _readBufferSize))
- .Returns(_serverData);
- }
- [TestCleanup]
- public void TearDown()
- {
- SftpSessionMock.InSequence(MockSequence)
- .Setup(p => p.RequestClose(_handle));
- }
- protected override void Arrange()
- {
- base.Arrange();
- _target = new SftpFileStream(SftpSessionMock.Object,
- _path,
- FileMode.Open,
- FileAccess.Read,
- (int)_bufferSize);
- }
- protected override void Act()
- {
- _actual = _target.Read(_buffer, 0, _numberOfBytesToRead);
- }
- [TestMethod]
- public void ReadShouldHaveReturnedTheNumberOfBytesWrittenToCallerSuppliedBuffer()
- {
- Assert.AreEqual(_numberOfBytesToRead, _actual);
- }
- [TestMethod]
- public void ReadShouldHaveWrittenBytesToTheCallerSuppliedBuffer()
- {
- Assert.IsTrue(_serverData.Take(_actual).IsEqualTo(_buffer));
- }
- [TestMethod]
- public void PositionShouldReturnNumberOfBytesWrittenToCallerProvidedBuffer()
- {
- SftpSessionMock.InSequence(MockSequence).Setup(p => p.IsOpen).Returns(true);
- Assert.AreEqual(_actual, _target.Position);
- SftpSessionMock.Verify(p => p.IsOpen, Times.Exactly(2));
- }
- [TestMethod]
- public void SubsequentReadShouldReturnAllRemaningBytesFromReadBufferWhenCountIsEqualToNumberOfRemainingBytes()
- {
- SftpSessionMock.InSequence(MockSequence).Setup(p => p.IsOpen).Returns(true);
- var buffer = new byte[_numberOfBytesToWriteToReadBuffer];
- var actual = _target.Read(buffer, 0, _numberOfBytesToWriteToReadBuffer);
- Assert.AreEqual(_numberOfBytesToWriteToReadBuffer, actual);
- Assert.IsTrue(_serverData.Take(_numberOfBytesToRead, _numberOfBytesToWriteToReadBuffer).IsEqualTo(buffer));
- SftpSessionMock.Verify(p => p.IsOpen, Times.Exactly(2));
- }
- [TestMethod]
- public void SubsequentReadShouldReturnAllRemaningBytesFromReadBufferAndReadAgainWhenCountIsGreaterThanNumberOfRemainingBytesAndNewReadReturnsZeroBytes()
- {
- SftpSessionMock.InSequence(MockSequence).Setup(p => p.IsOpen).Returns(true);
- SftpSessionMock.InSequence(MockSequence).Setup(p => p.RequestRead(_handle, (ulong)(_serverData.Length), _readBufferSize)).Returns(Array.Empty<byte>());
- var buffer = new byte[_numberOfBytesToWriteToReadBuffer + 1];
- var actual = _target.Read(buffer, 0, buffer.Length);
- Assert.AreEqual(_numberOfBytesToWriteToReadBuffer, actual);
- Assert.IsTrue(_serverData.Take(_numberOfBytesToRead, _numberOfBytesToWriteToReadBuffer).IsEqualTo(buffer.Take(_numberOfBytesToWriteToReadBuffer)));
- Assert.AreEqual(0, buffer[_numberOfBytesToWriteToReadBuffer]);
- SftpSessionMock.Verify(p => p.IsOpen, Times.Exactly(2));
- SftpSessionMock.Verify(p => p.RequestRead(_handle, (ulong)(_serverData.Length), _readBufferSize));
- }
- }
- }
|