/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.runtime.module.extension.internal.runtime.config;
import static java.util.Arrays.asList;
import static java.util.Optional.of;
import static org.hamcrest.CoreMatchers.instanceOf;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.notNullValue;
import static org.hamcrest.CoreMatchers.sameInstance;
import static org.hamcrest.Matchers.containsInAnyOrder;
import static org.junit.Assert.assertThat;
import static org.mockito.Answers.RETURNS_DEEP_STUBS;
import static org.mockito.Mockito.when;
import static org.mule.test.module.extension.internal.util.ExtensionsTestUtils.mockConfigurationInstance;
import static org.mule.test.module.extension.internal.util.ExtensionsTestUtils.mockInterceptors;
import org.mule.runtime.api.connection.ConnectionException;
import org.mule.runtime.api.connection.ConnectionProvider;
import org.mule.runtime.api.connection.ConnectionValidationResult;
import org.mule.runtime.api.meta.model.ComponentModel;
import org.mule.runtime.api.meta.model.ExtensionModel;
import org.mule.runtime.api.meta.model.config.ConfigurationModel;
import org.mule.runtime.api.meta.model.operation.OperationModel;
import org.mule.runtime.api.meta.model.source.SourceCallbackModel;
import org.mule.runtime.api.meta.model.source.SourceModel;
import org.mule.runtime.core.api.Event;
import org.mule.runtime.core.api.MuleContext;
import org.mule.runtime.extension.api.runtime.ConfigurationInstance;
import org.mule.runtime.extension.api.runtime.Interceptable;
import org.mule.runtime.extension.api.runtime.operation.Interceptor;
import org.mule.runtime.module.extension.internal.loader.java.property.ConnectivityModelProperty;
import org.mule.runtime.module.extension.internal.runtime.execution.ConfigurationObjectBuilderTestCase;
import org.mule.runtime.module.extension.internal.runtime.execution.ConfigurationObjectBuilderTestCase.TestConfig;
import org.mule.runtime.module.extension.internal.runtime.resolver.ResolverSet;
import org.mule.runtime.module.extension.internal.runtime.resolver.ResolverSetResult;
import org.mule.runtime.module.extension.internal.runtime.resolver.StaticValueResolver;
import org.mule.tck.junit4.AbstractMuleTestCase;
import org.mule.tck.size.SmallTest;
import org.mule.tck.testmodels.fruit.Banana;
import org.mule.tck.testmodels.fruit.Kiwi;
import com.google.common.collect.ImmutableList;
import java.util.Optional;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
@SmallTest
@RunWith(MockitoJUnitRunner.class)
public class ConfigurationInstanceFactoryTestCase extends AbstractMuleTestCase {
private static final String CONFIG_NAME = "config";
@Mock(answer = RETURNS_DEEP_STUBS)
private ConfigurationModel configurationModel;
@Mock
private OperationModel operationModel;
@Mock
private ExtensionModel extensionModel;
@Mock
private SourceModel sourceModel;
@Mock
private SourceCallbackModel sourceCallbackModel;
@Mock
private ComponentModel componentModel;
@Mock
private Interceptor interceptor1;
@Mock
private Interceptor interceptor2;
@Mock(answer = RETURNS_DEEP_STUBS)
private Event event;
@Mock
private MuleContext muleContext;
private ResolverSet resolverSet;
private ConfigurationInstanceFactory<TestConfig> factory;
@Before
public void before() throws Exception {
mockConfigurationInstance(configurationModel, new TestConfig());
mockInterceptors(configurationModel, asList(() -> interceptor1, () -> interceptor2));
when(configurationModel.getOperationModels()).thenReturn(ImmutableList.of());
when(configurationModel.getSourceModels()).thenReturn(ImmutableList.of());
when(extensionModel.getOperationModels()).thenReturn(asList(operationModel));
when(extensionModel.getSourceModels()).thenReturn(asList(sourceModel));
when(operationModel.getModelProperty(ConnectivityModelProperty.class))
.thenReturn(of(new ConnectivityModelProperty(Banana.class)));
when(sourceModel.getModelProperty(ConnectivityModelProperty.class))
.thenReturn(of(new ConnectivityModelProperty(Banana.class)));
when(sourceModel.getErrorCallback()).thenReturn(of(sourceCallbackModel));
when(sourceModel.getSuccessCallback()).thenReturn(of(sourceCallbackModel));
resolverSet = ConfigurationObjectBuilderTestCase.createResolverSet();
factory = new ConfigurationInstanceFactory<>(extensionModel, configurationModel, resolverSet, muleContext);
}
@Test
public void createFromEvent() throws Exception {
ConfigurationInstance configurationInstance =
factory.createConfiguration(CONFIG_NAME, event, new StaticValueResolver<>(null));
assertConfiguration(configurationInstance);
}
@Test
public void createFromResolverSetResult() throws Exception {
ResolverSetResult result = ResolverSetResult.newBuilder().build();
ConfigurationInstance configurationInstance = factory.createConfiguration(CONFIG_NAME, result, Optional.empty());
assertConfiguration(configurationInstance);
assertThat(configurationInstance.getConnectionProvider().isPresent(), is(false));
}
private void assertConfiguration(ConfigurationInstance configurationInstance) {
assertThat(configurationInstance, is(notNullValue()));
assertThat(configurationInstance.getName(), is(CONFIG_NAME));
assertThat(configurationInstance.getModel(), is(sameInstance(configurationModel)));
assertThat(configurationInstance.getValue(), is(instanceOf(TestConfig.class)));
assertThat(configurationInstance, is(instanceOf(Interceptable.class)));
assertThat(((Interceptable) configurationInstance).getInterceptors(), containsInAnyOrder(interceptor1, interceptor2));
}
public static class InvalidConfigTestConnectionProvider implements ConnectionProvider<Banana> {
@Override
public Banana connect() throws ConnectionException {
return new Banana();
}
@Override
public void disconnect(Banana banana) {
}
@Override
public ConnectionValidationResult validate(Banana banana) {
return ConnectionValidationResult.success();
}
}
public static class InvalidConnectionTypeProvider implements ConnectionProvider<Kiwi> {
@Override
public Kiwi connect() throws ConnectionException {
return new Kiwi();
}
@Override
public void disconnect(Kiwi kiwi) {
}
@Override
public ConnectionValidationResult validate(Kiwi kiwi) {
return ConnectionValidationResult.success();
}
}
}