mirror of https://github.com/apache/nifi.git
NIFI-12275 Disabled Keepalive in SFTP Tests
This closes #7932 Signed-off-by: Chris Sampson <chris.sampson82@gmail.com>
This commit is contained in:
parent
9eb2038585
commit
2eb5b79353
|
@ -36,40 +36,42 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class TestGetSFTP {
|
public class TestGetSFTP {
|
||||||
|
|
||||||
private TestRunner getSFTPRunner;
|
private TestRunner runner;
|
||||||
private static SSHTestServer sshTestServer;
|
private static SSHTestServer sshTestServer;
|
||||||
|
|
||||||
@BeforeAll
|
@BeforeAll
|
||||||
public static void setupSSHD() throws IOException {
|
public static void startServer() throws IOException {
|
||||||
sshTestServer = new SSHTestServer();
|
sshTestServer = new SSHTestServer();
|
||||||
sshTestServer.startServer();
|
sshTestServer.startServer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@AfterAll
|
@AfterAll
|
||||||
public static void cleanupSSHD() throws IOException {
|
public static void stopServer() throws IOException {
|
||||||
sshTestServer.stopServer();
|
sshTestServer.stopServer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
public void setup(){
|
public void setup(){
|
||||||
getSFTPRunner = TestRunners.newTestRunner(GetSFTP.class);
|
runner = TestRunners.newTestRunner(GetSFTP.class);
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.HOSTNAME, "localhost");
|
runner.setProperty(SFTPTransfer.HOSTNAME, sshTestServer.getHost());
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
|
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
|
runner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.PASSWORD, sshTestServer.getPassword());
|
runner.setProperty(SFTPTransfer.PASSWORD, sshTestServer.getPassword());
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.STRICT_HOST_KEY_CHECKING, "false");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.DATA_TIMEOUT, "30 sec");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.REMOTE_PATH, "/");
|
|
||||||
getSFTPRunner.removeProperty(SFTPTransfer.FILE_FILTER_REGEX);
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.PATH_FILTER_REGEX, "");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.POLLING_INTERVAL, "60 sec");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.RECURSIVE_SEARCH, "false");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.IGNORE_DOTTED_FILES, "true");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.DELETE_ORIGINAL, "true");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.MAX_SELECTS, "100");
|
|
||||||
getSFTPRunner.setProperty(SFTPTransfer.REMOTE_POLL_BATCH_SIZE, "5000");
|
|
||||||
|
|
||||||
getSFTPRunner.setValidateExpressionUsage(false);
|
runner.setProperty(SFTPTransfer.USE_KEEPALIVE_ON_TIMEOUT, Boolean.FALSE.toString());
|
||||||
|
runner.setProperty(SFTPTransfer.STRICT_HOST_KEY_CHECKING, Boolean.FALSE.toString());
|
||||||
|
runner.setProperty(SFTPTransfer.DATA_TIMEOUT, "30 sec");
|
||||||
|
runner.setProperty(SFTPTransfer.REMOTE_PATH, "/");
|
||||||
|
runner.removeProperty(SFTPTransfer.FILE_FILTER_REGEX);
|
||||||
|
runner.setProperty(SFTPTransfer.PATH_FILTER_REGEX, "");
|
||||||
|
runner.setProperty(SFTPTransfer.POLLING_INTERVAL, "60 sec");
|
||||||
|
runner.setProperty(SFTPTransfer.RECURSIVE_SEARCH, "false");
|
||||||
|
runner.setProperty(SFTPTransfer.IGNORE_DOTTED_FILES, "true");
|
||||||
|
runner.setProperty(SFTPTransfer.DELETE_ORIGINAL, "true");
|
||||||
|
runner.setProperty(SFTPTransfer.MAX_SELECTS, "100");
|
||||||
|
runner.setProperty(SFTPTransfer.REMOTE_POLL_BATCH_SIZE, "5000");
|
||||||
|
|
||||||
|
runner.setValidateExpressionUsage(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -81,17 +83,17 @@ public class TestGetSFTP {
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.txt");
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile4.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile4.txt");
|
||||||
|
|
||||||
getSFTPRunner.run();
|
runner.run();
|
||||||
|
|
||||||
getSFTPRunner.assertTransferCount(GetSFTP.REL_SUCCESS, 4);
|
runner.assertTransferCount(GetSFTP.REL_SUCCESS, 4);
|
||||||
|
|
||||||
//Verify files deleted
|
//Verify files deleted
|
||||||
for(int i=1;i<5;i++){
|
for (int i = 1; i < 5 ; i++) {
|
||||||
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile" + i + ".txt");
|
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile" + i + ".txt");
|
||||||
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
|
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
|
||||||
}
|
}
|
||||||
|
|
||||||
getSFTPRunner.clearTransferState();
|
runner.clearTransferState();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -105,9 +107,9 @@ public class TestGetSFTP {
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile1.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile1.txt");
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile2.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile2.txt");
|
||||||
|
|
||||||
getSFTPRunner.run();
|
runner.run();
|
||||||
|
|
||||||
getSFTPRunner.assertTransferCount(GetSFTP.REL_SUCCESS, 2);
|
runner.assertTransferCount(GetSFTP.REL_SUCCESS, 2);
|
||||||
|
|
||||||
// Verify files deleted
|
// Verify files deleted
|
||||||
for (int i = 1; i < 3; i++) {
|
for (int i = 1; i < 3; i++) {
|
||||||
|
@ -115,7 +117,7 @@ public class TestGetSFTP {
|
||||||
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
|
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
|
||||||
}
|
}
|
||||||
|
|
||||||
getSFTPRunner.clearTransferState();
|
runner.clearTransferState();
|
||||||
|
|
||||||
} finally {
|
} finally {
|
||||||
// set back the original value for 'user.home' system property
|
// set back the original value for 'user.home' system property
|
||||||
|
@ -132,9 +134,9 @@ public class TestGetSFTP {
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.txt");
|
||||||
touchFile(sshTestServer.getVirtualFileSystemPath() + ".testFile4.txt");
|
touchFile(sshTestServer.getVirtualFileSystemPath() + ".testFile4.txt");
|
||||||
|
|
||||||
getSFTPRunner.run();
|
runner.run();
|
||||||
|
|
||||||
getSFTPRunner.assertTransferCount(GetSFTP.REL_SUCCESS, 2);
|
runner.assertTransferCount(GetSFTP.REL_SUCCESS, 2);
|
||||||
|
|
||||||
//Verify non-dotted files were deleted and dotted files were not deleted
|
//Verify non-dotted files were deleted and dotted files were not deleted
|
||||||
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile1.txt");
|
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile1.txt");
|
||||||
|
@ -149,7 +151,7 @@ public class TestGetSFTP {
|
||||||
file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/.testFile4.txt");
|
file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/.testFile4.txt");
|
||||||
assertTrue(file1.toAbsolutePath().toFile().exists(), "File deleted.");
|
assertTrue(file1.toAbsolutePath().toFile().exists(), "File deleted.");
|
||||||
|
|
||||||
getSFTPRunner.clearTransferState();
|
runner.clearTransferState();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void touchFile(String file) throws IOException {
|
private void touchFile(String file) throws IOException {
|
||||||
|
|
|
@ -33,7 +33,6 @@ import org.apache.nifi.flowfile.attributes.CoreAttributes;
|
||||||
import org.apache.nifi.processor.VerifiableProcessor;
|
import org.apache.nifi.processor.VerifiableProcessor;
|
||||||
import org.apache.nifi.processor.util.list.AbstractListProcessor;
|
import org.apache.nifi.processor.util.list.AbstractListProcessor;
|
||||||
import org.apache.nifi.processor.util.list.ListedEntityTracker;
|
import org.apache.nifi.processor.util.list.ListedEntityTracker;
|
||||||
import org.apache.nifi.processors.standard.util.FTPTransfer;
|
|
||||||
import org.apache.nifi.processors.standard.util.SFTPTransfer;
|
import org.apache.nifi.processors.standard.util.SFTPTransfer;
|
||||||
import org.apache.nifi.processors.standard.util.SSHTestServer;
|
import org.apache.nifi.processors.standard.util.SSHTestServer;
|
||||||
import org.apache.nifi.reporting.InitializationException;
|
import org.apache.nifi.reporting.InitializationException;
|
||||||
|
@ -64,11 +63,14 @@ public class TestListSFTP {
|
||||||
sshServer = new SSHTestServer();
|
sshServer = new SSHTestServer();
|
||||||
sshServer.startServer();
|
sshServer.startServer();
|
||||||
writeTempFile();
|
writeTempFile();
|
||||||
|
|
||||||
runner = TestRunners.newTestRunner(ListSFTP.class);
|
runner = TestRunners.newTestRunner(ListSFTP.class);
|
||||||
runner.setProperty(ListSFTP.HOSTNAME, sshServer.getHost());
|
runner.setProperty(SFTPTransfer.HOSTNAME, sshServer.getHost());
|
||||||
runner.setProperty(ListSFTP.USERNAME, sshServer.getUsername());
|
runner.setProperty(SFTPTransfer.USERNAME, sshServer.getUsername());
|
||||||
runner.setProperty(SFTPTransfer.PASSWORD, sshServer.getPassword());
|
runner.setProperty(SFTPTransfer.PASSWORD, sshServer.getPassword());
|
||||||
runner.setProperty(FTPTransfer.PORT, Integer.toString(sshServer.getSSHPort()));
|
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshServer.getSSHPort()));
|
||||||
|
runner.setProperty(SFTPTransfer.USE_KEEPALIVE_ON_TIMEOUT, Boolean.FALSE.toString());
|
||||||
|
|
||||||
runner.setProperty(ListSFTP.REMOTE_PATH, REMOTE_DIRECTORY);
|
runner.setProperty(ListSFTP.REMOTE_PATH, REMOTE_DIRECTORY);
|
||||||
runner.setProperty(ListFile.TARGET_SYSTEM_TIMESTAMP_PRECISION, ListFile.PRECISION_MILLIS);
|
runner.setProperty(ListFile.TARGET_SYSTEM_TIMESTAMP_PRECISION, ListFile.PRECISION_MILLIS);
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
|
|
|
@ -67,6 +67,8 @@ class TestPutSFTP {
|
||||||
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
|
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
|
||||||
runner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
|
runner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
|
||||||
runner.setProperty(SFTPTransfer.PASSWORD, sshTestServer.getPassword());
|
runner.setProperty(SFTPTransfer.PASSWORD, sshTestServer.getPassword());
|
||||||
|
|
||||||
|
runner.setProperty(SFTPTransfer.USE_KEEPALIVE_ON_TIMEOUT, Boolean.FALSE.toString());
|
||||||
runner.setProperty(SFTPTransfer.STRICT_HOST_KEY_CHECKING, Boolean.FALSE.toString());
|
runner.setProperty(SFTPTransfer.STRICT_HOST_KEY_CHECKING, Boolean.FALSE.toString());
|
||||||
runner.setProperty(SFTPTransfer.BATCH_SIZE, Integer.toString(BATCH_SIZE));
|
runner.setProperty(SFTPTransfer.BATCH_SIZE, Integer.toString(BATCH_SIZE));
|
||||||
runner.setProperty(SFTPTransfer.REMOTE_PATH, REMOTE_DIRECTORY);
|
runner.setProperty(SFTPTransfer.REMOTE_PATH, REMOTE_DIRECTORY);
|
||||||
|
|
|
@ -34,7 +34,7 @@ public class SSHTestServer {
|
||||||
|
|
||||||
private String virtualFileSystemPath = "target/ssh_vfs/";
|
private String virtualFileSystemPath = "target/ssh_vfs/";
|
||||||
|
|
||||||
private String host = "127.0.0.1";
|
private final String host = "127.0.0.1";
|
||||||
|
|
||||||
private String username = "nifiuser";
|
private String username = "nifiuser";
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue