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

[libraries] Update System.Runtime.Extensions tests for iOS,MacCatalyst,tvOS #57210

Merged
merged 6 commits into from
Aug 14, 2021

Conversation

mdh1418
Copy link
Member

@mdh1418 mdh1418 commented Aug 11, 2021

Fixes #34030
Fixes #36896

Rerunning the test suite after removing SkipOnPlatform and ActiveIssue in #36896 before the latest edit, it was found that the only changes are that TestingCreateInstanceFromObjectHandle passes on iOS and tvOS, and that TestingCreateInstanceFromObjectHandleFullSignature no longer fails. The other tests still fail and the activeIssues/SkipOnPlatform stand.

@mdh1418 mdh1418 requested a review from steveisok August 11, 2021 13:55
@dotnet-issue-labeler
Copy link

I couldn't figure out the best area label to add to this PR. If you have write-permissions please help me learn by adding exactly one area label.

@mdh1418 mdh1418 added this to the 6.0.0 milestone Aug 12, 2021
@@ -333,7 +332,8 @@ public void FailFast_ExceptionStackTrace_InnerException()

[Fact]
[PlatformSpecific(TestPlatforms.AnyUnix | TestPlatforms.Browser)] // Tests OS-specific environment
[ActiveIssue("https://github.com/dotnet/runtime/issues/36896", TestPlatforms.iOS | TestPlatforms.tvOS | TestPlatforms.MacCatalyst)]
[SkipOnPlatform(TestPlatforms.iOS | TestPlatforms.tvOS, "Not valid on iOS or tvOS")]
[ActiveIssue("https://github.com/dotnet/runtime/issues/36896", TestPlatforms.MacCatalyst)]
Copy link
Member

Choose a reason for hiding this comment

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

Do you expect that this test can be fixed to be valid on Catalyst? Catalyst is generally like iOS.

Copy link
Member

Choose a reason for hiding this comment

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

Yeah Catalyst has the same behavior as iOS here. We can actually enable parts of the test since we just use a different value for SpecialFolder.Personal / SpecialFolder.MyDocuments. Will push to the PR.

Copy link
Member Author

@mdh1418 mdh1418 Aug 13, 2021

Choose a reason for hiding this comment

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

Looking more closely, it looks like Environment.GetEnvironmentVariable("Home") is null or empty on iOSSimulator and tvOSSimulator. However, on MacCatalyst, it seems to be /Users/mdhwang and the tests expected paths are
Environment.GetFolderPath(Environment.SpecialFolder.Personal) evaluates to /Users/mdhwang/Documents
Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments) evaluates to /Users/mdhwang/Documents
Environment.GetFolderPath(Environment.SpecialFolder.UserProfile) evaluates to /Users/mdhwang

However, it seems like a previous tvOSSimulator's failure message was
Assert.Equal() Failure\n ↓ (pos 161)\nExpected: ···F1-ADDB-B49F66D98B32\nActual: ···F1-ADDB-B49F66D98B32/Documents\n ↑ (pos 161) which suggests that sometimes the Home environment variable is not empty or null? possibly flakey?

@filipnavara

GetFolderPath_Unix_PersonalIsHomeAndUserProfile is not valid for iOS, tvOS

Could you elaborate on why its not valid for iOS/tvOS?

Copy link
Member

Choose a reason for hiding this comment

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

Hm I tried with preview7 on iOSSimulator and Environment.GetEnvironmentVariable("HOME") returned a path there. did you test with Home or HOME?

Copy link
Member

Choose a reason for hiding this comment

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

Could you elaborate on why its not valid for iOS/tvOS?

On iOS:

  • Personal/MyDocuments (same enum value) returns value of NSSearchPathDirectory.NSDocumentDirectory
  • UserProfile return the HOME environment variable. I remember testing it but I don't remember the value anymore, my previous comment would imply that it was null

On tvOS:

Copy link
Member Author

@mdh1418 mdh1418 Aug 13, 2021

Choose a reason for hiding this comment

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

did you test with Home or HOME?

I used HOME and I temporarily modified the test for these OSes and it passes on MacCatalyst after this modification.

[Fact]
[PlatformSpecific(TestPlatforms.AnyUnix | TestPlatforms.Browser)]  // Tests OS-specific environment
public void GetFolderPath_Unix_PersonalIsHomeAndUserProfile()
{
    Console.WriteLine("Mitchell Hwang");
    Console.WriteLine(Environment.GetEnvironmentVariable("HOME"));
    Console.WriteLine(Environment.GetFolderPath(Environment.SpecialFolder.Personal));
    Console.WriteLine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments));
    Console.WriteLine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile));
    Assert.Equal(Environment.GetEnvironmentVariable("HOME")+"/Documents", Environment.GetFolderPath(Environment.SpecialFolder.Personal));
    Assert.Equal(Environment.GetEnvironmentVariable("HOME")+"/Documents", Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments));
    Assert.Equal(Environment.GetEnvironmentVariable("HOME"), Environment.GetFolderPath(Environment.SpecialFolder.UserProfile));
}

The most recent run locally on preview 6 was
Assert.Equal() Failure\nExpected: (null)\nActual: /Users/mdhwang/Library/Developer/CoreSimulator/Devices/71D00C72-A1BD-4EF7-87EA-B22842EC1650/data/Containers/Data/Application/E3609B50-9E46-4864-A413-A1C506C5295D/Documents

@akoeplinger akoeplinger changed the title [libraries] Update AppDomainTests for iOS,MacCatalyst,tvOS [libraries] Update System.Runtime.Extensions tests for iOS,MacCatalyst,tvOS Aug 13, 2021
@mdh1418
Copy link
Member Author

mdh1418 commented Aug 13, 2021

Both System.Tests.EnvironmentUserName.UserName_Valid and System.Tests.EnvironmentTests.GetFolderPath_Unix_PersonalIsHomeAndUserProfile are failing on iOS and tvOS due to the values Environment.UserName being string.Empty and Environment.GetEnvironmentVariable("HOME") being null.

On MacCatalyst, the values are not empty or null.

@danmoseley danmoseley merged commit 84ca07f into dotnet:main Aug 14, 2021
@mdh1418 mdh1418 deleted the ios_tvos_reenable_crashing_suites branch August 16, 2021 01:32
@ghost ghost locked as resolved and limited conversation to collaborators Sep 15, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
5 participants