Fix test failure in SlicedByteBuf / Add tests for built-in ByteBufProcessor impls
- Related: #1378
This commit is contained in:
parent
98531313de
commit
9804741fb3
@ -276,6 +276,27 @@ public class SlicedByteBuf extends AbstractDerivedByteBuf {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int forEachByte(int fromIndex, int toIndex, ByteBufProcessor processor) {
|
public int forEachByte(int fromIndex, int toIndex, ByteBufProcessor processor) {
|
||||||
return buffer.forEachByte(fromIndex + adjustment, toIndex + adjustment, processor);
|
int ret = buffer.forEachByte(fromIndex + adjustment, toIndex + adjustment, new SlicedByteBufProcessor(processor));
|
||||||
|
if (ret >= adjustment) {
|
||||||
|
return ret - adjustment;
|
||||||
|
} else {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private final class SlicedByteBufProcessor implements ByteBufProcessor {
|
||||||
|
private final ByteBufProcessor processor;
|
||||||
|
|
||||||
|
SlicedByteBufProcessor(ByteBufProcessor processor) {
|
||||||
|
if (processor == null) {
|
||||||
|
throw new NullPointerException("processor");
|
||||||
|
}
|
||||||
|
this.processor = processor;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int process(ByteBuf buf, int index, byte value) throws Exception {
|
||||||
|
return processor.process(buf, index - adjustment, value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,15 +15,16 @@
|
|||||||
*/
|
*/
|
||||||
package io.netty.buffer;
|
package io.netty.buffer;
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
|
||||||
import io.netty.util.CharsetUtil;
|
import io.netty.util.CharsetUtil;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the index-finding capabilities of channel buffers
|
* Tests the index-finding capabilities of channel buffers
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
public class ByteBufIndexFinderTest {
|
public class ByteBufIndexFinderTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2013 The Netty Project
|
||||||
|
*
|
||||||
|
* The Netty Project licenses this file to you under the Apache License,
|
||||||
|
* version 2.0 (the "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at:
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package io.netty.buffer;
|
||||||
|
|
||||||
|
import io.netty.util.CharsetUtil;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
public class ByteBufProcessorTest {
|
||||||
|
@Test
|
||||||
|
public void testForward() {
|
||||||
|
ByteBuf buf = Unpooled.copiedBuffer("abc\r\n\ndef\r\rghi\n\njkl\0\0mno \t\tx", CharsetUtil.ISO_8859_1);
|
||||||
|
|
||||||
|
assertEquals(3, buf.forEachByte(0, buf.capacity(), ByteBufProcessor.FIND_CRLF));
|
||||||
|
assertEquals(6, buf.forEachByte(3, buf.capacity(), ByteBufProcessor.FIND_NON_CRLF));
|
||||||
|
assertEquals(9, buf.forEachByte(6, buf.capacity(), ByteBufProcessor.FIND_CR));
|
||||||
|
assertEquals(11, buf.forEachByte(9, buf.capacity(), ByteBufProcessor.FIND_NON_CR));
|
||||||
|
assertEquals(14, buf.forEachByte(11, buf.capacity(), ByteBufProcessor.FIND_LF));
|
||||||
|
assertEquals(16, buf.forEachByte(14, buf.capacity(), ByteBufProcessor.FIND_NON_LF));
|
||||||
|
assertEquals(19, buf.forEachByte(16, buf.capacity(), ByteBufProcessor.FIND_NUL));
|
||||||
|
assertEquals(21, buf.forEachByte(19, buf.capacity(), ByteBufProcessor.FIND_NON_NUL));
|
||||||
|
assertEquals(24, buf.forEachByte(21, buf.capacity(), ByteBufProcessor.FIND_LINEAR_WHITESPACE));
|
||||||
|
assertEquals(28, buf.forEachByte(24, buf.capacity(), ByteBufProcessor.FIND_NON_LINEAR_WHITESPACE));
|
||||||
|
assertEquals(-1, buf.forEachByte(28, buf.capacity(), ByteBufProcessor.FIND_LINEAR_WHITESPACE));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBackward() {
|
||||||
|
ByteBuf buf = Unpooled.copiedBuffer("abc\r\n\ndef\r\rghi\n\njkl\0\0mno \t\tx", CharsetUtil.ISO_8859_1);
|
||||||
|
|
||||||
|
assertEquals(27, buf.forEachByte(buf.capacity() - 1, -1, ByteBufProcessor.FIND_LINEAR_WHITESPACE));
|
||||||
|
assertEquals(23, buf.forEachByte(27, -1, ByteBufProcessor.FIND_NON_LINEAR_WHITESPACE));
|
||||||
|
assertEquals(20, buf.forEachByte(23, -1, ByteBufProcessor.FIND_NUL));
|
||||||
|
assertEquals(18, buf.forEachByte(20, -1, ByteBufProcessor.FIND_NON_NUL));
|
||||||
|
assertEquals(15, buf.forEachByte(18, -1, ByteBufProcessor.FIND_LF));
|
||||||
|
assertEquals(13, buf.forEachByte(15, -1, ByteBufProcessor.FIND_NON_LF));
|
||||||
|
assertEquals(10, buf.forEachByte(13, -1, ByteBufProcessor.FIND_CR));
|
||||||
|
assertEquals(8, buf.forEachByte(10, -1, ByteBufProcessor.FIND_NON_CR));
|
||||||
|
assertEquals(5, buf.forEachByte(8, -1, ByteBufProcessor.FIND_CRLF));
|
||||||
|
assertEquals(2, buf.forEachByte(5, -1, ByteBufProcessor.FIND_NON_CRLF));
|
||||||
|
assertEquals(-1, buf.forEachByte(2, -1, ByteBufProcessor.FIND_CRLF));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user