|
|
|
@ -4,7 +4,7 @@ import com.taobao.arthas.core.shell.cli.CliToken;
|
|
|
|
|
import org.junit.Assert;
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
|
|
|
|
|
import java.util.Iterator;
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
|
|
public class CliTokenImplTest {
|
|
|
|
@ -25,14 +25,86 @@ public class CliTokenImplTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void testSupportedPipeCharWithoutRegex() {
|
|
|
|
|
String[] expectedTextTokenValue = new String[]{"thread", "|", "grep", "xxx"};
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize("thread| grep xxx");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
String cmd = "thread| grep xxx";
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread | grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread |grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread'|' grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread '|' grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread '|'grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread\"|\" grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread \"|\" grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread \"|\"grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"thread| grep", "xxx"};
|
|
|
|
|
cmd = "thread'| 'grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread\"| \"grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"thread |grep", "xxx"};
|
|
|
|
|
cmd = "thread' |'grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "thread\" |\"grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"thread \"|\"grep", "xxx"};
|
|
|
|
|
cmd = "thread' \"|\"'grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"thread '|'grep", "xxx"};
|
|
|
|
|
cmd = "thread\" '|'\"grep xxx";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("thread | grep xxx");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("thread |grep xxx");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
@ -51,14 +123,85 @@ public class CliTokenImplTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void testSupportedPipeCharWithRegex() {
|
|
|
|
|
String[] expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB", "|", "grep", "classA"};
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize("trace -E classA|classB methodA|methodB| grep classA");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
String cmd = "trace -E classA|classB methodA|methodB| grep classA";
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB | grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB |grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB'|' grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB '|' grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB '|'grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("trace -E classA|classB methodA|methodB | grep classA");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB\"|\" grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("trace -E classA|classB methodA|methodB |grep classA");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB \"|\" grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB \"|\"grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB| grep", "classA"};
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB'| 'grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB\"| \"grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB |grep", "classA"};
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB' |'grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB\" |\"grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB '|'grep", "classA"};
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB\" '|'\"grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB \"|\"grep", "classA"};
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB' \"|\"'grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
@ -77,34 +220,247 @@ public class CliTokenImplTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void testUnSupportedPipeChar() {
|
|
|
|
|
String[] expectedTextTokenValue = new String[]{"thread|grep", "xxx"};
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize("thread|grep xxx");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
String cmd = "thread|grep xxx";
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "methodA|methodB|grep", "classA"};
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("trace -E classA|classB methodA|methodB|grep classA");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
cmd = "trace -E classA|classB methodA|methodB|grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"trace", "-E", "classA|classB", "|", "methodA|methodB", "|", "grep", "classA"};
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize("trace -E classA|classB| methodA|methodB | grep classA");
|
|
|
|
|
assertEquals(expectedTextTokenValue, actualTokens);
|
|
|
|
|
cmd = "trace -E classA|classB| methodA|methodB | grep classA";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void assertEquals(String[] expectedTextTokenValue, List<CliToken> actualTokens) {
|
|
|
|
|
removeBlankToken(actualTokens);
|
|
|
|
|
for (int i = 0; i < expectedTextTokenValue.length; i++) {
|
|
|
|
|
Assert.assertEquals(expectedTextTokenValue[i], actualTokens.get(i).value());
|
|
|
|
|
}
|
|
|
|
|
@Test
|
|
|
|
|
public void testSeparateRedirect() {
|
|
|
|
|
String[] expectedTextTokenValue = new String[]{"jad", "aaa", ">", "bbb"};
|
|
|
|
|
String cmd = "jad aaa> bbb";
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa > bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa >bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa '>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa '>'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\">\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa \">\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa \">\"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa >bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa' >'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\" >\"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa> bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\"> \"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'> 'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa\\r", ">", "bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'\\r>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\"\\r>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa'", ">", "bbb"};
|
|
|
|
|
cmd = "jad aaa\"'>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa'>'", "bbb"};
|
|
|
|
|
cmd = "jad aaa\"'>'\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa\">\"", "bbb"};
|
|
|
|
|
cmd = "jad aaa'\">\"' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void testSeparateRedirectAppend() {
|
|
|
|
|
String[] expectedTextTokenValue = new String[]{"jad", "aaa", ">>", "bbb"};
|
|
|
|
|
String cmd = "jad aaa>> bbb";
|
|
|
|
|
List<CliToken> actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa >> bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa >>bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'>>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa '>>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa '>>'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\">>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa \">>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa \">>\"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa >>bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa' >>'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\" >>\"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa>> bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\">> \"bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'>> 'bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa\\r", ">>", "bbb"};
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa'\\r>>' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
cmd = "jad aaa\"\\r>>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa'", ">>", "bbb"};
|
|
|
|
|
cmd = "jad aaa\"'>>\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa'>>'", "bbb"};
|
|
|
|
|
cmd = "jad aaa\"'>>'\" bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
|
|
|
|
|
expectedTextTokenValue = new String[]{"jad", "aaa\">>\"", "bbb"};
|
|
|
|
|
cmd = "jad aaa'\">>\"' bbb";
|
|
|
|
|
actualTokens = CliTokenImpl.tokenize(cmd);
|
|
|
|
|
assertEqualsIgnoreBlank(expectedTextTokenValue, actualTokens);
|
|
|
|
|
Assert.assertEquals(cmd, concatRaw(actualTokens));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void assertEqualsIgnoreBlank(String[] expectedTextTokenValue, List<CliToken> actualTokens) {
|
|
|
|
|
Assert.assertArrayEquals(expectedTextTokenValue, removeBlankToken(actualTokens));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static String[] removeBlankToken(List<CliToken> cliTokens) {
|
|
|
|
|
List<CliToken> copy = new ArrayList<>(cliTokens);
|
|
|
|
|
return copy.stream()
|
|
|
|
|
.filter(token -> !token.isBlank())
|
|
|
|
|
.map(CliToken::value)
|
|
|
|
|
.toArray(String[]::new);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void removeBlankToken(List<CliToken> cliTokens) {
|
|
|
|
|
CliToken blankToken = new CliTokenImpl(false, " ");
|
|
|
|
|
Iterator<CliToken> it = cliTokens.iterator();
|
|
|
|
|
while (it.hasNext()) {
|
|
|
|
|
CliToken token = it.next();
|
|
|
|
|
if (blankToken.equals(token)) {
|
|
|
|
|
it.remove();
|
|
|
|
|
}
|
|
|
|
|
private static String concatRaw(List<CliToken> tokens) {
|
|
|
|
|
StringBuilder builder = new StringBuilder();
|
|
|
|
|
for (CliToken token : tokens) {
|
|
|
|
|
builder.append(token.raw());
|
|
|
|
|
}
|
|
|
|
|
return builder.toString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|