use of com.tencent.polaris.api.plugin.configuration.ConfigFileConnector in project polaris-java by polarismesh.
the class ConfigFileLongPollingServiceTest method testNotReceivedPushEvent.
@Test
public void testNotReceivedPushEvent() throws InterruptedException {
// 初始化 LongPollingService
DefaultConfigFileLongPollingService longPollingService = new DefaultConfigFileLongPollingService(sdkContext, configFileConnector);
RemoteConfigFileRepo remoteConfigFileRepo = mock(RemoteConfigFileRepo.class);
ConfigFileMetadata configFileMetadata = ConfigFileTestUtils.assembleDefaultConfigFileMeta();
when(remoteConfigFileRepo.getConfigFileMetadata()).thenReturn(configFileMetadata);
longPollingService.addConfigFile(remoteConfigFileRepo);
// 第一次收到变更事件,第二次也没有变化
when(configFileConnector.watchConfigFiles(anyList())).then(invocation -> {
return new ConfigFileResponse(ServerCodes.DATA_NO_CHANGE, "", null);
}).then(invocation -> {
TimeUnit.SECONDS.sleep(6);
return new ConfigFileResponse(ServerCodes.DATA_NO_CHANGE, "", null);
});
// 因为LongPolling会在 5s 后开始执行
TimeUnit.SECONDS.sleep(7);
verify(configFileConnector, times(2)).watchConfigFiles(anyList());
// 没有触发回调
verify(remoteConfigFileRepo, times(0)).onLongPollNotified(anyLong());
}
use of com.tencent.polaris.api.plugin.configuration.ConfigFileConnector in project polaris-java by polarismesh.
the class ConfigFileLongPollingServiceTest method testSecondReceivedVersionLessThanFirstReceived.
@Test
public void testSecondReceivedVersionLessThanFirstReceived() throws InterruptedException {
// 初始化 LongPollingService
DefaultConfigFileLongPollingService longPollingService = new DefaultConfigFileLongPollingService(sdkContext, configFileConnector);
RemoteConfigFileRepo remoteConfigFileRepo = mock(RemoteConfigFileRepo.class);
ConfigFileMetadata configFileMetadata = ConfigFileTestUtils.assembleDefaultConfigFileMeta();
when(remoteConfigFileRepo.getConfigFileMetadata()).thenReturn(configFileMetadata);
longPollingService.addConfigFile(remoteConfigFileRepo);
// 第一次版本号为100,第二次版本号为99
when(configFileConnector.watchConfigFiles(anyList())).then(invocation -> {
ConfigFile configFile = new ConfigFile(ConfigFileTestUtils.testNamespace, ConfigFileTestUtils.testGroup, ConfigFileTestUtils.testFileName);
String content = "hello world";
long version = 100;
configFile.setContent(content);
configFile.setVersion(version);
return new ConfigFileResponse(ServerCodes.EXECUTE_SUCCESS, "", configFile);
}).then(invocation -> {
ConfigFile configFile = new ConfigFile(ConfigFileTestUtils.testNamespace, ConfigFileTestUtils.testGroup, ConfigFileTestUtils.testFileName);
String content = "hello world";
long version = 99;
configFile.setContent(content);
configFile.setVersion(version);
return new ConfigFileResponse(ServerCodes.EXECUTE_SUCCESS, "", configFile);
}).then(invocation -> {
TimeUnit.SECONDS.sleep(30);
return new ConfigFileResponse(ServerCodes.DATA_NO_CHANGE, "", null);
});
// 因为LongPolling会在 5s 后开始执行
TimeUnit.SECONDS.sleep(7);
verify(configFileConnector, times(3)).watchConfigFiles(anyList());
// 没有触发回调
verify(remoteConfigFileRepo, times(2)).onLongPollNotified(100);
}
Aggregations