Imported Upstream version 5.18.0.237

Former-commit-id: 656d32283cda0da3af4016476796d9184d8cdd84
This commit is contained in:
Xamarin Public Jenkins (auto-signing)
2019-01-12 08:22:06 +00:00
parent 2785a80efd
commit fbc511bfbe
237 changed files with 908 additions and 638 deletions

View File

@@ -100,7 +100,7 @@ namespace Mono {
static extern void DisableMicrosoftTelemetry ();
[MethodImplAttribute (MethodImplOptions.InternalCall)]
static extern void EnableMicrosoftTelemetry_internal (IntPtr appBundleID, IntPtr appSignature, IntPtr appVersion, IntPtr merpGUIPath, IntPtr eventType, IntPtr appPath);
static extern void EnableMicrosoftTelemetry_internal (IntPtr appBundleID, IntPtr appSignature, IntPtr appVersion, IntPtr merpGUIPath, IntPtr eventType, IntPtr appPath, IntPtr configDir);
[MethodImplAttribute (MethodImplOptions.InternalCall)]
static extern void SendMicrosoftTelemetry_internal (IntPtr payload, ulong portable_hash, ulong unportable_hash);
@@ -147,6 +147,7 @@ namespace Mono {
SendMicrosoftTelemetry (payload_str, portable_hash, unportable_hash);
}
// All must be set except for configDir_str
static void EnableMicrosoftTelemetry (string appBundleID_str, string appSignature_str, string appVersion_str, string merpGUIPath_str, string eventType_str, string appPath_str)
{
if (RuntimeInformation.IsOSPlatform (OSPlatform.OSX)) {
@@ -157,12 +158,13 @@ namespace Mono {
using (var eventType_chars = RuntimeMarshal.MarshalString (eventType_str))
using (var appPath_chars = RuntimeMarshal.MarshalString (appPath_str))
{
EnableMicrosoftTelemetry_internal (appBundleID_chars.Value, appSignature_chars.Value, appVersion_chars.Value, merpGUIPath_chars.Value, eventType_chars.Value, appPath_chars.Value);
EnableMicrosoftTelemetry_internal (appBundleID_chars.Value, appSignature_chars.Value, appVersion_chars.Value, merpGUIPath_chars.Value, eventType_chars.Value, appPath_chars.Value, IntPtr.Zero);
}
} else {
throw new PlatformNotSupportedException("Merp support is currently only supported on OSX.");
}
}
#endif
[MethodImplAttribute (MethodImplOptions.InternalCall)]
@@ -192,14 +194,24 @@ namespace Mono {
}
[MethodImplAttribute (MethodImplOptions.InternalCall)]
static extern void RegisterReportingForNativeLib_internal (IntPtr modulePathSuffix, IntPtr moduleName);
static extern void EnableCrashReportLog_internal (IntPtr directory);
static void RegisterReportingForNativeLib (string modulePathSuffix_str, string moduleName_str)
static void EnableCrashReportLog (string directory_str)
{
using (var modulePathSuffix_chars = RuntimeMarshal.MarshalString (modulePathSuffix_str))
using (var moduleName_chars = RuntimeMarshal.MarshalString (moduleName_str))
using (var directory_chars = RuntimeMarshal.MarshalString (directory_str))
{
RegisterReportingForNativeLib_internal (modulePathSuffix_chars.Value, moduleName_chars.Value);
EnableCrashReportLog_internal (directory_chars.Value);
}
}
[MethodImplAttribute (MethodImplOptions.InternalCall)]
static extern int CheckCrashReportLog_internal (IntPtr directory, bool clear);
static int CheckCrashReportLog (string directory_str, bool clear)
{
using (var directory_chars = RuntimeMarshal.MarshalString (directory_str))
{
return CheckCrashReportLog_internal (directory_chars.Value, clear);
}
}

View File

@@ -507,6 +507,39 @@ namespace MonoTests.System
Assert.IsTrue (dump.Length > 0, "#3");
}
void DumpLogSet ()
{
var monoType = Type.GetType ("Mono.Runtime", false);
var convert = monoType.GetMethod("EnableCrashReportLog", BindingFlags.NonPublic | BindingFlags.Static);
convert.Invoke(null, new object[] { "./" });
}
void DumpLogUnset ()
{
var monoType = Type.GetType ("Mono.Runtime", false);
var convert = monoType.GetMethod("EnableCrashReportLog", BindingFlags.NonPublic | BindingFlags.Static);
convert.Invoke(null, new object[] { null });
}
void DumpLogCheck ()
{
var monoType = Type.GetType ("Mono.Runtime", false);
var convert = monoType.GetMethod("CheckCrashReportLog", BindingFlags.NonPublic | BindingFlags.Static);
var result = (int) convert.Invoke(null, new object[] { "./", true });
var monoSummaryDone = 8;
Assert.AreEqual (monoSummaryDone, result, "#DLC1");
}
[Test]
[Category("NotOnWindows")]
public void DumpICallTotalLogged ()
{
DumpLogSet ();
DumpTotal ();
DumpLogUnset ();
DumpLogCheck ();
}
[Test]
[Category("NotOnWindows")]
public void DumpICallSingleOnce ()

Some files were not shown because too many files have changed in this diff Show More