mirror of https://github.com/SixLabors/ImageSharp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
5.6 KiB
133 lines
5.6 KiB
// Copyright (c) Six Labors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
using System.IO;
|
|
using SixLabors.ImageSharp.Formats.Webp;
|
|
using SixLabors.ImageSharp.Metadata.Profiles.Exif;
|
|
using SixLabors.ImageSharp.PixelFormats;
|
|
using Xunit;
|
|
|
|
// ReSharper disable InconsistentNaming
|
|
namespace SixLabors.ImageSharp.Tests.Formats.Webp
|
|
{
|
|
[Trait("Format", "Webp")]
|
|
public class WebpMetaDataTests
|
|
{
|
|
private static WebpDecoder WebpDecoder => new() { IgnoreMetadata = false };
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Webp.Lossy.WithExif, PixelTypes.Rgba32, false)]
|
|
[WithFile(TestImages.Webp.Lossy.WithExif, PixelTypes.Rgba32, true)]
|
|
[WithFile(TestImages.Webp.Lossless.WithExif, PixelTypes.Rgba32, false)]
|
|
[WithFile(TestImages.Webp.Lossless.WithExif, PixelTypes.Rgba32, true)]
|
|
public void IgnoreMetadata_ControlsWhetherExifIsParsed<TPixel>(TestImageProvider<TPixel> provider, bool ignoreMetadata)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
var decoder = new WebpDecoder { IgnoreMetadata = ignoreMetadata };
|
|
|
|
using Image<TPixel> image = provider.GetImage(decoder);
|
|
if (ignoreMetadata)
|
|
{
|
|
Assert.Null(image.Metadata.ExifProfile);
|
|
}
|
|
else
|
|
{
|
|
ExifProfile exifProfile = image.Metadata.ExifProfile;
|
|
Assert.NotNull(exifProfile);
|
|
Assert.NotEmpty(exifProfile.Values);
|
|
Assert.Contains(exifProfile.Values, m => m.Tag.Equals(ExifTag.Make) && m.GetValue().Equals("Canon"));
|
|
Assert.Contains(exifProfile.Values, m => m.Tag.Equals(ExifTag.Model) && m.GetValue().Equals("Canon PowerShot S40"));
|
|
Assert.Contains(exifProfile.Values, m => m.Tag.Equals(ExifTag.Software) && m.GetValue().Equals("GIMP 2.10.2"));
|
|
}
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Webp.Lossy.WithIccp, PixelTypes.Rgba32, false)]
|
|
[WithFile(TestImages.Webp.Lossy.WithIccp, PixelTypes.Rgba32, true)]
|
|
[WithFile(TestImages.Webp.Lossless.WithIccp, PixelTypes.Rgba32, false)]
|
|
[WithFile(TestImages.Webp.Lossless.WithIccp, PixelTypes.Rgba32, true)]
|
|
public void IgnoreMetadata_ControlsWhetherIccpIsParsed<TPixel>(TestImageProvider<TPixel> provider, bool ignoreMetadata)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
var decoder = new WebpDecoder { IgnoreMetadata = ignoreMetadata };
|
|
|
|
using Image<TPixel> image = provider.GetImage(decoder);
|
|
if (ignoreMetadata)
|
|
{
|
|
Assert.Null(image.Metadata.IccProfile);
|
|
}
|
|
else
|
|
{
|
|
Assert.NotNull(image.Metadata.IccProfile);
|
|
Assert.NotEmpty(image.Metadata.IccProfile.Entries);
|
|
}
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(WebpFileFormatType.Lossy)]
|
|
[InlineData(WebpFileFormatType.Lossless)]
|
|
public void Encode_WritesExifWithPadding(WebpFileFormatType fileFormatType)
|
|
{
|
|
// arrange
|
|
using var input = new Image<Rgba32>(25, 25);
|
|
using var memoryStream = new MemoryStream();
|
|
var expectedExif = new ExifProfile();
|
|
string expectedSoftware = "ImageSharp";
|
|
expectedExif.SetValue(ExifTag.Software, expectedSoftware);
|
|
input.Metadata.ExifProfile = expectedExif;
|
|
|
|
// act
|
|
input.Save(memoryStream, new WebpEncoder() { FileFormat = fileFormatType });
|
|
memoryStream.Position = 0;
|
|
|
|
// assert
|
|
using var image = Image.Load<Rgba32>(memoryStream);
|
|
ExifProfile actualExif = image.Metadata.ExifProfile;
|
|
Assert.NotNull(actualExif);
|
|
Assert.Equal(expectedExif.Values.Count, actualExif.Values.Count);
|
|
Assert.Equal(expectedSoftware, actualExif.GetValue(ExifTag.Software).Value);
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Webp.Lossy.WithExif, PixelTypes.Rgba32)]
|
|
public void EncodeLossyWebp_PreservesExif<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
// arrange
|
|
using Image<TPixel> input = provider.GetImage(WebpDecoder);
|
|
using var memoryStream = new MemoryStream();
|
|
ExifProfile expectedExif = input.Metadata.ExifProfile;
|
|
|
|
// act
|
|
input.Save(memoryStream, new WebpEncoder() { FileFormat = WebpFileFormatType.Lossy });
|
|
memoryStream.Position = 0;
|
|
|
|
// assert
|
|
using var image = Image.Load<Rgba32>(memoryStream);
|
|
ExifProfile actualExif = image.Metadata.ExifProfile;
|
|
Assert.NotNull(actualExif);
|
|
Assert.Equal(expectedExif.Values.Count, actualExif.Values.Count);
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Webp.Lossless.WithExif, PixelTypes.Rgba32)]
|
|
public void EncodeLosslessWebp_PreservesExif<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
// arrange
|
|
using Image<TPixel> input = provider.GetImage(WebpDecoder);
|
|
using var memoryStream = new MemoryStream();
|
|
ExifProfile expectedExif = input.Metadata.ExifProfile;
|
|
|
|
// act
|
|
input.Save(memoryStream, new WebpEncoder() { FileFormat = WebpFileFormatType.Lossless });
|
|
memoryStream.Position = 0;
|
|
|
|
// assert
|
|
using var image = Image.Load<Rgba32>(memoryStream);
|
|
ExifProfile actualExif = image.Metadata.ExifProfile;
|
|
Assert.NotNull(actualExif);
|
|
Assert.Equal(expectedExif.Values.Count, actualExif.Values.Count);
|
|
}
|
|
}
|
|
}
|
|
|