mirror of
https://github.com/phpseclib/phpseclib.git
synced 2025-01-03 22:27:29 +00:00
Merge branch '3.0'
This commit is contained in:
commit
1d75d080f1
@ -1867,8 +1867,6 @@ class SFTP extends SSH2
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->remove_from_stat_cache($remote_file);
|
|
||||||
|
|
||||||
$flags = NET_SFTP_OPEN_WRITE | NET_SFTP_OPEN_CREATE;
|
$flags = NET_SFTP_OPEN_WRITE | NET_SFTP_OPEN_CREATE;
|
||||||
// according to the SFTP specs, NET_SFTP_OPEN_APPEND should "force all writes to append data at the end of the file."
|
// according to the SFTP specs, NET_SFTP_OPEN_APPEND should "force all writes to append data at the end of the file."
|
||||||
// in practice, it doesn't seem to do that.
|
// in practice, it doesn't seem to do that.
|
||||||
@ -1885,6 +1883,8 @@ class SFTP extends SSH2
|
|||||||
$flags|= NET_SFTP_OPEN_TRUNCATE;
|
$flags|= NET_SFTP_OPEN_TRUNCATE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->remove_from_stat_cache($remote_file);
|
||||||
|
|
||||||
$packet = Strings::packSSH2('sNN', $remote_file, $flags, 0);
|
$packet = Strings::packSSH2('sNN', $remote_file, $flags, 0);
|
||||||
if (!$this->send_sftp_packet(NET_SFTP_OPEN, $packet)) {
|
if (!$this->send_sftp_packet(NET_SFTP_OPEN, $packet)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -55,6 +55,20 @@ class Functional_Net_SFTPStreamTest extends Functional_Net_SFTPTestCase
|
|||||||
$this->assertEquals(['.', '..'], array_slice($dirs, 0, 2));
|
$this->assertEquals(['.', '..'], array_slice($dirs, 0, 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group github1552
|
||||||
|
*/
|
||||||
|
public function testStreamSelect()
|
||||||
|
{
|
||||||
|
$context = stream_context_create([
|
||||||
|
'sftp' => ['session' => $this->sftp],
|
||||||
|
]);
|
||||||
|
$fp = fopen($this->buildUrl('fooo.txt'), 'wb', false, $context);
|
||||||
|
$read = [$fp];
|
||||||
|
$write = $except = null;
|
||||||
|
stream_select($read, $write, $except, 0);
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildUrl($suffix)
|
protected function buildUrl($suffix)
|
||||||
{
|
{
|
||||||
return sprintf(
|
return sprintf(
|
||||||
|
@ -167,6 +167,23 @@ class Functional_Net_SFTPUserStoryTest extends PhpseclibFunctionalTestCase
|
|||||||
'Failed asserting that get() returns expected example data.'
|
'Failed asserting that get() returns expected example data.'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$this->assertTrue(
|
||||||
|
$sftp->put('file1.txt', 'xxx', SFTP::RESUME),
|
||||||
|
'Failed asserting that an upload could be successfully resumed'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
self::$exampleDataLength + 3,
|
||||||
|
$sftp->filesize('file1.txt'),
|
||||||
|
'Failed asserting that put example data has the expected length'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
self::$exampleData . 'zzz',
|
||||||
|
$sftp->get('file1.txt'),
|
||||||
|
'Failed asserting that get() returns expected example data.'
|
||||||
|
);
|
||||||
|
|
||||||
return $sftp;
|
return $sftp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user