All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.gerrit.acceptance.ServerTestRule Maven / Gradle / Ivy

There is a newer version: 3.11.0
Show newest version
// Copyright (C) 2024 The Android Open Source Project
//
// 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.

package com.google.gerrit.acceptance;

import com.google.gerrit.acceptance.ProjectResetter.Config;
import com.google.gerrit.common.Nullable;
import com.google.gerrit.server.config.AllProjectsName;
import com.google.gerrit.server.config.AllUsersName;
import com.google.gerrit.server.util.RequestContext;
import com.google.inject.Injector;
import java.net.InetSocketAddress;
import java.util.Optional;
import java.util.function.BiFunction;
import org.junit.rules.TestRule;

public interface ServerTestRule extends TestRule {
  /**
   * Initialize a server.
   *
   * 

All other methods must be called after this method is executed. */ void initServer() throws Exception; @Nullable ProjectResetter createProjectResetter( BiFunction resetConfigSupplier) throws Exception; Injector getTestInjector(); Optional getHttpdInjector(); /** * Initializes Ssh if a test requires it. * *

The method shouldn't throw an exception if the test doesn't require Ssh. If the test * requires ssh and ssh is not supported (e.g. in internal google tests) the method throws {@link * UnsupportedOperationException}. */ void initSsh() throws Exception; /** * Restart backend as a replica and re-init Ssh if a test requires ssh. * *

The method throws {@link UnsupportedOperationException} if restarting is not supported (e.g. * in internal google tests). */ void restartAsSlave() throws Exception; /** * Restart backend as a primary and re-init Ssh if a test requires ssh. * *

The method throws {@link UnsupportedOperationException} if restarting is not supported (e.g. * in internal google tests). */ void restart() throws Exception; /** * Creates {@link RestSession} which sends all requests as a specified account. * *

For sending anonymous requests pass null as the {@code account}. */ RestSession createRestSession(@Nullable TestAccount account); /** Returns true if the started server is a replica. */ boolean isReplica(); /** Returns address to be used for http requests (if present). */ Optional getHttpAddress(); /** * Gets or creates a session associated with the given context. * *

The method throws {@link UnsupportedOperationException} if ssh is not supported (e.g. in * internal google tests). The method must be called only if a test or class is annotated with the * UseSsh annotation. */ SshSession getOrCreateSshSessionForContext(RequestContext ctx); /** Returns url to be used for git operations. */ String getGitUrl(); /** Returns true if ssh has been initialized. */ boolean sshInitialized(); /** * Returns true if username is supported. * *

If it is not supported tests must either skip username checks or use something else instead * (e.g. email) */ boolean isUsernameSupported(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy