Java Code Examples for com.alibaba.dubbo.config.ReferenceConfig#get()
The following examples show how to use
com.alibaba.dubbo.config.ReferenceConfig#get() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: ReferenceManager.java From swagger-dubbo with Apache License 2.0 | 6 votes |
public Object getProxy(String interfaceClass) { Set<Entry<Class<?>, Object>> entrySet = interfaceMapProxy.entrySet(); for (Entry<Class<?>, Object> entry : entrySet) { if (entry.getKey().getName().equals(interfaceClass)) { return entry.getValue(); } } for (ServiceBean<?> service : services) { if (interfaceClass.equals(service.getInterfaceClass().getName())) { ReferenceConfig<Object> reference = new ReferenceConfig<Object>(); reference.setApplication(service.getApplication()); reference.setRegistry(service.getRegistry()); reference.setRegistries(service.getRegistries()); reference.setInterface(service.getInterfaceClass()); reference.setVersion(service.getVersion()); interfaceMapProxy.put(service.getInterfaceClass(), reference.get()); return reference.get(); } } return null; }
Example 2
Source File: ConfigTest.java From dubbo3 with Apache License 2.0 | 6 votes |
@Test public void testSystemPropertyOverrideReferenceConfig() throws Exception { System.setProperty("dubbo.reference.retries", "5"); try { ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); service.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); ProtocolConfig protocolConfig = new ProtocolConfig("injvm"); service.setProtocol(protocolConfig); service.export(); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setInterface(DemoService.class); reference.setInjvm(true); reference.setRetries(2); reference.get(); assertEquals(Integer.valueOf(5), reference.getRetries()); } finally { System.setProperty("dubbo.reference.retries", ""); } }
Example 3
Source File: APIConfigurationLiveTest.java From tutorials with MIT License | 6 votes |
@Test public void givenProviderConsumer_whenSayHi_thenGotResponse() { ApplicationConfig application = new ApplicationConfig(); application.setName("demo-consumer"); application.setVersion("1.0"); RegistryConfig registryConfig = new RegistryConfig(); registryConfig.setAddress("multicast://224.1.1.1:9090"); ReferenceConfig<GreetingsService> reference = new ReferenceConfig<>(); reference.setApplication(application); reference.setRegistry(registryConfig); reference.setInterface(GreetingsService.class); GreetingsService greetingsService = reference.get(); String hiMessage = greetingsService.sayHi("baeldung"); assertEquals("hi, baeldung", hiMessage); }
Example 4
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 6 votes |
@Test public void testSystemPropertyOverrideReferenceConfig() throws Exception { System.setProperty("dubbo.reference.retries", "5"); try { ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); service.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); ProtocolConfig protocolConfig = new ProtocolConfig("injvm"); service.setProtocol(protocolConfig); service.export(); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setInterface(DemoService.class); reference.setInjvm(true); reference.setRetries(2); reference.get(); assertEquals(Integer.valueOf(5), reference.getRetries()); } finally { System.setProperty("dubbo.reference.retries", ""); } }
Example 5
Source File: CompensablePrimaryFilter.java From ByteTCC with GNU Lesser General Public License v3.0 | 5 votes |
private void processInitRemoteParticipantIfNecessary(RemoteAddr remoteAddr) throws RpcException { RemoteCoordinatorRegistry participantRegistry = RemoteCoordinatorRegistry.getInstance(); CompensableBeanRegistry beanRegistry = CompensableBeanRegistry.getInstance(); RemoteCoordinator participant = participantRegistry.getPhysicalInstance(remoteAddr); if (participant == null) { ApplicationConfig applicationConfig = beanRegistry.getBean(ApplicationConfig.class); RegistryConfig registryConfig = beanRegistry.getBean(RegistryConfig.class); ProtocolConfig protocolConfig = beanRegistry.getBean(ProtocolConfig.class); ReferenceConfig<RemoteCoordinator> referenceConfig = new ReferenceConfig<RemoteCoordinator>(); referenceConfig.setInterface(RemoteCoordinator.class); referenceConfig.setTimeout(6 * 1000); referenceConfig.setCluster("failfast"); referenceConfig.setFilter("bytetcc"); referenceConfig.setGroup("z-bytetcc"); referenceConfig.setCheck(false); referenceConfig.setRetries(-1); referenceConfig.setUrl(String.format("%s:%s", remoteAddr.getServerHost(), remoteAddr.getServerPort())); referenceConfig.setScope(Constants.SCOPE_REMOTE); referenceConfig.setApplication(applicationConfig); if (registryConfig != null) { referenceConfig.setRegistry(registryConfig); } if (protocolConfig != null) { referenceConfig.setProtocol(protocolConfig.getName()); } // end-if (protocolConfig != null) RemoteCoordinator reference = referenceConfig.get(); if (reference == null) { throw new RpcException("Cannot get the application name of the remote application."); } participantRegistry.putPhysicalInstance(remoteAddr, reference); } }
Example 6
Source File: ReferenceConfigCache.java From dubbox-hystrix with Apache License 2.0 | 5 votes |
@SuppressWarnings("unchecked") public <T> T get(ReferenceConfig<T> referenceConfig) { String key = generator.generateKey(referenceConfig); ReferenceConfig<?> config = cache.get(key); if(config != null) { return (T) config.get(); } cache.putIfAbsent(key, referenceConfig); config = cache.get(key); return (T) config.get(); }
Example 7
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 5 votes |
private DemoService refer(String url) { ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl(url); return reference.get(); }
Example 8
Source File: XAResourceDeserializerImpl.java From ByteJTA with GNU Lesser General Public License v3.0 | 5 votes |
private void processInitRemoteParticipantIfNecessary(String application) { RemoteCoordinatorRegistry participantRegistry = RemoteCoordinatorRegistry.getInstance(); TransactionBeanRegistry beanRegistry = TransactionBeanRegistry.getInstance(); RemoteCoordinator participant = participantRegistry.getParticipant(application); if (participant == null) { ApplicationConfig applicationConfig = beanRegistry.getBean(ApplicationConfig.class); RegistryConfig registryConfig = beanRegistry.getBean(RegistryConfig.class); ProtocolConfig protocolConfig = beanRegistry.getBean(ProtocolConfig.class); ReferenceConfig<RemoteCoordinator> referenceConfig = new ReferenceConfig<RemoteCoordinator>(); referenceConfig.setInterface(RemoteCoordinator.class); referenceConfig.setTimeout(15000); referenceConfig.setCluster("failfast"); referenceConfig.setLoadbalance("bytejta"); referenceConfig.setFilter("bytejta"); referenceConfig.setGroup(application); referenceConfig.setCheck(false); referenceConfig.setRetries(-1); referenceConfig.setScope(Constants.SCOPE_REMOTE); referenceConfig.setApplication(applicationConfig); if (registryConfig != null) { referenceConfig.setRegistry(registryConfig); } if (protocolConfig != null) { referenceConfig.setProtocol(protocolConfig.getName()); } // end-if (protocolConfig != null) RemoteCoordinator reference = referenceConfig.get(); if (reference == null) { throw new RpcException("Cannot get the application name of the remote application."); } participantRegistry.putParticipant(application, reference); } }
Example 9
Source File: DubboMonitorConsumerFactory.java From EasyTransaction with Apache License 2.0 | 5 votes |
private GenericService generateService(String appId, Class<?> monitorInterface) { ReferenceConfig<GenericService> referenceConfig = new ReferenceConfig<GenericService>(); referenceConfig.setInterface(monitorInterface); // 弱类型接口名 referenceConfig.setVersion("1.0.0"); referenceConfig.setGeneric(true); // 声明为泛化接口 referenceConfig.setGroup(appId + "-" + monitorInterface.getSimpleName()); referenceConfig.setCheck(false); if(applicationConfig != null) { referenceConfig.setApplication(applicationConfig); } if(registryConfig != null) { referenceConfig.setRegistry(registryConfig); } if(protocolConfig != null) { referenceConfig.setProtocol(protocolConfig.getName()); } if(moduleConfig != null) { referenceConfig.setModule(moduleConfig); } if(monitorConfig != null) { referenceConfig.setMonitor(monitorConfig); } if(consumerConfig != null) { referenceConfig.setConsumer(consumerConfig); } if(customizationer != null) { customizationer.customDubboReferance(appId,null,referenceConfig); } return referenceConfig.get(); }
Example 10
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 5 votes |
@Test public void testReferGenericExport() throws Exception { ApplicationConfig ac = new ApplicationConfig("test-refer-generic-export"); RegistryConfig rc = new RegistryConfig(); rc.setAddress(RegistryConfig.NO_AVAILABLE); ServiceConfig<GenericService> sc = new ServiceConfig<GenericService>(); sc.setApplication(ac); sc.setRegistry(rc); sc.setInterface(DemoService.class.getName()); sc.setRef(new GenericService() { public Object $invoke(String method, String[] parameterTypes, Object[] args) throws GenericException { return null; } }); ReferenceConfig<DemoService> ref = new ReferenceConfig<DemoService>(); ref.setApplication(ac); ref.setRegistry(rc); ref.setInterface(DemoService.class.getName()); try { sc.export(); ref.get(); Assert.fail(); } catch (Exception e) { e.printStackTrace(); } finally { sc.unexport(); ref.destroy(); } }
Example 11
Source File: ApplicationConfigCache.java From soul with Apache License 2.0 | 5 votes |
/** * Build reference config. * * @param metaData the meta data * @return the reference config */ public ReferenceConfig<GenericService> build(final MetaData metaData) { ReferenceConfig<GenericService> reference = new ReferenceConfig<>(); reference.setGeneric(true); reference.setApplication(applicationConfig); reference.setRegistry(registryConfig); reference.setInterface(metaData.getServiceName()); reference.setProtocol("dubbo"); String rpcExt = metaData.getRpcExt(); DubboParamExtInfo dubboParamExtInfo = GsonUtils.getInstance().fromJson(rpcExt, DubboParamExtInfo.class); if (Objects.nonNull(dubboParamExtInfo)) { if (StringUtils.isNoneBlank(dubboParamExtInfo.getVersion())) { reference.setVersion(dubboParamExtInfo.getVersion()); } if (StringUtils.isNoneBlank(dubboParamExtInfo.getGroup())) { reference.setGroup(dubboParamExtInfo.getGroup()); } if (StringUtils.isNoneBlank(dubboParamExtInfo.getLoadbalance())) { final String loadBalance = dubboParamExtInfo.getLoadbalance(); reference.setLoadbalance(buildLoadBalanceName(loadBalance)); } Optional.ofNullable(dubboParamExtInfo.getTimeout()).ifPresent(reference::setTimeout); Optional.ofNullable(dubboParamExtInfo.getRetries()).ifPresent(reference::setRetries); } Object obj = reference.get(); if (obj != null) { log.info("init aliaba dubbo reference success there meteData is :{}", metaData.toString()); cache.put(metaData.getServiceName(), reference); } return reference; }
Example 12
Source File: CompensableSecondaryFilter.java From ByteTCC with GNU Lesser General Public License v3.0 | 5 votes |
private void processInitRemoteParticipantIfNecessary(RemoteAddr remoteAddr) throws RpcException { RemoteCoordinatorRegistry participantRegistry = RemoteCoordinatorRegistry.getInstance(); CompensableBeanRegistry beanRegistry = CompensableBeanRegistry.getInstance(); RemoteCoordinator participant = participantRegistry.getPhysicalInstance(remoteAddr); if (participant == null) { ApplicationConfig applicationConfig = beanRegistry.getBean(ApplicationConfig.class); RegistryConfig registryConfig = beanRegistry.getBean(RegistryConfig.class); ProtocolConfig protocolConfig = beanRegistry.getBean(ProtocolConfig.class); ReferenceConfig<RemoteCoordinator> referenceConfig = new ReferenceConfig<RemoteCoordinator>(); referenceConfig.setInterface(RemoteCoordinator.class); referenceConfig.setTimeout(6 * 1000); referenceConfig.setCluster("failfast"); referenceConfig.setFilter("bytetcc"); referenceConfig.setGroup("x-bytetcc"); referenceConfig.setCheck(false); referenceConfig.setRetries(-1); referenceConfig.setUrl(String.format("%s:%s", remoteAddr.getServerHost(), remoteAddr.getServerPort())); referenceConfig.setScope(Constants.SCOPE_REMOTE); referenceConfig.setApplication(applicationConfig); if (registryConfig != null) { referenceConfig.setRegistry(registryConfig); } if (protocolConfig != null) { referenceConfig.setProtocol(protocolConfig.getName()); } // end-if (protocolConfig != null) RemoteCoordinator reference = referenceConfig.get(); if (reference == null) { throw new RpcException("Cannot get the application name of the remote application."); } participantRegistry.putPhysicalInstance(remoteAddr, reference); } }
Example 13
Source File: TransactionServiceFilter.java From ByteJTA with GNU Lesser General Public License v3.0 | 5 votes |
private void processInitPhysicalInstanceIfNecessary(RemoteAddr remoteAddr) throws RpcException { RemoteCoordinatorRegistry participantRegistry = RemoteCoordinatorRegistry.getInstance(); TransactionBeanRegistry beanRegistry = TransactionBeanRegistry.getInstance(); RemoteCoordinator participant = participantRegistry.getPhysicalInstance(remoteAddr); if (participant == null) { ApplicationConfig applicationConfig = beanRegistry.getBean(ApplicationConfig.class); RegistryConfig registryConfig = beanRegistry.getBean(RegistryConfig.class); ProtocolConfig protocolConfig = beanRegistry.getBean(ProtocolConfig.class); ReferenceConfig<RemoteCoordinator> referenceConfig = new ReferenceConfig<RemoteCoordinator>(); referenceConfig.setInterface(RemoteCoordinator.class); referenceConfig.setTimeout(15000); referenceConfig.setCluster("failfast"); referenceConfig.setLoadbalance("bytejta"); referenceConfig.setFilter("bytejta"); referenceConfig.setGroup("org-bytesoft-bytejta"); referenceConfig.setCheck(false); referenceConfig.setRetries(-1); referenceConfig.setUrl(String.format("%s:%s", remoteAddr.getServerHost(), remoteAddr.getServerPort())); referenceConfig.setScope(Constants.SCOPE_REMOTE); referenceConfig.setApplication(applicationConfig); if (registryConfig != null) { referenceConfig.setRegistry(registryConfig); } if (protocolConfig != null) { referenceConfig.setProtocol(protocolConfig.getName()); } // end-if (protocolConfig != null) RemoteCoordinator reference = referenceConfig.get(); if (reference == null) { throw new RpcException("Cannot get the application name of the remote application."); } participantRegistry.putPhysicalInstance(remoteAddr, reference); } }
Example 14
Source File: ReferenceConfigCache.java From dubbox with Apache License 2.0 | 5 votes |
@SuppressWarnings("unchecked") public <T> T get(ReferenceConfig<T> referenceConfig) { String key = generator.generateKey(referenceConfig); ReferenceConfig<?> config = cache.get(key); if(config != null) { return (T) config.get(); } cache.putIfAbsent(key, referenceConfig); config = cache.get(key); return (T) config.get(); }
Example 15
Source File: ConfigTest.java From dubbo-2.6.5 with Apache License 2.0 | 4 votes |
@Test public void testApiOverrideProperties() throws Exception { ApplicationConfig application = new ApplicationConfig(); application.setName("api-override-properties"); RegistryConfig registry = new RegistryConfig(); registry.setAddress("N/A"); ProtocolConfig protocol = new ProtocolConfig(); protocol.setName("dubbo"); protocol.setPort(13123); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); service.setApplication(application); service.setRegistry(registry); service.setProtocol(protocol); service.export(); try { URL url = service.toUrls().get(0); assertEquals("api-override-properties", url.getParameter("application")); assertEquals("world", url.getParameter("owner")); assertEquals(13123, url.getPort()); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://127.0.0.1:13123"); reference.get(); try { url = reference.toUrls().get(0); assertEquals("2000", url.getParameter("timeout")); } finally { reference.destroy(); } } finally { service.unexport(); } }
Example 16
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 4 votes |
@Test public void testApiOverrideProperties() throws Exception { ApplicationConfig application = new ApplicationConfig(); application.setName("api-override-properties"); RegistryConfig registry = new RegistryConfig(); registry.setAddress("N/A"); ProtocolConfig protocol = new ProtocolConfig(); protocol.setName("dubbo"); protocol.setPort(13123); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); service.setApplication(application); service.setRegistry(registry); service.setProtocol(protocol); service.export(); try { URL url = service.toUrls().get(0); assertEquals("api-override-properties", url.getParameter("application")); assertEquals("world", url.getParameter("owner")); assertEquals(13123, url.getPort()); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://127.0.0.1:13123"); reference.get(); try { url = reference.toUrls().get(0); assertEquals("2000", url.getParameter("timeout")); } finally { reference.destroy(); } } finally { service.unexport(); } }
Example 17
Source File: ConfigTest.java From dubbox-hystrix with Apache License 2.0 | 4 votes |
@Test public void testAppendFilter() throws Exception { ProviderConfig provider = new ProviderConfig(); provider.setFilter("classloader,monitor"); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setFilter("accesslog,trace"); service.setProvider(provider); service.setProtocol(new ProtocolConfig("dubbo", 20880)); service.setApplication(new ApplicationConfig("provider")); service.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); try { service.export(); List<URL> urls = service.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("service.filter")); ConsumerConfig consumer = new ConsumerConfig(); consumer.setFilter("classloader,monitor"); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setFilter("accesslog,trace"); reference.setConsumer(consumer); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://" + NetUtils.getLocalHost() + ":20880?" + DemoService.class.getName() + "?check=false"); try { reference.get(); urls = reference.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("reference.filter")); } finally { reference.destroy(); } } finally { service.unexport(); } }
Example 18
Source File: ConfigTest.java From dubbo-2.6.5 with Apache License 2.0 | 4 votes |
@Test public void testAppendFilter() throws Exception { ProviderConfig provider = new ProviderConfig(); provider.setFilter("classloader,monitor"); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setFilter("accesslog,trace"); service.setProvider(provider); service.setProtocol(new ProtocolConfig("dubbo", 20880)); service.setApplication(new ApplicationConfig("provider")); service.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); try { service.export(); List<URL> urls = service.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("service.filter")); ConsumerConfig consumer = new ConsumerConfig(); consumer.setFilter("classloader,monitor"); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setFilter("accesslog,trace"); reference.setConsumer(consumer); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://" + NetUtils.getLocalHost() + ":20880?" + DemoService.class.getName() + "?check=false"); try { reference.get(); urls = reference.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("reference.filter")); } finally { reference.destroy(); } } finally { service.unexport(); } }
Example 19
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 4 votes |
@Test public void testAppendFilter() throws Exception { ProviderConfig provider = new ProviderConfig(); provider.setFilter("classloader,monitor"); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setFilter("accesslog,trace"); service.setProvider(provider); service.setProtocol(new ProtocolConfig("dubbo", 20880)); service.setApplication(new ApplicationConfig("provider")); service.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); try { service.export(); List<URL> urls = service.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("service.filter")); ConsumerConfig consumer = new ConsumerConfig(); consumer.setFilter("classloader,monitor"); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setFilter("accesslog,trace"); reference.setConsumer(consumer); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://" + NetUtils.getLocalHost() + ":20880?" + DemoService.class.getName() + "?check=false"); try { reference.get(); urls = reference.toUrls(); assertNotNull(urls); assertEquals(1, urls.size()); assertEquals("classloader,monitor,accesslog,trace", urls.get(0).getParameter("reference.filter")); } finally { reference.destroy(); } } finally { service.unexport(); } }
Example 20
Source File: ConfigTest.java From dubbox with Apache License 2.0 | 4 votes |
@Test public void testApiOverrideProperties() throws Exception { ApplicationConfig application = new ApplicationConfig(); application.setName("api-override-properties"); RegistryConfig registry = new RegistryConfig(); registry.setAddress("N/A"); ProtocolConfig protocol = new ProtocolConfig(); protocol.setName("dubbo"); protocol.setPort(13123); ServiceConfig<DemoService> service = new ServiceConfig<DemoService>(); service.setInterface(DemoService.class); service.setRef(new DemoServiceImpl()); service.setApplication(application); service.setRegistry(registry); service.setProtocol(protocol); service.export(); try { URL url = service.toUrls().get(0); assertEquals("api-override-properties", url.getParameter("application")); assertEquals("world", url.getParameter("owner")); assertEquals(13123, url.getPort()); ReferenceConfig<DemoService> reference = new ReferenceConfig<DemoService>(); reference.setApplication(new ApplicationConfig("consumer")); reference.setRegistry(new RegistryConfig(RegistryConfig.NO_AVAILABLE)); reference.setInterface(DemoService.class); reference.setUrl("dubbo://127.0.0.1:13123"); reference.get(); try { url = reference.toUrls().get(0); assertEquals("2000", url.getParameter("timeout")); } finally { reference.destroy(); } } finally { service.unexport(); } }