Package org.spincast.core.guice
Class GuiceTweaker
java.lang.Object
org.spincast.core.guice.GuiceTweaker
- All Implemented Interfaces:
- SpincastContextTypesInterested,- SpincastPlugin
Spincast plugin made available through a ThreadLocal.
 
This allows the tweaking of the Guice context of an application without touching its bootstrapping code.
The first use case for this is to be able to mock some parts of an application in order to test it.
It is the responsibility of the code creating the GuiceTweaker to make sure the ThreadLocal variable is removed.
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected com.google.inject.ModuleaddOverridingModules(com.google.inject.Module combinedModule) Those overriding modules will be added both *before* and then, again, *after* the plugins are applied.com.google.inject.ModuleafterPlugins(com.google.inject.Module combinedModule) Ran after the plugins are applied in SpincastBootstrapper.com.google.inject.Moduleapply(com.google.inject.Module currentModule) Ran as a regular plugin.com.google.inject.ModulebeforePlugins(com.google.inject.Module combinedModule) Ran before the plugins are applied in SpincastBootstrapper.voidbindingHierarchyToRemove(Class<?> parentClass) An binding hierarchy to remove from the combined modules.voidcreatedGuiceInjector(com.google.inject.Injector injector) Once all the plugins have been applied, this method is called with the resulting Guice injector.voidvoidexactBindingToRemove(com.google.inject.Key<?> key) An exact binding to remove from the combined modules.protected Set<com.google.inject.Key<?>>protected List<SpincastPlugin>getId()The id of the plugin.com.google.inject.Injectorprotected Set<com.google.inject.Module>If required, the ids of plugins that shouldn't be installed.protected Class<? extends RequestContext<?>>protected Class<? extends WebsocketContext<?>>booleanvoidoverridingModule(com.google.inject.Module overridingModule) Adds an overriding Module.voidplugin(SpincastPlugin plugin) Adds an extra plugin to be applied when the Guice context is created.voidpluginToDisable(String pluginId) voidsetRequestContextImplementationClass(Class<? extends RequestContext<?>> requestContextImplementationClass) The implementation class to use for RequestContext.voidsetWebsocketContextImplementationClass(Class<? extends WebsocketContext<?>> websocketContextImplementationClass) The implementation class to use for WebsocletContext.
- 
Field Details- 
threadLocal
- 
PLUGIN_ID
 
- 
- 
Constructor Details- 
GuiceTweakerpublic GuiceTweaker()
 
- 
- 
Method Details- 
getIdDescription copied from interface:SpincastPluginThe id of the plugin.- Specified by:
- getIdin interface- SpincastPlugin
 
- 
getExtraPlugins
- 
getOverridingModules
- 
getExactBindingsToRemoveBeforePlugins
- 
getBindingsHierarchiesToRemoveBeforePlugins
- 
isDisableBindCurrentClasspublic boolean isDisableBindCurrentClass()
- 
createdGuiceInjectorpublic void createdGuiceInjector(com.google.inject.Injector injector) Description copied from interface:SpincastPluginOnce all the plugins have been applied, this method is called with the resulting Guice injector.- Specified by:
- createdGuiceInjectorin interface- SpincastPlugin
 
- 
getInjectorpublic com.google.inject.Injector getInjector()
- 
beforePluginspublic com.google.inject.Module beforePlugins(com.google.inject.Module combinedModule) Ran before the plugins are applied in SpincastBootstrapper.- Parameters:
- combinedModule- the combinaison of all the Guice modules just before the plugins are applied.
 
- 
applypublic com.google.inject.Module apply(com.google.inject.Module currentModule) Ran as a regular plugin.- Specified by:
- applyin interface- SpincastPlugin
- Returns:
- an ajusted Guice module.
 
- 
afterPluginspublic com.google.inject.Module afterPlugins(com.google.inject.Module combinedModule) Ran after the plugins are applied in SpincastBootstrapper.- Parameters:
- combinedModule- the combinaison of all the Guice modules just after the plugins have been applied.
 
- 
addOverridingModulesprotected com.google.inject.Module addOverridingModules(com.google.inject.Module combinedModule) Those overriding modules will be added both *before* and then, again, *after* the plugins are applied.
- 
getPluginsToDisableDescription copied from interface:SpincastPluginIf required, the ids of plugins that shouldn't be installed.This plugin is repsonsible to bind any components that won't be bound because it marks some plugins as "to be ignored". - Specified by:
- getPluginsToDisablein interface- SpincastPlugin
 
- 
setRequestContextImplementationClasspublic void setRequestContextImplementationClass(Class<? extends RequestContext<?>> requestContextImplementationClass) Description copied from interface:SpincastContextTypesInterestedThe implementation class to use for RequestContext.- Specified by:
- setRequestContextImplementationClassin interface- SpincastContextTypesInterested
 
- 
setWebsocketContextImplementationClasspublic void setWebsocketContextImplementationClass(Class<? extends WebsocketContext<?>> websocketContextImplementationClass) Description copied from interface:SpincastContextTypesInterestedThe implementation class to use for WebsocletContext.- Specified by:
- setWebsocketContextImplementationClassin interface- SpincastContextTypesInterested
 
- 
getRequestContextImplementationClass
- 
getWebsocketContextImplementationClass
- 
overridingModulepublic void overridingModule(com.google.inject.Module overridingModule) Adds an overriding Module. The bindings of this Module will be applied before the plugins run in SpincastBootstrapper.
- 
exactBindingToRemovepublic void exactBindingToRemove(com.google.inject.Key<?> key) An exact binding to remove from the combined modules. This will be done before the plugins run in SpincastBootstrapper.
- 
bindingHierarchyToRemoveAn binding hierarchy to remove from the combined modules. All bindings implementing or extending the specified parent class, directly or indirectly, will be removed. This will be done before the plugins run in SpincastBootstrapper.
- 
pluginAdds an extra plugin to be applied when the Guice context is created.
- 
disableBindCurrentClasspublic void disableBindCurrentClass()
- 
pluginToDisable
 
-