Skip to content

Commit

Permalink
NIFI-12275 Disabled Keepalive in SFTP Tests
Browse files Browse the repository at this point in the history
This closes apache#7932

Signed-off-by: Chris Sampson <[email protected]>
  • Loading branch information
exceptionfactory authored and ChrisSamo632 committed Oct 25, 2023
1 parent 9eb2038 commit 2eb5b79
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 36 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -36,40 +36,42 @@

public class TestGetSFTP {

private TestRunner getSFTPRunner;
private TestRunner runner;
private static SSHTestServer sshTestServer;

@BeforeAll
public static void setupSSHD() throws IOException {
public static void startServer() throws IOException {
sshTestServer = new SSHTestServer();
sshTestServer.startServer();
}

@AfterAll
public static void cleanupSSHD() throws IOException {
public static void stopServer() throws IOException {
sshTestServer.stopServer();
}

@BeforeEach
public void setup(){
getSFTPRunner = TestRunners.newTestRunner(GetSFTP.class);
getSFTPRunner.setProperty(SFTPTransfer.HOSTNAME, "localhost");
getSFTPRunner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
getSFTPRunner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
getSFTPRunner.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 = TestRunners.newTestRunner(GetSFTP.class);
runner.setProperty(SFTPTransfer.HOSTNAME, sshTestServer.getHost());
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
runner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
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.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
Expand All @@ -81,17 +83,17 @@ public void testGetSFTPFileBasicRead() throws IOException {
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.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
for(int i=1;i<5;i++){
for (int i = 1; i < 5 ; i++) {
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile" + i + ".txt");
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
}

getSFTPRunner.clearTransferState();
runner.clearTransferState();
}

@Test
Expand All @@ -105,17 +107,17 @@ public void testGetSFTPShouldNotThrowIOExceptionIfUserHomeDirNotExixts() throws
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile1.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
for (int i = 1; i < 3; i++) {
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile" + i + ".txt");
assertFalse(file1.toAbsolutePath().toFile().exists(), "File not deleted.");
}

getSFTPRunner.clearTransferState();
runner.clearTransferState();

} finally {
// set back the original value for 'user.home' system property
Expand All @@ -132,9 +134,9 @@ public void testGetSFTPIgnoreDottedFiles() throws IOException {
touchFile(sshTestServer.getVirtualFileSystemPath() + "testFile3.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
Path file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/testFile1.txt");
Expand All @@ -149,7 +151,7 @@ public void testGetSFTPIgnoreDottedFiles() throws IOException {
file1 = Paths.get(sshTestServer.getVirtualFileSystemPath() + "/.testFile4.txt");
assertTrue(file1.toAbsolutePath().toFile().exists(), "File deleted.");

getSFTPRunner.clearTransferState();
runner.clearTransferState();
}

private void touchFile(String file) throws IOException {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@
import org.apache.nifi.processor.VerifiableProcessor;
import org.apache.nifi.processor.util.list.AbstractListProcessor;
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.SSHTestServer;
import org.apache.nifi.reporting.InitializationException;
Expand Down Expand Up @@ -64,11 +63,14 @@ public void startServer() throws Exception {
sshServer = new SSHTestServer();
sshServer.startServer();
writeTempFile();

runner = TestRunners.newTestRunner(ListSFTP.class);
runner.setProperty(ListSFTP.HOSTNAME, sshServer.getHost());
runner.setProperty(ListSFTP.USERNAME, sshServer.getUsername());
runner.setProperty(SFTPTransfer.HOSTNAME, sshServer.getHost());
runner.setProperty(SFTPTransfer.USERNAME, sshServer.getUsername());
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(ListFile.TARGET_SYSTEM_TIMESTAMP_PRECISION, ListFile.PRECISION_MILLIS);
runner.assertValid();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,8 @@ void setRunner() throws IOException {
runner.setProperty(SFTPTransfer.PORT, Integer.toString(sshTestServer.getSSHPort()));
runner.setProperty(SFTPTransfer.USERNAME, sshTestServer.getUsername());
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.BATCH_SIZE, Integer.toString(BATCH_SIZE));
runner.setProperty(SFTPTransfer.REMOTE_PATH, REMOTE_DIRECTORY);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ public class SSHTestServer {

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";

Expand Down

0 comments on commit 2eb5b79

Please sign in to comment.