io.wcm.testing.mock.wcmio.config.MockConfig Maven / Gradle / Ivy
/*
* #%L
* wcm.io
* %%
* Copyright (C) 2014 wcm.io
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
package io.wcm.testing.mock.wcmio.config;
import io.wcm.config.api.Parameter;
import io.wcm.config.core.impl.ApplicationImplementationPicker;
import io.wcm.config.core.impl.ConfigurationAdapterFactory;
import io.wcm.config.core.management.ParameterPersistence;
import io.wcm.config.core.management.ParameterPersistenceData;
import io.wcm.config.core.management.impl.ApplicationFinderImpl;
import io.wcm.config.core.management.impl.ConfigurationFinderImpl;
import io.wcm.config.core.management.impl.ParameterOverrideImpl;
import io.wcm.config.core.management.impl.ParameterPersistenceImpl;
import io.wcm.config.core.management.impl.ParameterResolverImpl;
import io.wcm.config.core.persistence.impl.ToolsConfigPagePersistenceProvider;
import io.wcm.config.spi.ApplicationProvider;
import io.wcm.config.spi.ConfigurationFinderStrategy;
import io.wcm.config.spi.ParameterProvider;
import io.wcm.config.spi.helpers.AbstractAbsoluteParentConfigurationFinderStrategy;
import io.wcm.config.spi.helpers.AbstractParameterProvider;
import io.wcm.config.spi.helpers.AbstractPathApplicationProvider;
import io.wcm.sling.commons.resource.ImmutableValueMap;
import io.wcm.testing.mock.aem.junit.AemContext;
import java.util.Map;
import java.util.Set;
import org.apache.jackrabbit.util.Text;
import org.apache.sling.api.resource.PersistenceException;
import org.osgi.annotation.versioning.ProviderType;
import com.google.common.collect.ImmutableSortedSet;
/**
* Helps setting up a mock environment for wcm.io Configuration.
*/
@ProviderType
public final class MockConfig {
private MockConfig() {
// static methods only
}
/**
* Set up all mandatory OSGi services for wcm.io Configuration support.
* @param context Aem context
*/
public static void setUp(AemContext context) {
// persistence providers
context.registerInjectActivateService(new ToolsConfigPagePersistenceProvider(),
ImmutableValueMap.of("enabled", true));
// management services
context.registerInjectActivateService(new ApplicationFinderImpl());
context.registerInjectActivateService(new ParameterOverrideImpl());
context.registerInjectActivateService(new ParameterPersistenceImpl());
context.registerInjectActivateService(new ParameterResolverImpl());
context.registerInjectActivateService(new ConfigurationFinderImpl());
// adapter factory
context.registerInjectActivateService(new ConfigurationAdapterFactory());
// models implementation picker
context.registerInjectActivateService(new ApplicationImplementationPicker());
}
/**
* {@link ConfigurationFinderStrategy} that supports one or multiple fixed levels in content hierarchy where
* configurations are supported.
* @param applicationId Application ID
* @param levels List of absolute levels where configuration is supported.
* Levels are used in the same way as {@link Text#getAbsoluteParent(String, int)}.
* Example:
* Text.getAbsoluteParent("/foo/bar/test", 1) == "/foo/bar"
* @return Configuration finder strategy
*/
public static ConfigurationFinderStrategy configurationFinderStrategyAbsoluteParent(
final String applicationId, final int... levels) {
return new AbstractAbsoluteParentConfigurationFinderStrategy(applicationId, levels) {
// nothing to override
};
}
/**
* {@link ParameterProvider} providing list of parameters from given parameter set.
* @param parameters Parameter set
* @return Parameter provider
*/
public static ParameterProvider parameterProvider(final Set> parameters) {
return new AbstractParameterProvider(parameters) {
// nothing to override
};
}
/**
* {@link ParameterProvider} providing list of parameters from given from reading all public static fields from a
* given class definition.
* @param type Class definition
* @return Parameter provider
*/
public static ParameterProvider parameterProvider(final Class> type) {
return new AbstractParameterProvider(type) {
// nothing to override
};
}
/**
* {@link ApplicationProvider} that supports detecting an application based on one or multiple fixed paths subtrees.
* @param applicationId Application id
* @param paths List of paths/subtrees this application belongs to
* @return Application provider
*/
public static ApplicationProvider applicationProvider(final String applicationId, final String... paths) {
return new AbstractPathApplicationProvider(applicationId, applicationId, paths) {
// nothing to override
};
}
/**
* Writes configuration parameters using the primary configured persistence provider.
* @param context AEM context
* @param configurationId Configuration id
* @param values Configuration values
*/
public static void writeConfiguration(AemContext context, String configurationId, Map values) {
try {
ParameterPersistence persistence = context.getService(ParameterPersistence.class);
persistence.storeData(context.resourceResolver(), configurationId,
new ParameterPersistenceData(values, ImmutableSortedSet.of()));
}
catch (PersistenceException ex) {
throw new RuntimeException("Storing parameter values for " + configurationId + " failed.", ex);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy