12 Commits

Author SHA1 Message Date
15220e7135 Merge pull request 'Fix checkForNewerStuffTest' (#5) from fix/checkForNewerStuffTest into dev
Reviewed-on: #5
2023-06-19 22:37:06 +00:00
590b06fc86 Fix checkForNewerStuffTest
Fixed the tests that stopped working after refactoring #4
2023-06-20 00:35:31 +02:00
65b15f657d remove getDatabaseFromRegex 2023-06-19 22:37:52 +02:00
82a854dd8b refactor writeDatabaseAccessTimeToFile 2023-06-19 22:33:30 +02:00
5018856aab refactor writePackageNamesAndVersionToFile 2023-06-19 22:30:48 +02:00
dc811d7462 Merge pull request 'Major changes in package acquisition' (#4) from refactor/packageAcquisition into dev
Reviewed-on: #4
2023-06-18 20:55:56 +00:00
07982425e0 Write package name and version into text file 2023-06-18 22:55:15 +02:00
e609caf892 Major changes in package acquisition
This breaks a bunch of things that depended on the older version of this method
2023-06-18 22:44:43 +02:00
60dfb368e6 Merge pull request 'Use regex to filter databases' (#3) from feature/filterDatabasesForTransfer into dev
Reviewed-on: #3
2023-06-18 18:59:19 +00:00
41692548f2 Use regex to filter Databases 2023-06-18 20:46:43 +02:00
f923628c53 Merge pull request 'feature/checkForNewerPackagesAndDatabases' (#2) from feature/checkForNewerPackagesAndDatabases into dev
Reviewed-on: #2
2023-06-18 15:40:02 +00:00
1994e92e9e Minor changes && Add tests
Made a seperate method for writing the database access time files
Added tests for checkIfDatabasesWereModified
2023-06-18 17:24:56 +02:00
4 changed files with 117 additions and 59 deletions

View File

@ -7,9 +7,11 @@ public class checkForNewerStuffTest {
public void checkForNewerPackages_throwsExceptionIfNoFilesExist() { public void checkForNewerPackages_throwsExceptionIfNoFilesExist() {
// Arrange // Arrange
PacserverUtils utils = new PacserverUtils(); PacserverUtils utils = new PacserverUtils();
File.Delete("/tmp/packages_before.txt");
File.Delete("/tmp/packages_after.txt");
// Act // Act
Action act = () => utils.diff("/tmp/before_update.txt", "/tmp/after_update.txt"); Action act = () => utils.diff("/tmp/packages_before.txt", "/tmp/packages_after.txt");
// Assert // Assert
act.Should().Throw<FileNotFoundException>().WithMessage("Necessary files could not be found"); act.Should().Throw<FileNotFoundException>().WithMessage("Necessary files could not be found");
@ -22,12 +24,12 @@ public class checkForNewerStuffTest {
utils.readPacmanConfig(); utils.readPacmanConfig();
// Act // Act
utils.getEveryPackageNameAndVersionViaFolderName("/tmp/before_update.txt"); utils.getEveryPackageNameAndVersion("before", "/tmp/packages_before.txt");
utils.getEveryPackageNameAndVersionViaFolderName("/tmp/after_update.txt"); utils.getEveryPackageNameAndVersion("after", "/tmp/packages_after.txt");
// Assert // Assert
File.Exists("/tmp/before_update.txt").Should().BeTrue(); File.Exists("/tmp/packages_before.txt").Should().BeTrue();
File.Exists("/tmp/after_update.txt").Should().BeTrue(); File.Exists("/tmp/packages_before.txt").Should().BeTrue();
} }
[Fact] [Fact]
@ -35,7 +37,7 @@ public class checkForNewerStuffTest {
// Arrange // Arrange
PacserverUtils utils = new PacserverUtils(); PacserverUtils utils = new PacserverUtils();
utils.readPacmanConfig(); utils.readPacmanConfig();
utils.getEveryPackageNameAndVersionViaFolderName("/tmp/before_update.txt"); utils.getEveryPackageNameAndVersion("before", "/tmp/packages_before.txt");
// Act // Act
List<String> packageList = utils.packageNamesAndVersion; List<String> packageList = utils.packageNamesAndVersion;
@ -45,16 +47,14 @@ public class checkForNewerStuffTest {
} }
[Fact] [Fact]
public void getEveryPackageNameAndVersionViaFolderName_throwsExceptionIfListIsEmpty() { public void getEveryPackageNameAndVersionViaFolderName_throwsExceptionIfModeIsNotValid() {
// Arrange // Arrange
PacserverUtils utils = new PacserverUtils(); PacserverUtils utils = new PacserverUtils();
Directory.CreateDirectory("/tmp/local");
utils.pacmanDatabaseDirectory = "/tmp/";
// Act // Act
Action act = () => utils.getEveryPackageNameAndVersionViaFolderName("/tmp/before_update.txt"); Action act = () => utils.getEveryPackageNameAndVersion("test", "/tmp/test.txt");
// Assert // Assert
act.Should().Throw<Exception>().WithMessage("How did you execute this without any packages?"); act.Should().Throw<ArgumentException>().WithMessage("No valid mode was given. Valid modes are before and after");
} }
} }

View File

@ -0,0 +1,31 @@
using Pacserver.Utils;
namespace Pacserver.Tests;
public class checkIfDatabasesWereModifiedTest {
[Fact]
public void checkIfDatabasesWereModified_throwsExceptionIfNoValidModeIsGiven() {
// Arrange
PacserverUtils utils = new PacserverUtils();
utils.readPacmanConfig();
// Act
Action act = () => utils.checkIfDatabasesWereModified("test", "/tmp/test.txt");
// Assert
act.Should().Throw<ArgumentException>().WithMessage("No valid mode was given. Valid modes are before and after");
}
[Fact]
public void checkIfDatabasesWereModified_throwsNoExceptionIfValidModeIsGiven() {
// Arrange
PacserverUtils utils = new PacserverUtils();
utils.readPacmanConfig();
// Act
Action act = () => utils.checkIfDatabasesWereModified("before", "/tmp/test.txt");
// Assert
act.Should().NotThrow();
}
}

View File

@ -37,16 +37,42 @@ public class PacserverUtils {
} }
public List<String> packageNamesAndVersion = new List<String>(); public List<String> packageNamesAndVersion = new List<String>();
public void getEveryPackageNameAndVersionViaFolderName(string filePath) { public void getEveryPackageNameAndVersion(string mode, string filePath) {
string[] directories = Directory.GetDirectories(pacmanDatabaseDirectory + "local/"); Regex regex = new Regex(@".+\.pkg\.tar\.zst$");
foreach (string directory in directories) {
packageNamesAndVersion.Add(new DirectoryInfo(directory).Name); if (Directory.Exists(pacmanCacheDirectory)) {
if (Directory.GetFiles(pacmanCacheDirectory) is not null) {
packageNamesAndVersion = Directory.GetFiles(pacmanCacheDirectory).Where(file => regex.IsMatch(file)).ToList();
} else {
Console.WriteLine("No packages found in pacman cache");
}
} else {
Console.WriteLine("No pacman cache directory found");
} }
if (packageNamesAndVersion.Capacity > 0) { switch (mode) {
File.WriteAllLines(filePath, packageNamesAndVersion); case "before":
} else { writePackageNamesAndVersionToFile(filePath);
throw new Exception("How did you execute this without any packages?"); break;
case "after":
writePackageNamesAndVersionToFile(filePath);
break;
default:
throw new ArgumentException("No valid mode was given. Valid modes are before and after");
}
}
public void writePackageNamesAndVersionToFile(string filePath) {
if (File.Exists(filePath)) {
File.Delete(filePath);
}
using (File.Open(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (StreamWriter sw = new StreamWriter(filePath)) {
foreach (string package in packageNamesAndVersion) {
sw.WriteLine(package);
}
}
} }
} }
@ -63,50 +89,39 @@ public class PacserverUtils {
public void checkIfDatabasesWereModified(string mode, string filePath) { public void checkIfDatabasesWereModified(string mode, string filePath) {
string[] databases = Directory.GetFiles(pacmanDatabaseDirectory + "sync/"); string[] databases = Directory.GetFiles(pacmanDatabaseDirectory + "sync/");
// if (mode == "nuke") {
// using (File.Open(filePath, FileMode.Truncate, FileAccess.ReadWrite, FileShare.Delete)) {
// File.Delete(filePath);
// }
// }
foreach (string database in databases) { foreach (string database in databases) {
switch (mode) { switch (mode) {
case "before": case "before":
if (!File.Exists(filePath)) { writeDatabaseAccessTimeToFile(filePath, database);
using (File.Open(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (StreamWriter sw = new StreamWriter(filePath)) {
sw.WriteLine(database + " " + File.GetLastAccessTime(database));
}
}
} else if (File.Exists(filePath)) {
using (File.Open(filePath, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (var sw = new StreamWriter(filePath, true)) {
sw.WriteLine(database + " " + File.GetLastAccessTime(database));
}
}
}
break; break;
case "after": case "after":
if (!File.Exists(filePath)) { writeDatabaseAccessTimeToFile(filePath, database);
using (File.Open(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (StreamWriter sw = new StreamWriter(filePath)) {
sw.WriteLine(database + " " + File.GetLastAccessTime(database));
}
}
} else if (File.Exists(filePath)) {
using (File.Open(filePath, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (var sw = new StreamWriter(filePath, true)) {
sw.WriteLine(database + " " + File.GetLastAccessTime(database));
}
}
}
break; break;
default: default:
throw new ArgumentException("No valid mode was selected"); throw new ArgumentException("No valid mode was given. Valid modes are before and after");
} }
} }
} }
public void writeDatabaseAccessTimeToFile(string filePath, string database) {
if (File.Exists(filePath)) {
File.Delete(filePath);
}
using (File.Open(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite)) {
using (StreamWriter sw = new StreamWriter(filePath)) {
sw.WriteLine(database + " " + File.GetLastAccessTime(database));
}
}
}
public List<String> databasesToTransfer = new List<String>();
public void filterDiffOutputForDatabases() {
foreach (string database in diffOfPackagesOrDatabases) {
databasesToTransfer.Add(Regex.Match(database, @"\/(?:[\w.-]+\/)*[\w.-]+(?:\.\w+)*\/*db").Value); // https://regex101.com/r/Wm5M0P/1
}
}
private static List<String> newerPackagesAndDatabases = new List<String>(); private static List<String> newerPackagesAndDatabases = new List<String>();
public async void transferPacmanCache() { public async void transferPacmanCache() {
HttpClient client = new HttpClient(); HttpClient client = new HttpClient();

View File

@ -6,7 +6,7 @@ public class Program {
Console.ForegroundColor = ConsoleColor.Red; Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("Please specify an option."); Console.WriteLine("Please specify an option.");
Console.ResetColor(); Console.ResetColor();
Console.WriteLine("Possible options are: determinePacmanCacheDirectory, packagesBefore, packagesAfter, diffPackages, databasesBefore, databasesAfter, diffDatabases"); Console.WriteLine("Possible options are: determinePacmanCacheDirectory, packagesBefore, packagesAfter, diffPackages, databasesBefore, databasesAfter, diffDatabases, filter");
return; return;
} }
@ -19,15 +19,15 @@ public class Program {
break; break;
case "packagesBefore": case "packagesBefore":
utils.readPacmanConfig(); utils.readPacmanConfig();
utils.getEveryPackageNameAndVersionViaFolderName("/tmp/before_update.txt"); utils.getEveryPackageNameAndVersion("before", "/tmp/packages_before.txt");
break; break;
case "packagesAfter": case "packagesAfter":
utils.readPacmanConfig(); utils.readPacmanConfig();
utils.getEveryPackageNameAndVersionViaFolderName("/tmp/after_update.txt"); utils.getEveryPackageNameAndVersion("after", "/tmp/packages_after.txt");
break; break;
case "diffPackages": case "diffPackages":
utils.diff("/tmp/before_update.txt", "/tmp/after_update.txt"); utils.diff("/tmp/packages_before.txt", "/tmp/packages_after.txt");
string packages = string.Join(",", utils.diffOfPackagesOrDatabases); string packages = string.Join("\n", utils.diffOfPackagesOrDatabases);
Console.WriteLine(packages); Console.WriteLine(packages);
break; break;
case "databasesBefore": case "databasesBefore":
@ -40,14 +40,26 @@ public class Program {
break; break;
case "diffDatabases": case "diffDatabases":
utils.diff("/tmp/databases_before.txt", "/tmp/databases_after.txt"); utils.diff("/tmp/databases_before.txt", "/tmp/databases_after.txt");
string databases = string.Join(",", utils.diffOfPackagesOrDatabases); string databases = string.Join("\n", utils.diffOfPackagesOrDatabases);
Console.WriteLine(databases); Console.WriteLine(databases);
break; break;
case "filter":
utils.diff("/tmp/databases_before.txt", "/tmp/databases_after.txt");
utils.filterDiffOutputForDatabases();
string filteredDatabases = string.Join("\n", utils.databasesToTransfer);
Console.WriteLine(filteredDatabases);
break;
case "getEveryPackageInCache":
utils.readPacmanConfig();
utils.getEveryPackageNameAndVersion("before", "/tmp/packages_before.txt");
string allPackages = string.Join("\n", utils.packageNamesAndVersion);
Console.WriteLine(allPackages);
break;
default: default:
Console.ForegroundColor = ConsoleColor.Red; Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine(args[0] + " is not a recognized option."); Console.WriteLine(args[0] + " is not a recognized option.");
Console.ResetColor(); Console.ResetColor();
Console.WriteLine("Possible options are: determinePacmanCacheDirectory"); Console.WriteLine("Possible options are: determinePacmanCacheDirectory, packagesBefore, packagesAfter, diffPackages, databasesBefore, databasesAfter, diffDatabases, filter");
break; break;
} }
} }