org.springframework.mock.env.MockPropertySource.java Source code

Java tutorial

Introduction

Here is the source code for org.springframework.mock.env.MockPropertySource.java

Source

/*
 * Copyright 2002-2012 the original author or authors.
 *
 * 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
 *
 *      https://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.
 */

package org.springframework.mock.env;

import java.util.Properties;

import org.springframework.core.env.PropertiesPropertySource;
import org.springframework.core.env.PropertySource;

/**
 * Simple {@link PropertySource} implementation for use in testing. Accepts
 * a user-provided {@link Properties} object, or if omitted during construction,
 * the implementation will initialize its own.
 *
 * The {@link #setProperty} and {@link #withProperty} methods are exposed for
 * convenience, for example:
 * <pre class="code">
 * {@code
 *   PropertySource<?> source = new MockPropertySource().withProperty("foo", "bar");
 * }
 * </pre>
 *
 * @author Chris Beams
 * @since 3.1
 * @see org.springframework.mock.env.MockEnvironment
 */
public class MockPropertySource extends PropertiesPropertySource {

    /**
     * {@value} is the default name for {@link MockPropertySource} instances not
     * otherwise given an explicit name.
     * @see #MockPropertySource()
     * @see #MockPropertySource(String)
     */
    public static final String MOCK_PROPERTIES_PROPERTY_SOURCE_NAME = "mockProperties";

    /**
     * Create a new {@code MockPropertySource} named {@value #MOCK_PROPERTIES_PROPERTY_SOURCE_NAME}
     * that will maintain its own internal {@link Properties} instance.
     */
    public MockPropertySource() {
        this(new Properties());
    }

    /**
     * Create a new {@code MockPropertySource} with the given name that will
     * maintain its own internal {@link Properties} instance.
     * @param name the {@linkplain #getName() name} of the property source
     */
    public MockPropertySource(String name) {
        this(name, new Properties());
    }

    /**
     * Create a new {@code MockPropertySource} named {@value #MOCK_PROPERTIES_PROPERTY_SOURCE_NAME}
     * and backed by the given {@link Properties} object.
     * @param properties the properties to use
     */
    public MockPropertySource(Properties properties) {
        this(MOCK_PROPERTIES_PROPERTY_SOURCE_NAME, properties);
    }

    /**
     * Create a new {@code MockPropertySource} with the given name and backed by the given
     * {@link Properties} object.
     * @param name the {@linkplain #getName() name} of the property source
     * @param properties the properties to use
     */
    public MockPropertySource(String name, Properties properties) {
        super(name, properties);
    }

    /**
     * Set the given property on the underlying {@link Properties} object.
     */
    public void setProperty(String name, Object value) {
        this.source.put(name, value);
    }

    /**
     * Convenient synonym for {@link #setProperty} that returns the current instance.
     * Useful for method chaining and fluent-style use.
     * @return this {@link MockPropertySource} instance
     */
    public MockPropertySource withProperty(String name, Object value) {
        this.setProperty(name, value);
        return this;
    }

}