Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove restrictions required by netstandard 1.x but available in 2.0 #3790

Merged
Merged
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
a43207d
Enable features that are now in the netstandard2.0 library set (but w…
transmax-open-source May 16, 2019
98680a2
Correct version numbers for Clean target #3668
transmax-open-source May 16, 2019
0e52d7a
Merge branch 'dev' into remove-1x-netcore-restriction
heatonmatthew May 17, 2019
5d6c75b
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb May 21, 2019
587a396
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb May 23, 2019
48929a5
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb Jun 4, 2019
b25daa0
Merge branch 'dev' into remove-1x-netcore-restriction
heatonmatthew Jun 9, 2019
bf43ec0
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb Jul 16, 2019
8a2abe8
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 1, 2021
23a583e
Post-merge cleanup
Arkatufus Apr 1, 2021
bd0bd38
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 15, 2021
47a8530
csproj and code cleanup
Arkatufus Apr 16, 2021
71e1b68
Fix Akka.Persistence.TCK outdated journal spec, original assumption w…
Arkatufus Apr 16, 2021
72d6823
Avoid hardwiring names, spec name isn't hardwired anymore.
Arkatufus Apr 16, 2021
d0008b1
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 16, 2021
b7c7611
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb Apr 16, 2021
0740894
Add serialization support to exceptions (at least for those in the Ak…
Arkatufus Apr 16, 2021
f6a5df8
Add support to wrap exceptions in custom fields for ExceptionSupport
Arkatufus Apr 16, 2021
c8c4d0b
Add spec for ExceptionSupport
Arkatufus Apr 16, 2021
5b584c1
Merge branch 'remove-1x-netcore-restriction' of github.com:heatonmatt…
Arkatufus Apr 16, 2021
3dfd0c0
Update APIApproval list
Arkatufus Apr 16, 2021
6422da1
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 19, 2021
c34b2a6
Fix flaky spec
Arkatufus Apr 20, 2021
d0b5302
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 22, 2021
5bb8450
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus Apr 30, 2021
e53cc2c
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb May 3, 2021
6e33872
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus May 4, 2021
bd7e10c
Merge branch 'dev' into remove-1x-netcore-restriction
Arkatufus May 5, 2021
68cc15b
Revert "Fix flaky spec"
Arkatufus May 5, 2021
0956e76
Fix flaky tests
Arkatufus May 5, 2021
0a196e0
Merge branch 'dev' into remove-1x-netcore-restriction
Aaronontheweb May 6, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 28 additions & 13 deletions src/core/Akka.Remote/Serialization/ExceptionSupport.cs
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,15 @@
using Akka.Util.Internal;
using Google.Protobuf;
using System.Runtime.Serialization;
using Akka.Remote.Serialization.Proto.Msg;

namespace Akka.Remote.Serialization
{
internal class ExceptionSupport
{
private readonly WrappedPayloadSupport _wrappedPayloadSupport;
private const BindingFlags All = BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public;
private HashSet<string> DefaultProperties = new HashSet<string>
private readonly HashSet<string> _defaultProperties = new HashSet<string>
{
"ClassName",
"Message",
Expand Down Expand Up @@ -66,7 +67,7 @@ internal Exception ExceptionFromProto(Proto.Msg.ExceptionData proto)
return ExceptionFromProtoNet(proto);
}

private FormatterConverter DefaultFormatterConverter = new FormatterConverter();
private readonly FormatterConverter _defaultFormatterConverter = new FormatterConverter();

public Proto.Msg.ExceptionData ExceptionToProtoNet(Exception exception)
{
Expand All @@ -84,14 +85,22 @@ public Proto.Msg.ExceptionData ExceptionToProtoNet(Exception exception)
message.InnerException = ExceptionToProto(exception.InnerException);

var serializable = exception as ISerializable;
var serializationInfo = new SerializationInfo(exceptionType, DefaultFormatterConverter);
var serializationInfo = new SerializationInfo(exceptionType, _defaultFormatterConverter);
serializable.GetObjectData(serializationInfo, new StreamingContext());

foreach (var info in serializationInfo)
{
if (DefaultProperties.Contains(info.Name)) continue;
var preparedValue = _wrappedPayloadSupport.PayloadToProto(info.Value);
message.CustomFields.Add(info.Name, preparedValue);
if (_defaultProperties.Contains(info.Name)) continue;
if (info.Value is Exception exceptionValue)
{
var exceptionPayload = ExceptionToProto(exceptionValue);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Old code would fail if it encounters an Exception property inside an Exception, have to make sure that the serializer recurse through these

var preparedValue = _wrappedPayloadSupport.PayloadToProto(exceptionPayload);
message.CustomFields.Add(info.Name, preparedValue);
} else
{
var preparedValue = _wrappedPayloadSupport.PayloadToProto(info.Value);
message.CustomFields.Add(info.Name, preparedValue);
}
}

return message;
Expand All @@ -104,22 +113,25 @@ public Exception ExceptionFromProtoNet(Proto.Msg.ExceptionData proto)

Type exceptionType = Type.GetType(proto.TypeName);

var serializationInfo = new SerializationInfo(exceptionType, DefaultFormatterConverter);
var serializationInfo = new SerializationInfo(exceptionType, _defaultFormatterConverter);

serializationInfo.AddValue("ClassName", proto.TypeName);
serializationInfo.AddValue("Message", proto.Message);
serializationInfo.AddValue("StackTraceString", proto.StackTrace);
serializationInfo.AddValue("Source", proto.Source);
serializationInfo.AddValue("Message", ValueOrNull(proto.Message));
serializationInfo.AddValue("StackTraceString", ValueOrNull(proto.StackTrace));
serializationInfo.AddValue("Source", ValueOrNull(proto.Source));
serializationInfo.AddValue("InnerException", ExceptionFromProto(proto.InnerException));
serializationInfo.AddValue("HelpURL", string.Empty);
serializationInfo.AddValue("RemoteStackTraceString", string.Empty);
serializationInfo.AddValue("RemoteStackTraceString", null);
serializationInfo.AddValue("RemoteStackIndex", 0);
serializationInfo.AddValue("ExceptionMethod", string.Empty);
serializationInfo.AddValue("ExceptionMethod", null);
serializationInfo.AddValue("HResult", int.MinValue);

foreach (var field in proto.CustomFields)
{
serializationInfo.AddValue(field.Key, _wrappedPayloadSupport.PayloadFrom(field.Value));
var payload = _wrappedPayloadSupport.PayloadFrom(field.Value);
if (payload is ExceptionData exception)
payload = ExceptionFromProto(exception);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Old code would fail if it encounters an Exception property inside an Exception, have to make sure that the serializer recurse through these

serializationInfo.AddValue(field.Key, payload);
}

Exception obj = null;
Expand All @@ -137,5 +149,8 @@ public Exception ExceptionFromProtoNet(Proto.Msg.ExceptionData proto)

return obj;
}

private string ValueOrNull(string value)
=> string.IsNullOrEmpty(value) ? null : value;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Default value for strings inside an Exception is null, have to convert proto empty strings to null to make a proper Exception object

}
}