mirror of
https://github.com/bitwarden/server.git
synced 2024-12-01 13:43:23 +01:00
4377c7a897
* Rewrite Icon fetching * Move validation to IconUri, Uri, or UriBuilder * `dotnet format` 🤖 * PR suggestions * Add not null compiler hint * Add twitter to test case * Move Uri manipulation to UriService * Implement MockedHttpClient Presents better, fluent handling of message matching and response building. * Add redirect handling tests * Add testing to models * More aggressively dispose content in icon link * Format 🤖 * Update icon lockfile * Convert to cloned stream for HttpResponseBuilder Content was being disposed when HttResponseMessage was being disposed. This avoids losing our reference to our content and allows multiple usages of the same `MockedHttpMessageResponse` * Move services to extension Extension is shared by testing and allows access to services from our service tests * Remove unused `using` * Prefer awaiting asyncs for better exception handling * `dotnet format` 🤖 * Await async * Update tests to use test TLD and ip ranges * Remove unused interfaces * Make assignments static when possible * Prefer invariant comparer to downcasing * Prefer injecting interface services to implementations * Prefer comparer set in HashSet initialization * Allow SVG icons * Filter out icons with unknown formats * Seek to beginning of MemoryStream after writing it * More appropriate to not return icon if it's invalid * Add svg icon test
40 lines
1.2 KiB
C#
40 lines
1.2 KiB
C#
using Bit.Icons.Services;
|
|
using Xunit;
|
|
|
|
namespace Bit.Icons.Test.Services;
|
|
|
|
public class IconFetchingServiceTests : ServiceTestBase<IconFetchingService>
|
|
{
|
|
[Theory]
|
|
[InlineData("www.twitter.com")] // https site
|
|
[InlineData("www.google.com")] // https site
|
|
[InlineData("neverssl.com")] // http site
|
|
[InlineData("neopets.com")] // uses favicon.ico
|
|
[InlineData("hopin.com")] // uses svg+xml format
|
|
[InlineData("ameritrade.com")] // redirects to tdameritrace.com
|
|
[InlineData("icloud.com")]
|
|
[InlineData("bofa.com", Skip = "Broken in pipeline for .NET 6. Tracking link: https://bitwarden.atlassian.net/browse/PS-982")]
|
|
public async Task GetIconAsync_Success(string domain)
|
|
{
|
|
var sut = BuildSut();
|
|
var result = await sut.GetIconAsync(domain);
|
|
|
|
Assert.NotNull(result);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("1.1.1.1")]
|
|
[InlineData("")]
|
|
[InlineData("localhost")]
|
|
public async Task GetIconAsync_ReturnsNull(string domain)
|
|
{
|
|
var sut = BuildSut();
|
|
var result = await sut.GetIconAsync(domain);
|
|
|
|
Assert.Null(result);
|
|
}
|
|
|
|
private IconFetchingService BuildSut() =>
|
|
GetService<IconFetchingService>();
|
|
}
|