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

Add mobile configurations to WasmBuildTests and rename it to something more generic #75015

Open
3 tasks
steveisok opened this issue Sep 2, 2022 · 9 comments
Open
3 tasks

Comments

@steveisok
Copy link
Member

steveisok commented Sep 2, 2022

The startup code in our mobile test runners can differ from the startup in XA and XI, resulting in issues like mono_marshal_ilgen_init symbol is private going undetected. Wasm built a CI leg that would grab the workloads, install them, and then replace the mono runtime pack with the one built in tree. It would then execute smoke tests, which would be able to root out fundamental startup problems.

We should add the mobile configurations to this leg and rename it to something like "WorkloadBuildTests". For iOS/Android, we should execute tests on device.

  • iOS/tvOS
  • MacCatalyst
  • Android
@ghost ghost added the untriaged New issue has not been triaged by the area owner label Sep 2, 2022
@ghost
Copy link

ghost commented Sep 2, 2022

Tagging subscribers to this area: @directhex
See info in area-owners.md if you want to be subscribed.

Issue Details

The startup code in our mobile test runners can differ from the startup in XA and XI resulting in issues like mono_marshal_ilgen_init symbol is private going undetected. Wasm built a CI leg that would grab the workloads, install them, and then replace the mono runtime pack with the one built in tree. It would then execute smoke tests, which would be able to root out fundamental startup problems.

We should add the mobile configurations to this leg and rename it to something like "WorkloadBuildTests". For iOS/Android, we should execute tests on device.

  • iOS/tvOS
  • MacCatalyst
  • Android
Author: steveisok
Assignees: -
Labels:

area-Infrastructure-mono

Milestone: -

@steveisok
Copy link
Member Author

/cc @lewing @radical

@steveisok steveisok removed the untriaged New issue has not been triaged by the area owner label Sep 2, 2022
@steveisok steveisok added this to the 8.0.0 milestone Sep 2, 2022
@radical
Copy link
Member

radical commented Sep 2, 2022

fyi, I have some non-trivial changes in the pipeline to support net6-on-7 workload cases.

@radical
Copy link
Member

radical commented Sep 3, 2022

The various mobile jobs should be split into build+library-tests. And the build jobs can upload the nuget packages, which can then be downloaded by a workload-install-test job, and then dotnet workload install android etc.
This is what I ran into in https://dev.azure.com/dnceng-public/public/_build/results?buildId=4041&view=logs&jobId=b6e5d97f-d4f8-506b-9e47-e3e32385754a&j=b6e5d97f-d4f8-506b-9e47-e3e32385754a&t=ba5f3b69-30bf-59c6-ecb5-9209a4fc913d

I will add src/tests/Workload.Tests or something which can install the sdk+workloads as configured. And will get used by wasm too, as setup for Wasm.Build.Tests .

@radical
Copy link
Member

radical commented Sep 3, 2022

This should fit in well with my work on doing the same kinda "collect nugets then install workload" stuff to support multithreaded and perftrace for wasm.

@steveisok steveisok assigned directhex and unassigned akoeplinger Sep 12, 2022
directhex added a commit to directhex/runtime that referenced this issue Oct 27, 2022
Right now, I'm running this via:

```
./.dotnet/dotnet msbuild src/mono/mobile/test-workloads.proj /p:Workload=WORKLOADNAME /t:restore
./.dotnet/dotnet msbuild src/mono/mobile/test-workloads.proj /p:Workload=WORKLOADNAME /t:build
./.dotnet/dotnet msbuild src/mono/mobile/test-workloads.proj /p:Workload=WORKLOADNAME /t:buildtests /p:RunSmokeTestsOnly=true /p:TestOS=OSOFTESTBUILD /p:TestArchitecture=ARCHOFTESTBUILD
```

Probably needs a value for DevTeamProvisioning passing through to it too.

Just throwing this into a draft PR for some initial eyeballs. With the extra properties and slight changes, workloads-testing.targets was basically already fine. The annoyance is that you need to build so many configurations (everything within a workload, which might be 5 runtimes and 5 cross-compilers) for a simple test of a single workload (which expects all the relevant nupkgs to be available, even if you're only testing one of them)
@steveisok
Copy link
Member Author

@directhex instead of going the WBT route and depending on all the mobile jobs to finish, add a job that runs against the last good official build. That way you have all of the artifacts in place and can just test. It's still early enough to catch things should they happen.

@directhex
Copy link
Contributor

Do we have any existing cases like that of consuming builds across executions I can use as a model?

@steveisok
Copy link
Member Author

I'm not sure. I'm open to any ideas you have that would make the setup less daunting of a task.

@steveisok steveisok modified the milestones: 8.0.0, 9.0.0 Aug 8, 2023
@lewing
Copy link
Member

lewing commented Feb 9, 2024

please resolve this

cc @radical

@lewing lewing assigned steveisok and vitek-karas and unassigned directhex and steveisok Feb 21, 2024
@vitek-karas vitek-karas modified the milestones: 9.0.0, Future Feb 27, 2024
@vitek-karas vitek-karas removed their assignment Feb 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants