Skip to content

Commit

Permalink
BinaryData.Empty.ToString throws ArgumentNullException (#68349)
Browse files Browse the repository at this point in the history
* BinaryData.Empty.ToString throws ArgumentNullException

* Update src/libraries/System.Memory.Data/src/System/BinaryData.cs

Co-authored-by: Jan Kotas <jkotas@microsoft.com>
  • Loading branch information
pedrobsaila and jkotas committed Apr 22, 2022
1 parent 7810536 commit a685d88
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 0 deletions.
6 changes: 6 additions & 0 deletions src/libraries/System.Memory.Data/src/System/BinaryData.cs
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,12 @@ public static BinaryData FromObjectAsJson<T>(T jsonSerializable, JsonSerializerO
public override unsafe string ToString()
{
ReadOnlySpan<byte> span = _bytes.Span;

if (span.IsEmpty)
{
return string.Empty;
}

fixed (byte* ptr = span)
{
return Encoding.UTF8.GetString(ptr, span.Length);
Expand Down
6 changes: 6 additions & 0 deletions src/libraries/System.Memory.Data/tests/BinaryDataTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -585,6 +585,12 @@ public void EmptyIsSingleton()
Assert.Same(BinaryData.Empty, BinaryData.Empty);
}

[Fact]
public void ToStringReturnEmptyStringWhenBinaryDataEmpty()
{
Assert.Equal(string.Empty, BinaryData.Empty.ToString());
}

private class TestModel
{
public string A { get; set; }
Expand Down

0 comments on commit a685d88

Please sign in to comment.