Add test to azure sample

This commit is contained in:
Dave Syer
2018-01-25 09:20:20 +00:00
parent b0bddd3160
commit ab30b755ba
4 changed files with 67 additions and 20 deletions

View File

@@ -30,7 +30,9 @@ import reactor.core.publisher.Flux;
public class AzureSpringBootRequestHandler<I, O> extends AzureSpringFunctionInitializer {
public O handleRequest(I foo, ExecutionContext context) {
context.getLogger().info("Handler Java HTTP trigger processed a request.");
if (context != null) {
context.getLogger().fine("Handler Java HTTP trigger processed a request.");
}
initialize(context);
Object convertedEvent = convertEvent(foo);

View File

@@ -46,7 +46,7 @@ public class AzureSpringFunctionInitializer implements Closeable {
private AtomicBoolean initialized = new AtomicBoolean();
private Class<?> configurationClass;
private Class<?> configurationClass;
@Autowired(required = false)
private FunctionCatalog catalog;
@@ -61,7 +61,6 @@ public class AzureSpringFunctionInitializer implements Closeable {
this(getStartClass());
}
@Override
public void close() throws IOException {
if (AzureSpringFunctionInitializer.context != null) {
@@ -73,24 +72,27 @@ public class AzureSpringFunctionInitializer implements Closeable {
protected void initialize(ExecutionContext ctxt) {
ConfigurableApplicationContext context = AzureSpringFunctionInitializer.context;
if (!this.initialized.compareAndSet(false, true)) {
return;
}
ctxt.getLogger().info("Initializing function");
if (context==null) {
if (ctxt != null) {
ctxt.getLogger().info("Initializing function");
}
if (context == null) {
synchronized (AzureSpringFunctionInitializer.class) {
if (context==null) {
if (context == null) {
SpringApplicationBuilder builder = new SpringApplicationBuilder(
configurationClass);
ClassUtils.overrideThreadContextClassLoader(AzureSpringFunctionInitializer.class.getClassLoader());
ClassUtils.overrideThreadContextClassLoader(
AzureSpringFunctionInitializer.class.getClassLoader());
context = builder.web(false).run();
AzureSpringFunctionInitializer.context = context;
}
}
}
context.getAutowireCapableBeanFactory().autowireBean(this);
@@ -116,7 +118,8 @@ public class AzureSpringFunctionInitializer implements Closeable {
}
private static Class<?> getStartClass() {
ClassLoader classLoader = org.springframework.cloud.function.adapter.azure.AzureSpringFunctionInitializer.class.getClassLoader();
ClassLoader classLoader = org.springframework.cloud.function.adapter.azure.AzureSpringFunctionInitializer.class
.getClassLoader();
if (System.getenv("MAIN_CLASS") != null) {
return ClassUtils.resolveClassName(System.getenv("MAIN_CLASS"), classLoader);
}
@@ -144,8 +147,10 @@ public class AzureSpringFunctionInitializer implements Closeable {
.getValue("Main-Class");
if (startClass != null) {
Class<?> aClass = ClassUtils.forName(startClass,
org.springframework.cloud.function.adapter.azure.AzureSpringFunctionInitializer.class.getClassLoader());
SpringBootApplication declaredAnnotation = aClass.getDeclaredAnnotation(SpringBootApplication.class);
org.springframework.cloud.function.adapter.azure.AzureSpringFunctionInitializer.class
.getClassLoader());
SpringBootApplication declaredAnnotation = aClass
.getDeclaredAnnotation(SpringBootApplication.class);
if (declaredAnnotation != null) {
return aClass;
}