Introduce server.util.DelegateSystemReader

This removes duplicated code in classes that implement SystemReader.

Change-Id: Id255aa3d6ac629ca25198d31be072291347d7c13
This commit is contained in:
Han-Wen Nienhuys
2019-09-02 19:00:19 +02:00
parent dfa596adac
commit 896e94f091
6 changed files with 73 additions and 95 deletions

View File

@@ -126,6 +126,7 @@ java_library2(
"//java/com/google/gerrit/server/git/receive",
"//java/com/google/gerrit/server/restapi",
"//java/com/google/gerrit/server/schema",
"//java/com/google/gerrit/server/util/git",
"//java/com/google/gerrit/server/util/time",
"//java/com/google/gerrit/sshd",
"//lib:args4j",

View File

@@ -30,6 +30,7 @@ import com.google.gerrit.server.config.SitePaths;
import com.google.gerrit.server.util.ManualRequestContext;
import com.google.gerrit.server.util.OneOffRequestContext;
import com.google.gerrit.server.util.RequestContext;
import com.google.gerrit.server.util.git.DelegateSystemReader;
import com.google.gerrit.testing.ConfigSuite;
import com.google.inject.Injector;
import com.google.inject.Module;
@@ -134,22 +135,7 @@ public abstract class StandaloneSiteTest {
private static SystemReader setFakeSystemReader(File tempDir) {
SystemReader oldSystemReader = SystemReader.getInstance();
SystemReader.setInstance(
new SystemReader() {
@Override
public String getHostname() {
return oldSystemReader.getHostname();
}
@Override
public String getenv(String variable) {
return oldSystemReader.getenv(variable);
}
@Override
public String getProperty(String key) {
return oldSystemReader.getProperty(key);
}
new DelegateSystemReader(oldSystemReader) {
@Override
public FileBasedConfig openUserConfig(Config parent, FS fs) {
return new FileBasedConfig(parent, new File(tempDir, "user.config"), FS.detect());
@@ -159,16 +145,6 @@ public abstract class StandaloneSiteTest {
public FileBasedConfig openSystemConfig(Config parent, FS fs) {
return new FileBasedConfig(parent, new File(tempDir, "system.config"), FS.detect());
}
@Override
public long getCurrentTime() {
return oldSystemReader.getCurrentTime();
}
@Override
public int getTimezone(long when) {
return oldSystemReader.getTimezone(when);
}
});
return oldSystemReader;
}

View File

@@ -17,6 +17,7 @@ package com.google.gerrit.server.git;
import com.google.common.flogger.FluentLogger;
import com.google.gerrit.extensions.events.LifecycleListener;
import com.google.gerrit.server.config.SitePaths;
import com.google.gerrit.server.util.git.DelegateSystemReader;
import com.google.inject.Inject;
import com.google.inject.Singleton;
import org.eclipse.jgit.lib.Config;
@@ -47,41 +48,11 @@ public class SystemReaderInstaller implements LifecycleListener {
private SystemReader customReader() {
SystemReader current = SystemReader.getInstance();
return new SystemReader() {
@Override
public String getHostname() {
return current.getHostname();
}
@Override
public String getenv(String variable) {
return current.getenv(variable);
}
@Override
public String getProperty(String key) {
return current.getProperty(key);
}
@Override
public FileBasedConfig openUserConfig(Config parent, FS fs) {
return current.openUserConfig(parent, fs);
}
return new DelegateSystemReader(current) {
@Override
public FileBasedConfig openSystemConfig(Config parent, FS fs) {
return new FileBasedConfig(parent, site.jgit_config.toFile(), FS.DETECTED);
}
@Override
public long getCurrentTime() {
return current.getCurrentTime();
}
@Override
public int getTimezone(long when) {
return current.getTimezone(when);
}
};
}
}

View File

@@ -0,0 +1,63 @@
// Copyright (C) 2019 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.server.util.git;
import org.eclipse.jgit.lib.Config;
import org.eclipse.jgit.storage.file.FileBasedConfig;
import org.eclipse.jgit.util.FS;
import org.eclipse.jgit.util.SystemReader;
public class DelegateSystemReader extends SystemReader {
private final SystemReader delegate;
public DelegateSystemReader(SystemReader delegate) {
this.delegate = delegate;
}
@Override
public String getHostname() {
return delegate.getHostname();
}
@Override
public String getenv(String variable) {
return delegate.getenv(variable);
}
@Override
public String getProperty(String key) {
return delegate.getProperty(key);
}
@Override
public FileBasedConfig openUserConfig(Config parent, FS fs) {
return delegate.openUserConfig(parent, fs);
}
@Override
public FileBasedConfig openSystemConfig(Config parent, FS fs) {
return delegate.openSystemConfig(parent, fs);
}
@Override
public long getCurrentTime() {
return delegate.getCurrentTime();
}
@Override
public int getTimezone(long when) {
return delegate.getTimezone(when);
}
}

View File

@@ -4,6 +4,7 @@ java_library(
visibility = ["//visibility:public"],
deps = [
"//java/com/google/gerrit/common:annotations",
"//java/com/google/gerrit/server/util/git",
"//lib:guava",
"//lib/jgit/org.eclipse.jgit:jgit",
],

View File

@@ -17,12 +17,10 @@ package com.google.gerrit.server.util.time;
import com.google.common.annotations.VisibleForTesting;
import com.google.gerrit.common.UsedAt;
import com.google.gerrit.common.UsedAt.Project;
import com.google.gerrit.server.util.git.DelegateSystemReader;
import java.sql.Timestamp;
import java.time.Instant;
import java.util.function.LongSupplier;
import org.eclipse.jgit.lib.Config;
import org.eclipse.jgit.storage.file.FileBasedConfig;
import org.eclipse.jgit.util.FS;
import org.eclipse.jgit.util.SystemReader;
/** Static utility methods for dealing with dates and times. */
@@ -76,47 +74,15 @@ public class TimeUtil {
SystemReader.setInstance(null);
}
private static class GerritSystemReader extends SystemReader {
SystemReader delegate;
GerritSystemReader(SystemReader delegate) {
this.delegate = delegate;
}
@Override
public String getHostname() {
return delegate.getHostname();
}
@Override
public String getenv(String variable) {
return delegate.getenv(variable);
}
@Override
public String getProperty(String key) {
return delegate.getProperty(key);
}
@Override
public FileBasedConfig openUserConfig(Config parent, FS fs) {
return delegate.openUserConfig(parent, fs);
}
@Override
public FileBasedConfig openSystemConfig(Config parent, FS fs) {
return delegate.openSystemConfig(parent, fs);
static class GerritSystemReader extends DelegateSystemReader {
GerritSystemReader(SystemReader reader) {
super(reader);
}
@Override
public long getCurrentTime() {
return currentMillisSupplier.getAsLong();
}
@Override
public int getTimezone(long when) {
return delegate.getTimezone(when);
}
}
private TimeUtil() {}