2011-09-05 23:36:14 +02:00
|
|
|
package ftp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"io/ioutil"
|
2015-08-19 00:17:44 +02:00
|
|
|
"net/textproto"
|
2011-09-05 23:36:14 +02:00
|
|
|
"testing"
|
2015-03-16 23:45:56 +01:00
|
|
|
"time"
|
2017-02-04 12:42:50 +01:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
2011-09-05 23:36:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
testData = "Just some text"
|
2013-02-17 10:31:56 +01:00
|
|
|
testDir = "mydir"
|
2011-09-05 23:36:14 +02:00
|
|
|
)
|
|
|
|
|
2015-08-20 01:46:22 +02:00
|
|
|
func TestConnPASV(t *testing.T) {
|
|
|
|
testConn(t, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestConnEPSV(t *testing.T) {
|
|
|
|
testConn(t, false)
|
|
|
|
}
|
|
|
|
|
2016-11-24 14:49:16 +01:00
|
|
|
func testConn(t *testing.T, disableEPSV bool) {
|
2015-08-18 18:39:31 +02:00
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("skipping test in short mode.")
|
|
|
|
}
|
2017-02-04 12:42:50 +01:00
|
|
|
require := require.New(t)
|
2015-08-18 18:39:31 +02:00
|
|
|
|
2015-03-16 23:45:56 +01:00
|
|
|
c, err := DialTimeout("localhost:21", 5*time.Second)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-06 18:27:30 +02:00
|
|
|
|
2016-11-24 14:49:16 +01:00
|
|
|
if disableEPSV {
|
2015-08-20 01:46:22 +02:00
|
|
|
delete(c.features, "EPSV")
|
2016-11-24 14:49:16 +01:00
|
|
|
c.disableEPSV = true
|
2015-08-20 01:46:22 +02:00
|
|
|
}
|
|
|
|
|
2011-09-06 18:27:30 +02:00
|
|
|
err = c.Login("anonymous", "anonymous")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
|
|
|
err = c.NoOp()
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
2015-08-18 19:34:22 +02:00
|
|
|
err = c.ChangeDir("incoming")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2015-08-18 19:34:22 +02:00
|
|
|
|
2011-09-05 23:36:14 +02:00
|
|
|
data := bytes.NewBufferString(testData)
|
|
|
|
err = c.Stor("test", data)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
|
|
|
_, err = c.List(".")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
|
|
|
err = c.Rename("test", "tset")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
|
|
|
r, err := c.Retr("tset")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
|
|
|
buf, err := ioutil.ReadAll(r)
|
|
|
|
require.NoError(err)
|
|
|
|
require.Equal(testData, string(buf))
|
|
|
|
err = r.Close()
|
|
|
|
require.NoError(err)
|
2011-09-05 23:36:14 +02:00
|
|
|
|
2015-08-20 22:47:09 +02:00
|
|
|
r, err = c.RetrFrom("tset", 5)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
|
|
|
buf, err = ioutil.ReadAll(r)
|
|
|
|
require.NoError(err)
|
|
|
|
require.Equal(testData[5:], string(buf))
|
|
|
|
r.Close()
|
2013-07-10 12:18:32 +02:00
|
|
|
|
2011-09-06 00:02:01 +02:00
|
|
|
err = c.Delete("tset")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-06 00:02:01 +02:00
|
|
|
|
2011-09-07 16:52:52 +02:00
|
|
|
err = c.MakeDir(testDir)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-06 00:02:01 +02:00
|
|
|
|
2011-09-07 16:52:52 +02:00
|
|
|
err = c.ChangeDir(testDir)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-07 16:52:52 +02:00
|
|
|
|
|
|
|
dir, err := c.CurrentDir()
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
|
|
|
require.Equal("/incoming/"+testDir, dir)
|
2011-09-07 16:52:52 +02:00
|
|
|
|
|
|
|
err = c.ChangeDirToParent()
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-07 16:52:52 +02:00
|
|
|
|
2015-08-20 10:32:28 +02:00
|
|
|
entries, err := c.NameList("/")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
|
|
|
require.EqualValues([]string{"/incoming"}, entries)
|
2015-08-20 10:32:28 +02:00
|
|
|
|
2011-09-07 16:52:52 +02:00
|
|
|
err = c.RemoveDir(testDir)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2011-09-06 00:02:01 +02:00
|
|
|
|
2013-05-19 21:15:23 +02:00
|
|
|
err = c.Logout()
|
|
|
|
if err != nil {
|
2015-08-19 00:17:44 +02:00
|
|
|
if protoErr := err.(*textproto.Error); protoErr != nil {
|
|
|
|
if protoErr.Code != StatusNotImplemented {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2013-05-19 21:15:23 +02:00
|
|
|
}
|
|
|
|
|
2017-02-04 12:42:50 +01:00
|
|
|
err = c.Quit()
|
|
|
|
require.NoError(err)
|
2011-09-07 16:52:52 +02:00
|
|
|
|
|
|
|
err = c.NoOp()
|
2017-02-04 12:42:50 +01:00
|
|
|
require.Error(err)
|
|
|
|
require.Regexp("write tcp .* use of closed network connection", err.Error())
|
2011-09-05 23:36:14 +02:00
|
|
|
}
|
2013-07-08 07:48:11 +02:00
|
|
|
|
2013-12-04 19:12:09 +01:00
|
|
|
func TestConnIPv6(t *testing.T) {
|
2015-08-18 19:02:23 +02:00
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("skipping test in short mode.")
|
|
|
|
}
|
2017-02-04 12:42:50 +01:00
|
|
|
require := require.New(t)
|
2015-08-18 19:02:23 +02:00
|
|
|
|
2015-08-18 22:10:32 +02:00
|
|
|
c, err := DialTimeout("[::1]:21", 5*time.Second)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2013-12-04 19:12:09 +01:00
|
|
|
|
|
|
|
err = c.Login("anonymous", "anonymous")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2013-12-04 19:12:09 +01:00
|
|
|
|
|
|
|
_, err = c.List(".")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2013-12-04 19:12:09 +01:00
|
|
|
|
2017-02-04 12:42:50 +01:00
|
|
|
err = c.Quit()
|
|
|
|
require.NoError(err)
|
2013-12-04 19:12:09 +01:00
|
|
|
}
|
2015-08-21 18:36:56 +02:00
|
|
|
|
2015-08-21 18:47:44 +02:00
|
|
|
// TestConnect tests the legacy Connect function
|
|
|
|
func TestConnect(t *testing.T) {
|
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("skipping test in short mode.")
|
|
|
|
}
|
|
|
|
|
|
|
|
c, err := Connect("localhost:21")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(t, err)
|
2015-08-21 18:47:44 +02:00
|
|
|
|
|
|
|
c.Quit()
|
|
|
|
}
|
|
|
|
|
2017-02-04 12:42:50 +01:00
|
|
|
func TestDialTimeout(t *testing.T) {
|
2015-08-21 18:36:56 +02:00
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("skipping test in short mode.")
|
|
|
|
}
|
2017-02-04 12:42:50 +01:00
|
|
|
require := require.New(t)
|
2015-08-21 18:36:56 +02:00
|
|
|
|
2017-02-04 12:42:50 +01:00
|
|
|
_, err := DialTimeout("localhost:2121", 1*time.Second)
|
|
|
|
require.Error(err)
|
|
|
|
require.Regexp("dial tcp .* connection refused", err.Error())
|
2015-08-21 18:36:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestWrongLogin(t *testing.T) {
|
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("skipping test in short mode.")
|
|
|
|
}
|
2017-02-04 12:42:50 +01:00
|
|
|
require := require.New(t)
|
2015-08-21 18:36:56 +02:00
|
|
|
|
|
|
|
c, err := DialTimeout("localhost:21", 5*time.Second)
|
2017-02-04 12:42:50 +01:00
|
|
|
require.NoError(err)
|
2015-08-21 18:36:56 +02:00
|
|
|
defer c.Quit()
|
|
|
|
|
|
|
|
err = c.Login("zoo2Shia", "fei5Yix9")
|
2017-02-04 12:42:50 +01:00
|
|
|
require.Error(err)
|
|
|
|
require.Regexp("(Login incorrect|anonymous only)", err.Error())
|
2015-08-21 18:36:56 +02:00
|
|
|
}
|