mirror of https://github.com/apache/nifi.git
NIFI-13625 Removed or Replaced System.out.println in Tests (#9150)
Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
parent
c5ed5c51e9
commit
f64e68b23c
|
@ -20,7 +20,6 @@ package org.apache.nifi.minifi.bootstrap.configuration.ingestors;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import okhttp3.Headers;
|
|
||||||
import okhttp3.MediaType;
|
import okhttp3.MediaType;
|
||||||
import okhttp3.OkHttpClient;
|
import okhttp3.OkHttpClient;
|
||||||
import okhttp3.Request;
|
import okhttp3.Request;
|
||||||
|
@ -68,11 +67,6 @@ public abstract class RestChangeIngestorCommonTest {
|
||||||
throw new IOException("Unexpected code " + response);
|
throw new IOException("Unexpected code " + response);
|
||||||
}
|
}
|
||||||
|
|
||||||
Headers responseHeaders = response.headers();
|
|
||||||
for (int i = 0; i < responseHeaders.size(); i++) {
|
|
||||||
System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals(RestChangeIngestor.GET_TEXT, response.body().string());
|
assertEquals(RestChangeIngestor.GET_TEXT, response.body().string());
|
||||||
verify(testNotifier, Mockito.never()).notifyListeners(Mockito.any(ByteBuffer.class));
|
verify(testNotifier, Mockito.never()).notifyListeners(Mockito.any(ByteBuffer.class));
|
||||||
}
|
}
|
||||||
|
@ -93,11 +87,6 @@ public abstract class RestChangeIngestorCommonTest {
|
||||||
throw new IOException("Unexpected code " + response);
|
throw new IOException("Unexpected code " + response);
|
||||||
}
|
}
|
||||||
|
|
||||||
Headers responseHeaders = response.headers();
|
|
||||||
for (int i = 0; i < responseHeaders.size(); i++) {
|
|
||||||
System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals("The result of notifying listeners:\nMockChangeListener successfully handled the configuration change\n", response.body().string());
|
assertEquals("The result of notifying listeners:\nMockChangeListener successfully handled the configuration change\n", response.body().string());
|
||||||
|
|
||||||
verify(testNotifier, Mockito.times(1)).notifyListeners(Mockito.eq(ByteBuffer.wrap(testString.getBytes())));
|
verify(testNotifier, Mockito.times(1)).notifyListeners(Mockito.eq(ByteBuffer.wrap(testString.getBytes())));
|
||||||
|
@ -119,11 +108,6 @@ public abstract class RestChangeIngestorCommonTest {
|
||||||
throw new IOException("Unexpected code " + response);
|
throw new IOException("Unexpected code " + response);
|
||||||
}
|
}
|
||||||
|
|
||||||
Headers responseHeaders = response.headers();
|
|
||||||
for (int i = 0; i < responseHeaders.size(); i++) {
|
|
||||||
System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals("Request received but instance is already running this config.", response.body().string());
|
assertEquals("Request received but instance is already running this config.", response.body().string());
|
||||||
|
|
||||||
verify(testNotifier, Mockito.never()).notifyListeners(Mockito.any());
|
verify(testNotifier, Mockito.never()).notifyListeners(Mockito.any());
|
||||||
|
|
|
@ -50,8 +50,6 @@ public class OrderedPropertiesTest {
|
||||||
String actualLine = actualReader.readLine();
|
String actualLine = actualReader.readLine();
|
||||||
if (!"#Tue Feb 21 11:03:08 EST 2017".equals(expectedLine)) {
|
if (!"#Tue Feb 21 11:03:08 EST 2017".equals(expectedLine)) {
|
||||||
assertEquals(expectedLine, actualLine);
|
assertEquals(expectedLine, actualLine);
|
||||||
} else {
|
|
||||||
System.out.println("Skipping timestamp comment line");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
assertNull(actualReader.readLine());
|
assertNull(actualReader.readLine());
|
||||||
|
|
|
@ -21,6 +21,8 @@ import org.apache.nifi.parameter.ParameterDescriptor;
|
||||||
import org.apache.nifi.parameter.ParameterLookup;
|
import org.apache.nifi.parameter.ParameterLookup;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -39,6 +41,8 @@ import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class TestStandardPreparedQuery {
|
public class TestStandardPreparedQuery {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestStandardPreparedQuery.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimpleReference() {
|
public void testSimpleReference() {
|
||||||
final Map<String, String> attrs = new HashMap<>();
|
final Map<String, String> attrs = new HashMap<>();
|
||||||
|
@ -69,7 +73,7 @@ public class TestStandardPreparedQuery {
|
||||||
assertEquals("world", prepared.evaluateExpressions(new StandardEvaluationContext(attrs), null));
|
assertEquals("world", prepared.evaluateExpressions(new StandardEvaluationContext(attrs), null));
|
||||||
}
|
}
|
||||||
final long nanos = System.nanoTime() - start;
|
final long nanos = System.nanoTime() - start;
|
||||||
System.out.println(TimeUnit.NANOSECONDS.toMillis(nanos));
|
logger.info("{}", TimeUnit.NANOSECONDS.toMillis(nanos));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -83,8 +87,7 @@ public class TestStandardPreparedQuery {
|
||||||
assertEquals("world", Query.evaluateExpressions("${xx}", attrs, ParameterLookup.EMPTY));
|
assertEquals("world", Query.evaluateExpressions("${xx}", attrs, ParameterLookup.EMPTY));
|
||||||
}
|
}
|
||||||
final long nanos = System.nanoTime() - start;
|
final long nanos = System.nanoTime() - start;
|
||||||
System.out.println(TimeUnit.NANOSECONDS.toMillis(nanos));
|
logger.info("{}", TimeUnit.NANOSECONDS.toMillis(nanos));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -89,10 +89,6 @@ public class TestHL7Query {
|
||||||
possibleValueMap.put("C", valuesC);
|
possibleValueMap.put("C", valuesC);
|
||||||
possibleValueMap.put("D", valuesD);
|
possibleValueMap.put("D", valuesD);
|
||||||
|
|
||||||
for (int i = 0; i < valuesA.size() * valuesB.size() * valuesC.size() * valuesD.size(); i++) {
|
|
||||||
System.out.println(i + " : " + HL7Query.assignAliases(possibleValueMap, i));
|
|
||||||
}
|
|
||||||
|
|
||||||
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 0), "a", "d", "e", "g");
|
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 0), "a", "d", "e", "g");
|
||||||
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 1), "b", "d", "e", "g");
|
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 1), "b", "d", "e", "g");
|
||||||
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 2), "c", "d", "e", "g");
|
verifyAssignments(HL7Query.assignAliases(possibleValueMap, 2), "c", "d", "e", "g");
|
||||||
|
|
|
@ -21,6 +21,8 @@ import org.junit.jupiter.api.BeforeAll;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import javax.security.auth.Subject;
|
import javax.security.auth.Subject;
|
||||||
import javax.security.auth.kerberos.KerberosPrincipal;
|
import javax.security.auth.kerberos.KerberosPrincipal;
|
||||||
|
@ -42,6 +44,8 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
|
||||||
public class KerberosUserIT {
|
public class KerberosUserIT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(KerberosUserIT.class);
|
||||||
|
|
||||||
private static KDCServer kdc;
|
private static KDCServer kdc;
|
||||||
|
|
||||||
private static KerberosPrincipal principal1;
|
private static KerberosPrincipal principal1;
|
||||||
|
@ -155,11 +159,11 @@ public class KerberosUserIT {
|
||||||
boolean performedRelogin = false;
|
boolean performedRelogin = false;
|
||||||
for (int i = 0; i < 30; i++) {
|
for (int i = 0; i < 30; i++) {
|
||||||
Thread.sleep(1000);
|
Thread.sleep(1000);
|
||||||
System.out.println("checkTGTAndRelogin #" + i);
|
logger.info("checkTGTAndRelogin #{}", i);
|
||||||
performedRelogin = user1.checkTGTAndRelogin();
|
performedRelogin = user1.checkTGTAndRelogin();
|
||||||
|
|
||||||
if (performedRelogin) {
|
if (performedRelogin) {
|
||||||
System.out.println("Performed relogin!");
|
logger.info("Performed relogin!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -179,7 +183,7 @@ public class KerberosUserIT {
|
||||||
long currentTimeMillis = System.currentTimeMillis();
|
long currentTimeMillis = System.currentTimeMillis();
|
||||||
long startMilli = kerberosTicket.getStartTime().toInstant().toEpochMilli();
|
long startMilli = kerberosTicket.getStartTime().toInstant().toEpochMilli();
|
||||||
long endMilli = kerberosTicket.getEndTime().toInstant().toEpochMilli();
|
long endMilli = kerberosTicket.getEndTime().toInstant().toEpochMilli();
|
||||||
System.out.println("New ticket is valid for " + TimeUnit.MILLISECONDS.toSeconds(endMilli - startMilli) + " seconds");
|
logger.info("New ticket is valid for {}", TimeUnit.MILLISECONDS.toSeconds(endMilli - startMilli) + " seconds");
|
||||||
assertTrue(startMilli < currentTimeMillis);
|
assertTrue(startMilli < currentTimeMillis);
|
||||||
assertTrue(endMilli > currentTimeMillis);
|
assertTrue(endMilli > currentTimeMillis);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,8 @@ package org.apache.nifi.stream.io;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.Timeout;
|
import org.junit.jupiter.api.Timeout;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -35,6 +37,8 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
@Disabled("Tests are time-based")
|
@Disabled("Tests are time-based")
|
||||||
public class TestLeakyBucketThrottler {
|
public class TestLeakyBucketThrottler {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestLeakyBucketThrottler.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Timeout(value = 10000, unit = TimeUnit.MILLISECONDS)
|
@Timeout(value = 10000, unit = TimeUnit.MILLISECONDS)
|
||||||
public void testOutputStreamInterface() throws IOException {
|
public void testOutputStreamInterface() throws IOException {
|
||||||
|
@ -144,7 +148,7 @@ public class TestLeakyBucketThrottler {
|
||||||
long millisElapsed = now - startMillis;
|
long millisElapsed = now - startMillis;
|
||||||
bytesWritten += data.length;
|
bytesWritten += data.length;
|
||||||
float bytesPerSec = (float) bytesWritten / (float) millisElapsed * 1000F;
|
float bytesPerSec = (float) bytesWritten / (float) millisElapsed * 1000F;
|
||||||
System.out.println(idx + " : copied data at a rate of " + bytesPerSec + " bytes/sec");
|
logger.info("{} : copied data at a rate of {} bytes/sec", idx, bytesPerSec);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,8 @@ package org.apache.nifi.stream.io.util;
|
||||||
import org.apache.nifi.stream.io.RepeatingInputStream;
|
import org.apache.nifi.stream.io.RepeatingInputStream;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -36,6 +38,8 @@ import static org.junit.jupiter.api.Assertions.assertLinesMatch;
|
||||||
|
|
||||||
public class TestLineDemarcator {
|
public class TestLineDemarcator {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestLineDemarcator.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSingleCharacterLines() throws IOException {
|
public void testSingleCharacterLines() throws IOException {
|
||||||
final String input = "A\nB\nC\rD\r\nE\r\nF\r\rG";
|
final String input = "A\nB\nC\rD\r\nE\r\nF\r\rG";
|
||||||
|
@ -120,7 +124,7 @@ public class TestLineDemarcator {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println("Took " + millis + " millis to demarcate " + count + " lines");
|
logger.info("Took {} millis to demarcate {} lines", millis, count);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@ package org.apache.nifi.wali;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.TestInfo;
|
import org.junit.jupiter.api.TestInfo;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
import org.wali.DummyRecord;
|
import org.wali.DummyRecord;
|
||||||
import org.wali.DummyRecordSerde;
|
import org.wali.DummyRecordSerde;
|
||||||
import org.wali.SerDeFactory;
|
import org.wali.SerDeFactory;
|
||||||
|
@ -50,6 +52,9 @@ import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class TestSequentialAccessWriteAheadLog {
|
public class TestSequentialAccessWriteAheadLog {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestSequentialAccessWriteAheadLog.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateWithExternalFile(TestInfo testInfo) throws IOException {
|
public void testUpdateWithExternalFile(TestInfo testInfo) throws IOException {
|
||||||
final DummyRecordSerde serde = new DummyRecordSerde();
|
final DummyRecordSerde serde = new DummyRecordSerde();
|
||||||
|
@ -369,11 +374,11 @@ public class TestSequentialAccessWriteAheadLog {
|
||||||
final String bps = NumberFormat.getInstance().format(bytesPerSecond);
|
final String bps = NumberFormat.getInstance().format(bytesPerSecond);
|
||||||
|
|
||||||
if (j == 0) {
|
if (j == 0) {
|
||||||
System.out.println(millis + " ms to insert " + updateCountPerThread * numThreads + " updates using " + numThreads
|
logger.info("{} ms to insert {} updates using {} threads, *as a warmup!* {} events per second, {} bytes per second",
|
||||||
+ " threads, *as a warmup!* " + eps + " events per second, " + bps + " bytes per second");
|
millis, updateCountPerThread * numThreads, numThreads, eps, bps);
|
||||||
} else {
|
} else {
|
||||||
System.out.println(millis + " ms to insert " + updateCountPerThread * numThreads + " updates using " + numThreads
|
logger.info("{} ms to insert {} updates using {} threads, {} events per second, {} bytes per second",
|
||||||
+ " threads, " + eps + " events per second, " + bps + " bytes per second");
|
millis, updateCountPerThread * numThreads, numThreads, eps, bps);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,7 +169,6 @@ public class PutDynamoDBTest extends AbstractDynamoDBTest {
|
||||||
|
|
||||||
final List<MockFlowFile> flowFiles = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
final List<MockFlowFile> flowFiles = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
||||||
for (final MockFlowFile flowFile : flowFiles) {
|
for (final MockFlowFile flowFile : flowFiles) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
assertEquals(document, new String(flowFile.toByteArray()));
|
assertEquals(document, new String(flowFile.toByteArray()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -191,14 +190,12 @@ public class PutDynamoDBTest extends AbstractDynamoDBTest {
|
||||||
|
|
||||||
final List<MockFlowFile> flowFilesFailed = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
final List<MockFlowFile> flowFilesFailed = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
||||||
for (final MockFlowFile flowFile : flowFilesFailed) {
|
for (final MockFlowFile flowFile : flowFilesFailed) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
||||||
assertEquals(item.length, flowFile.getSize());
|
assertEquals(item.length, flowFile.getSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<MockFlowFile> flowFilesSuccessful = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
final List<MockFlowFile> flowFilesSuccessful = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
||||||
for (final MockFlowFile flowFile : flowFilesSuccessful) {
|
for (final MockFlowFile flowFile : flowFilesSuccessful) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
assertEquals(document, new String(flowFile.toByteArray()));
|
assertEquals(document, new String(flowFile.toByteArray()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -221,14 +218,12 @@ public class PutDynamoDBTest extends AbstractDynamoDBTest {
|
||||||
|
|
||||||
final List<MockFlowFile> flowFilesFailed = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
final List<MockFlowFile> flowFilesFailed = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
||||||
for (final MockFlowFile flowFile : flowFilesFailed) {
|
for (final MockFlowFile flowFile : flowFilesFailed) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
||||||
assertEquals(item.length, flowFile.getSize());
|
assertEquals(item.length, flowFile.getSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<MockFlowFile> flowFilesSuccessful = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
final List<MockFlowFile> flowFilesSuccessful = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_SUCCESS);
|
||||||
for (final MockFlowFile flowFile : flowFilesSuccessful) {
|
for (final MockFlowFile flowFile : flowFilesSuccessful) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
assertEquals(document, new String(flowFile.toByteArray()));
|
assertEquals(document, new String(flowFile.toByteArray()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -250,7 +245,6 @@ public class PutDynamoDBTest extends AbstractDynamoDBTest {
|
||||||
final List<MockFlowFile> flowFiles = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
final List<MockFlowFile> flowFiles = putRunner.getFlowFilesForRelationship(AbstractDynamoDBProcessor.REL_FAILURE);
|
||||||
assertEquals(1, flowFiles.size());
|
assertEquals(1, flowFiles.size());
|
||||||
for (final MockFlowFile flowFile : flowFiles) {
|
for (final MockFlowFile flowFile : flowFiles) {
|
||||||
System.out.println(flowFile.getAttributes());
|
|
||||||
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
flowFile.assertAttributeExists(PutDynamoDB.AWS_DYNAMO_DB_ITEM_SIZE_ERROR);
|
||||||
assertEquals(item.length, flowFile.getSize());
|
assertEquals(item.length, flowFile.getSize());
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,8 @@ import org.apache.nifi.util.MockFlowFile;
|
||||||
import org.apache.nifi.util.TestRunner;
|
import org.apache.nifi.util.TestRunner;
|
||||||
import org.apache.nifi.util.TestRunners;
|
import org.apache.nifi.util.TestRunners;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
|
@ -35,6 +37,8 @@ import java.util.Map;
|
||||||
* Provides integration level testing with actual AWS S3 resources for {@link FetchS3Object} and requires additional configuration and resources to work.
|
* Provides integration level testing with actual AWS S3 resources for {@link FetchS3Object} and requires additional configuration and resources to work.
|
||||||
*/
|
*/
|
||||||
public class ITFetchS3Object extends AbstractS3IT {
|
public class ITFetchS3Object extends AbstractS3IT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(ITFetchS3Object.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimpleGet() throws IOException {
|
public void testSimpleGet() throws IOException {
|
||||||
putTestFile("test-file", getFileFromResourceName(SAMPLE_FILE_RESOURCE_NAME));
|
putTestFile("test-file", getFileFromResourceName(SAMPLE_FILE_RESOURCE_NAME));
|
||||||
|
@ -125,7 +129,7 @@ public class ITFetchS3Object extends AbstractS3IT {
|
||||||
out.assertContentEquals(new String(expectedBytes));
|
out.assertContentEquals(new String(expectedBytes));
|
||||||
|
|
||||||
for (final Map.Entry<String, String> entry : out.getAttributes().entrySet()) {
|
for (final Map.Entry<String, String> entry : out.getAttributes().entrySet()) {
|
||||||
System.out.println(entry.getKey() + " : " + entry.getValue());
|
logger.info("{}:{}", entry.getKey(), entry.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,8 @@ import org.apache.nifi.util.TestRunner;
|
||||||
import org.junit.jupiter.api.BeforeAll;
|
import org.junit.jupiter.api.BeforeAll;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
@ -81,7 +83,7 @@ public class ITPutS3Object extends AbstractS3IT {
|
||||||
|
|
||||||
final static Pattern reS3ETag = Pattern.compile("[0-9a-fA-f]{32}(-[0-9]+)?");
|
final static Pattern reS3ETag = Pattern.compile("[0-9a-fA-f]{32}(-[0-9]+)?");
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(ITPutS3Object.class);
|
||||||
private static String kmsKeyId = "";
|
private static String kmsKeyId = "";
|
||||||
private static String randomKeyMaterial = "";
|
private static String randomKeyMaterial = "";
|
||||||
|
|
||||||
|
@ -710,7 +712,7 @@ public class ITPutS3Object extends AbstractS3IT {
|
||||||
tempByteCount += megabyte.length;
|
tempByteCount += megabyte.length;
|
||||||
}
|
}
|
||||||
tempOut.close();
|
tempOut.close();
|
||||||
System.out.println("file size: " + tempByteCount);
|
logger.info("file size: {}", tempByteCount);
|
||||||
assertTrue(tempByteCount < S3_MINIMUM_PART_SIZE);
|
assertTrue(tempByteCount < S3_MINIMUM_PART_SIZE);
|
||||||
|
|
||||||
assertTrue(megabyte.length < S3_MINIMUM_PART_SIZE);
|
assertTrue(megabyte.length < S3_MINIMUM_PART_SIZE);
|
||||||
|
@ -754,7 +756,7 @@ public class ITPutS3Object extends AbstractS3IT {
|
||||||
tempByteCount += megabyte.length;
|
tempByteCount += megabyte.length;
|
||||||
}
|
}
|
||||||
tempOut.close();
|
tempOut.close();
|
||||||
System.out.println("file size: " + tempByteCount);
|
logger.info("file size: {}", tempByteCount);
|
||||||
assertTrue(tempByteCount > S3_MINIMUM_PART_SIZE && tempByteCount < S3_MAXIMUM_OBJECT_SIZE);
|
assertTrue(tempByteCount > S3_MINIMUM_PART_SIZE && tempByteCount < S3_MAXIMUM_OBJECT_SIZE);
|
||||||
assertTrue(tempByteCount > TEST_PARTSIZE_LONG);
|
assertTrue(tempByteCount > TEST_PARTSIZE_LONG);
|
||||||
|
|
||||||
|
@ -806,7 +808,7 @@ public class ITPutS3Object extends AbstractS3IT {
|
||||||
List<Tag> objectTags = result.getTagSet();
|
List<Tag> objectTags = result.getTagSet();
|
||||||
|
|
||||||
for (Tag tag : objectTags) {
|
for (Tag tag : objectTags) {
|
||||||
System.out.println("Tag Key : " + tag.getKey() + ", Tag Value : " + tag.getValue());
|
logger.info("Tag Key : {}, Tag Value : {}", tag.getKey(), tag.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
assertEquals(1, objectTags.size());
|
assertEquals(1, objectTags.size());
|
||||||
|
|
|
@ -64,8 +64,6 @@ public class TestMetricsFactory {
|
||||||
public void testGetVirtualMachineMetrics() {
|
public void testGetVirtualMachineMetrics() {
|
||||||
JvmMetrics virtualMachineMetrics = JmxJvmMetrics.getInstance();
|
JvmMetrics virtualMachineMetrics = JmxJvmMetrics.getInstance();
|
||||||
List<Metric> metrics = AzureLogAnalyticsMetricsFactory.getJvmMetrics(virtualMachineMetrics, "testcase", "tests");
|
List<Metric> metrics = AzureLogAnalyticsMetricsFactory.getJvmMetrics(virtualMachineMetrics, "testcase", "tests");
|
||||||
String metricsInString = gson.toJson(metrics);
|
|
||||||
System.out.println(metricsInString);
|
|
||||||
TestVerification.assertJVMMetrics(metrics);
|
TestVerification.assertJVMMetrics(metrics);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -248,7 +248,6 @@ class TestModifyCompression {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyCompression.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyCompression.REL_SUCCESS, 1);
|
||||||
MockFlowFile flowFile = runner.getFlowFilesForRelationship(ModifyCompression.REL_SUCCESS).getFirst();
|
MockFlowFile flowFile = runner.getFlowFilesForRelationship(ModifyCompression.REL_SUCCESS).getFirst();
|
||||||
System.err.println(new String(flowFile.toByteArray()));
|
|
||||||
flowFile.assertContentEquals(getSamplePath("SampleFile.txt"));
|
flowFile.assertContentEquals(getSamplePath("SampleFile.txt"));
|
||||||
flowFile.assertAttributeEquals(CoreAttributes.FILENAME.key(), "SampleFile.txt");
|
flowFile.assertAttributeEquals(CoreAttributes.FILENAME.key(), "SampleFile.txt");
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,7 +125,6 @@ public class TestJdbcClobReadable {
|
||||||
|
|
||||||
final byte[] serializedBytes = outStream.toByteArray();
|
final byte[] serializedBytes = outStream.toByteArray();
|
||||||
assertNotNull(serializedBytes);
|
assertNotNull(serializedBytes);
|
||||||
System.out.println("Avro serialized result size in bytes: " + serializedBytes.length);
|
|
||||||
|
|
||||||
st.close();
|
st.close();
|
||||||
con.close();
|
con.close();
|
||||||
|
@ -140,7 +139,6 @@ public class TestJdbcClobReadable {
|
||||||
while (dataFileReader.hasNext()) {
|
while (dataFileReader.hasNext()) {
|
||||||
record = dataFileReader.next(record);
|
record = dataFileReader.next(record);
|
||||||
assertEquals(someClob, record.get("SOMECLOB").toString(), "Unreadable code for this Clob value.");
|
assertEquals(someClob, record.get("SOMECLOB").toString(), "Unreadable code for this Clob value.");
|
||||||
System.out.println(record);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -240,24 +240,8 @@ public class TestJdbcCommon {
|
||||||
|
|
||||||
final byte[] serializedBytes = outStream.toByteArray();
|
final byte[] serializedBytes = outStream.toByteArray();
|
||||||
assertNotNull(serializedBytes);
|
assertNotNull(serializedBytes);
|
||||||
System.out.println("Avro serialized result size in bytes: " + serializedBytes.length);
|
|
||||||
|
|
||||||
st.close();
|
st.close();
|
||||||
|
|
||||||
// Deserialize bytes to records
|
|
||||||
final InputStream instream = new ByteArrayInputStream(serializedBytes);
|
|
||||||
|
|
||||||
final DatumReader<GenericRecord> datumReader = new GenericDatumReader<>();
|
|
||||||
try (final DataFileStream<GenericRecord> dataFileReader = new DataFileStream<>(instream, datumReader)) {
|
|
||||||
GenericRecord record = null;
|
|
||||||
while (dataFileReader.hasNext()) {
|
|
||||||
// Reuse record object by passing it to next(). This saves us from
|
|
||||||
// allocating and garbage collecting many objects for files with
|
|
||||||
// many items.
|
|
||||||
record = dataFileReader.next(record);
|
|
||||||
System.out.println(record);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -121,7 +121,6 @@ public class TestJdbcHugeStream {
|
||||||
record = dataFileReader.next(record);
|
record = dataFileReader.next(record);
|
||||||
recordsFromStream += 1;
|
recordsFromStream += 1;
|
||||||
}
|
}
|
||||||
System.out.println("total nr of records from stream: " + recordsFromStream);
|
|
||||||
assertEquals(nrOfRows, recordsFromStream);
|
assertEquals(nrOfRows, recordsFromStream);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -140,10 +139,6 @@ public class TestJdbcHugeStream {
|
||||||
|
|
||||||
static public void loadTestData2Database(Connection con, int nrOfPersons, int nrOfProducts, int nrOfRels) throws ClassNotFoundException, SQLException {
|
static public void loadTestData2Database(Connection con, int nrOfPersons, int nrOfProducts, int nrOfRels) throws ClassNotFoundException, SQLException {
|
||||||
|
|
||||||
System.out.println(createRandomName());
|
|
||||||
System.out.println(createRandomName());
|
|
||||||
System.out.println(createRandomName());
|
|
||||||
|
|
||||||
final Statement st = con.createStatement();
|
final Statement st = con.createStatement();
|
||||||
|
|
||||||
// tables may not exist, this is not serious problem.
|
// tables may not exist, this is not serious problem.
|
||||||
|
|
|
@ -16,21 +16,15 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.nifi.util.db;
|
package org.apache.nifi.util.db;
|
||||||
|
|
||||||
import org.apache.avro.file.DataFileStream;
|
|
||||||
import org.apache.avro.generic.GenericDatumReader;
|
|
||||||
import org.apache.avro.generic.GenericRecord;
|
|
||||||
import org.apache.avro.io.DatumReader;
|
|
||||||
import org.apache.nifi.util.file.FileUtils;
|
import org.apache.nifi.util.file.FileUtils;
|
||||||
import org.junit.jupiter.api.AfterEach;
|
import org.junit.jupiter.api.AfterEach;
|
||||||
import org.junit.jupiter.api.Assertions;
|
import org.junit.jupiter.api.Assertions;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.DriverManager;
|
import java.sql.DriverManager;
|
||||||
|
@ -84,7 +78,7 @@ public class TestJdbcTypesH2 {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSQLTypesMapping() throws ClassNotFoundException, SQLException, IOException {
|
public void testSQLTypesMapping() throws SQLException, IOException {
|
||||||
final Connection con = createConnection(dbPath);
|
final Connection con = createConnection(dbPath);
|
||||||
final Statement st = con.createStatement();
|
final Statement st = con.createStatement();
|
||||||
|
|
||||||
|
@ -106,26 +100,9 @@ public class TestJdbcTypesH2 {
|
||||||
|
|
||||||
final byte[] serializedBytes = outStream.toByteArray();
|
final byte[] serializedBytes = outStream.toByteArray();
|
||||||
Assertions.assertNotNull(serializedBytes);
|
Assertions.assertNotNull(serializedBytes);
|
||||||
System.out.println("Avro serialized result size in bytes: " + serializedBytes.length);
|
|
||||||
|
|
||||||
st.close();
|
st.close();
|
||||||
con.close();
|
con.close();
|
||||||
|
|
||||||
// Deserialize bytes to records
|
|
||||||
|
|
||||||
final InputStream instream = new ByteArrayInputStream(serializedBytes);
|
|
||||||
|
|
||||||
final DatumReader<GenericRecord> datumReader = new GenericDatumReader<>();
|
|
||||||
try (final DataFileStream<GenericRecord> dataFileReader = new DataFileStream<>(instream, datumReader)) {
|
|
||||||
GenericRecord record = null;
|
|
||||||
while (dataFileReader.hasNext()) {
|
|
||||||
// Reuse record object by passing it to next(). This saves us from
|
|
||||||
// allocating and garbage collecting many objects for files with
|
|
||||||
// many items.
|
|
||||||
record = dataFileReader.next(record);
|
|
||||||
System.out.println(record);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// verify H2 driver loading and get Connections works
|
// verify H2 driver loading and get Connections works
|
||||||
|
|
|
@ -58,6 +58,8 @@ import org.apache.nifi.serialization.record.RecordSchema;
|
||||||
import org.apache.nifi.serialization.record.type.RecordDataType;
|
import org.apache.nifi.serialization.record.type.RecordDataType;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
|
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
@ -67,6 +69,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
import static org.junit.jupiter.api.Assertions.fail;
|
import static org.junit.jupiter.api.Assertions.fail;
|
||||||
|
|
||||||
public class TestAvroTypeUtil {
|
public class TestAvroTypeUtil {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestAvroTypeUtil.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@EnabledIfSystemProperty(
|
@EnabledIfSystemProperty(
|
||||||
|
@ -104,7 +107,7 @@ public class TestAvroTypeUtil {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = System.currentTimeMillis() - start;
|
final long millis = System.currentTimeMillis() - start;
|
||||||
System.out.println(millis);
|
logger.info("{}", millis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -343,7 +343,6 @@ public class TestStandardSchemaValidator {
|
||||||
assertEquals(1, validationErrors.size());
|
assertEquals(1, validationErrors.size());
|
||||||
final ValidationError validationError = validationErrors.iterator().next();
|
final ValidationError validationError = validationErrors.iterator().next();
|
||||||
assertEquals("/name", validationError.getFieldName().get());
|
assertEquals("/name", validationError.getFieldName().get());
|
||||||
System.out.println(validationError);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@ import org.apache.nifi.components.ConfigVerificationResult;
|
||||||
import org.apache.nifi.util.MockFlowFile;
|
import org.apache.nifi.util.MockFlowFile;
|
||||||
import org.apache.nifi.util.TestRunner;
|
import org.apache.nifi.util.TestRunner;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -35,6 +37,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
public class FetchGCSObjectIT extends AbstractGCSIT {
|
public class FetchGCSObjectIT extends AbstractGCSIT {
|
||||||
static final String KEY = "delete-me";
|
static final String KEY = "delete-me";
|
||||||
static final byte[] CONTENT = {10, 11, 12};
|
static final byte[] CONTENT = {10, 11, 12};
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(FetchGCSObjectIT.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimpleFetch() throws Exception {
|
public void testSimpleFetch() throws Exception {
|
||||||
|
@ -60,7 +63,7 @@ public class FetchGCSObjectIT extends AbstractGCSIT {
|
||||||
ff.assertAttributeNotExists(StorageAttributes.ENCRYPTION_SHA256_ATTR);
|
ff.assertAttributeNotExists(StorageAttributes.ENCRYPTION_SHA256_ATTR);
|
||||||
|
|
||||||
for (final Map.Entry<String, String> entry : ff.getAttributes().entrySet()) {
|
for (final Map.Entry<String, String> entry : ff.getAttributes().entrySet()) {
|
||||||
System.out.println(entry.getKey() + ":" + entry.getValue());
|
logger.info("{}:{}", entry.getKey(), entry.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,8 @@ import com.google.cloud.storage.BlobId;
|
||||||
import org.apache.nifi.util.MockFlowFile;
|
import org.apache.nifi.util.MockFlowFile;
|
||||||
import org.apache.nifi.util.TestRunner;
|
import org.apache.nifi.util.TestRunner;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
@ -32,6 +34,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
* Integration tests for {@link PutGCSObject} which actually use Google Cloud resources.
|
* Integration tests for {@link PutGCSObject} which actually use Google Cloud resources.
|
||||||
*/
|
*/
|
||||||
public class PutGCSObjectIT extends AbstractGCSIT {
|
public class PutGCSObjectIT extends AbstractGCSIT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(PutGCSObjectIT.class);
|
||||||
private static final String KEY = "delete-me";
|
private static final String KEY = "delete-me";
|
||||||
private static final byte[] CONTENT = {12, 13, 14};
|
private static final byte[] CONTENT = {12, 13, 14};
|
||||||
|
|
||||||
|
@ -52,7 +55,7 @@ public class PutGCSObjectIT extends AbstractGCSIT {
|
||||||
flowFile.assertAttributeNotExists(ENCRYPTION_ALGORITHM_ATTR);
|
flowFile.assertAttributeNotExists(ENCRYPTION_ALGORITHM_ATTR);
|
||||||
|
|
||||||
for (Map.Entry<String, String> entry : flowFile.getAttributes().entrySet()) {
|
for (Map.Entry<String, String> entry : flowFile.getAttributes().entrySet()) {
|
||||||
System.out.println(entry.getKey() + ":" + entry.getValue());
|
logger.info("{}:{}", entry.getKey(), entry.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,7 +77,7 @@ public class PutGCSObjectIT extends AbstractGCSIT {
|
||||||
flowFile.assertAttributeExists(ENCRYPTION_ALGORITHM_ATTR);
|
flowFile.assertAttributeExists(ENCRYPTION_ALGORITHM_ATTR);
|
||||||
|
|
||||||
for (Map.Entry<String, String> entry : flowFile.getAttributes().entrySet()) {
|
for (Map.Entry<String, String> entry : flowFile.getAttributes().entrySet()) {
|
||||||
System.out.println(entry.getKey() + ":" + entry.getValue());
|
logger.info("{}:{}", entry.getKey(), entry.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -162,7 +162,6 @@ public abstract class AbstractTestRecordReaderWriter {
|
||||||
final RecordReader reader = createReader(fis, journalFile.getName(), tocReader, 2048)) {
|
final RecordReader reader = createReader(fis, journalFile.getName(), tocReader, 2048)) {
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
final StandardProvenanceEventRecord recovered = reader.nextRecord();
|
final StandardProvenanceEventRecord recovered = reader.nextRecord();
|
||||||
System.out.println(recovered);
|
|
||||||
assertNotNull(recovered);
|
assertNotNull(recovered);
|
||||||
assertEquals(i, recovered.getEventId());
|
assertEquals(i, recovered.getEventId());
|
||||||
assertEquals("nifi://unit-test", recovered.getTransitUri());
|
assertEquals("nifi://unit-test", recovered.getTransitUri());
|
||||||
|
@ -204,8 +203,6 @@ public abstract class AbstractTestRecordReaderWriter {
|
||||||
final RecordReader reader = createReader(fis, journalFile.getName(), tocReader, 2048)) {
|
final RecordReader reader = createReader(fis, journalFile.getName(), tocReader, 2048)) {
|
||||||
|
|
||||||
for (int i = 0; i < numEvents; i++) {
|
for (int i = 0; i < numEvents; i++) {
|
||||||
System.out.println(i);
|
|
||||||
|
|
||||||
final Optional<ProvenanceEventRecord> eventOption = reader.skipToEvent(i);
|
final Optional<ProvenanceEventRecord> eventOption = reader.skipToEvent(i);
|
||||||
assertTrue(eventOption.isPresent());
|
assertTrue(eventOption.isPresent());
|
||||||
assertEquals(i, eventOption.get().getEventId());
|
assertEquals(i, eventOption.get().getEventId());
|
||||||
|
|
|
@ -28,6 +28,8 @@ import org.apache.nifi.util.file.FileUtils;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
|
@ -47,6 +49,7 @@ import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
import static org.junit.jupiter.api.Assertions.assertNull;
|
import static org.junit.jupiter.api.Assertions.assertNull;
|
||||||
|
|
||||||
public class TestEventIdFirstSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter {
|
public class TestEventIdFirstSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestEventIdFirstSchemaRecordReaderWriter.class);
|
||||||
private final AtomicLong idGenerator = new AtomicLong(0L);
|
private final AtomicLong idGenerator = new AtomicLong(0L);
|
||||||
private File journalFile;
|
private File journalFile;
|
||||||
private File tocFile;
|
private File tocFile;
|
||||||
|
@ -452,7 +455,7 @@ public class TestEventIdFirstSchemaRecordReaderWriter extends AbstractTestRecord
|
||||||
}
|
}
|
||||||
|
|
||||||
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(ms + " ms total");
|
logger.info("{} ms total", ms);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -62,8 +62,11 @@ import org.apache.nifi.stream.io.NullOutputStream;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class TestSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter {
|
public class TestSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestSchemaRecordReaderWriter.class);
|
||||||
private final AtomicLong idGenerator = new AtomicLong(0L);
|
private final AtomicLong idGenerator = new AtomicLong(0L);
|
||||||
private File journalFile;
|
private File journalFile;
|
||||||
private File tocFile;
|
private File tocFile;
|
||||||
|
@ -110,7 +113,7 @@ public class TestSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(ms + " ms total");
|
logger.info("{} ms total", ms);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -307,7 +310,7 @@ public class TestSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter
|
||||||
|
|
||||||
final long nanos = System.nanoTime() - startNanos;
|
final long nanos = System.nanoTime() - startNanos;
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
||||||
System.out.println("Took " + millis + " millis to write " + numEvents + " events");
|
logger.info("Took {} millis to write {} events", millis, numEvents);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -358,7 +361,7 @@ public class TestSchemaRecordReaderWriter extends AbstractTestRecordReaderWriter
|
||||||
final double seconds = millis / 1000D;
|
final double seconds = millis / 1000D;
|
||||||
final long bytesPerSecond = (long) (totalRecordBytes / seconds);
|
final long bytesPerSecond = (long) (totalRecordBytes / seconds);
|
||||||
final long megaBytesPerSecond = bytesPerSecond / 1024 / 1024;
|
final long megaBytesPerSecond = bytesPerSecond / 1024 / 1024;
|
||||||
System.out.println("Took " + millis + " millis to read " + numEvents + " events or " + megaBytesPerSecond + " MB/sec");
|
logger.info("Took {} millis to read {} events or {} MB/sec", millis, numEvents, megaBytesPerSecond);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -38,6 +38,8 @@ import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -63,6 +65,7 @@ import static org.mockito.ArgumentMatchers.anyLong;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class TestPartitionedWriteAheadEventStore {
|
public class TestPartitionedWriteAheadEventStore {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestPartitionedWriteAheadEventStore.class);
|
||||||
private static final RecordWriterFactory writerFactory = (file, idGen, compress, createToc) -> RecordWriters.newSchemaRecordWriter(file, idGen, compress, createToc);
|
private static final RecordWriterFactory writerFactory = (file, idGen, compress, createToc) -> RecordWriters.newSchemaRecordWriter(file, idGen, compress, createToc);
|
||||||
private static final RecordReaderFactory readerFactory = (file, logs, maxChars) -> RecordReaders.newRecordReader(file, logs, maxChars);
|
private static final RecordReaderFactory readerFactory = (file, logs, maxChars) -> RecordReaders.newRecordReader(file, logs, maxChars);
|
||||||
|
|
||||||
|
@ -108,7 +111,7 @@ public class TestPartitionedWriteAheadEventStore {
|
||||||
task.call();
|
task.call();
|
||||||
final long nanos = System.nanoTime() - start;
|
final long nanos = System.nanoTime() - start;
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
||||||
System.out.println("Took " + millis + " ms to " + taskDescription);
|
logger.info("Took {} ms to {}", millis, taskDescription);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -45,8 +45,11 @@ import org.apache.nifi.provenance.toc.TocUtil;
|
||||||
import org.apache.nifi.provenance.toc.TocWriter;
|
import org.apache.nifi.provenance.toc.TocWriter;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class TestSelectiveRecordReaderEventIterator {
|
public class TestSelectiveRecordReaderEventIterator {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestSelectiveRecordReaderEventIterator.class);
|
||||||
|
|
||||||
private RecordWriter createWriter(final File file, final TocWriter tocWriter, final boolean compressed, final int uncompressedBlockSize) throws IOException {
|
private RecordWriter createWriter(final File file, final TocWriter tocWriter, final boolean compressed, final int uncompressedBlockSize) throws IOException {
|
||||||
return new EventIdFirstSchemaRecordWriter(file, new AtomicLong(0L), tocWriter, compressed, uncompressedBlockSize, IdentifierLookup.EMPTY);
|
return new EventIdFirstSchemaRecordWriter(file, new AtomicLong(0L), tocWriter, compressed, uncompressedBlockSize, IdentifierLookup.EMPTY);
|
||||||
|
@ -146,7 +149,7 @@ public class TestSelectiveRecordReaderEventIterator {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long ms = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(ms + " ms total");
|
logger.info("{} ms total", ms);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -116,9 +116,6 @@ public class TestVolatileProvenanceRepository {
|
||||||
}
|
}
|
||||||
|
|
||||||
assertEquals(10, submission.getResult().getMatchingEvents().size());
|
assertEquals(10, submission.getResult().getMatchingEvents().size());
|
||||||
for (final ProvenanceEventRecord match : submission.getResult().getMatchingEvents()) {
|
|
||||||
System.out.println(match);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -260,7 +260,6 @@ public class TestCompressContent {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(CompressContent.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(CompressContent.REL_SUCCESS, 1);
|
||||||
MockFlowFile flowFile = runner.getFlowFilesForRelationship(CompressContent.REL_SUCCESS).get(0);
|
MockFlowFile flowFile = runner.getFlowFilesForRelationship(CompressContent.REL_SUCCESS).get(0);
|
||||||
System.err.println(new String(flowFile.toByteArray()));
|
|
||||||
flowFile.assertContentEquals(Paths.get("src/test/resources/CompressedData/SampleFile.txt"));
|
flowFile.assertContentEquals(Paths.get("src/test/resources/CompressedData/SampleFile.txt"));
|
||||||
flowFile.assertAttributeEquals("filename", "SampleFile.txt");
|
flowFile.assertAttributeEquals("filename", "SampleFile.txt");
|
||||||
}
|
}
|
||||||
|
|
|
@ -106,7 +106,6 @@ public class TestDistributeLoad {
|
||||||
testRunner.assertQueueEmpty();
|
testRunner.assertQueueEmpty();
|
||||||
|
|
||||||
for (int i = 1; i <= 100; i++) {
|
for (int i = 1; i <= 100; i++) {
|
||||||
System.out.println(i);
|
|
||||||
testRunner.assertTransferCount(String.valueOf(i), (i == 50) ? 0 : 1);
|
testRunner.assertTransferCount(String.valueOf(i), (i == 50) ? 0 : 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,8 +97,6 @@ public class TestExecuteProcess {
|
||||||
|
|
||||||
final List<MockFlowFile> flowFiles = runner.getFlowFilesForRelationship(ExecuteProcess.REL_SUCCESS);
|
final List<MockFlowFile> flowFiles = runner.getFlowFilesForRelationship(ExecuteProcess.REL_SUCCESS);
|
||||||
for (final MockFlowFile flowFile : flowFiles) {
|
for (final MockFlowFile flowFile : flowFiles) {
|
||||||
System.out.println(flowFile);
|
|
||||||
System.out.println(new String(flowFile.toByteArray()));
|
|
||||||
flowFile.assertAttributeNotExists(CoreAttributes.MIME_TYPE.key());
|
flowFile.assertAttributeNotExists(CoreAttributes.MIME_TYPE.key());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -145,14 +143,12 @@ public class TestExecuteProcess {
|
||||||
runner.setProperty(ExecuteProcess.WORKING_DIR, workingDirName);
|
runner.setProperty(ExecuteProcess.WORKING_DIR, workingDirName);
|
||||||
|
|
||||||
File inFile = new File(workingDirName, testFile);
|
File inFile = new File(workingDirName, testFile);
|
||||||
System.out.println(inFile.getAbsolutePath());
|
|
||||||
|
|
||||||
runner.run();
|
runner.run();
|
||||||
|
|
||||||
final List<MockFlowFile> flowFiles = runner.getFlowFilesForRelationship(ExecuteProcess.REL_SUCCESS);
|
final List<MockFlowFile> flowFiles = runner.getFlowFilesForRelationship(ExecuteProcess.REL_SUCCESS);
|
||||||
long totalFlowFilesSize = 0;
|
long totalFlowFilesSize = 0;
|
||||||
for (final MockFlowFile flowFile : flowFiles) {
|
for (final MockFlowFile flowFile : flowFiles) {
|
||||||
System.out.println(flowFile);
|
|
||||||
totalFlowFilesSize += flowFile.getSize();
|
totalFlowFilesSize += flowFile.getSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -175,9 +171,6 @@ public class TestExecuteProcess {
|
||||||
runner.setProperty(ExecuteProcess.BATCH_DURATION, "150 millis");
|
runner.setProperty(ExecuteProcess.BATCH_DURATION, "150 millis");
|
||||||
|
|
||||||
File inFile = new File(workingDirName, testFile);
|
File inFile = new File(workingDirName, testFile);
|
||||||
System.out.println(inFile.getAbsolutePath());
|
|
||||||
|
|
||||||
// runner.run(1,false,true);
|
|
||||||
|
|
||||||
ProcessContext processContext = runner.getProcessContext();
|
ProcessContext processContext = runner.getProcessContext();
|
||||||
|
|
||||||
|
|
|
@ -956,7 +956,6 @@ public class TestLookupRecord {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(LookupRecord.REL_UNMATCHED);
|
runner.assertAllFlowFilesTransferred(LookupRecord.REL_UNMATCHED);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(LookupRecord.REL_UNMATCHED).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(LookupRecord.REL_UNMATCHED).get(0);
|
||||||
System.out.println(out.getContent());
|
|
||||||
out.assertContentEquals(new File("src/test/resources/TestLookupRecord/lookup-array-output-unmatched.json").toPath());
|
out.assertContentEquals(new File("src/test/resources/TestLookupRecord/lookup-array-output-unmatched.json").toPath());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,6 @@ import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -89,8 +88,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals(noHeaderFile);
|
out.assertContentEquals(noHeaderFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,8 +104,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals(noHeaderFile);
|
out.assertContentEquals(noHeaderFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -123,8 +118,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals("<<<FOOTER>>>".getBytes("UTF-8"));
|
out.assertContentEquals("<<<FOOTER>>>".getBytes("UTF-8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -169,8 +162,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals(noFooterFile);
|
out.assertContentEquals(noFooterFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,8 +176,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals(noFooterNoHeaderFile);
|
out.assertContentEquals(noFooterNoHeaderFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,8 +204,6 @@ public class TestModifyBytes {
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ModifyBytes.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ModifyBytes.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
System.out.println(outContent);
|
|
||||||
out.assertContentEquals("Dew".getBytes("UTF-8"));
|
out.assertContentEquals("Dew".getBytes("UTF-8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -905,7 +905,6 @@ public class TestQueryRecord {
|
||||||
runner.assertTransferCount(REL_NAME, 1);
|
runner.assertTransferCount(REL_NAME, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
||||||
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
||||||
System.out.println(new String(out.toByteArray()));
|
|
||||||
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n");
|
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -941,7 +940,6 @@ public class TestQueryRecord {
|
||||||
runner.assertTransferCount(REL_NAME, 1);
|
runner.assertTransferCount(REL_NAME, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
||||||
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
||||||
System.out.println(new String(out.toByteArray()));
|
|
||||||
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n\"Alice\",\n,\"36\"\n");
|
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n\"Alice\",\n,\"36\"\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -975,7 +973,6 @@ public class TestQueryRecord {
|
||||||
runner.assertTransferCount(REL_NAME, 1);
|
runner.assertTransferCount(REL_NAME, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
||||||
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
||||||
System.out.println(new String(out.toByteArray()));
|
|
||||||
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n");
|
out.assertContentEquals("\"name\",\"points\"\n\"Tom\",\"49\"\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1004,7 +1001,6 @@ public class TestQueryRecord {
|
||||||
runner.assertTransferCount(REL_NAME, 1);
|
runner.assertTransferCount(REL_NAME, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(REL_NAME).get(0);
|
||||||
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
out.assertAttributeEquals(QueryRecord.ROUTE_ATTRIBUTE_KEY, REL_NAME);
|
||||||
System.out.println(new String(out.toByteArray()));
|
|
||||||
out.assertContentEquals("\"name\",\"age\"\n");
|
out.assertContentEquals("\"name\",\"age\"\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1244,9 +1240,7 @@ public class TestQueryRecord {
|
||||||
|
|
||||||
// Iterate over the rest of the records to ensure that we read the entire stream. If we don't
|
// Iterate over the rest of the records to ensure that we read the entire stream. If we don't
|
||||||
// do this, we won't consume all of the data and as a result we will not close the stream properly
|
// do this, we won't consume all of the data and as a result we will not close the stream properly
|
||||||
Record record;
|
while (rs.next() != null) {
|
||||||
while ((record = rs.next()) != null) {
|
|
||||||
System.out.println(record);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return WriteResult.of(0, Collections.emptyMap());
|
return WriteResult.of(0, Collections.emptyMap());
|
||||||
|
|
|
@ -560,7 +560,6 @@ public class TestReplaceText {
|
||||||
runner.assertAllFlowFilesTransferred(ReplaceText.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ReplaceText.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
||||||
final String actual = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
final String actual = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
||||||
System.out.println(actual);
|
|
||||||
assertEquals(expected, actual);
|
assertEquals(expected, actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -831,7 +830,6 @@ public class TestReplaceText {
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
||||||
assertTrue(outContent.startsWith("abc.txt\t"));
|
assertTrue(outContent.startsWith("abc.txt\t"));
|
||||||
System.out.println(outContent);
|
|
||||||
assertTrue(outContent.endsWith("13\n"));
|
assertTrue(outContent.endsWith("13\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -852,7 +850,6 @@ public class TestReplaceText {
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
||||||
assertTrue(outContent.equals("attribute header\n\nabc.txt\n\ndata header\n\nHello\nWorld!\n\nfooter"));
|
assertTrue(outContent.equals("attribute header\n\nabc.txt\n\ndata header\n\nHello\nWorld!\n\nfooter"));
|
||||||
System.out.println(outContent);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -1437,7 +1434,6 @@ public class TestReplaceText {
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
||||||
final String outContent = translateNewLines(new String(out.toByteArray(), StandardCharsets.UTF_8));
|
final String outContent = translateNewLines(new String(out.toByteArray(), StandardCharsets.UTF_8));
|
||||||
assertTrue(outContent.startsWith("abc.txt\t"));
|
assertTrue(outContent.startsWith("abc.txt\t"));
|
||||||
System.out.println(outContent);
|
|
||||||
assertTrue(outContent.endsWith("193\n") || outContent.endsWith("203\r\n"));
|
assertTrue(outContent.endsWith("193\n") || outContent.endsWith("203\r\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1457,7 +1453,6 @@ public class TestReplaceText {
|
||||||
runner.assertAllFlowFilesTransferred(ReplaceText.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(ReplaceText.REL_SUCCESS, 1);
|
||||||
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
final MockFlowFile out = runner.getFlowFilesForRelationship(ReplaceText.REL_SUCCESS).get(0);
|
||||||
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
final String outContent = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
||||||
System.out.println(outContent);
|
|
||||||
final String expectedContent = "attribute header\n\nabc.txt\n\ndata header\n\nHello\n\n\nfooter\n"
|
final String expectedContent = "attribute header\n\nabc.txt\n\ndata header\n\nHello\n\n\nfooter\n"
|
||||||
+ "attribute header\n\nabc.txt\n\ndata header\n\nWorld!\n\nfooter\n";
|
+ "attribute header\n\nabc.txt\n\ndata header\n\nWorld!\n\nfooter\n";
|
||||||
assertEquals(expectedContent, outContent);
|
assertEquals(expectedContent, outContent);
|
||||||
|
|
|
@ -34,8 +34,6 @@ import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.DisabledOnOs;
|
import org.junit.jupiter.api.condition.DisabledOnOs;
|
||||||
import org.junit.jupiter.api.condition.OS;
|
import org.junit.jupiter.api.condition.OS;
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -65,7 +63,6 @@ import static org.junit.jupiter.api.Assertions.fail;
|
||||||
|
|
||||||
@DisabledOnOs({ OS.WINDOWS })
|
@DisabledOnOs({ OS.WINDOWS })
|
||||||
public class TestTailFile {
|
public class TestTailFile {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(TestTailFile.class);
|
|
||||||
|
|
||||||
private File file;
|
private File file;
|
||||||
private File existingFile;
|
private File existingFile;
|
||||||
|
@ -79,7 +76,6 @@ public class TestTailFile {
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
public void setup() throws IOException {
|
public void setup() throws IOException {
|
||||||
System.setProperty("org.slf4j.simpleLogger.log.org.apache.nifi.processors.standard", "TRACE");
|
|
||||||
clean();
|
clean();
|
||||||
|
|
||||||
file = new File("target/log.txt");
|
file = new File("target/log.txt");
|
||||||
|
@ -352,8 +348,6 @@ public class TestTailFile {
|
||||||
assertTrue(renamed);
|
assertTrue(renamed);
|
||||||
raf.getChannel().force(true);
|
raf.getChannel().force(true);
|
||||||
|
|
||||||
System.out.println("Wrote d\\n and rolled file");
|
|
||||||
|
|
||||||
// Create the new file
|
// Create the new file
|
||||||
final RandomAccessFile newFile = new RandomAccessFile(new File("target/log.txt"), "rw");
|
final RandomAccessFile newFile = new RandomAccessFile(new File("target/log.txt"), "rw");
|
||||||
newFile.write("new file\n".getBytes()); // This should not get consumed until the old file's last modified date indicates it's complete
|
newFile.write("new file\n".getBytes()); // This should not get consumed until the old file's last modified date indicates it's complete
|
||||||
|
@ -367,7 +361,6 @@ public class TestTailFile {
|
||||||
|
|
||||||
// Write to the file and trigger again.
|
// Write to the file and trigger again.
|
||||||
raf.write("e\nf".getBytes());
|
raf.write("e\nf".getBytes());
|
||||||
System.out.println("Wrote e\\nf");
|
|
||||||
runner.run(1, false, false);
|
runner.run(1, false, false);
|
||||||
|
|
||||||
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
||||||
|
@ -379,7 +372,6 @@ public class TestTailFile {
|
||||||
raf.write(0);
|
raf.write(0);
|
||||||
raf.write(0);
|
raf.write(0);
|
||||||
raf.write(0);
|
raf.write(0);
|
||||||
System.out.println("Wrote \\n\\0\\0\\0");
|
|
||||||
|
|
||||||
runner.run(1, false, false);
|
runner.run(1, false, false);
|
||||||
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
||||||
|
@ -389,7 +381,6 @@ public class TestTailFile {
|
||||||
// Truncate the NUL bytes and replace with additional data, ending with a new line. This should ingest the entire line of text.
|
// Truncate the NUL bytes and replace with additional data, ending with a new line. This should ingest the entire line of text.
|
||||||
raf.setLength(raf.length() - 3);
|
raf.setLength(raf.length() - 3);
|
||||||
raf.write("g\nh".getBytes());
|
raf.write("g\nh".getBytes());
|
||||||
System.out.println("Truncated the NUL bytes and replaced with g\\nh");
|
|
||||||
|
|
||||||
runner.run(1, false, false);
|
runner.run(1, false, false);
|
||||||
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
||||||
|
@ -405,7 +396,6 @@ public class TestTailFile {
|
||||||
|
|
||||||
// Set last modified time so that processor believes file to have not been modified in a very long time, then run again.
|
// Set last modified time so that processor believes file to have not been modified in a very long time, then run again.
|
||||||
assertTrue(rolledFile.setLastModified(500L));
|
assertTrue(rolledFile.setLastModified(500L));
|
||||||
System.out.println("Set lastModified on " + rolledFile + " to 500");
|
|
||||||
runner.run(1, false, false);
|
runner.run(1, false, false);
|
||||||
|
|
||||||
// Verify results
|
// Verify results
|
||||||
|
@ -429,14 +419,12 @@ public class TestTailFile {
|
||||||
runner.run();
|
runner.run();
|
||||||
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
||||||
runner.getFlowFilesForRelationship(TailFile.REL_SUCCESS).get(0).assertContentEquals("hello\n");
|
runner.getFlowFilesForRelationship(TailFile.REL_SUCCESS).get(0).assertContentEquals("hello\n");
|
||||||
System.out.println("Ingested 6 bytes");
|
|
||||||
runner.clearTransferState();
|
runner.clearTransferState();
|
||||||
|
|
||||||
// roll over the file
|
// roll over the file
|
||||||
raf.close();
|
raf.close();
|
||||||
file.renameTo(new File(file.getParentFile(), file.getName() + ".previous"));
|
file.renameTo(new File(file.getParentFile(), file.getName() + ".previous"));
|
||||||
raf = new RandomAccessFile(file, "rw");
|
raf = new RandomAccessFile(file, "rw");
|
||||||
System.out.println("Rolled over file to " + file.getName() + ".previous");
|
|
||||||
|
|
||||||
// truncate file
|
// truncate file
|
||||||
raf.setLength(0L);
|
raf.setLength(0L);
|
||||||
|
@ -447,7 +435,6 @@ public class TestTailFile {
|
||||||
Thread.sleep(1000L); // we need to wait at least one second because of the granularity of timestamps on many file systems.
|
Thread.sleep(1000L); // we need to wait at least one second because of the granularity of timestamps on many file systems.
|
||||||
raf.write("HELLO\n".getBytes());
|
raf.write("HELLO\n".getBytes());
|
||||||
|
|
||||||
System.out.println("Wrote out 6 bytes to tailed file");
|
|
||||||
runner.run();
|
runner.run();
|
||||||
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
runner.assertAllFlowFilesTransferred(TailFile.REL_SUCCESS, 1);
|
||||||
runner.getFlowFilesForRelationship(TailFile.REL_SUCCESS).get(0).assertContentEquals("HELLO\n");
|
runner.getFlowFilesForRelationship(TailFile.REL_SUCCESS).get(0).assertContentEquals("HELLO\n");
|
||||||
|
@ -876,7 +863,6 @@ public class TestTailFile {
|
||||||
runner.clearTransferState();
|
runner.clearTransferState();
|
||||||
|
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
logger.info("i = {}", i);
|
|
||||||
raf.write(String.valueOf(i).getBytes());
|
raf.write(String.valueOf(i).getBytes());
|
||||||
raf.write("\n".getBytes());
|
raf.write("\n".getBytes());
|
||||||
|
|
||||||
|
|
|
@ -33,8 +33,6 @@ public class TestMonitorDiskUsage {
|
||||||
|
|
||||||
final ComponentLog logger = Mockito.mock(ComponentLog.class);
|
final ComponentLog logger = Mockito.mock(ComponentLog.class);
|
||||||
Mockito.doAnswer(invocation -> {
|
Mockito.doAnswer(invocation -> {
|
||||||
final String message = (String) invocation.getArguments()[0];
|
|
||||||
System.out.println(message);
|
|
||||||
callCounter.incrementAndGet();
|
callCounter.incrementAndGet();
|
||||||
return null;
|
return null;
|
||||||
}).when(logger).warn(Mockito.anyString());
|
}).when(logger).warn(Mockito.anyString());
|
||||||
|
|
|
@ -39,6 +39,8 @@ import org.apache.nifi.stream.io.NullOutputStream;
|
||||||
import org.apache.nifi.util.MockComponentLog;
|
import org.apache.nifi.util.MockComponentLog;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
@ -55,6 +57,7 @@ import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
|
|
||||||
public class TestWriteAvroResultWithoutSchema extends TestWriteAvroResult {
|
public class TestWriteAvroResultWithoutSchema extends TestWriteAvroResult {
|
||||||
|
|
||||||
|
private static final Logger LOGGER = LoggerFactory.getLogger(TestWriteAvroResultWithoutSchema.class);
|
||||||
private final BlockingQueue<BinaryEncoder> encoderPool = new LinkedBlockingQueue<>(32);
|
private final BlockingQueue<BinaryEncoder> encoderPool = new LinkedBlockingQueue<>(32);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -121,6 +124,6 @@ public class TestWriteAvroResultWithoutSchema extends TestWriteAvroResult {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(millis);
|
LOGGER.info("{}", millis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,8 @@ import org.junit.jupiter.params.ParameterizedTest;
|
||||||
import org.junit.jupiter.params.provider.Arguments;
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
import org.junit.jupiter.params.provider.MethodSource;
|
import org.junit.jupiter.params.provider.MethodSource;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.BufferedInputStream;
|
import java.io.BufferedInputStream;
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
|
@ -53,6 +55,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
class TestInferJsonSchemaAccessStrategy {
|
class TestInferJsonSchemaAccessStrategy {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestInferJsonSchemaAccessStrategy.class);
|
||||||
private final SchemaInferenceEngine<JsonNode> timestampInference = new JsonSchemaInference(new TimeValueInference("yyyy-MM-dd", "HH:mm:ss", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
|
private final SchemaInferenceEngine<JsonNode> timestampInference = new JsonSchemaInference(new TimeValueInference("yyyy-MM-dd", "HH:mm:ss", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
|
||||||
private final SchemaInferenceEngine<JsonNode> noTimestampInference = new JsonSchemaInference(new TimeValueInference("yyyy-MM-dd", "HH:mm:ss", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
|
private final SchemaInferenceEngine<JsonNode> noTimestampInference = new JsonSchemaInference(new TimeValueInference("yyyy-MM-dd", "HH:mm:ss", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
|
||||||
|
|
||||||
|
@ -81,7 +84,7 @@ class TestInferJsonSchemaAccessStrategy {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(millis);
|
logger.info("{}", millis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,7 +112,7 @@ class TestInferJsonSchemaAccessStrategy {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println(millis);
|
logger.info("{}", millis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,6 +38,8 @@ import org.apache.nifi.util.EqualsWrapper;
|
||||||
import org.apache.nifi.util.MockComponentLog;
|
import org.apache.nifi.util.MockComponentLog;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -69,6 +71,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
|
||||||
class TestJsonTreeRowRecordReader {
|
class TestJsonTreeRowRecordReader {
|
||||||
|
private static final Logger LOGGER = LoggerFactory.getLogger(TestJsonTreeRowRecordReader.class);
|
||||||
private final String dateFormat = RecordFieldType.DATE.getDefaultFormat();
|
private final String dateFormat = RecordFieldType.DATE.getDefaultFormat();
|
||||||
private final String timeFormat = RecordFieldType.TIME.getDefaultFormat();
|
private final String timeFormat = RecordFieldType.TIME.getDefaultFormat();
|
||||||
private final String timestampFormat = RecordFieldType.TIMESTAMP.getDefaultFormat();
|
private final String timestampFormat = RecordFieldType.TIMESTAMP.getDefaultFormat();
|
||||||
|
@ -155,7 +158,7 @@ class TestJsonTreeRowRecordReader {
|
||||||
}
|
}
|
||||||
final long nanos = System.nanoTime() - start;
|
final long nanos = System.nanoTime() - start;
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
||||||
System.out.println("Took " + millis + " millis to read " + recordCount + " records");
|
LOGGER.info("Took {} millis to read {} records", millis, recordCount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,7 +187,7 @@ class TestJsonTreeRowRecordReader {
|
||||||
}
|
}
|
||||||
final long nanos = System.nanoTime() - start;
|
final long nanos = System.nanoTime() - start;
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(nanos);
|
||||||
System.out.println("Took " + millis + " millis to read " + recordCount + " records");
|
LOGGER.info("Took {} millis to read {} records", millis, recordCount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
|
|
||||||
package org.apache.nifi.syslog;
|
package org.apache.nifi.syslog;
|
||||||
|
|
||||||
import org.apache.nifi.avro.AvroTypeUtil;
|
|
||||||
import org.apache.nifi.serialization.MalformedRecordException;
|
import org.apache.nifi.serialization.MalformedRecordException;
|
||||||
import org.apache.nifi.serialization.record.Record;
|
import org.apache.nifi.serialization.record.Record;
|
||||||
import org.apache.nifi.syslog.attributes.SyslogAttributes;
|
import org.apache.nifi.syslog.attributes.SyslogAttributes;
|
||||||
|
@ -189,10 +188,4 @@ public class TestSyslogRecordReader {
|
||||||
deserializer.close();
|
deserializer.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeSchema() {
|
|
||||||
String s = SyslogReader.createRecordSchema().toString();
|
|
||||||
System.out.println(s);
|
|
||||||
System.out.println(AvroTypeUtil.extractAvroSchema( SyslogReader.createRecordSchema() ).toString(true));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,8 @@ import org.junit.jupiter.api.condition.DisabledOnOs;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
import org.junit.jupiter.api.condition.OS;
|
import org.junit.jupiter.api.condition.OS;
|
||||||
import org.opentest4j.AssertionFailedError;
|
import org.opentest4j.AssertionFailedError;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -44,8 +46,9 @@ import static org.apache.nifi.processors.stateful.analysis.AttributeRollingWindo
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class AttributeRollingWindowIT {
|
public class AttributeRollingWindowIT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(AttributeRollingWindowIT.class);
|
||||||
private static final double EPSILON = 0.000001d; // "Error" threshold for floating-point arithmetic
|
private static final double EPSILON = 0.000001d; // "Error" threshold for floating-point arithmetic
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFailureDueToBadAttribute() {
|
public void testFailureDueToBadAttribute() {
|
||||||
final TestRunner runner = TestRunners.newTestRunner(AttributeRollingWindow.class);
|
final TestRunner runner = TestRunners.newTestRunner(AttributeRollingWindow.class);
|
||||||
|
@ -238,7 +241,7 @@ public class AttributeRollingWindowIT {
|
||||||
try {
|
try {
|
||||||
assertTrue(Precision.equals(variance.getResult(), Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_VARIANCE_KEY)), EPSILON));
|
assertTrue(Precision.equals(variance.getResult(), Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_VARIANCE_KEY)), EPSILON));
|
||||||
} catch (AssertionFailedError ae) {
|
} catch (AssertionFailedError ae) {
|
||||||
System.err.println("Error at " + i + ": " + variance.getResult() + " != " + Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_VARIANCE_KEY)));
|
logger.error("Error at {}: {} != {}", i, variance.getResult(), Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_VARIANCE_KEY)));
|
||||||
}
|
}
|
||||||
assertTrue(Precision.equals(Math.sqrt(variance.getResult()), Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_STDDEV_KEY)), EPSILON));
|
assertTrue(Precision.equals(Math.sqrt(variance.getResult()), Double.parseDouble(flowFile.getAttribute(ROLLING_WINDOW_STDDEV_KEY)), EPSILON));
|
||||||
Thread.sleep(10L);
|
Thread.sleep(10L);
|
||||||
|
|
|
@ -26,7 +26,7 @@ import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
import static org.junit.jupiter.api.Assertions.assertNull;
|
import static org.junit.jupiter.api.Assertions.assertNull;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
public class TestRingBufferEventRepository {
|
public class TestRingBufferEventRepository {
|
||||||
|
|
||||||
|
@ -45,9 +45,10 @@ public class TestRingBufferEventRepository {
|
||||||
final long queryStart = System.nanoTime();
|
final long queryStart = System.nanoTime();
|
||||||
final StandardRepositoryStatusReport report = repo.reportTransferEvents(System.currentTimeMillis());
|
final StandardRepositoryStatusReport report = repo.reportTransferEvents(System.currentTimeMillis());
|
||||||
final long queryNanos = System.nanoTime() - queryStart;
|
final long queryNanos = System.nanoTime() - queryStart;
|
||||||
System.out.println(report);
|
assertNotNull(report);
|
||||||
System.out.println("Insert: " + TimeUnit.MILLISECONDS.convert(insertNanos, TimeUnit.NANOSECONDS));
|
assertTrue(TimeUnit.MILLISECONDS.convert(insertNanos, TimeUnit.NANOSECONDS) > 0L);
|
||||||
System.out.println("Query: " + TimeUnit.MILLISECONDS.convert(queryNanos, TimeUnit.NANOSECONDS));
|
assertTrue(TimeUnit.MILLISECONDS.convert(queryNanos, TimeUnit.NANOSECONDS) >= 0L);
|
||||||
|
|
||||||
repo.close();
|
repo.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,8 @@ import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.Timeout;
|
import org.junit.jupiter.api.Timeout;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -54,6 +56,7 @@ import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class TestSwappablePriorityQueue {
|
public class TestSwappablePriorityQueue {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestSwappablePriorityQueue.class);
|
||||||
|
|
||||||
private MockSwapManager swapManager;
|
private MockSwapManager swapManager;
|
||||||
private final List<String> events = new ArrayList<>();
|
private final List<String> events = new ArrayList<>();
|
||||||
|
@ -136,7 +139,7 @@ public class TestSwappablePriorityQueue {
|
||||||
queue.setPriorities(Collections.singletonList(iAttributePrioritizer));
|
queue.setPriorities(Collections.singletonList(iAttributePrioritizer));
|
||||||
|
|
||||||
for (final int queueSize : new int[] {1, 9999, 10_000, 10_001, 19_999, 20_000, 20_001}) {
|
for (final int queueSize : new int[] {1, 9999, 10_000, 10_001, 19_999, 20_000, 20_001}) {
|
||||||
System.out.println("Queue Size: " + queueSize);
|
logger.info("Queue Size: {}", queueSize);
|
||||||
|
|
||||||
for (int i = 0; i < queueSize; i++) {
|
for (int i = 0; i < queueSize; i++) {
|
||||||
final MockFlowFileRecord flowFile = new MockFlowFileRecord(Map.of("i", String.valueOf(i)), i);
|
final MockFlowFileRecord flowFile = new MockFlowFileRecord(Map.of("i", String.valueOf(i)), i);
|
||||||
|
@ -253,7 +256,7 @@ public class TestSwappablePriorityQueue {
|
||||||
}
|
}
|
||||||
|
|
||||||
ffs.forEach(queue::put);
|
ffs.forEach(queue::put);
|
||||||
System.out.println(StringUtils.join(attrs, ", "));
|
logger.info(StringUtils.join(attrs, ", "));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -68,6 +68,8 @@ import org.junit.jupiter.api.Test;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
import org.mockito.invocation.InvocationOnMock;
|
import org.mockito.invocation.InvocationOnMock;
|
||||||
import org.mockito.stubbing.Answer;
|
import org.mockito.stubbing.Answer;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -123,6 +125,7 @@ import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class StandardProcessSessionIT {
|
public class StandardProcessSessionIT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(StandardProcessSessionIT.class);
|
||||||
private static final Relationship FAKE_RELATIONSHIP = new Relationship.Builder().name("FAKE").build();
|
private static final Relationship FAKE_RELATIONSHIP = new Relationship.Builder().name("FAKE").build();
|
||||||
|
|
||||||
private StandardProcessSession session;
|
private StandardProcessSession session;
|
||||||
|
@ -1793,11 +1796,11 @@ public class StandardProcessSessionIT {
|
||||||
try {
|
try {
|
||||||
standardProcessSessions[i].read(flowFile, in -> StreamUtils.fillBuffer(in, buff));
|
standardProcessSessions[i].read(flowFile, in -> StreamUtils.fillBuffer(in, buff));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
System.out.println("Failed at file:" + i);
|
logger.error("Failed at file:{}", i);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
if (i % 1000 == 0) {
|
if (i % 1000 == 0) {
|
||||||
System.out.println("i:" + i);
|
logger.info("i:{}", i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,8 @@ import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.Timeout;
|
import org.junit.jupiter.api.Timeout;
|
||||||
import org.junit.jupiter.api.condition.DisabledOnOs;
|
import org.junit.jupiter.api.condition.DisabledOnOs;
|
||||||
import org.junit.jupiter.api.condition.OS;
|
import org.junit.jupiter.api.condition.OS;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -70,6 +72,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
public class TestFileSystemRepository {
|
public class TestFileSystemRepository {
|
||||||
|
|
||||||
public static final File helloWorldFile = new File("src/test/resources/hello.txt");
|
public static final File helloWorldFile = new File("src/test/resources/hello.txt");
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestFileSystemRepository.class);
|
||||||
|
|
||||||
private FileSystemRepository repository = null;
|
private FileSystemRepository repository = null;
|
||||||
private StandardResourceClaimManager claimManager = null;
|
private StandardResourceClaimManager claimManager = null;
|
||||||
|
@ -117,8 +120,8 @@ public class TestFileSystemRepository {
|
||||||
final long mb = bytesToWrite / (1024 * 1024);
|
final long mb = bytesToWrite / (1024 * 1024);
|
||||||
final long seconds = millis / 1000L;
|
final long seconds = millis / 1000L;
|
||||||
final double mbps = (double) mb / (double) seconds;
|
final double mbps = (double) mb / (double) seconds;
|
||||||
System.out.println("Took " + millis + " millis to write " + contentSize + " bytes " + iterations + " times (total of "
|
logger.info("Took {} millis to write {} bytes {} times (total of {} bytes) for a write rate of {} MB/s",
|
||||||
+ NumberFormat.getNumberInstance(Locale.US).format(bytesToWrite) + " bytes) for a write rate of " + mbps + " MB/s");
|
millis, contentSize, iterations, NumberFormat.getNumberInstance(Locale.US).format(bytesToWrite), mbps);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -51,6 +51,8 @@ import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
import org.mockito.stubbing.Answer;
|
import org.mockito.stubbing.Answer;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
import org.wali.WriteAheadRepository;
|
import org.wali.WriteAheadRepository;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -79,7 +81,7 @@ import static org.mockito.Mockito.doAnswer;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class TestWriteAheadFlowFileRepository {
|
public class TestWriteAheadFlowFileRepository {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestWriteAheadFlowFileRepository.class);
|
||||||
private static NiFiProperties niFiProperties;
|
private static NiFiProperties niFiProperties;
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
|
@ -408,9 +410,11 @@ public class TestWriteAheadFlowFileRepository {
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
if (j == 0) {
|
if (j == 0) {
|
||||||
System.out.println(millis + " ms to insert " + updateCountPerThread * numThreads + " updates using " + numPartitions + " partitions and " + numThreads + " threads, *as a warmup!*");
|
logger.info("{} ms to insert {} updates using {} partitions and {} threads, *as a warmup!*",
|
||||||
|
millis, updateCountPerThread * numThreads, numPartitions, numThreads);
|
||||||
} else {
|
} else {
|
||||||
System.out.println(millis + " ms to insert " + updateCountPerThread * numThreads + " updates using " + numPartitions + " partitions and " + numThreads + " threads");
|
logger.info("{} ms to insert {} updates using {} partitions and {} threads",
|
||||||
|
millis, updateCountPerThread * numThreads, numPartitions, numThreads);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,8 @@ import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.BufferedInputStream;
|
import java.io.BufferedInputStream;
|
||||||
import java.io.BufferedOutputStream;
|
import java.io.BufferedOutputStream;
|
||||||
|
@ -56,6 +58,8 @@ import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
|
||||||
public class TestSchemaSwapSerializerDeserializer {
|
public class TestSchemaSwapSerializerDeserializer {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(TestSchemaSwapSerializerDeserializer.class);
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
public void setup() {
|
public void setup() {
|
||||||
MockFlowFile.resetIdGenerator();
|
MockFlowFile.resetIdGenerator();
|
||||||
|
@ -194,6 +198,6 @@ public class TestSchemaSwapSerializerDeserializer {
|
||||||
}
|
}
|
||||||
|
|
||||||
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
final long millis = TimeUnit.NANOSECONDS.toMillis(System.nanoTime() - start);
|
||||||
System.out.println("Wrote " + iterations + " Swap Files in " + millis + " millis");
|
logger.info("Wrote {} Swap Files in {} millis", iterations, millis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,6 @@ import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
|
@ -48,9 +47,6 @@ public class TestJAXBVersionedProcessGroupSerializer {
|
||||||
final ByteArrayOutputStream out = new ByteArrayOutputStream();
|
final ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
serializer.serialize(1, processGroup1, out);
|
serializer.serialize(1, processGroup1, out);
|
||||||
|
|
||||||
final String snapshotStr = new String(out.toByteArray(), StandardCharsets.UTF_8);
|
|
||||||
//System.out.println(snapshotStr);
|
|
||||||
|
|
||||||
final ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray());
|
final ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray());
|
||||||
in.mark(1024);
|
in.mark(1024);
|
||||||
final int version = serializer.readDataModelVersion(in);
|
final int version = serializer.readDataModelVersion(in);
|
||||||
|
|
|
@ -25,11 +25,15 @@ import org.apache.nifi.stateless.flow.StatelessDataflow;
|
||||||
import org.apache.nifi.stateless.flow.TriggerResult;
|
import org.apache.nifi.stateless.flow.TriggerResult;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
import org.junit.jupiter.api.condition.EnabledIfSystemProperty;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class StatelessPerformanceIT extends StatelessSystemIT {
|
public class StatelessPerformanceIT extends StatelessSystemIT {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(StatelessPerformanceIT.class);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@EnabledIfSystemProperty(named = "nifi.test.performance", matches = "true")
|
@EnabledIfSystemProperty(named = "nifi.test.performance", matches = "true")
|
||||||
public void testCreateDestroyPerf() throws InterruptedException {
|
public void testCreateDestroyPerf() throws InterruptedException {
|
||||||
|
@ -58,7 +62,7 @@ public class StatelessPerformanceIT extends StatelessSystemIT {
|
||||||
result.acknowledge();
|
result.acknowledge();
|
||||||
}
|
}
|
||||||
final long millis = System.currentTimeMillis() - start;
|
final long millis = System.currentTimeMillis() - start;
|
||||||
System.out.println("Took " + millis + " millis to run " + iterations + " iterations");
|
logger.info("Took {} millis to run {} iterations", millis, iterations);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,7 @@ public class NarUploadPythonIT extends NiFiSystemIT {
|
||||||
assertNotNull(processorTypeFromUploadedNar);
|
assertNotNull(processorTypeFromUploadedNar);
|
||||||
|
|
||||||
final BundleDTO processorBundle = processorTypeFromUploadedNar.getBundle();
|
final BundleDTO processorBundle = processorTypeFromUploadedNar.getBundle();
|
||||||
System.out.println(processorBundle.getGroup() + " - " + processorBundle.getArtifact() + " - " + processorBundle.getVersion());
|
logger.info("{} - {} - {}", processorBundle.getGroup(), processorBundle.getArtifact(), processorBundle.getVersion());
|
||||||
|
|
||||||
// Create instance of the WriteBech32Charset processor, and connect a GenerateFlowFile to it
|
// Create instance of the WriteBech32Charset processor, and connect a GenerateFlowFile to it
|
||||||
final ProcessorEntity generateProcessor = getClientUtil().createProcessor("GenerateFlowFile");
|
final ProcessorEntity generateProcessor = getClientUtil().createProcessor("GenerateFlowFile");
|
||||||
|
|
|
@ -66,7 +66,6 @@ public class TestBucketsResult {
|
||||||
result.write(printStream);
|
result.write(printStream);
|
||||||
|
|
||||||
final String resultOut = new String(outputStream.toByteArray(), StandardCharsets.UTF_8);
|
final String resultOut = new String(outputStream.toByteArray(), StandardCharsets.UTF_8);
|
||||||
//System.out.println(resultOut);
|
|
||||||
|
|
||||||
final String expected = "\n" +
|
final String expected = "\n" +
|
||||||
"# Name Id Description \n" +
|
"# Name Id Description \n" +
|
||||||
|
|
Loading…
Reference in New Issue