mirror of
https://github.com/SoPat712/allstarr.git
synced 2026-04-27 12:02:51 -04:00
v1.3.0: Massive WebUI cleanup, Fixed/Stabilized scrobbling, Significant security hardening, added user login to WebUI, refactored searching/interleaving to work MUCH better, Tidal Powered recommendations for SquidWTF provider, Fixed double scrobbling, inferring stops much better, fixed playlist cron rebuilding, stale injected playlist artwork, and search cache TTL
This commit is contained in:
@@ -0,0 +1,42 @@
|
||||
using System.Reflection;
|
||||
using allstarr.Controllers;
|
||||
|
||||
namespace allstarr.Tests;
|
||||
|
||||
public class JellyfinQueryRedactionTests
|
||||
{
|
||||
[Fact]
|
||||
public void MaskSensitiveQueryString_RedactsSensitiveValues()
|
||||
{
|
||||
var masked = InvokeMaskSensitiveQueryString(
|
||||
"?api_key=secret1&query=hello&x-emby-token=secret2&AuthToken=secret3");
|
||||
|
||||
Assert.Contains("api_key=<redacted>", masked);
|
||||
Assert.Contains("query=hello", masked);
|
||||
Assert.Contains("x-emby-token=<redacted>", masked);
|
||||
Assert.Contains("AuthToken=<redacted>", masked);
|
||||
Assert.DoesNotContain("secret1", masked);
|
||||
Assert.DoesNotContain("secret2", masked);
|
||||
Assert.DoesNotContain("secret3", masked);
|
||||
}
|
||||
|
||||
[Theory]
|
||||
[InlineData(null)]
|
||||
[InlineData("")]
|
||||
public void MaskSensitiveQueryString_EmptyOrNull_ReturnsEmpty(string? input)
|
||||
{
|
||||
var masked = InvokeMaskSensitiveQueryString(input);
|
||||
Assert.Equal(string.Empty, masked);
|
||||
}
|
||||
|
||||
private static string InvokeMaskSensitiveQueryString(string? queryString)
|
||||
{
|
||||
var method = typeof(JellyfinController).GetMethod(
|
||||
"MaskSensitiveQueryString",
|
||||
BindingFlags.Static | BindingFlags.NonPublic);
|
||||
|
||||
Assert.NotNull(method);
|
||||
var result = method!.Invoke(null, new object?[] { queryString });
|
||||
return Assert.IsType<string>(result);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user