mirror of
https://gitee.com/mirrors/Spring-Cloud-Alibaba.git
synced 2021-06-26 13:25:11 +08:00
supplement case and circleci test failed
This commit is contained in:
parent
d610f0e421
commit
e774cbe74d
@ -0,0 +1,271 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed 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 com.alibaba.cloud.nacos;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
import static org.springframework.boot.test.context.SpringBootTest.WebEnvironment.NONE;
|
||||||
|
|
||||||
|
import java.lang.reflect.InvocationHandler;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.api.mockito.PowerMockito;
|
||||||
|
import org.powermock.api.support.MethodProxy;
|
||||||
|
import org.powermock.core.classloader.annotations.PowerMockIgnore;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunnerDelegate;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
||||||
|
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.context.EnvironmentAware;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.core.env.CompositePropertySource;
|
||||||
|
import org.springframework.core.env.Environment;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.alibaba.cloud.nacos.client.NacosPropertySourceLocator;
|
||||||
|
import com.alibaba.cloud.nacos.endpoint.NacosConfigEndpoint;
|
||||||
|
import com.alibaba.cloud.nacos.endpoint.NacosConfigEndpointAutoConfiguration;
|
||||||
|
import com.alibaba.cloud.nacos.refresh.NacosRefreshHistory;
|
||||||
|
import com.alibaba.nacos.client.config.NacosConfigService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author zkz
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PowerMockIgnore("javax.management.*")
|
||||||
|
@PowerMockRunnerDelegate(SpringRunner.class)
|
||||||
|
@PrepareForTest({ NacosConfigService.class })
|
||||||
|
@SpringBootTest(classes = NacosConfigurationNoSuffixTest.TestConfig.class, properties = {
|
||||||
|
"spring.application.name=app-no-suffix", "spring.profiles.active=dev",
|
||||||
|
"spring.cloud.nacos.config.server-addr=127.0.0.1:8848",
|
||||||
|
"spring.cloud.nacos.config.namespace=test-namespace",
|
||||||
|
"spring.cloud.nacos.config.encode=utf-8",
|
||||||
|
"spring.cloud.nacos.config.timeout=1000",
|
||||||
|
"spring.cloud.nacos.config.group=test-group",
|
||||||
|
"spring.cloud.nacos.config.name=test-no-suffix-name",
|
||||||
|
"spring.cloud.nacos.config.cluster-name=test-cluster",
|
||||||
|
"spring.cloud.nacos.config.contextPath=test-contextpath",
|
||||||
|
"spring.cloud.nacos.config.ext-config[0].data-id=ext-json-test.json",
|
||||||
|
"spring.cloud.nacos.config.ext-config[1].data-id=ext-common02.properties",
|
||||||
|
"spring.cloud.nacos.config.ext-config[1].group=GLOBAL_GROUP",
|
||||||
|
"spring.cloud.nacos.config.shared-dataids=shared-data1.properties,shared-data2.xml",
|
||||||
|
"spring.cloud.nacos.config.accessKey=test-accessKey",
|
||||||
|
"spring.cloud.nacos.config.secretKey=test-secretKey" }, webEnvironment = NONE)
|
||||||
|
public class NacosConfigurationNoSuffixTest {
|
||||||
|
|
||||||
|
static {
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Method method = PowerMockito.method(NacosConfigService.class, "getConfig",
|
||||||
|
String.class, String.class, long.class);
|
||||||
|
MethodProxy.proxy(method, new InvocationHandler() {
|
||||||
|
@Override
|
||||||
|
public Object invoke(Object proxy, Method method, Object[] args)
|
||||||
|
throws Throwable {
|
||||||
|
|
||||||
|
if ("app-no-suffix".equals(args[0]) && "test-group".equals(args[1])) {
|
||||||
|
return "test-no-suffix=value-no-suffix-1";
|
||||||
|
}
|
||||||
|
if ("app-no-suffix.properties".equals(args[0])
|
||||||
|
&& "test-group".equals(args[1])) {
|
||||||
|
return "test-no-suffix=value-no-suffix-2";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("test-no-suffix-name".equals(args[0])
|
||||||
|
&& "test-group".equals(args[1])) {
|
||||||
|
return "test-no-suffix-assign=assign-value-no-suffix-111";
|
||||||
|
}
|
||||||
|
if ("test-no-suffix-name.properties".equals(args[0])
|
||||||
|
&& "test-group".equals(args[1])) {
|
||||||
|
return "test-no-suffix-assign=assign-value-no-suffix-222";
|
||||||
|
}
|
||||||
|
if ("test-no-suffix-name-dev.properties".equals(args[0])
|
||||||
|
&& "test-group".equals(args[1])) {
|
||||||
|
return "test-no-suffix-assign=assign-dev-value-no-suffix-333";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("ext-json-test.json".equals(args[0])
|
||||||
|
&& "DEFAULT_GROUP".equals(args[1])) {
|
||||||
|
return "{\n" + " \"people\":{\n"
|
||||||
|
+ " \"firstName\":\"Brett\",\n"
|
||||||
|
+ " \"lastName\":\"McLaughlin\"\n" + " }\n"
|
||||||
|
+ "}";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("ext-config-common02.properties".equals(args[0])
|
||||||
|
&& "GLOBAL_GROUP".equals(args[1])) {
|
||||||
|
return "global-ext-config=global-config-value-2";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("shared-data1.properties".equals(args[0])
|
||||||
|
&& "DEFAULT_GROUP".equals(args[1])) {
|
||||||
|
return "shared-name=shared-value-1";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("shared-data2.xml".equals(args[0])
|
||||||
|
&& "DEFAULT_GROUP".equals(args[1])) {
|
||||||
|
return "<Server port=\"8005\" shutdown=\"SHUTDOWN\"> \n"
|
||||||
|
+ " <Service name=\"Catalina\"> \n"
|
||||||
|
+ " <Connector value=\"第二个连接器\"> \n"
|
||||||
|
+ " <open>开启服务</open> \n"
|
||||||
|
+ " <init>初始化一下</init> \n"
|
||||||
|
+ " <process>\n" + " <top>\n"
|
||||||
|
+ " <first>one</first>\n"
|
||||||
|
+ " <sencond value=\"two\">\n"
|
||||||
|
+ " <third>three</third>\n"
|
||||||
|
+ " </sencond>\n"
|
||||||
|
+ " </top>\n" + " </process> \n"
|
||||||
|
+ " <destory>销毁一下</destory> \n"
|
||||||
|
+ " <close>关闭服务</close> \n"
|
||||||
|
+ " </Connector> \n" + " </Service> \n"
|
||||||
|
+ "</Server> ";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ignore) {
|
||||||
|
ignore.printStackTrace();
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private NacosPropertySourceLocator locator;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private NacosConfigProperties properties;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private NacosRefreshHistory refreshHistory;
|
||||||
|
@Autowired
|
||||||
|
private Environment environment;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void contextLoads() throws Exception {
|
||||||
|
|
||||||
|
assertNotNull("NacosPropertySourceLocator was not created", locator);
|
||||||
|
assertNotNull("NacosConfigProperties was not created", properties);
|
||||||
|
|
||||||
|
checkoutNacosConfigServerAddr();
|
||||||
|
checkoutNacosConfigNamespace();
|
||||||
|
checkoutNacosConfigClusterName();
|
||||||
|
checkoutNacosConfigAccessKey();
|
||||||
|
checkoutNacosConfigSecrectKey();
|
||||||
|
checkoutNacosConfigName();
|
||||||
|
checkoutNacosConfigGroup();
|
||||||
|
checkoutNacosConfigContextPath();
|
||||||
|
checkoutNacosConfigFileExtension();
|
||||||
|
checkoutNacosConfigTimeout();
|
||||||
|
checkoutNacosConfigEncode();
|
||||||
|
|
||||||
|
checkoutEndpoint();
|
||||||
|
checkEnvironmentProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkEnvironmentProperties() {
|
||||||
|
assertNull(
|
||||||
|
"The configuration of `spring.cloud.nacos.config.name` must be used first",
|
||||||
|
environment.getProperty("test-no-suffix"));
|
||||||
|
assertEquals(
|
||||||
|
"Priority of configuration is wrong , should be in this order : `profile->hasSuffix->noSuffix`",
|
||||||
|
"assign-dev-value-no-suffix-333",
|
||||||
|
environment.getProperty("test-no-suffix-assign"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigServerAddr() {
|
||||||
|
assertEquals("NacosConfigProperties server address is wrong", "127.0.0.1:8848",
|
||||||
|
properties.getServerAddr());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigNamespace() {
|
||||||
|
assertEquals("NacosConfigProperties namespace is wrong", "test-namespace",
|
||||||
|
properties.getNamespace());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigClusterName() {
|
||||||
|
assertEquals("NacosConfigProperties' cluster is wrong", "test-cluster",
|
||||||
|
properties.getClusterName());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigAccessKey() {
|
||||||
|
assertEquals("NacosConfigProperties' is access key is wrong", "test-accessKey",
|
||||||
|
properties.getAccessKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigSecrectKey() {
|
||||||
|
assertEquals("NacosConfigProperties' is secret key is wrong", "test-secretKey",
|
||||||
|
properties.getSecretKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigContextPath() {
|
||||||
|
assertEquals("NacosConfigProperties' context path is wrong", "test-contextpath",
|
||||||
|
properties.getContextPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigName() {
|
||||||
|
assertEquals("NacosConfigProperties' name is wrong", "test-no-suffix-name",
|
||||||
|
properties.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigGroup() {
|
||||||
|
assertEquals("NacosConfigProperties' group is wrong", "test-group",
|
||||||
|
properties.getGroup());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigFileExtension() {
|
||||||
|
assertEquals("NacosConfigProperties' file extension is wrong", "properties",
|
||||||
|
properties.getFileExtension());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigTimeout() {
|
||||||
|
assertEquals("NacosConfigProperties' timeout is wrong", 1000,
|
||||||
|
properties.getTimeout());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutNacosConfigEncode() {
|
||||||
|
assertEquals("NacosConfigProperties' encode is wrong", "utf-8",
|
||||||
|
properties.getEncode());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkoutEndpoint() throws Exception {
|
||||||
|
NacosConfigEndpoint nacosConfigEndpoint = new NacosConfigEndpoint(properties,
|
||||||
|
refreshHistory);
|
||||||
|
Map<String, Object> map = nacosConfigEndpoint.invoke();
|
||||||
|
assertEquals(map.get("NacosConfigProperties"), properties);
|
||||||
|
assertEquals(map.get("RefreshHistory"), refreshHistory.getRecords());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@EnableAutoConfiguration
|
||||||
|
@ImportAutoConfiguration({ NacosConfigEndpointAutoConfiguration.class,
|
||||||
|
NacosConfigAutoConfiguration.class, NacosConfigBootstrapConfiguration.class })
|
||||||
|
public static class TestConfig {
|
||||||
|
}
|
||||||
|
}
|
@ -50,7 +50,8 @@ import static org.springframework.boot.test.context.SpringBootTest.WebEnvironmen
|
|||||||
* @author Ryan Baxter
|
* @author Ryan Baxter
|
||||||
*/
|
*/
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(webEnvironment = RANDOM_PORT, classes = ReactiveSentinelCircuitBreakerIntegrationTest.Application.class)
|
@SpringBootTest(webEnvironment = RANDOM_PORT, classes = ReactiveSentinelCircuitBreakerIntegrationTest.Application.class, properties = {
|
||||||
|
"spring.cloud.discovery.client.health-indicator.enabled=false" })
|
||||||
@DirtiesContext
|
@DirtiesContext
|
||||||
public class ReactiveSentinelCircuitBreakerIntegrationTest {
|
public class ReactiveSentinelCircuitBreakerIntegrationTest {
|
||||||
|
|
||||||
|
@ -48,7 +48,8 @@ import static org.springframework.boot.test.context.SpringBootTest.WebEnvironmen
|
|||||||
* @author Eric Zhao
|
* @author Eric Zhao
|
||||||
*/
|
*/
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(webEnvironment = RANDOM_PORT, classes = SentinelCircuitBreakerIntegrationTest.Application.class)
|
@SpringBootTest(webEnvironment = RANDOM_PORT, classes = SentinelCircuitBreakerIntegrationTest.Application.class, properties = {
|
||||||
|
"spring.cloud.discovery.client.health-indicator.enabled=false" })
|
||||||
@DirtiesContext
|
@DirtiesContext
|
||||||
public class SentinelCircuitBreakerIntegrationTest {
|
public class SentinelCircuitBreakerIntegrationTest {
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user