use of org.wildfly.clustering.web.routing.RouteLocator in project wildfly by wildfly.
the class NullRouteLocatorTestCase method test.
@Test
public void test() {
RouteLocator locator = new NullRouteLocator();
Assert.assertNull(locator.locate("abc123"));
}
use of org.wildfly.clustering.web.routing.RouteLocator in project wildfly by wildfly.
the class PrimaryOwnerRouteLocatorTestCase method test.
@Test
public void test() {
Function<GroupedKey<String>, Node> locator = mock(Function.class);
Registry<String, Void> registry = mock(Registry.class);
Group group = mock(Group.class);
Node primary = mock(Node.class);
Node local = mock(Node.class);
Node missing = mock(Node.class);
String primaryRoute = "primary";
String localRoute = "local";
when(registry.getGroup()).thenReturn(group);
when(group.getLocalMember()).thenReturn(local);
when(registry.getEntry(local)).thenReturn(new SimpleImmutableEntry<>(localRoute, null));
RouteLocator routeLocator = new PrimaryOwnerRouteLocator(locator, registry);
when(locator.apply(new GroupedKey<>("session"))).thenReturn(primary);
when(registry.getEntry(primary)).thenReturn(new SimpleImmutableEntry<>(primaryRoute, null));
String result = routeLocator.locate("session");
assertSame(primaryRoute, result);
when(locator.apply(new GroupedKey<>("missing"))).thenReturn(missing);
when(registry.getEntry(missing)).thenReturn(null);
result = routeLocator.locate("missing");
assertSame(localRoute, result);
}
use of org.wildfly.clustering.web.routing.RouteLocator in project wildfly by wildfly.
the class RankedRouteLocatorTestCase method test.
@Test
public void test() {
KeyDistribution distribution = mock(KeyDistribution.class);
NodeFactory<Address> factory = mock(NodeFactory.class);
Registry<String, Void> registry = mock(Registry.class);
Group group = mock(Group.class);
Address owner1 = mock(Address.class);
Address owner2 = mock(Address.class);
Address owner3 = mock(Address.class);
Address owner4 = mock(Address.class);
Address unregistered = mock(Address.class);
Address local = mock(Address.class);
Node member1 = mock(Node.class);
Node member2 = mock(Node.class);
Node member3 = mock(Node.class);
Node member4 = mock(Node.class);
Node unregisteredMember = mock(Node.class);
Node localMember = mock(Node.class);
when(registry.getGroup()).thenReturn(group);
when(group.getLocalMember()).thenReturn(localMember);
when(registry.getEntry(member1)).thenReturn(new SimpleImmutableEntry<>("member1", null));
when(registry.getEntry(member2)).thenReturn(new SimpleImmutableEntry<>("member2", null));
when(registry.getEntry(member3)).thenReturn(new SimpleImmutableEntry<>("member3", null));
when(registry.getEntry(member4)).thenReturn(new SimpleImmutableEntry<>("member4", null));
when(registry.getEntry(localMember)).thenReturn(new SimpleImmutableEntry<>("local", null));
when(registry.getEntry(unregisteredMember)).thenReturn(null);
when(factory.createNode(owner1)).thenReturn(member1);
when(factory.createNode(owner2)).thenReturn(member2);
when(factory.createNode(owner3)).thenReturn(member3);
when(factory.createNode(owner4)).thenReturn(member4);
when(factory.createNode(local)).thenReturn(localMember);
when(factory.createNode(unregistered)).thenReturn(unregisteredMember);
RouteLocator locator = new RankedRouteLocator(distribution, registry, factory, ".", 3);
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1, owner2, owner3, owner4));
assertEquals("member1.member2.member3", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1, owner2, owner3, local));
assertEquals("member1.member2.member3", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1, owner2, unregistered, owner4));
assertEquals("member1.member2.member4", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1, local, owner3));
assertEquals("member1.local.member3", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1, owner2));
assertEquals("member1.member2.local", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(local, owner2));
assertEquals("local.member2", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(owner1));
assertEquals("member1.local", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(local));
assertEquals("local", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Arrays.asList(unregistered));
assertEquals("local", locator.locate("key"));
when(distribution.getOwners(new GroupedKey<>("key"))).thenReturn(Collections.emptyList());
assertEquals("local", locator.locate("key"));
}
use of org.wildfly.clustering.web.routing.RouteLocator in project wildfly by wildfly.
the class DistributableSessionIdentifierCodecServiceConfigurator method build.
@Override
public ServiceBuilder<?> build(ServiceTarget target) {
this.configurator.build(target).install();
ServiceBuilder<?> builder = target.addService(this.getServiceName());
Consumer<SessionIdentifierCodec> codec = builder.provides(this.getServiceName());
Supplier<RouteLocator> locator = builder.requires(this.configurator.getServiceName());
Service service = new FunctionalService<>(codec, this, locator);
return builder.setInstance(service).setInitialMode(ServiceController.Mode.ON_DEMAND);
}
use of org.wildfly.clustering.web.routing.RouteLocator in project wildfly by wildfly.
the class PrimaryOwnerRouteLocatorServiceConfigurator method build.
@Override
public ServiceBuilder<?> build(ServiceTarget target) {
ServiceName name = this.getServiceName();
ServiceBuilder<?> builder = new AsyncServiceConfigurator(name).build(target);
Consumer<RouteLocator> locator = new CompositeDependency(this.registry, this.cache, this.factory).register(builder).provides(name);
Service service = new FunctionalService<>(locator, Function.identity(), this);
return builder.setInstance(service).setInitialMode(ServiceController.Mode.ON_DEMAND);
}
Aggregations