/* * SonarQube * Copyright (C) 2009-2025 SonarSource SA * mailto:info AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.sonar.api.internal; import org.sonar.api.Plugin; import org.sonar.api.SonarRuntime; import org.sonar.api.config.Configuration; import org.sonar.api.config.internal.MapSettings; /** * Implementation of {@link Plugin.Context} that plugins could use in their unit tests. * * Example: * *
 *   import org.sonar.api.internal.SonarRuntimeImpl;
 *   import org.sonar.api.config.internal.MapSettings;
 *
 *   ...
 *
 *   SonarRuntime runtime = SonarRuntimeImpl.forSonarQube(Version.create(7, 1), SonarQubeSide.SCANNER);
 *   MapSettings settings = new MapSettings().setProperty("foo", "bar");
 *   Plugin.Context context = new PluginContextImpl.Builder()
 *     .setSonarRuntime(runtime)
 *     .setBootConfiguration(settings.asConfig());
 *     .build();
 * 
* * @since 7.1 */ public class PluginContextImpl extends Plugin.Context { private final Configuration bootConfiguration; private PluginContextImpl(Builder builder) { super(builder.sonarRuntime); this.bootConfiguration = builder.bootConfiguration != null ? builder.bootConfiguration : new MapSettings().asConfig(); } @Override public Configuration getBootConfiguration() { return bootConfiguration; } public static class Builder { private SonarRuntime sonarRuntime; private Configuration bootConfiguration; /** * Required. * @see SonarRuntimeImpl * @return this */ public Builder setSonarRuntime(SonarRuntime r) { this.sonarRuntime = r; return this; } /** * If not set, then an empty configuration is used. * @return this */ public Builder setBootConfiguration(Configuration c) { this.bootConfiguration = c; return this; } public Plugin.Context build() { return new PluginContextImpl(this); } } }