use /Users/<your_user_name>/Logs/SCM-Manager as log directory on OSX

This commit is contained in:
Sebastian Sdorra
2020-04-25 16:49:33 +02:00
parent dd7a727def
commit dbca56ce6b
3 changed files with 124 additions and 33 deletions

View File

@@ -25,9 +25,6 @@
package sonia.scm; package sonia.scm;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import lombok.Builder;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Nested; import org.junit.jupiter.api.Nested;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;

View File

@@ -27,34 +27,32 @@ package sonia.scm;
//~--- non-JDK imports -------------------------------------------------------- //~--- non-JDK imports --------------------------------------------------------
import ch.qos.logback.core.PropertyDefinerBase; import ch.qos.logback.core.PropertyDefinerBase;
import com.google.common.annotations.VisibleForTesting;
import sonia.scm.util.SystemUtil;
//~--- JDK imports ------------------------------------------------------------ //~--- JDK imports ------------------------------------------------------------
import java.io.File; import java.io.File;
import java.util.Properties;
/** /**
* Resolve directory path for SCM-Manager logs.
* *
* @author Sebastian Sdorra * @author Sebastian Sdorra
*/ */
public class ScmLogFilePropertyDefiner extends PropertyDefinerBase public class ScmLogFilePropertyDefiner extends PropertyDefinerBase {
{
/** Field description */ private final String logDirectoryPath;
public static final String LOG_DIRECTORY = "logs";
//~--- constructors --------------------------------------------------------- public ScmLogFilePropertyDefiner() {
this(SCMContext.getContext(), SystemUtil.getPlatform(), System.getProperties());
}
/** @VisibleForTesting
* Constructs ... ScmLogFilePropertyDefiner(SCMContextProvider context, Platform platform, Properties properties) {
* File logDirectory = resolveDirectory(context, platform, properties);
*/
public ScmLogFilePropertyDefiner()
{
File logDirectory = new File(SCMContext.getContext().getBaseDirectory(),
LOG_DIRECTORY);
if (!logDirectory.exists() &&!logDirectory.mkdirs()) if (!logDirectory.exists() && !logDirectory.mkdirs()) {
{
throw new ConfigurationException( throw new ConfigurationException(
"could not create log directory ".concat(logDirectory.getPath())); "could not create log directory ".concat(logDirectory.getPath()));
} }
@@ -62,22 +60,25 @@ public class ScmLogFilePropertyDefiner extends PropertyDefinerBase
this.logDirectoryPath = logDirectory.getAbsolutePath(); this.logDirectoryPath = logDirectory.getAbsolutePath();
} }
//~--- get methods ---------------------------------------------------------- private File resolveDirectory(SCMContextProvider context, Platform platform, Properties properties) {
if (platform.isMac()) {
return resolveOsX(properties);
} else {
return resolveDefault(context);
}
}
private File resolveOsX(Properties properties) {
return new File(properties.getProperty("user.home"), "Library/Logs/SCM-Manager");
}
private File resolveDefault(SCMContextProvider context) {
return new File(context.getBaseDirectory(), "logs");
}
/**
* Method description
*
*
* @return
*/
@Override @Override
public String getPropertyValue() public String getPropertyValue() {
{
return logDirectoryPath; return logDirectoryPath;
} }
//~--- fields ---------------------------------------------------------------
/** Field description */
private String logDirectoryPath;
} }

View File

@@ -0,0 +1,93 @@
/*
* MIT License
*
* Copyright (c) 2020-present Cloudogu GmbH and Contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package sonia.scm;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.junitpioneer.jupiter.TempDirectory;
import org.mockito.Mock;
import org.mockito.junit.jupiter.MockitoExtension;
import java.nio.file.Path;
import java.util.Properties;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.when;
@ExtendWith({MockitoExtension.class, TempDirectory.class})
class ScmLogFilePropertyDefinerTest {
@Mock
private SCMContextProvider context;
@Test
void shouldReturnPath(@TempDirectory.TempDir Path tempDir) {
when(context.getBaseDirectory()).thenReturn(tempDir.toFile());
ScmLogFilePropertyDefiner definer = builder().create();
Path logDirectory = tempDir.resolve("logs");
assertThat(definer.getPropertyValue()).isEqualTo(logDirectory.toAbsolutePath().toString());
}
@Test
void shouldReturnOsxPath(@TempDirectory.TempDir Path tempDir) {
ScmLogFilePropertyDefiner definer = builder()
.withOs("Mac OS X")
.withUserHome(tempDir.toAbsolutePath().toString())
.create();
Path logDirectory = tempDir.resolve("Library/Logs/SCM-Manager");
assertThat(definer.getPropertyValue()).isEqualTo(logDirectory.toAbsolutePath().toString());
}
private ScmLogFilePropertyDefinerBuilder builder() {
return new ScmLogFilePropertyDefinerBuilder();
}
private class ScmLogFilePropertyDefinerBuilder {
private Platform platform;
private Properties properties = new Properties();
public ScmLogFilePropertyDefinerBuilder() {
withOs("Linux");
}
public ScmLogFilePropertyDefinerBuilder withOs(String osName) {
platform = new Platform(osName, "64", "x86_64");
return this;
}
public ScmLogFilePropertyDefinerBuilder withUserHome(String path) {
properties.setProperty("user.home", path);
return this;
}
public ScmLogFilePropertyDefiner create() {
return new ScmLogFilePropertyDefiner(context, platform, properties);
}
}
}