Fix MacCatalyst DatePicker focus handling#35553
Conversation
|
🚀 Dogfood this PR with:
curl -fsSL https://raw.githubusercontent.com/dotnet/maui/main/eng/scripts/get-maui-pr.sh | bash -s -- 35553Or
iex "& { $(irm https://raw.githubusercontent.com/dotnet/maui/main/eng/scripts/get-maui-pr.ps1) } 35553" |
|
Hey there @@AdamEssenmacher! Thank you so much for your PR! Someone from the team will get assigned to your PR shortly and we'll get it reviewed. |
|
/review -b feature/regression-check -p catalyst |
<!-- Please let the below note in for people that find this PR --> > [!NOTE] > Are you waiting for the changes in this PR to be merged? > It would be very helpful if you could [test the resulting artifacts](https://github.com/dotnet/maui/wiki/Testing-PR-Builds) from this PR and let us know in a comment if this change resolves your issue. Thank you! ## What Restrict the agentic-labeler to apply **exactly one `area-*` label** per item, while still allowing multiple `platform/*` labels. ## Why Backfilling the 26 items affected by the `max:1` bug (fixed in dotnet#35540) revealed that the labeler occasionally applies multiple `area-*` labels for ambiguous cases: - **dotnet#35501** got both `area-layout` and `area-safearea` - **dotnet#35490** got both `area-navigation` and `area-controls-tabbedpage` The intended behavior is exactly one best-fit `area-*` per item (a label-quota distinction not expressible via `safe-outputs.add-labels.max:` — that field counts total labels, not labels per prefix). The fix has to live in the agent's instructions. ## Changes ### `.github/skills/agentic-labeler/SKILL.md` - Scope section: "Exactly one `area-*`" / "One or more `platform/*`". - Area rules section: renamed heading, changed "pick one or more" → "apply exactly one". - New **tie-breaking heuristics** for the area-* selection: - Specific control beats generic area (`area-controls-tabbedpage` over `area-navigation`) - Sub-area beats parent area (`area-safearea` over `area-layout`) - Subject-matter focus beats incidental touch - When genuinely tied, prefer the user-visible feature - Mixed-PR rule clarified: infra-primary PRs get only `area-infrastructure` (no second product area). ### `.github/workflows/agentic-labeler.md` - Added explicit reinforcement in the workflow prompt: "Apply exactly one `area-*` label … and one or more `platform/*` labels". - Fixed two stale `max: 1` comments left over from dotnet#35540 (the cap is now `max: 10`). ### `.github/workflows/agentic-labeler.lock.yml` - Regenerated via `gh aw compile`. Diff is frontmatter-hash + heredoc rotations only — no semantic change to the compiled config. ## Validation - Reviewed all 21 existing eval scenarios in `tests/eval.yaml` — none assert multiple `area-*` labels, so no test updates needed. - The `max: 10` cap in `safe-outputs` is preserved as a blast-radius safeguard (one area + several platforms still fit comfortably). ## Follow-ups (not in this PR) If accuracy of the "one area" rule drops below ~95% in eval runs, consider adding a deterministic post-step that strips extra `area-*` labels per a known precedence list (Option B from the design discussion). Co-authored-by: bot <bot@test> Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
## Description
Extends the `maui-copilot` DevDiv pipeline (pipeline 27723) with a
3-stage architecture that runs real UI tests on platform-pool agents and
reports results directly in the AI summary PR comment.
### Pipeline Workflow
```
┌─────────────────────────────────────────────────────────┐
│ Stage 1: ReviewPR │
│ │
│ STEP 1: Branch Setup (checkout + cherry-pick PR) │
│ STEP 2: Detect UI Test Categories │
│ STEP 3: Run Detected UI Tests (in-process, fast) │
│ STEP 4: Regression Cross-Reference │
│ STEP 5: Gate — verify tests fail/pass before/after fix │
│ STEP 6: Code Review — deep analysis via Copilot agent │
│ │
│ Outputs → CopilotLogs artifact + detectedCategories │
└──────────────────────┬──────────────────────────────────┘
│
┌──────────────────────▼──────────────────────────────────┐
│ Stage 2: RunDeepUITests (platform-pool agent) │
│ │
│ iOS: AcesShared Tahoe + iOS 26.4 │
│ Android: ubuntu-22.04 + KVM + AVD │
│ │
│ Runs BuildAndRunHostApp.ps1 per detected category │
│ Outputs → drop-deep-uitests artifact (TRX + diffs) │
└──────────────────────┬──────────────────────────────────┘
│
┌──────────────────────▼──────────────────────────────────┐
│ Stage 3: PostResults │
│ │
│ 1. Download CopilotLogs (review content files) │
│ 2. Download drop-deep-uitests (TRX results) │
│ 3. Merge deep results into uitests/content.md │
│ 4. Post full AI Summary comment on PR │
│ 5. Apply labels (s/agent-reviewed, etc.) │
│ │
│ One comment with everything — no patching needed │
└─────────────────────────────────────────────────────────┘
```
### What's New
**Deep UI Test Execution (Stage 2)**
- Runs detected UI test categories on proper platform-pool agents (not
in-process on Linux)
- **iOS**: AcesShared Tahoe agents with iOS 26.4 simulator, iPhone 11
Pro (matching `ios-26` baselines from PR dotnet#35061)
- **Android**: ubuntu-22.04 with KVM, AVD boot with `-partition-size
2048`, `ignoreHiddenApiPolicyError` capability
- TRX results + snapshot-diff PNGs published as `drop-deep-uitests`
artifact
**Unified Comment Posting (Stage 3)**
- Comment posting and label application deferred to Stage 3 (after deep
tests complete)
- Single AI summary comment includes ALL results: code review + deep
test results
- Nested collapsible `<details>` for failed tests with full error +
stack trace
- Dynamic section title: `🧪 UI Tests — CollectionView, TabbedPage`
- Artifact download link for snapshot-diff PNGs
**Android Emulator Improvements**
- AVD boot step with proper partition size, ADB key pre-authorization,
boot wait
- `DEVICE_UDID` pass-through prevents double emulator boot
- Disk cleanup on hosted ubuntu agents (frees ~22GB)
- KVM enablement + `appium:ignoreHiddenApiPolicyError` for API 30
**iOS Simulator Improvements**
- Tahoe pool demand ensures macOS 26.x agents
- Explicit iOS 26.4 download via latest Xcode
- Auto-creates iPhone 11 Pro for baseline resolution match
### Validation
Tested across 30+ pipeline iterations on 6 PRs:
| PR | iOS | Android |
|---|---|---|
| 35358 (ViewBaseTests) | **112/112 ALL PASS** ✅ | **118/119 PASS** ✅ |
| 35359 (TabbedPage) | 44/50 (1 real failure) | 74/75 (1 real failure) |
| 35356 (CollectionView) | **415/417 PASS** ✅ | 593/619 (26 real
failures) |
---------
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
…35589) > [!NOTE] > Are you waiting for the changes in this PR to be merged? > It would be very helpful if you could [test the resulting artifacts](https://github.com/dotnet/maui/wiki/Testing-PR-Builds) from this PR and let us know in a comment if this change resolves your issue. Thank you! Backport of dotnet#35460 to `main`. /cc @PureWeen Co-authored-by: HarishKumarSF4517 <harish.kumar@syncfusion.com>
|
/review -b feature/refactor-copilot-yml |
kubaflo
left a comment
There was a problem hiding this comment.
Could you please try the ai's suggestions?
Also, I remember that changes to focus/unfocus functionalities caused problems with a11y. Please verify if these changes don't regress keyboard navigation
|
/review -b feature/refactor-copilot-yml |
MauiBot
left a comment
There was a problem hiding this comment.
Expert Review — 1 findings
See inline comments for details.
|
Validated deeper MacCatalyst DatePicker a11y behavior. Automated:
Manual:
|
0336b85 to
6486835
Compare
|
/review -b feature/refactor-copilot-yml |
kubaflo
left a comment
There was a problem hiding this comment.
Looks like tests are failing
|
/azp run maui-pr-uitests |
|
Commenter does not have sufficient privileges for PR 35553 in repo dotnet/maui |
|
@kubaflo MauiBot is flip-flopping. The PR's current state is what I think is probably the best shape for the fix. As commented above, I do not believe the test failures are caused by this PR. |
|
/azp run maui-pr-uitests |
|
Azure Pipelines successfully started running 1 pipeline(s). |
|
/review -b feature/refactor-copilot-yml -p macos |
This comment has been minimized.
This comment has been minimized.
kubaflo
left a comment
There was a problem hiding this comment.
Looks good! Can you check if you can open/close picker with keyboard navigation only?
|
Keyboard navigation works the way it did before on iOS and Catalyst. |
kubaflo
left a comment
There was a problem hiding this comment.
Almost merge! Can you please resolve conflicts?
# Conflicts: # src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs
|
/review -b feature/enhanced-reviewer |
MauiBot
left a comment
There was a problem hiding this comment.
AI Review Summary
@AdamEssenmacher — new AI review results are available based on this last commit:
188d3f4.
Merge remote-tracking branch 'dotnet/inflight/current' into issue-5947 To request a fresh review after new comments or commits, comment/review rerun.
Review Sessions — click to expand
Gate — Test Before & After Fix
Gate Result: ✅ PASSED
Platform: CATALYST · Base: main · Merge base: b0ea772f
| Test | Without Fix (expect FAIL) | With Fix (expect PASS) |
|---|---|---|
📱 DatePickerHandlerTests (DefaultHandlerUsesPublicCommandMapper, FocusOpensDatePickerWhenVirtualFocusIsStale, FocusCanBeRepeatedAfterUnfocus, FocusCanBeRepeatedWhileOpen, IsOpenCanReopenDatePicker, NativeFocusRefusalKeepsDatePickerClosed, NativeCloseRunsAfterAcceptedOpenWithoutFirstResponder) Category=DatePicker |
✅ FAIL — 7s | ✅ PASS — 76s |
📱 DatePickerTests (FocusOpensDatePickerWhenVirtualFocusIsStale, IsOpenRaisesSingleOpenedAndClosedEvents, RepeatedFocusWhileOpenRaisesNoExtraOpenedOrClosedEvents) Category=DatePicker |
✅ FAIL — 3s | ✅ PASS — 45s |
🔴 Without fix — 📱 DatePickerHandlerTests (DefaultHandlerUsesPublicCommandMapper, FocusOpensDatePickerWhenVirtualFocusIsStale, FocusCanBeRepeatedAfterUnfocus, FocusCanBeRepeatedWhileOpen, IsOpenCanReopenDatePicker, NativeFocusRefusalKeepsDatePickerClosed, NativeCloseRunsAfterAcceptedOpenWithoutFirstResponder): FAIL ✅ · 7s
Determining projects to restore...
Restored /Users/cloudtest/vss/_work/1/s/src/Graphics/src/Graphics/Graphics.csproj (in 818 ms).
Restored /Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners.SourceGen/TestUtils.DeviceTests.Runners.SourceGen.csproj (in 4.63 sec).
Restored /Users/cloudtest/vss/_work/1/s/src/Controls/src/BindingSourceGen/Controls.BindingSourceGen.csproj (in 14 ms).
Restored /Users/cloudtest/vss/_work/1/s/src/Essentials/src/Essentials.csproj (in 4.89 sec).
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.execution (= 2.9.0) but version xunit.extensibility.execution 2.9.3 was resolved. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.execution (= 2.9.0) but version xunit.extensibility.execution 2.9.3 was resolved. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Version conflict detected for xunit.extensibility.core. Install/reference xunit.extensibility.core 2.9.3 directly to project Microsoft.Maui.DeviceTests.Shared to resolve this issue. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Microsoft.Maui.DeviceTests.Shared -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution 2.9.3 -> xunit.extensibility.core (= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Microsoft.Maui.DeviceTests.Shared -> xunit 2.9.0 -> xunit.core 2.9.0 -> xunit.extensibility.core (= 2.9.0). [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.extensibility.execution from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution (>= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> xunit.extensibility.execution (>= 2.9.0) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.runner.utility from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.runner.utility (>= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> xunit.runner.utility (>= 2.9.0) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Version conflict detected for xunit.extensibility.core. Install/reference xunit.extensibility.core 2.9.3 directly to project Microsoft.Maui.TestUtils.DeviceTests.Runners to resolve this issue. [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Microsoft.Maui.TestUtils.DeviceTests.Runners -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution 2.9.3 -> xunit.extensibility.core (= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Microsoft.Maui.TestUtils.DeviceTests.Runners -> xunit 2.9.0 -> xunit.core 2.9.0 -> xunit.extensibility.core (= 2.9.0). [/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj]
Restored /Users/cloudtest/vss/_work/1/s/src/Controls/src/Xaml/Controls.Xaml.csproj (in 5.31 sec).
Restored /Users/cloudtest/vss/_work/1/s/src/Controls/src/Core/Controls.Core.csproj (in 5.31 sec).
Failed to restore /Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj (in 5.33 sec).
Failed to restore /Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj (in 5.31 sec).
Failed to restore /Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj (in 4.47 sec).
Restored /Users/cloudtest/vss/_work/1/s/src/Core/src/Core.csproj (in 5.34 sec).
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.extensibility.execution from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version.
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Microsoft.Maui.Core.DeviceTests -> Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution (>= 2.9.3)
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Microsoft.Maui.Core.DeviceTests -> Microsoft.Maui.TestUtils.DeviceTests -> xunit.extensibility.execution (>= 2.9.0)
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.runner.utility from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version.
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Microsoft.Maui.Core.DeviceTests -> Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.runner.utility (>= 2.9.3)
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj : error NU1605: Microsoft.Maui.Core.DeviceTests -> Microsoft.Maui.TestUtils.DeviceTests -> xunit.runner.utility (>= 2.9.0)
Failed to restore /Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests/Core.DeviceTests.csproj (in 5.4 sec).
🟢 With fix — 📱 DatePickerHandlerTests (DefaultHandlerUsesPublicCommandMapper, FocusOpensDatePickerWhenVirtualFocusIsStale, FocusCanBeRepeatedAfterUnfocus, FocusCanBeRepeatedWhileOpen, IsOpenCanReopenDatePicker, NativeFocusRefusalKeepsDatePickerClosed, NativeCloseRunsAfterAcceptedOpenWithoutFirstResponder): PASS ✅ · 76s
(truncated to last 15,000 chars)
stUtils.DeviceTests/Release/net10.0-maccatalyst/Microsoft.Maui.TestUtils.DeviceTests.dll
/Users/cloudtest/vss/_work/1/s/src/Controls/src/Core/PublicAPI/net-maccatalyst/PublicAPI.Unshipped.txt(17,1): warning RS0025: The symbol 'override Microsoft.Maui.Controls.Handlers.Items2.StructuredItemsViewController2<TItemsView>.UpdateFlowDirection() -> void' appears more than once in the public API files (https://github.com/dotnet/roslyn/blob/main/src/RoslynAnalyzers/PublicApiAnalyzers/PublicApiAnalyzers.Help.md) [/Users/cloudtest/vss/_work/1/s/src/Controls/src/Core/Controls.Core.csproj::TargetFramework=net10.0-maccatalyst26.0]
Controls.Core -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.Core/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Controls.dll
##vso[build.updatebuildnumber]10.0.80-ci+azdo.14251605
Controls.Xaml -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.Xaml/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Controls.Xaml.dll
TestUtils.DeviceTests.Runners -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/TestUtils.DeviceTests.Runners/Release/net10.0-maccatalyst/Microsoft.Maui.TestUtils.DeviceTests.Runners.dll
Core.DeviceTests.Shared -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests.Shared/Release/net10.0-maccatalyst/Microsoft.Maui.DeviceTests.Shared.dll
TestUtils.DeviceTests.Runners.SourceGen -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/TestUtils.DeviceTests.Runners.SourceGen/Release/netstandard2.0/Microsoft.Maui.TestUtils.DeviceTests.Runners.SourceGen.dll
Detected signing identity:
Code Signing Key: "" (-)
Provisioning Profile: "" () - no entitlements
Bundle Id: com.microsoft.maui.core.devicetests
App Id: com.microsoft.maui.core.devicetests
Core.DeviceTests -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Microsoft.Maui.Core.DeviceTests.dll
Optimizing assemblies for size may change the behavior of the app. Be sure to test after publishing. See: https://aka.ms/dotnet-illink
Optimizing assemblies for size. This process might take a while.
IL stripping assemblies
Build succeeded.
/Users/cloudtest/vss/_work/1/s/src/Controls/src/Core/PublicAPI/net-maccatalyst/PublicAPI.Unshipped.txt(17,1): warning RS0025: The symbol 'override Microsoft.Maui.Controls.Handlers.Items2.StructuredItemsViewController2<TItemsView>.UpdateFlowDirection() -> void' appears more than once in the public API files (https://github.com/dotnet/roslyn/blob/main/src/RoslynAnalyzers/PublicApiAnalyzers/PublicApiAnalyzers.Help.md) [/Users/cloudtest/vss/_work/1/s/src/Controls/src/Core/Controls.Core.csproj::TargetFramework=net10.0-maccatalyst26.0]
1 Warning(s)
0 Error(s)
Time Elapsed 00:01:00.06
[11.0.0-prerelease.26230.4+92962e5c46ac08a66ded4c5696209cc60f1a232f] XHarness command issued: apple test --app /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app --target maccatalyst -o artifacts/log --timeout 01:00:00 -v --set-env=TestFilter=Category=DatePicker
�[40m�[32minfo�[39m�[22m�[49m: Preparing run for maccatalyst
�[40m�[32minfo�[39m�[22m�[49m: Getting app bundle information from '/Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app'..
�[40m�[37mdbug�[39m�[22m�[49m: Test log server listening on: 0.0.0.0:50588
�[40m�[37mdbug�[39m�[22m�[49m: *** Executing 'Core Tests' on MacCatalyst ***
�[40m�[37mdbug�[39m�[22m�[49m: Environmental variable TestFilter is already passed to the application to drive test run, skipping..
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running chmod
�[40m�[37mdbug�[39m�[22m�[49m: Process chmod exited with 0
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running /System/Library/Frameworks/CoreServices.framework/Frameworks/LaunchServices.framework/Support/lsregister
�[40m�[37mdbug�[39m�[22m�[49m: Process lsregister exited with 0
�[40m�[37mdbug�[39m�[22m�[49m: Scanning log stream for Microsoft.Maui.Core.DeviceTests into '/Users/cloudtest/vss/_work/1/s/artifacts/log/Microsoft.Maui.Core.DeviceTests.log'..
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running log
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running open
With env vars:
NUNIT_AUTOEXIT = 'true'
NUNIT_HOSTPORT = '50588'
NUNIT_ENABLE_XML_OUTPUT = 'true'
NUNIT_XML_VERSION = 'xUnit'
TestFilter = 'Category=DatePicker'
NUNIT_HOSTNAME = '127.0.0.1'
�[40m�[37mdbug�[39m�[22m�[49m: Connection from 127.0.0.1:50589 saving logs to /Users/cloudtest/vss/_work/1/s/artifacts/log/test-maccatalyst-20260601_125039.log
�[40m�[37mdbug�[39m�[22m�[49m: Test execution started
�[40m�[37mdbug�[39m�[22m�[49m: Tests have finished executing
�[40m�[37mdbug�[39m�[22m�[49m: Process open exited with 0
�[40m�[37mdbug�[39m�[22m�[49m: Test run completed
�[40m�[37mdbug�[39m�[22m�[49m: Process log exited with 137
�[40m�[37mdbug�[39m�[22m�[49m: Test run succeeded
�[40m�[37mdbug�[39m�[22m�[49m: No crash reports, waiting 0 seconds for the crash report service...
�[40m�[32minfo�[39m�[22m�[49m: Application finished the test run successfully
�[40m�[32minfo�[39m�[22m�[49m: Tests run: 7 Passed: 7 Inconclusive: 0 Failed: 0 Ignored: 0
�[40m�[32minfo�[39m�[22m�[49m: Copying SystemLog logs to the main log for better failure investigation. Logs count: 2.
�[40m�[37mdbug�[39m�[22m�[49m: ==================== SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m: Log file: /Users/cloudtest/vss/_work/1/s/artifacts/log/MacCatalyst.system.log
�[40m�[37mdbug�[39m�[22m�[49m: ==================== End of SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: ==================== SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m: Log file: /Users/cloudtest/vss/_work/1/s/artifacts/log/Microsoft.Maui.Core.DeviceTests.log
�[40m�[37mdbug�[39m�[22m�[49m: Filtering the log data using "senderImagePath CONTAINS "Microsoft.Maui.Core.DeviceTests""
�[40m�[37mdbug�[39m�[22m�[49m: Timestamp Ty Process[PID:TID]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.065 Df Microsoft.Maui.Core.DeviceTests[9718:f664] TestFilter: Category=DatePicker
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_AUTOSTART = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_AUTOEXIT = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_ENABLE_NETWORK = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] DISABLE_SYSTEM_PERMISSION_TESTS = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_HOSTNAME = '127.0.0.1'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_TRANSPORT = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_LOG_FILE = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_HOSTPORT = '50588'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] USE_TCP_TUNNEL = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] RUN_END_TAG = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_ENABLE_XML_OUTPUT = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_ENABLE_XML_MODE = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_XML_VERSION = 'xUnit'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_SORTNAMES = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_RUN_ALL = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.073 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_SKIPPED_METHODS = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.074 Df Microsoft.Maui.Core.DeviceTests[9718:f664] NUNIT_SKIPPED_CLASSES = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.074 Df Microsoft.Maui.Core.DeviceTests[9718:f664] headlessrunner = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.101 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Runner executing: Run everything]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.101 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [arm64: MacCatalyst v18.7]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.101 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Name: iPad]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.101 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device UDID: b8bfd30344a541b49322d4826725ccd3]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.102 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Locale: en-US]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.107 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Date/Time: 6/1/2026 12:50:41 PM]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.107 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Bundle: com.microsoft.maui.core.devicetests]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Runner executing: Run everything]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [arm64: MacCatalyst v18.7]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Name: iPad]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device UDID: dbce86eee8ef43e6b2a390a8e32cb0a0]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Locale: en-US]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Device Date/Time: 6/1/2026 12:50:41 PM]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] [Bundle: com.microsoft.maui.core.devicetests]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.108 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Skipping categories: Category=ActivityIndicator, Category=Border, Category=Button, Category=CheckBox, Category=ContentView, Category=Element, Category=Dispatcher, Category=Editor, Category=Entry, Category=FlowDirection, Category=FlyoutView, Category=Fonts, Category=Graphics, Category=GraphicsView, Category=Image, Category=ImageButton, Category=ImageSource, Category=IndicatorView, Category=Label, Category=Layout, Category=Memory, Category=NavigationPage, Category=Page, Category=Picker, Category=ProgressBar, Category=RefreshView, Category=ScrollView, Category=SearchBar, Category=ShapeView, Category=Slider, Category=Stepper, Category=SwipeView, Category=Switch, Category=Formatting, Category=TimePicker, Category=View, Category=WebView, Category=Window
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.109 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Using reflection-based Xunit runner (threaded execution)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.115 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Discovering: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app/Contents/MonoBundle/Microsoft.Maui.Core.DeviceTests.dll (method display = ClassAndMethod, method display options = None)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.308 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Discovered: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app/Contents/MonoBundle/Microsoft.Maui.Core.DeviceTests.dll (found 7 of 1061 test cases)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:41.310 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Starting: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app/Contents/MonoBundle/Microsoft.Maui.Core.DeviceTests.dll
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:42.931 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Finished: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Core Tests.app/Contents/MonoBundle/Microsoft.Maui.Core.DeviceTests.dll
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:42.933 Df Microsoft.Maui.Core.DeviceTests[9718:f706] Tests run: 7 Passed: 7 Inconclusive: 0 Failed: 0 Ignored: 0
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:42.936 Df Microsoft.Maui.Core.DeviceTests[9718:f664] Xml file was written to the provided writer.
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:50:42.936 Df Microsoft.Maui.Core.DeviceTests[9718:f664]
�[40m�[37mdbug�[39m�[22m�[49m: === TEST EXECUTION SUMMARY ===
�[40m�[37mdbug�[39m�[22m�[49m: Tests run: 7 Passed: 7 Inconclusive: 0 Failed: 0 Ignored: 0 Skipped: 0
�[40m�[37mdbug�[39m�[22m�[49m: Killing process 9715 as it was cancelled
�[40m�[37mdbug�[39m�[22m�[49m: ==================== End of SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[32minfo�[39m�[22m�[49m: <<XHARNESS_RESULT_START>>
{
"version": 1,
"machineName": "X4X3X7214G-1",
"exitCode": 0,
"exitCodeName": "SUCCESS",
"platform": "apple",
"device": "X4X3X7214G-1",
"deviceOsVersion": "macOS 15.7.2",
"files": [
{
"name": "test-maccatalyst.log",
"type": "executionlog"
},
{
"name": "test-maccatalyst-20260601_125039.log",
"type": "testlog"
},
{
"name": "Microsoft.Maui.Core.DeviceTests.log",
"type": "systemlog"
},
{
"name": "xunit-test-maccatalyst-20260601_125039.xml",
"type": "xmllog"
}
]
}
<<XHARNESS_RESULT_END>>
XHarness exit code: 0
Passed: 0
Failed: 0
Tests completed successfully
🔴 Without fix — 📱 DatePickerTests (FocusOpensDatePickerWhenVirtualFocusIsStale, IsOpenRaisesSingleOpenedAndClosedEvents, RepeatedFocusWhileOpenRaisesNoExtraOpenedOrClosedEvents): FAIL ✅ · 3s
Determining projects to restore...
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.execution (= 2.9.0) but version xunit.extensibility.execution 2.9.3 was resolved. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Version conflict detected for xunit.extensibility.core. Install/reference xunit.extensibility.core 2.9.3 directly to project Microsoft.Maui.DeviceTests.Shared to resolve this issue. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Microsoft.Maui.DeviceTests.Shared -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution 2.9.3 -> xunit.extensibility.core (= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj : error NU1107: Microsoft.Maui.DeviceTests.Shared -> xunit 2.9.0 -> xunit.core 2.9.0 -> xunit.extensibility.core (= 2.9.0). [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.extensibility.execution from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution (>= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> xunit.extensibility.execution (>= 2.9.0) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.runner.utility from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.runner.utility (>= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj : error NU1605: Microsoft.Maui.TestUtils.DeviceTests -> xunit.runner.utility (>= 2.9.0) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
Failed to restore /Users/cloudtest/vss/_work/1/s/src/Core/tests/DeviceTests.Shared/Core.DeviceTests.Shared.csproj (in 284 ms).
Failed to restore /Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests/TestUtils.DeviceTests.csproj (in 293 ms).
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.execution (= 2.9.0) but version xunit.extensibility.execution 2.9.3 was resolved. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Version conflict detected for xunit.extensibility.core. Install/reference xunit.extensibility.core 2.9.3 directly to project Microsoft.Maui.TestUtils.DeviceTests.Runners to resolve this issue. [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Microsoft.Maui.TestUtils.DeviceTests.Runners -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.extensibility.execution 2.9.3 -> xunit.extensibility.core (= 2.9.3) [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
/Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj : error NU1107: Microsoft.Maui.TestUtils.DeviceTests.Runners -> xunit 2.9.0 -> xunit.core 2.9.0 -> xunit.extensibility.core (= 2.9.0). [/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj]
Failed to restore /Users/cloudtest/vss/_work/1/s/src/TestUtils/src/DeviceTests.Runners/TestUtils.DeviceTests.Runners.csproj (in 439 ms).
/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.core (= 2.9.0) but version xunit.extensibility.core 2.9.3 was resolved.
/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj : warning NU1608: Detected package version outside of dependency constraint: xunit.core 2.9.0 requires xunit.extensibility.execution (= 2.9.0) but version xunit.extensibility.execution 2.9.3 was resolved.
/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj : error NU1605: Warning As Error: Detected package downgrade: xunit.runner.utility from 2.9.3 to 2.9.0. Reference the package directly from the project to select a different version.
/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj : error NU1605: Microsoft.Maui.Controls.DeviceTests -> Microsoft.Maui.DeviceTests.Shared -> Microsoft.DotNet.XHarness.TestRunners.Xunit 11.0.0-prerelease.26230.4 -> xunit.runner.utility (>= 2.9.3)
/Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj : error NU1605: Microsoft.Maui.Controls.DeviceTests -> Microsoft.Maui.DeviceTests.Shared -> xunit.runner.utility (>= 2.9.0)
Restored /Users/cloudtest/vss/_work/1/s/src/Core/maps/src/Maps.csproj (in 917 ms).
Restored /Users/cloudtest/vss/_work/1/s/src/Controls/Maps/src/Controls.Maps.csproj (in 961 ms).
Failed to restore /Users/cloudtest/vss/_work/1/s/src/Controls/tests/DeviceTests/Controls.DeviceTests.csproj (in 936 ms).
7 of 13 projects are up-to-date for restore.
🟢 With fix — 📱 DatePickerTests (FocusOpensDatePickerWhenVirtualFocusIsStale, IsOpenRaisesSingleOpenedAndClosedEvents, RepeatedFocusWhileOpenRaisesNoExtraOpenedOrClosedEvents): PASS ✅ · 45s
(truncated to last 15,000 chars)
/Controls.Core/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Controls.dll
##vso[build.updatebuildnumber]10.0.80-ci+azdo.14251605
Controls.Xaml -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.Xaml/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Controls.Xaml.dll
TestUtils.DeviceTests.Runners -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/TestUtils.DeviceTests.Runners/Release/net10.0-maccatalyst/Microsoft.Maui.TestUtils.DeviceTests.Runners.dll
Core.DeviceTests.Shared -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Core.DeviceTests.Shared/Release/net10.0-maccatalyst/Microsoft.Maui.DeviceTests.Shared.dll
##vso[build.updatebuildnumber]10.0.80-ci+azdo.14251605
Maps -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Maps/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Maps.dll
##vso[build.updatebuildnumber]10.0.80-ci+azdo.14251605
Controls.Maps -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.Maps/Release/net10.0-maccatalyst26.0/Microsoft.Maui.Controls.Maps.dll
TestUtils.DeviceTests.Runners.SourceGen -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/TestUtils.DeviceTests.Runners.SourceGen/Release/netstandard2.0/Microsoft.Maui.TestUtils.DeviceTests.Runners.SourceGen.dll
Detected signing identity:
Code Signing Key: "" (-)
Provisioning Profile: "" () - no entitlements
Bundle Id: com.microsoft.maui.controls.devicetests
App Id: com.microsoft.maui.controls.devicetests
Controls.DeviceTests -> /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Microsoft.Maui.Controls.DeviceTests.dll
Optimizing assemblies for size may change the behavior of the app. Be sure to test after publishing. See: https://aka.ms/dotnet-illink
Optimizing assemblies for size. This process might take a while.
IL stripping assemblies
Build succeeded.
0 Warning(s)
0 Error(s)
Time Elapsed 00:00:30.31
[11.0.0-prerelease.26230.4+92962e5c46ac08a66ded4c5696209cc60f1a232f] XHarness command issued: apple test --app /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app --target maccatalyst -o artifacts/log --timeout 01:00:00 -v --set-env=TestFilter=Category=DatePicker
�[40m�[32minfo�[39m�[22m�[49m: Preparing run for maccatalyst
�[40m�[32minfo�[39m�[22m�[49m: Getting app bundle information from '/Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app'..
�[40m�[37mdbug�[39m�[22m�[49m: Test log server listening on: 0.0.0.0:50597
�[40m�[37mdbug�[39m�[22m�[49m: *** Executing 'Controls Tests' on MacCatalyst ***
�[40m�[37mdbug�[39m�[22m�[49m: Environmental variable TestFilter is already passed to the application to drive test run, skipping..
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running chmod
�[40m�[37mdbug�[39m�[22m�[49m: Process chmod exited with 0
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running /System/Library/Frameworks/CoreServices.framework/Frameworks/LaunchServices.framework/Support/lsregister
�[40m�[37mdbug�[39m�[22m�[49m: Process lsregister exited with 0
�[40m�[37mdbug�[39m�[22m�[49m: Scanning log stream for Microsoft.Maui.Controls.DeviceTests into '/Users/cloudtest/vss/_work/1/s/artifacts/log/Microsoft.Maui.Controls.DeviceTests.log'..
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running log
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: Running open
With env vars:
NUNIT_AUTOEXIT = 'true'
NUNIT_HOSTPORT = '50597'
NUNIT_ENABLE_XML_OUTPUT = 'true'
NUNIT_XML_VERSION = 'xUnit'
TestFilter = 'Category=DatePicker'
NUNIT_HOSTNAME = '127.0.0.1'
�[40m�[37mdbug�[39m�[22m�[49m: Connection from 127.0.0.1:50598 saving logs to /Users/cloudtest/vss/_work/1/s/artifacts/log/test-maccatalyst-20260601_125125.log
�[40m�[37mdbug�[39m�[22m�[49m: Test execution started
�[40m�[37mdbug�[39m�[22m�[49m: Tests have finished executing
�[40m�[37mdbug�[39m�[22m�[49m: Process open exited with 0
�[40m�[37mdbug�[39m�[22m�[49m: Process log exited with 137
�[40m�[37mdbug�[39m�[22m�[49m: Test run completed
�[40m�[37mdbug�[39m�[22m�[49m: Test run succeeded
�[40m�[37mdbug�[39m�[22m�[49m: No crash reports, waiting 0 seconds for the crash report service...
�[40m�[32minfo�[39m�[22m�[49m: Application finished the test run successfully
�[40m�[32minfo�[39m�[22m�[49m: Tests run: 4 Passed: 4 Inconclusive: 0 Failed: 0 Ignored: 0
�[40m�[32minfo�[39m�[22m�[49m: Copying SystemLog logs to the main log for better failure investigation. Logs count: 2.
�[40m�[37mdbug�[39m�[22m�[49m: ==================== SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m: Log file: /Users/cloudtest/vss/_work/1/s/artifacts/log/MacCatalyst.system.log
�[40m�[37mdbug�[39m�[22m�[49m: ==================== End of SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[37mdbug�[39m�[22m�[49m: ==================== SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m: Log file: /Users/cloudtest/vss/_work/1/s/artifacts/log/Microsoft.Maui.Controls.DeviceTests.log
�[40m�[37mdbug�[39m�[22m�[49m: Filtering the log data using "senderImagePath CONTAINS "Microsoft.Maui.Controls.DeviceTests""
�[40m�[37mdbug�[39m�[22m�[49m: Timestamp Ty Process[PID:TID]
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: === Messages dropped during live streaming (use `log show` to see what they were)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.060 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] TestFilter: Category=DatePicker
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_AUTOSTART = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_AUTOEXIT = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_ENABLE_NETWORK = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] DISABLE_SYSTEM_PERMISSION_TESTS = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_HOSTNAME = '127.0.0.1'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_TRANSPORT = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_LOG_FILE = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_HOSTPORT = '50597'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] USE_TCP_TUNNEL = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] RUN_END_TAG = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_ENABLE_XML_OUTPUT = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_ENABLE_XML_MODE = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_XML_VERSION = 'xUnit'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_SORTNAMES = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_RUN_ALL = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_SKIPPED_METHODS = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] NUNIT_SKIPPED_CLASSES = ''
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.067 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] headlessrunner = 'true'
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.078 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Runner executing: Run everything]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.079 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [arm64: MacCatalyst v18.7]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.079 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Name: iPad]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.079 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device UDID: 838d41be6c144758a35a175513ce3a46]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.079 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Locale: en-US]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Date/Time: 6/1/2026 12:51:27 PM]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Bundle: com.microsoft.maui.controls.devicetests]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Runner executing: Run everything]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [arm64: MacCatalyst v18.7]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Name: iPad]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device UDID: 55b92320f349435ea3a361fea87cdce3]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Locale: en-US]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Device Date/Time: 6/1/2026 12:51:27 PM]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.083 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] [Bundle: com.microsoft.maui.controls.devicetests]
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.084 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Skipping categories: Category=Accessibility, Category=Application, Category=Behavior, Category=Border, Category=BoxView, Category=Button, Category=CarouselView, Category=CheckBox, Category=CollectionView, Category=Compatibility, Category=ContentView, Category=Dispatcher, Category=Editor, Category=Element, Category=Entry, Category=FlexLayout, Category=FlyoutPage, Category=Frame, Category=Gesture, Category=HybridWebView, Category=Image, Category=Label, Category=Layout, Category=Lifecycle, Category=ListView, Category=Map, Category=MenuFlyout, Category=Mapper, Category=Memory, Category=Modal, Category=NavigationPage, Category=Page, Category=Path, Category=Picker, Category=RadioButton, Category=RefreshView, Category=ScrollView, Category=SearchBar, Category=Shape, Category=Shell, Category=Slider, Category=SwipeView, Category=TabbedPage, Category=TextInput, Category=Toolbar, Category=TemplatedView, Category=View, Category=VisualElement, Category=VisualElementTree, Category=WebView, Category=Window, Category
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.085 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Using reflection-based Xunit runner (threaded execution)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.091 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Discovering: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app/Contents/MonoBundle/Microsoft.Maui.Controls.DeviceTests.dll (method display = ClassAndMethod, method display options = None)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.237 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Discovered: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app/Contents/MonoBundle/Microsoft.Maui.Controls.DeviceTests.dll (found 4 of 465 test cases)
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.239 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Starting: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app/Contents/MonoBundle/Microsoft.Maui.Controls.DeviceTests.dll
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.875 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Finished: /Users/cloudtest/vss/_work/1/s/artifacts/bin/Controls.DeviceTests/Release/net10.0-maccatalyst/maccatalyst-arm64/Controls Tests.app/Contents/MonoBundle/Microsoft.Maui.Controls.DeviceTests.dll
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.877 Df Microsoft.Maui.Controls.DeviceTests[10109:104cd] Tests run: 4 Passed: 4 Inconclusive: 0 Failed: 0 Ignored: 0
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.878 Df Microsoft.Maui.Controls.DeviceTests[10109:10465] Xml file was written to the provided writer.
�[40m�[37mdbug�[39m�[22m�[49m: 2026-06-01 12:51:27.878 Df Microsoft.Maui.Controls.DeviceTests[10109:10465]
�[40m�[37mdbug�[39m�[22m�[49m: === TEST EXECUTION SUMMARY ===
�[40m�[37mdbug�[39m�[22m�[49m: Tests run: 4 Passed: 4 Inconclusive: 0 Failed: 0 Ignored: 0 Skipped: 0
�[40m�[37mdbug�[39m�[22m�[49m: Killing process 10105 as it was cancelled
�[40m�[37mdbug�[39m�[22m�[49m: ==================== End of SystemLog ====================
�[40m�[37mdbug�[39m�[22m�[49m:
�[40m�[32minfo�[39m�[22m�[49m: <<XHARNESS_RESULT_START>>
{
"version": 1,
"machineName": "X4X3X7214G-1",
"exitCode": 0,
"exitCodeName": "SUCCESS",
"platform": "apple",
"device": "X4X3X7214G-1",
"deviceOsVersion": "macOS 15.7.2",
"files": [
{
"name": "test-maccatalyst.log",
"type": "executionlog"
},
{
"name": "test-maccatalyst-20260601_125125.log",
"type": "testlog"
},
{
"name": "Microsoft.Maui.Controls.DeviceTests.log",
"type": "systemlog"
},
{
"name": "xunit-test-maccatalyst-20260601_125125.xml",
"type": "xmllog"
}
]
}
<<XHARNESS_RESULT_END>>
XHarness exit code: 0
Passed: 0
Failed: 0
Tests completed successfully
📁 Fix files reverted (315 files)
eng/Signing.propseng/Versions.propseng/devices/run-windows-devicetests.cmdeng/devices/windows.cakeeng/pipelines/ci-copilot.ymlsrc/BlazorWebView/src/Maui/Android/BlazorAndroidWebView.cssrc/BlazorWebView/src/Maui/Android/BlazorWebViewHandler.Android.cssrc/BlazorWebView/src/Maui/Android/WebKitWebViewClient.cssrc/Compatibility/Core/src/Android/CollectionView/TemplatedItemViewHolder.cssrc/Compatibility/Core/src/Android/Renderers/SwipeViewRenderer.cssrc/Compatibility/Core/src/MacOS/Extensions/NSMenuExtensions.cssrc/Compatibility/Core/src/Windows/CollectionView/ItemContentControl.cssrc/Compatibility/Core/src/iOS/CollectionView/TemplatedCell.cssrc/Compatibility/Core/src/iOS/EventTracker.cssrc/Compatibility/Core/src/iOS/Renderers/SwipeViewRenderer.cssrc/Compatibility/Core/src/iOS/Renderers/UIContainerCell.cssrc/Controls/samples/Controls.Sample/Pages/Controls/MapsGalleries/MapPinsGallery.xamlsrc/Controls/samples/Controls.Sample/Pages/Controls/MapsGalleries/MapPinsGallery.xaml.cssrc/Controls/src/Build.Tasks/SetPropertiesVisitor.cssrc/Controls/src/Core/ActionSheetArguments.cssrc/Controls/src/Core/AlertArguments.cssrc/Controls/src/Core/BindableObject.cssrc/Controls/src/Core/BindableProperty.cssrc/Controls/src/Core/Border/Border.cssrc/Controls/src/Core/Button/Button.iOS.cssrc/Controls/src/Core/Compatibility/Android/Resources/layout/flyoutcontent.axmlsrc/Controls/src/Core/Compatibility/Handlers/FlyoutPage/iOS/PhoneFlyoutPageRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/NavigationPage/iOS/NavigationRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/SearchHandlerAppearanceTracker.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellFlyoutRecyclerAdapter.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellFlyoutTemplatedContentRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellFragmentContainer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellFragmentStateAdapter.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellItemRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellSectionRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/Android/ShellToolbarTracker.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/SearchHandlerAppearanceTracker.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellFlyoutLayoutManager.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellPageRendererTracker.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellSectionRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellSectionRootRenderer.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/ShellTableViewController.cssrc/Controls/src/Core/Compatibility/Handlers/Shell/iOS/UIContainerCell.cssrc/Controls/src/Core/Compatibility/Handlers/TabbedPage/iOS/TabbedRenderer.cssrc/Controls/src/Core/ContentPage/ContentPage.cssrc/Controls/src/Core/ContentView/ContentView.cssrc/Controls/src/Core/Editor/Editor.Mapper.cssrc/Controls/src/Core/Editor/Editor.iOS.cssrc/Controls/src/Core/Element/Element.cssrc/Controls/src/Core/Entry/Entry.Mapper.cssrc/Controls/src/Core/Entry/Entry.iOS.cssrc/Controls/src/Core/FlyoutPage/FlyoutPage.cssrc/Controls/src/Core/FormattedString.cssrc/Controls/src/Core/GestureElement.cssrc/Controls/src/Core/Handlers/Items/Android/Adapters/EmptyViewAdapter.cssrc/Controls/src/Core/Handlers/Items/Android/Adapters/GroupableItemsViewAdapter.cssrc/Controls/src/Core/Handlers/Items/Android/Adapters/ItemsViewAdapter.cssrc/Controls/src/Core/Handlers/Items/Android/GridLayoutSpanSizeLookup.cssrc/Controls/src/Core/Handlers/Items/Android/ItemContentView.cssrc/Controls/src/Core/Handlers/Items/Android/MauiCarouselRecyclerView.cssrc/Controls/src/Core/Handlers/Items/Android/MauiRecyclerView.cssrc/Controls/src/Core/Handlers/Items/Android/SimpleViewHolder.cssrc/Controls/src/Core/Handlers/Items/Android/SizedItemContentView.cssrc/Controls/src/Core/Handlers/Items/Android/TemplatedItemViewHolder.cssrc/Controls/src/Core/Handlers/Items/CarouselViewHandler.Android.cssrc/Controls/src/Core/Handlers/Items/CarouselViewHandler.Windows.cssrc/Controls/src/Core/Handlers/Items/CarouselViewHandler.cssrc/Controls/src/Core/Handlers/Items/ItemsViewHandler.cssrc/Controls/src/Core/Handlers/Items/ItemsViewHandler.iOS.cssrc/Controls/src/Core/Handlers/Items/StructuredItemsViewHandler.Android.cssrc/Controls/src/Core/Handlers/Items/Tizen/ItemTemplateAdaptor.cssrc/Controls/src/Core/Handlers/Items/iOS/CarouselViewController.cssrc/Controls/src/Core/Handlers/Items/iOS/ItemsViewController.cssrc/Controls/src/Core/Handlers/Items/iOS/ItemsViewDelegator.cssrc/Controls/src/Core/Handlers/Items/iOS/SelectableItemsViewController.cssrc/Controls/src/Core/Handlers/Items/iOS/TemplatedCell.cssrc/Controls/src/Core/Handlers/Items2/CarouselViewHandler2.iOS.cssrc/Controls/src/Core/Handlers/Items2/ItemsViewHandler2.iOS.cssrc/Controls/src/Core/Handlers/Items2/iOS/CarouselViewController2.cssrc/Controls/src/Core/Handlers/Items2/iOS/GroupableItemsViewController2.cssrc/Controls/src/Core/Handlers/Items2/iOS/ItemsViewController2.cssrc/Controls/src/Core/Handlers/Items2/iOS/ItemsViewDelegator2.cssrc/Controls/src/Core/Handlers/Items2/iOS/LayoutFactory2.cssrc/Controls/src/Core/Handlers/Items2/iOS/SelectableItemsViewController2.cssrc/Controls/src/Core/Handlers/Items2/iOS/StructuredItemsViewController2.cssrc/Controls/src/Core/Handlers/Items2/iOS/TemplatedCell2.cssrc/Controls/src/Core/Handlers/Shapes/Polygon/PolygonHandler.Android.cssrc/Controls/src/Core/Handlers/Shapes/Polygon/PolygonHandler.Tizen.cssrc/Controls/src/Core/Handlers/Shapes/Polygon/PolygonHandler.Windows.cssrc/Controls/src/Core/Handlers/Shapes/Polygon/PolygonHandler.cssrc/Controls/src/Core/Handlers/Shapes/Polygon/PolygonHandler.iOS.cssrc/Controls/src/Core/Handlers/Shapes/Polyline/PolylineHandler.Android.cssrc/Controls/src/Core/Handlers/Shapes/Polyline/PolylineHandler.Tizen.cssrc/Controls/src/Core/Handlers/Shapes/Polyline/PolylineHandler.Windows.cssrc/Controls/src/Core/Handlers/Shapes/Polyline/PolylineHandler.cssrc/Controls/src/Core/Handlers/Shapes/Polyline/PolylineHandler.iOS.cssrc/Controls/src/Core/Handlers/Shell/ShellHandler.Windows.cssrc/Controls/src/Core/Handlers/Shell/ShellItemHandler.Windows.cssrc/Controls/src/Core/Handlers/Shell/ShellSectionHandler.Windows.cssrc/Controls/src/Core/Handlers/Shell/Windows/ShellFlyoutItemView.cssrc/Controls/src/Core/Handlers/Shell/Windows/ShellView.cssrc/Controls/src/Core/Hosting/AppHostBuilderExtensions.cssrc/Controls/src/Core/ImageElement.cssrc/Controls/src/Core/IndicatorView/IndicatorStackLayout.cssrc/Controls/src/Core/InputView/InputView.cssrc/Controls/src/Core/Internals/WeakEventProxy.cssrc/Controls/src/Core/Items/SelectionList.cssrc/Controls/src/Core/Label/Label.Mapper.cssrc/Controls/src/Core/Label/Label.cssrc/Controls/src/Core/Label/Label.iOS.cssrc/Controls/src/Core/Layout/Layout.cssrc/Controls/src/Core/ListView/ListView.cssrc/Controls/src/Core/NavigationPage/NavigationPage.cssrc/Controls/src/Core/NavigationPage/NavigationPageToolbar.cssrc/Controls/src/Core/Page/Page.cssrc/Controls/src/Core/Picker/Picker.cssrc/Controls/src/Core/Platform/AlertManager/AlertManager.Android.cssrc/Controls/src/Core/Platform/AlertManager/AlertManager.cssrc/Controls/src/Core/Platform/Android/BottomNavigationViewUtils.cssrc/Controls/src/Core/Platform/Android/DragAndDropGestureHandler.cssrc/Controls/src/Core/Platform/Android/Extensions/ToolbarExtensions.cssrc/Controls/src/Core/Platform/Android/GenericAnimatorListener.cssrc/Controls/src/Core/Platform/Android/TabbedPageManager.cssrc/Controls/src/Core/Platform/GestureManager/GesturePlatformManager.iOS.cssrc/Controls/src/Core/Platform/ModalNavigationManager/ModalNavigationManager.iOS.cssrc/Controls/src/Core/Platform/Windows/CollectionView/ItemContentControl.cssrc/Controls/src/Core/Platform/Windows/CollectionView/ScrollHelpers.cssrc/Controls/src/Core/Platform/iOS/Extensions/FormattedStringExtensions.cssrc/Controls/src/Core/Platform/iOS/Extensions/LabelExtensions.cssrc/Controls/src/Core/PromptArguments.cssrc/Controls/src/Core/PublicAPI/net-android/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/net-ios/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/net-maccatalyst/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/net-tizen/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/net-windows/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/net/PublicAPI.Unshipped.txtsrc/Controls/src/Core/PublicAPI/netstandard/PublicAPI.Unshipped.txtsrc/Controls/src/Core/RadioButton/RadioButton.cssrc/Controls/src/Core/RadioButton/RadioButtonGroup.cssrc/Controls/src/Core/RadioButton/RadioButtonGroupController.cssrc/Controls/src/Core/ResourcesExtensions.cssrc/Controls/src/Core/ScrollView/ScrollView.cssrc/Controls/src/Core/Setter.cssrc/Controls/src/Core/Shadow.cssrc/Controls/src/Core/Shapes/Shape.cssrc/Controls/src/Core/Shell/Shell.cssrc/Controls/src/Core/Shell/ShellNavigationManager.cssrc/Controls/src/Core/Shell/ShellSection.cssrc/Controls/src/Core/SwipeView/SwipeItem.cssrc/Controls/src/Core/SwipeView/SwipeItemView.cssrc/Controls/src/Core/SwipeView/SwipeItems.cssrc/Controls/src/Core/SwipeView/SwipeView.cssrc/Controls/src/Core/TabbedPage/TabbedPage.Windows.cssrc/Controls/src/Core/Toolbar/Toolbar.Android.cssrc/Controls/src/Core/VisualElement/VisualElement.cssrc/Controls/src/Core/VisualStateManager.cssrc/Controls/src/Core/WebView/WebViewSource.cssrc/Controls/src/Core/Window/Window.Android.cssrc/Controls/src/Core/Window/Window.cssrc/Controls/src/SourceGen/NodeSGExtensions.cssrc/Controls/src/Xaml/ApplyPropertiesVisitor.cssrc/Controls/src/Xaml/MarkupExtensions/OnIdiomExtension.cssrc/Controls/src/Xaml/MarkupExtensions/StaticResourceExtension.cssrc/Core/AndroidNative/maui/src/main/java/com/microsoft/maui/PlatformWrapperView.javasrc/Core/maps/src/Handlers/Map/MapHandler.Android.cssrc/Core/maps/src/Handlers/Map/MapHandler.iOS.cssrc/Core/maps/src/Handlers/MapPin/MapPinHandler.Android.cssrc/Core/maps/src/Platform/iOS/MauiMKMapView.cssrc/Core/maps/src/PublicAPI/net-android/PublicAPI.Unshipped.txtsrc/Core/src/Animations/AnimationManager.cssrc/Core/src/Core/IMauiRecyclerView.cssrc/Core/src/Core/ISafeAreaView2.cssrc/Core/src/Diagnostics/DiagnosticsManager.cssrc/Core/src/Diagnostics/IDiagnosticsManager.cssrc/Core/src/Diagnostics/Instrumentation/DiagnosticInstrumentation.cssrc/Core/src/Diagnostics/Instrumentation/LayoutArrangeInstrumentation.cssrc/Core/src/Diagnostics/Instrumentation/LayoutDiagnosticMetrics.cssrc/Core/src/Diagnostics/Instrumentation/LayoutMeasureInstrumentation.cssrc/Core/src/Graphics/MauiDrawable.Android.cssrc/Core/src/Handlers/Button/ButtonHandler.Android.cssrc/Core/src/Handlers/Button/ButtonHandler.cssrc/Core/src/Handlers/Button/ButtonHandler.iOS.cssrc/Core/src/Handlers/DatePicker/DatePickerHandler.Android.cssrc/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cssrc/Core/src/Handlers/Editor/EditorHandler.iOS.cssrc/Core/src/Handlers/Entry/EntryHandler.cssrc/Core/src/Handlers/Entry/EntryHandler.iOS.cssrc/Core/src/Handlers/FlyoutView/FlyoutViewHandler.Android.cssrc/Core/src/Handlers/HybridWebView/HybridWebViewHandler.Standard.cssrc/Core/src/Handlers/HybridWebView/HybridWebViewHandler.Tizen.cssrc/Core/src/Handlers/HybridWebView/HybridWebViewHandler.Windows.cssrc/Core/src/Handlers/HybridWebView/HybridWebViewHandler.cssrc/Core/src/Handlers/Image/ImageHandler.Windows.cssrc/Core/src/Handlers/Image/ImageHandler.iOS.cssrc/Core/src/Handlers/Label/LabelHandler.cssrc/Core/src/Handlers/Label/LabelHandler.iOS.cssrc/Core/src/Handlers/Picker/PickerHandler.Windows.cssrc/Core/src/Handlers/Picker/PickerHandler.iOS.cssrc/Core/src/Handlers/ProgressBar/ProgressBarHandler.iOS.cssrc/Core/src/Handlers/RadioButton/RadioButtonHandler.cssrc/Core/src/Handlers/RadioButton/RadioButtonHandler.iOS.cssrc/Core/src/Handlers/RefreshView/RefreshViewHandler.Windows.cssrc/Core/src/Handlers/ScrollView/ScrollViewHandler.Android.cssrc/Core/src/Handlers/ScrollView/ScrollViewHandler.Windows.cssrc/Core/src/Handlers/ScrollView/ScrollViewHandler.iOS.cssrc/Core/src/Handlers/SearchBar/SearchBarHandler.iOS.cssrc/Core/src/Handlers/SearchBar/SearchBarHandler2.Android.cssrc/Core/src/Handlers/ShapeView/ShapeViewHandler.Standard.cssrc/Core/src/Handlers/ShapeView/ShapeViewHandler.cssrc/Core/src/Handlers/Stepper/StepperHandler.iOS.cssrc/Core/src/Handlers/SwipeItemMenuItem/SwipeItemMenuItemHandler.Android.cssrc/Core/src/Handlers/SwipeItemMenuItem/SwipeItemMenuItemHandler.Windows.cssrc/Core/src/Handlers/SwipeItemMenuItem/SwipeItemMenuItemHandler.cssrc/Core/src/Handlers/SwipeItemMenuItem/SwipeItemMenuItemHandler.iOS.cssrc/Core/src/Handlers/Switch/SwitchHandler.iOS.cssrc/Core/src/Handlers/TimePicker/TimePickerHandler.Android.cssrc/Core/src/Handlers/TimePicker/TimePickerHandler.Windows.cssrc/Core/src/Handlers/TimePicker/TimePickerHandler.cssrc/Core/src/Handlers/TimePicker/TimePickerHandler.iOS.cssrc/Core/src/Handlers/View/ViewHandler.cssrc/Core/src/Handlers/WebView/WebViewHandler.Android.cssrc/Core/src/Hosting/EssentialsMauiAppBuilderExtensions.cssrc/Core/src/Hosting/LifecycleEvents/AppHostBuilderExtensions.Android.cssrc/Core/src/ImageSources/FontImageSourceService/FontImageSourceService.Windows.cssrc/Core/src/Layouts/Flex.cssrc/Core/src/Platform/Android/ActivityIndicatorExtensions.cssrc/Core/src/Platform/Android/ActivityResultCallbackRegistry.cssrc/Core/src/Platform/Android/BorderDrawable.cssrc/Core/src/Platform/Android/ContainerView.cssrc/Core/src/Platform/Android/ContentViewGroup.cssrc/Core/src/Platform/Android/EditTextExtensions.cssrc/Core/src/Platform/Android/LayoutViewGroup.cssrc/Core/src/Platform/Android/MauiAppCompatActivity.Lifecycle.cssrc/Core/src/Platform/Android/MauiAppCompatActivity.cssrc/Core/src/Platform/Android/MauiHybridWebView.cssrc/Core/src/Platform/Android/MauiHybridWebViewClient.cssrc/Core/src/Platform/Android/MauiScrollView.cssrc/Core/src/Platform/Android/MauiSearchView.cssrc/Core/src/Platform/Android/MauiSwipeRefreshLayout.cssrc/Core/src/Platform/Android/MauiSwipeView.cssrc/Core/src/Platform/Android/MauiWebView.cssrc/Core/src/Platform/Android/MauiWebViewClient.cssrc/Core/src/Platform/Android/MauiWindowInsetListener.cssrc/Core/src/Platform/Android/Navigation/NavigationRootManager.cssrc/Core/src/Platform/Android/RadioButtonExtensions.cssrc/Core/src/Platform/Android/SafeAreaExtensions.cssrc/Core/src/Platform/Android/SearchViewExtensions.cssrc/Core/src/Platform/Android/TimePickerExtensions.cssrc/Core/src/Platform/Android/ViewExtensions.cssrc/Core/src/Platform/Android/WrapperView.cssrc/Core/src/Platform/Windows/ContentPanel.cssrc/Core/src/Platform/Windows/LayoutPanel.cssrc/Core/src/Platform/Windows/MauiPasswordTextBox.cssrc/Core/src/Platform/Windows/MauiToolbar.xaml.cssrc/Core/src/Platform/Windows/PickerExtensions.cssrc/Core/src/Platform/Windows/RadioButtonExtensions.cssrc/Core/src/Platform/Windows/RootNavigationView.cssrc/Core/src/Platform/Windows/ScrollViewerExtensions.cssrc/Core/src/Platform/Windows/Styles/MauiComboBoxStyle.xamlsrc/Core/src/Platform/Windows/Styles/Resources.xamlsrc/Core/src/Platform/Windows/TextBoxExtensions.cssrc/Core/src/Platform/Windows/TimePickerExtensions.cssrc/Core/src/Platform/Windows/WebViewExtensions.cssrc/Core/src/Platform/iOS/ButtonExtensions.cssrc/Core/src/Platform/iOS/KeyboardAcceleratorExtensions.cssrc/Core/src/Platform/iOS/LayerExtensions.cssrc/Core/src/Platform/iOS/MauiPageControl.cssrc/Core/src/Platform/iOS/MauiScrollView.cssrc/Core/src/Platform/iOS/MauiSwipeView.cssrc/Core/src/Platform/iOS/MauiTextField.cssrc/Core/src/Platform/iOS/MauiTextView.cssrc/Core/src/Platform/iOS/MauiUIApplicationDelegate.Menu.cssrc/Core/src/Platform/iOS/MauiView.cssrc/Core/src/Platform/iOS/NoCaretField.cssrc/Core/src/Platform/iOS/PickerExtensions.cssrc/Core/src/Platform/iOS/SemanticExtensions.cssrc/Core/src/Platform/iOS/SliderExtensions.cssrc/Core/src/Platform/iOS/TabbedViewExtensions.cssrc/Core/src/Platform/iOS/TextFieldExtensions.cssrc/Core/src/Platform/iOS/TimePickerExtensions.cssrc/Core/src/Platform/iOS/WrapperView.cssrc/Core/src/PublicAPI/net-android/PublicAPI.Unshipped.txtsrc/Core/src/PublicAPI/net-ios/PublicAPI.Unshipped.txtsrc/Core/src/PublicAPI/net-maccatalyst/PublicAPI.Unshipped.txtsrc/Core/src/PublicAPI/net-windows/PublicAPI.Unshipped.txtsrc/Core/src/ViewExtensions.cssrc/Core/src/WindowExtensions.cssrc/Essentials/samples/Samples/View/ScreenshotPage.xamlsrc/Essentials/src/AssemblyInfo/AssemblyInfo.shared.cssrc/Essentials/src/Browser/Browser.android.cssrc/Essentials/src/Clipboard/Clipboard.shared.cssrc/Essentials/src/FilePicker/FilePicker.tizen.cssrc/Essentials/src/FileSystem/FileSystemUtils.android.cssrc/Essentials/src/FileSystem/FileSystemUtils.shared.cssrc/Essentials/src/MainThread/MainThread.netstandard.cssrc/Essentials/src/MainThread/MainThread.shared.cssrc/Essentials/src/MediaPicker/MediaPicker.android.cssrc/Essentials/src/MediaPicker/MediaPicker.ios.cssrc/Essentials/src/MediaPicker/MediaPicker.tizen.cssrc/Essentials/src/Screenshot/Screenshot.android.cssrc/Essentials/src/TextToSpeech/TextToSpeech.ios.tvos.watchos.cssrc/Essentials/src/TextToSpeech/TextToSpeech.shared.cssrc/Essentials/src/TextToSpeech/TextToSpeech.windows.cssrc/Essentials/src/Types/Shared/WebUtils.shared.cssrc/Graphics/src/Graphics/Platforms/Android/PlatformGraphicsView.cssrc/Graphics/src/Graphics/Platforms/MaciOS/PlatformCanvas.cssrc/Graphics/src/Graphics/Platforms/Windows/PlatformGraphicsView.cssrc/Graphics/src/Graphics/Platforms/iOS/PlatformGraphicsView.cssrc/SingleProject/Resizetizer/src/GenerateTizenManifest.cssrc/SingleProject/Resizetizer/src/SkiaSharpSvgTools.cssrc/SingleProject/Resizetizer/src/nuget/buildTransitive/Microsoft.Maui.Resizetizer.After.targetssrc/Templates/src/Microsoft.Maui.Templates.csprojsrc/Templates/src/templates/maui-mobile/MauiApp.1.csproj
New files (not reverted):
eng/devices/Run-PackagedAppAndWait.ps1src/Controls/src/Core/Handlers/Items/iOS/IScrollTrackingDelegator.cssrc/Controls/src/Core/Platform/AlertManager/DelegateAlertSubscription.cssrc/Core/maps/src/Handlers/Map/MapElementPlatformOptions.Android.cssrc/Core/src/Handlers/HybridWebView/HybridWebViewHelper.cssrc/Core/src/Platform/Android/AppbarLayoutExtensions.cssrc/Core/src/Platform/Android/IBackNavigationState.cssrc/Core/src/Platform/Android/RefreshViewWebViewScrollCapture.cssrc/Core/src/Platform/Windows/CharacterSpacingConverter.cssrc/Core/src/Platform/Windows/ContentPanelAutomationPeer.cssrc/Core/src/Platform/Windows/MauiBorderAutomationPeer.cssrc/Core/src/Platform/Windows/MauiLayoutAutomationPeer.cssrc/Core/src/Platform/iOS/MauiProgressView.cssrc/Core/src/ScreenshotDispatch.cssrc/Templates/src/templates/maui-blazor-solution/.gitignoresrc/Templates/src/templates/maui-blazor/.gitignoresrc/Templates/src/templates/maui-lib/.gitignoresrc/Templates/src/templates/maui-mobile/.gitignoresrc/Templates/src/templates/maui-multiproject/.gitignore
UI Tests — ViewBaseTests
Detected UI test categories: ViewBaseTests
Pre-Flight — Context & Validation
Issue: #5947 - DatePicker Focus not working correctly on MacCatalyst
PR: #35553 - Fix MacCatalyst DatePicker focus handling
Platforms Affected: MacCatalyst
Files Changed: 1 implementation, 2 test
Key Findings
- The linked issue reports MacCatalyst-specific
DatePicker.Focus()behavior where focus/open state can become stale and prevent later opens. - The PR changes
DatePickerHandler.MacCatalyst.csto synchronizeIsFocusedandIsOpenaround programmatic focus/unfocus, native edit begin, value change, and native close notifications. - The PR adds MacCatalyst device coverage in Core and Controls DatePicker tests, including stale virtual focus, repeated focus,
IsOpenreopen, command mapper preservation, native focus refusal, and single Opened/Closed event behavior. - Prior inline review raised a command-mapper preservation concern; the author addressed it by keeping the default handler on
DatePickerHandler.CommandMapperand chaining MacCatalystIViewfocus/unfocus overrides instead. - Gate result provided by caller tests fail without fix and pass with fix. Gate was not re-run.PASSED :
Code Review Summary
Verdict: LGTM
Confidence: medium
Errors: 0 | Warnings: 0 | Suggestions: 0
Key code review findings:
- No actionable findings from the independent code review.
- Devil's advocate note: static command-mapper chaining is the primary risk area, but the PR includes default mapper preservation coverage.
Fix Candidates
| # | Source | Approach | Test Result | Files Changed | Notes |
|---|---|---|---|---|---|
| PR | PR #35553 | MacCatalyst-specific DatePicker handler synchronizes focused/open state and chains / overrides from the public command mapper. | PASSED (Gate) | src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs, src/Core/tests/DeviceTests/Handlers/DatePicker/DatePickerHandlerTests.MacCatalyst.cs, src/Controls/tests/DeviceTests/Elements/DatePicker/DatePickerTests.cs |
Original PR |
Code Review — Deep Analysis
Code PR #35553Review
Independent Assessment
What this changes: Adds MacCatalyst-specific DatePicker focus/unfocus command handling and synchronizes native open state with IDatePicker.IsOpen/IsFocused; adds MacCatalyst Core and Controls device coverage for stale focus, repeated focus, event counts, and native refusal/close paths.
Inferred motivation: Programmatic DatePicker.Focus() on MacCatalyst can leave MAUI virtual focus/open state stale, so later focus attempts no longer reopen the picker.
Reconciliation with PR Narrative
Author claims: PR fixes MacCatalyst DatePicker.Focus() state synchronization for #5947, validates targeted MacCatalyst DatePicker tests, and notes unrelated CI failures.
Agreement/disagreement: The code and tests match the stated MacCatalyst focus/open-state fix. Existing review feedback about bypassing the public command mapper appears addressed by keeping default handlers on DatePickerHandler.CommandMapper and chaining the MacCatalyst IView command mapper from it.
Findings
No actionable findings.
Devil's Advocate
The main risk is the static mapper-chain mutation in DatePickerHandler.MacCatalyst.cs; I checked CommandMapper.GetCommand ordering and the added DefaultHandlerUsesPublicCommandMapper test, and this preserves the public mapper as the handler mapper while routing missing IView.Focus/Unfocus commands through the chained MacCatalyst override. Platform scope is MacCatalyst-only; I did not execute device tests locally. GitHub check status is still pending (Build Analysis in progress), so this is a code-only LGTM, not a merge-readiness statement.
Verdict: LGTM
Confidence: medium
Summary: The implementation is targeted, preserves handler mapper extensibility, has lifecycle cleanup for observers/events, and includes regression coverage for the relevant MacCatalyst focus/open-state scenarios. No code correctness issues were found; CI was not fully complete at review time.
Fix — Analysis & Comparison
Fix Candidates
| # | Source | Approach | Test Result | Files Changed | Notes |
|---|---|---|---|---|---|
| 1 | maui-expert-reviewer | Make IDatePicker.IsOpen and native callbacks authoritative; remove MacCatalyst Focus/Unfocus override. | FAIL | 1 file | Built, but stale/repeated Focus tests returned false without explicit FocusRequest handling. |
| 2 | maui-expert-reviewer | Use an instance-local MacCatalyst command mapper wrapper selected by constructors and chained to the public DatePickerHandler.CommandMapper. | PASS | 3 files | Passes tests, but changes shared constructor plumbing and does not perfectly preserve Focus mapping ordering. |
| 3 | maui-expert-reviewer | Override MacCatalyst DatePickerHandler.Invoke to intercept Focus/Unfocus, then delegate to the public command mapper. | PASS | 1 file | More surgical than PR: no global mapper-chain mutation and default handler still uses public command mapper. |
| PR | PR #35553 | Chain MacCatalyst Focus/Unfocus overrides from the public command mapper and synchronize focused/open state. | PASSED (Gate) | 3 files | Original PR. |
Cross-Pollination
| Model | Round | New Ideas? | Details |
|---|---|---|---|
| maui-expert-reviewer | 1 | Yes | Candidate 1: IsOpen/native-callback authoritative state machine with no Focus override. |
| maui-expert-reviewer | 2 | Yes | Candidate 2: instance-local MacCatalyst mapper wrapper after candidate 1 proved explicit FocusRequest handling is required. |
| maui-expert-reviewer | 3 | Yes | Candidate 3: handler-level Invoke interception to avoid both global mapper mutation and shared constructor plumbing. |
Exhausted: No. Stopped because Candidate #3 passed all targeted tests and is demonstrably better than the PR on locality and mapper-chain safety.
Selected Fix: Candidate #3. It passes the same targeted MacCatalyst DatePicker regression tests, confines implementation changes to DatePickerHandler.MacCatalyst.cs, avoids mutating DatePickerHandler.CommandMapper.Chained, and preserves the existing default-handler public command-mapper identity test.
Report — Final Recommendation
Comparative PR #35553Report
Candidates compared
| Rank | Candidate | Result | Assessment |
|---|---|---|---|
| 1 | try-fix-3 |
PASS | Best candidate. It keeps the same tested behavior as the PR while avoiding mutation of DatePickerHandler.CommandMapper.Chained, preserving the default handler's public command mapper identity, and limiting implementation changes to DatePickerHandler.MacCatalyst.cs. |
| 2 | pr |
PASSED (Gate) | Correct and expert-reviewed LGTM. It fixes the MacCatalyst DatePicker focus/open-state bug and has targeted coverage, but relies on static command-mapper chain mutation, which is the main design risk compared with try-fix-3. |
| 2 | pr-plus-reviewer |
PASSED (equivalent to PR) | The expert reviewer produced no actionable findings, so this is identical to pr and ranks the same. |
| 4 | try-fix-2 |
PASS | Also avoids public mapper-chain mutation, but does so by changing shared constructor plumbing and using an instance-local mapper wrapper. It is broader than try-fix-3 and does not perfectly preserve public PrependToMapping ordering semantics for IView.Focus. |
| 5 | try-fix-1 |
FAIL | Failed the regression tests for stale/repeated focus because an IsOpen/native-callback-only state machine does not explicitly handle MacCatalyst FocusRequest. Per ranking rules, this failed candidate is below all passing candidates. |
Decision
try-fix-3 is the single winning candidate. It passed the same targeted MacCatalyst DatePicker regression tests as the PR, avoids the PR's static command-mapper-chain mutation, does not require the broader constructor changes from try-fix-2, and directly addresses the FocusRequest gap that made try-fix-1 fail.
Notes on PR fix and reviewer evaluation
The raw PR fix is acceptable: expert review found no actionable issues and wrote [] to inline-findings.json. Because no feedback needed applying, pr-plus-reviewer is not a distinct implementation. The deciding factor is therefore not correctness failure in the PR, but that try-fix-3 provides a more localized and lower-risk implementation while preserving the tested behavior.
Future Action — alternative fix proposed (try-fix-3)
Automated review — alternative fix proposed
The expert-reviewer evaluation compared the PR fix against automatically generated candidates and selected try-fix-3 as the strongest fix.
Why: try-fix-3 passes the MacCatalyst DatePicker regression tests while avoiding the PR's static command-mapper-chain mutation. It is more localized than try-fix-2 and explicitly handles FocusRequest, unlike failed try-fix-1.
Please consider applying the candidate diff below (or use it as guidance). Once you push an update, this workflow will re-trigger and re-evaluate.
Candidate diff (try-fix-3)
diff --git a/src/Controls/tests/DeviceTests/Elements/DatePicker/DatePickerTests.cs b/src/Controls/tests/DeviceTests/Elements/DatePicker/DatePickerTests.cs
index 1027a597ab..7569089a74 100644
--- a/src/Controls/tests/DeviceTests/Elements/DatePicker/DatePickerTests.cs
+++ b/src/Controls/tests/DeviceTests/Elements/DatePicker/DatePickerTests.cs
@@ -5,6 +5,7 @@ using Microsoft.Maui.Handlers;
using Microsoft.Maui.Hosting;
using Microsoft.Maui.Platform;
using Xunit;
+using static Microsoft.Maui.DeviceTests.AssertHelpers;
namespace Microsoft.Maui.DeviceTests;
@@ -68,6 +69,111 @@ public partial class DatePickerTests : ControlsHandlerTestBase
}
#endif
+#if MACCATALYST
+ [Fact(DisplayName = "Focus Opens DatePicker When Virtual Focus Is Stale")]
+ public async Task FocusOpensDatePickerWhenVirtualFocusIsStale()
+ {
+ SetupBuilder();
+
+ var datePicker = new DatePicker
+ {
+ Date = new DateTime(2026, 5, 20),
+ WidthRequest = 200,
+ HeightRequest = 44
+ };
+
+ await CreateHandlerAndAddToWindow<DatePickerHandler>(datePicker, async handler =>
+ {
+ ((IView)datePicker).IsFocused = true;
+ datePicker.IsOpen = false;
+
+ var focusResult = datePicker.Focus();
+
+ Assert.True(focusResult);
+ await AssertEventually(
+ () => datePicker.IsFocused && datePicker.IsOpen,
+ message: "DatePicker focus did not open the picker when virtual focus was stale.");
+
+ handler.Invoke(nameof(IView.Unfocus), null);
+ });
+ }
+
+ [Fact(DisplayName = "IsOpen Raises Single Opened And Closed Events")]
+ public async Task IsOpenRaisesSingleOpenedAndClosedEvents()
+ {
+ SetupBuilder();
+
+ var openedCount = 0;
+ var closedCount = 0;
+ var datePicker = new DatePicker
+ {
+ Date = new DateTime(2026, 5, 20),
+ WidthRequest = 200,
+ HeightRequest = 44
+ };
+
+ datePicker.Opened += (_, _) => openedCount++;
+ datePicker.Closed += (_, _) => closedCount++;
+
+ await CreateHandlerAndAddToWindow<DatePickerHandler>(datePicker, async handler =>
+ {
+ datePicker.IsOpen = true;
+
+ await AssertEventually(
+ () => datePicker.IsFocused && datePicker.IsOpen,
+ message: "DatePicker did not enter the focused/open state.");
+
+ datePicker.IsOpen = false;
+
+ await AssertEventually(
+ () => !datePicker.IsFocused && !datePicker.IsOpen,
+ message: "DatePicker did not leave the focused/open state.");
+
+ Assert.Equal(1, openedCount);
+ Assert.Equal(1, closedCount);
+ });
+ }
+
+ [Fact(DisplayName = "Repeated Focus While Open Raises No Extra Opened Or Closed Events")]
+ public async Task RepeatedFocusWhileOpenRaisesNoExtraOpenedOrClosedEvents()
+ {
+ SetupBuilder();
+
+ var openedCount = 0;
+ var closedCount = 0;
+ var datePicker = new DatePicker
+ {
+ Date = new DateTime(2026, 5, 20),
+ WidthRequest = 200,
+ HeightRequest = 44
+ };
+
+ datePicker.Opened += (_, _) => openedCount++;
+ datePicker.Closed += (_, _) => closedCount++;
+
+ await CreateHandlerAndAddToWindow<DatePickerHandler>(datePicker, async handler =>
+ {
+ Assert.True(datePicker.Focus());
+ await AssertEventually(
+ () => datePicker.IsFocused && datePicker.IsOpen,
+ message: "DatePicker did not enter the focused/open state.");
+
+ Assert.Equal(1, openedCount);
+ Assert.Equal(0, closedCount);
+
+ Assert.True(datePicker.Focus());
+ await Task.Delay(100);
+
+ Assert.True(datePicker.IsFocused);
+ Assert.True(datePicker.IsOpen);
+ Assert.Equal(1, openedCount);
+ Assert.Equal(0, closedCount);
+
+ handler.Invoke(nameof(IView.Unfocus), null);
+ });
+ }
+#endif
+
string GetDisplayedText(DatePickerHandler handler)
{
var platformView = handler.PlatformView;
@@ -151,4 +257,4 @@ public partial class DatePickerTests : ControlsHandlerTestBase
Assert.True(eventFired, "DateSelected event should fire when platform view date changes");
});
}
-}
\ No newline at end of file
+}
diff --git a/src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs b/src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs
index 63fe51ff5c..09df994372 100644
--- a/src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs
+++ b/src/Core/src/Handlers/DatePicker/DatePickerHandler.MacCatalyst.cs
@@ -19,6 +19,9 @@ namespace Microsoft.Maui.Handlers
return new UIDatePicker { Mode = UIDatePickerMode.Date, TimeZone = new NSTimeZone("UTC") };
}
+ bool _syncingOpenState;
+ bool _nativeOpenState;
+
internal bool UpdateImmediately { get; set; } = true;
protected override void ConnectHandler(UIDatePicker platformView)
@@ -109,10 +112,7 @@ namespace Microsoft.Maui.Handlers
// unrelated window closes while the picker is not open.
_windowCloseObserver = NSNotificationCenter.DefaultCenter.AddObserver(WindowDidCloseNotification, OnWindowClosed);
- if (VirtualView is IDatePicker virtualView)
- {
- virtualView.IsFocused = virtualView.IsOpen = true;
- }
+ SetVirtualOpenStateFromNative(true);
}
void OnWindowClosed(NSNotification notification)
@@ -126,10 +126,7 @@ namespace Microsoft.Maui.Handlers
_isDatePickerOpen = false;
- if (VirtualView is IDatePicker virtualView)
- {
- virtualView.IsFocused = virtualView.IsOpen = false;
- }
+ SetVirtualOpenStateFromNative(false);
// On MacCatalyst the internal UITextFields stay as first responder
// (visually highlighted) even after the popover window closes.
@@ -195,7 +192,118 @@ namespace Microsoft.Maui.Handlers
internal static partial void MapIsOpen(IDatePickerHandler handler, IDatePicker datePicker)
{
+ if (handler is DatePickerHandler datePickerHandler)
+ datePickerHandler.SyncOpenState(datePicker.IsOpen, refreshIfAlreadyFirstResponder: datePicker.IsOpen);
+ }
+
+ public override void Invoke(string command, object? args)
+ {
+ if (command == nameof(IView.Focus) && args is FocusRequest request)
+ {
+ InvokeMacCatalystFocus(request);
+ base.Invoke(command, args);
+ return;
+ }
+
+ if (command == nameof(IView.Unfocus))
+ {
+ InvokeMacCatalystUnfocus();
+ base.Invoke(command, args);
+ return;
+ }
+
+ base.Invoke(command, args);
+ }
+
+ void InvokeMacCatalystFocus(FocusRequest request)
+ {
+ if (VirtualView is not IDatePicker datePicker)
+ {
+ request.TrySetResult(false);
+ return;
+ }
+
+ var didOpen = SyncOpenState(shouldBeOpen: true, refreshIfAlreadyFirstResponder: !datePicker.IsOpen);
+ request.TrySetResult(didOpen);
+ }
+
+ void InvokeMacCatalystUnfocus()
+ {
+ if (VirtualView is not IDatePicker)
+ return;
+
+ SyncOpenState(shouldBeOpen: false, refreshIfAlreadyFirstResponder: false);
+ }
+
+ bool SyncOpenState(bool shouldBeOpen, bool refreshIfAlreadyFirstResponder)
+ {
+ if (_syncingOpenState)
+ return _nativeOpenState || PlatformView.IsFirstResponder;
+ _syncingOpenState = true;
+ try
+ {
+ var platformView = PlatformView;
+ bool actualOpen;
+ if (shouldBeOpen)
+ {
+ if (platformView.IsFirstResponder && refreshIfAlreadyFirstResponder)
+ platformView.ResignFirstResponder();
+
+ var didBecomeFirstResponder = platformView.IsFirstResponder;
+ if (!platformView.IsFirstResponder)
+ didBecomeFirstResponder = platformView.BecomeFirstResponder();
+
+ // Stock UIDatePicker on MacCatalyst does not reliably report first-responder
+ // state from a programmatic open request; custom platform views use native results.
+ var canAssumeStockPickerOpened = platformView.GetType() == typeof(UIDatePicker) &&
+ platformView.Enabled &&
+ platformView.UserInteractionEnabled;
+
+ actualOpen = platformView.IsFirstResponder || didBecomeFirstResponder || canAssumeStockPickerOpened;
+ }
+ else
+ {
+ if (platformView.IsFirstResponder || _nativeOpenState)
+ platformView.ResignFirstResponder();
+
+ actualOpen = platformView.IsFirstResponder;
+ }
+
+ SetVirtualOpenState(actualOpen);
+ return actualOpen;
+ }
+ finally
+ {
+ _syncingOpenState = false;
+ }
+ }
+
+ void SetVirtualOpenStateFromNative(bool isOpen)
+ {
+ if (_syncingOpenState)
+ return;
+
+ _syncingOpenState = true;
+ try
+ {
+ SetVirtualOpenState(isOpen);
+ }
+ finally
+ {
+ _syncingOpenState = false;
+ }
+ }
+
+ void SetVirtualOpenState(bool isOpen)
+ {
+ _nativeOpenState = isOpen;
+
+ if (VirtualView is IDatePicker virtualView)
+ {
+ virtualView.IsOpen = isOpen;
+ virtualView.IsFocused = isOpen;
+ }
}
void SetVirtualViewDate()
@@ -211,14 +319,10 @@ namespace Microsoft.Maui.Handlers
class UIDatePickerProxy
{
WeakReference<DatePickerHandler>? _handler;
- WeakReference<IDatePicker>? _virtualView;
-
- IDatePicker? VirtualView => _virtualView is not null && _virtualView.TryGetTarget(out var v) ? v : null;
public void Connect(DatePickerHandler handler, IDatePicker virtualView, UIDatePicker platformView)
{
_handler = new(handler);
- _virtualView = new(virtualView);
platformView.ValueChanged += OnValueChanged;
}
@@ -230,11 +334,13 @@ namespace Microsoft.Maui.Handlers
void OnValueChanged(object? sender, EventArgs? e)
{
- if (_handler is not null && _handler.TryGetTarget(out var handler) && handler.UpdateImmediately)
- handler.SetVirtualViewDate();
+ if (_handler is not null && _handler.TryGetTarget(out var handler))
+ {
+ if (handler.UpdateImmediately)
+ handler.SetVirtualViewDate();
- if (VirtualView is IDatePicker virtualView)
- virtualView.IsFocused = true;
+ handler.SetVirtualOpenStateFromNative(true);
+ }
}
}
}
### Description of Change Fixes `DatePicker.Focus()` on MacCatalyst so programmatic focus correctly updates the virtual view state. On MacCatalyst, `UIDatePicker.BecomeFirstResponder()` can return `false`, which prevented the MAUI focus request from completing successfully and left `IsFocused` / `IsOpen` out of sync. This change adds MacCatalyst-specific command handling for `IView.Focus` and `IView.Unfocus`, explicitly synchronizes `IsFocused` and `IsOpen`, and keeps native/user interaction callbacks aligned with the same state. A MacCatalyst-only regression test was added to verify that a `DatePicker` can be focused, unfocused, and focused again successfully. Validation: - Built `Core.DeviceTests` for `net10.0-maccatalyst`. - Ran focused MacCatalyst DatePicker device tests. - Verified the issue repro changes from reproduced to not reproduced with the local fix. - Verified iOS remains not reproduced. ### Issues Fixed Fixes #5947 ---------
Description of Change
Fixes
DatePicker.Focus()on MacCatalyst so programmatic focus correctly updates the virtual view state.On MacCatalyst,
UIDatePicker.BecomeFirstResponder()can returnfalse, which prevented the MAUI focus request from completing successfully and leftIsFocused/IsOpenout of sync. This change adds MacCatalyst-specific command handling forIView.FocusandIView.Unfocus, explicitly synchronizesIsFocusedandIsOpen, and keeps native/user interaction callbacks aligned with the same state.A MacCatalyst-only regression test was added to verify that a
DatePickercan be focused, unfocused, and focused again successfully.Validation:
Core.DeviceTestsfornet10.0-maccatalyst.Issues Fixed
Fixes #5947