DecoratingHttp2ConnectionEncoder.consumeRemoteSettings must not throw if delegate is instance of Http2SettingsReceivedConsumer (#9343)
Motivation: b3dba317d797e21cc253bb6ad6776307297f612e introduced the concept of Http2SettingsReceivedConsumer but did not correctly inplement DecoratingHttp2ConnectionEncoder.consumeRemoteSettings(...). Modifications: - Add missing `else` around the throws - Add unit tests Result: Correctly implement DecoratingHttp2ConnectionEncoder.consumeRemoteSettings(...)
This commit is contained in:
parent
91d6e0ea8f
commit
4312e11316
@ -65,8 +65,9 @@ public class DecoratingHttp2ConnectionEncoder extends DecoratingHttp2FrameWriter
|
|||||||
public void consumeReceivedSettings(Http2Settings settings) {
|
public void consumeReceivedSettings(Http2Settings settings) {
|
||||||
if (delegate instanceof Http2SettingsReceivedConsumer) {
|
if (delegate instanceof Http2SettingsReceivedConsumer) {
|
||||||
((Http2SettingsReceivedConsumer) delegate).consumeReceivedSettings(settings);
|
((Http2SettingsReceivedConsumer) delegate).consumeReceivedSettings(settings);
|
||||||
|
} else {
|
||||||
|
throw new IllegalStateException("delegate " + delegate + " is not an instance of " +
|
||||||
|
Http2SettingsReceivedConsumer.class);
|
||||||
}
|
}
|
||||||
throw new IllegalStateException("delegate " + delegate + " is not an instance of " +
|
|
||||||
Http2SettingsReceivedConsumer.class);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2019 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.handler.codec.http2;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import static org.mockito.Mockito.eq;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
|
||||||
|
public class DecoratingHttp2ConnectionEncoderTest {
|
||||||
|
|
||||||
|
@Test(expected = IllegalStateException.class)
|
||||||
|
public void testConsumeReceivedSettingsThrows() {
|
||||||
|
Http2ConnectionEncoder encoder = mock(Http2ConnectionEncoder.class);
|
||||||
|
DecoratingHttp2ConnectionEncoder decoratingHttp2ConnectionEncoder =
|
||||||
|
new DecoratingHttp2ConnectionEncoder(encoder);
|
||||||
|
decoratingHttp2ConnectionEncoder.consumeReceivedSettings(Http2Settings.defaultSettings());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumeReceivedSettingsDelegate() {
|
||||||
|
TestHttp2ConnectionEncoder encoder = mock(TestHttp2ConnectionEncoder.class);
|
||||||
|
DecoratingHttp2ConnectionEncoder decoratingHttp2ConnectionEncoder =
|
||||||
|
new DecoratingHttp2ConnectionEncoder(encoder);
|
||||||
|
|
||||||
|
Http2Settings settings = Http2Settings.defaultSettings();
|
||||||
|
decoratingHttp2ConnectionEncoder.consumeReceivedSettings(Http2Settings.defaultSettings());
|
||||||
|
verify(encoder, times(1)).consumeReceivedSettings(eq(settings));
|
||||||
|
}
|
||||||
|
|
||||||
|
private interface TestHttp2ConnectionEncoder extends Http2ConnectionEncoder, Http2SettingsReceivedConsumer { }
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user