blob: a32b5581eea4a6a28b054dd7ab44bfdeeb20c20f [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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 org.apache.servicecomb.it.testcase;
import static org.junit.Assert.assertEquals;
import org.apache.servicecomb.foundation.test.scaffolding.model.Media;
import org.apache.servicecomb.it.Consumers;
import org.apache.servicecomb.it.junit.ITJUnitUtils;
import org.junit.Test;
public class TestParamCodec {
interface ParamCodecSchemaIntf {
String spaceCharCodec(String pathVal, String q);
}
interface ParamCodecSchemaIntfRestOnly {
Media enumSpecialName(Media media);
}
static Consumers<ParamCodecSchemaIntf> consumers = new Consumers<>("paramCodec", ParamCodecSchemaIntf.class);
static Consumers<ParamCodecSchemaIntfRestOnly> consumersRestOnly = new Consumers<>("paramCodecRestOnly",
ParamCodecSchemaIntfRestOnly.class);
@Test
public void spaceCharEncode_intf() {
String paramString = "a%2B+%20b%% %20c";
String paramQueryStringResult = "a%2B %20b%% %20c";
String result = consumers.getIntf().spaceCharCodec(paramString, paramString);
assertEquals(matchOr(result, paramString + " +%20%% " + paramQueryStringResult + " true",
paramString + " +%20%% " + paramString + " true"), result);
}
private String matchOr(String result, String expected1, String expected2) {
// spring mvc & rpc handles "+' differently, both '+' or ' ' is correct according to HTTP SPEC. spring mvc changed from '+' to ' ' since spring 5.
if (result.equals(expected1)) {
return expected1;
}
return expected2;
}
@Test
public void spaceCharEncode_rt() {
String paramString = "a%2B+%20b%% %20c";
String paramQueryStringResult = "a%2B %20b%% %20c";
String result = consumers.getSCBRestTemplate()
.getForObject("/spaceCharCodec/" + paramString + "?q=" + paramString, String.class);
assertEquals(matchOr(result, paramString + " +%20%% " + paramQueryStringResult + " true",
paramString + " +%20%% " + paramString + " true"), result);
}
@Test
public void enumSpecialName_intf() {
// HIGHWAY do not support ENUM type contains special character like '.', '-', etc.
if ("rest".equalsIgnoreCase(ITJUnitUtils.getTransport())) {
assertEquals(Media.AAC, consumersRestOnly.getIntf().enumSpecialName(Media.AAC));
assertEquals(Media.FLAC, consumersRestOnly.getIntf().enumSpecialName(Media.FLAC));
assertEquals(Media.H_264, consumersRestOnly.getIntf().enumSpecialName(Media.H_264));
assertEquals(Media.MPEG_2, consumersRestOnly.getIntf().enumSpecialName(Media.MPEG_2));
assertEquals(Media.WMV, consumersRestOnly.getIntf().enumSpecialName(Media.WMV));
}
}
@Test
public void enumSpecialName_rt() {
// HIGHWAY do not support ENUM type contains special character like '.', '-', etc.
if ("rest".equalsIgnoreCase(ITJUnitUtils.getTransport())) {
assertEquals(Media.AAC,
consumersRestOnly.getSCBRestTemplate().postForObject("/enum/enumSpecialName", Media.AAC, Media.class));
assertEquals(Media.FLAC,
consumersRestOnly.getSCBRestTemplate().postForObject("/enum/enumSpecialName", Media.FLAC, Media.class));
assertEquals(Media.H_264,
consumersRestOnly.getSCBRestTemplate().postForObject("/enum/enumSpecialName", Media.H_264, Media.class));
assertEquals(Media.MPEG_2,
consumersRestOnly.getSCBRestTemplate().postForObject("/enum/enumSpecialName", Media.MPEG_2, Media.class));
assertEquals(Media.WMV,
consumersRestOnly.getSCBRestTemplate().postForObject("/enum/enumSpecialName", Media.WMV, Media.class));
}
}
}