Replace TestHelper with TestAssetsManager
This commit is contained in:
parent
f7e4714dc5
commit
13f97b0cb8
3 changed files with 41 additions and 137 deletions
|
@ -1,115 +0,0 @@
|
|||
using System;
|
||||
using System.IO;
|
||||
using Microsoft.DotNet.ProjectModel.Graph;
|
||||
using Microsoft.Extensions.Logging;
|
||||
|
||||
namespace Microsoft.DotNet.ProjectModel.Server.Tests.Helpers
|
||||
{
|
||||
public class TestHelper
|
||||
{
|
||||
private readonly string _tempPath;
|
||||
private readonly string _testProjectsDir;
|
||||
|
||||
public TestHelper()
|
||||
{
|
||||
LoggerFactory = new LoggerFactory();
|
||||
|
||||
var testVerbose = Environment.GetEnvironmentVariable("DOTNET_TEST_VERBOSE");
|
||||
if (testVerbose == "2")
|
||||
{
|
||||
LoggerFactory.AddConsole(LogLevel.Trace);
|
||||
}
|
||||
else if (testVerbose == "1")
|
||||
{
|
||||
LoggerFactory.AddConsole(LogLevel.Information);
|
||||
}
|
||||
else
|
||||
{
|
||||
LoggerFactory.AddConsole(LogLevel.Warning);
|
||||
}
|
||||
|
||||
_tempPath = CreateTempFolder();
|
||||
_testProjectsDir = Path.Combine(AppContext.BaseDirectory, "TestAssets", "ProjectModelServer");
|
||||
CopyFiles(_testProjectsDir, _tempPath);
|
||||
|
||||
var logger = LoggerFactory.CreateLogger<TestHelper>();
|
||||
logger.LogInformation($"Test projects are copied to {_tempPath}");
|
||||
}
|
||||
|
||||
public ILoggerFactory LoggerFactory { get; }
|
||||
|
||||
public string FindSampleProject(string name)
|
||||
{
|
||||
var result = Path.Combine(_tempPath, "DthTestProjects", "src", name);
|
||||
if (Directory.Exists(result))
|
||||
{
|
||||
return result;
|
||||
}
|
||||
else
|
||||
{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public string CreateSampleProject(string name)
|
||||
{
|
||||
var source = Path.Combine(AppContext.BaseDirectory, "TestAssets", "ProjectModelServer");
|
||||
if (!Directory.Exists(source))
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
var target = Path.Combine(CreateTempFolder(), name);
|
||||
CopyFiles(source, target);
|
||||
|
||||
return target;
|
||||
}
|
||||
|
||||
public string BuildProjectCopy(string projectName)
|
||||
{
|
||||
var projectPath = FindSampleProject(projectName);
|
||||
var movedProjectPath = Path.Combine(CreateTempFolder(), projectName);
|
||||
CopyFiles(projectPath, movedProjectPath);
|
||||
|
||||
return movedProjectPath;
|
||||
}
|
||||
|
||||
public void DeleteLockFile(string folder)
|
||||
{
|
||||
var lockFilePath = Path.Combine(folder, LockFile.FileName);
|
||||
if (File.Exists(lockFilePath))
|
||||
{
|
||||
File.Delete(lockFilePath);
|
||||
}
|
||||
}
|
||||
|
||||
private static string CreateTempFolder()
|
||||
{
|
||||
var result = Path.GetTempFileName();
|
||||
File.Delete(result);
|
||||
Directory.CreateDirectory(result);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
private static void CopyFiles(string sourceFolder, string targetFolder)
|
||||
{
|
||||
if (!Directory.Exists(targetFolder))
|
||||
{
|
||||
Directory.CreateDirectory(targetFolder);
|
||||
}
|
||||
|
||||
foreach (var filePath in Directory.EnumerateFiles(sourceFolder))
|
||||
{
|
||||
var filename = Path.GetFileName(filePath);
|
||||
File.Copy(filePath, Path.Combine(targetFolder, filename));
|
||||
}
|
||||
|
||||
foreach (var folderPath in Directory.EnumerateDirectories(sourceFolder))
|
||||
{
|
||||
var folderName = new DirectoryInfo(folderPath).Name;
|
||||
CopyFiles(folderPath, Path.Combine(targetFolder, folderName));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue