Skip to content

ci: remove usbmmidd_v2#220

Merged
ReenigneArcher merged 9 commits intomasterfrom
ci/replace-usbmmidd_v2
Mar 21, 2026
Merged

ci: remove usbmmidd_v2#220
ReenigneArcher merged 9 commits intomasterfrom
ci/replace-usbmmidd_v2

Conversation

@ReenigneArcher
Copy link
Member

@ReenigneArcher ReenigneArcher commented Mar 21, 2026

Description

Remove virtual display installation from CI. Tried a few different ones, without any success.

Screenshot

Issues Fixed or Closed

Roadmap Issues

Type of Change

  • feat: New feature (non-breaking change which adds functionality)
  • fix: Bug fix (non-breaking change which fixes an issue)
  • docs: Documentation only changes
  • style: Changes that do not affect the meaning of the code (white-space, formatting, missing semicolons, etc.)
  • refactor: Code change that neither fixes a bug nor adds a feature
  • perf: Code change that improves performance
  • test: Adding missing tests or correcting existing tests
  • build: Changes that affect the build system or external dependencies
  • ci: Changes to CI configuration files and scripts
  • chore: Other changes that don't modify src or test files
  • revert: Reverts a previous commit
  • BREAKING CHANGE: Introduces a breaking change (can be combined with any type above)

Checklist

  • Code follows the style guidelines of this project
  • Code has been self-reviewed
  • Code has been commented, particularly in hard-to-understand areas
  • Code docstring/documentation-blocks for new or existing methods/components have been added or updated
  • Unit tests have been added or updated for any new or modified functionality

AI Usage

  • None: No AI tools were used in creating this PR
  • Light: AI provided minor assistance (formatting, simple suggestions)
  • Moderate: AI helped with code generation or debugging specific parts
  • Heavy: AI generated most or all of the code changes

@codecov
Copy link

codecov bot commented Mar 21, 2026

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 92.27%. Comparing base (fb47963) to head (8c3a72e).
⚠️ Report is 1 commits behind head on master.
✅ All tests successful. No failed tests found.

Additional details and impacted files
@@            Coverage Diff             @@
##           master     #220      +/-   ##
==========================================
- Coverage   93.12%   92.27%   -0.85%     
==========================================
  Files          34       34              
  Lines        2123     2123              
  Branches     1086     1086              
==========================================
- Hits         1977     1959      -18     
- Misses         82       92      +10     
- Partials       64       72       +8     
Flag Coverage Δ
Linux 93.73% <ø> (ø)
Windows 91.92% <ø> (-0.88%) ⬇️
macOS 74.20% <ø> (ø)

Flags with carried forward coverage won't be shown. Click here to find out more.
see 2 files with indirect coverage changes

Add runtime guards in tests/unit/windows/test_win_display_device_hdr.cpp: skip the GetSetHdrStates test if no displays are available or if setting an extended topology fails. Replace hard ASSERT_TRUE topology check with conditional GTEST_SKIP_ to avoid failing on systems that don't support extended topologies.
@ReenigneArcher ReenigneArcher force-pushed the ci/replace-usbmmidd_v2 branch from d6d3da9 to e24994c Compare March 21, 2026 18:55
Replace the previous ParsecVDisplay portable download/start in the CI workflow with a new PowerShell script (scripts/parsec-vdd.ps1) that P/Invokes Win32 setupapi/kernel32 to add virtual displays and run a keepalive loop so the driver doesn't unplug them after ~1s. Update the workflow (.github/workflows/ci.yml) to launch the script with DisplayCount=2 and wait briefly for registration. Also tighten a unit test (tests/unit/windows/test_win_display_device_hdr.cpp) to ASSERT that setTopology succeeds instead of skipping when it fails.
@ReenigneArcher ReenigneArcher force-pushed the ci/replace-usbmmidd_v2 branch from e378368 to 413ce3b Compare March 21, 2026 19:26
Add enumeration and display-mode APIs to parsec-vdd.ps1 and set distinct resolutions for Parsec virtual displays so Windows can distinguish otherwise-identical VDDs for topology operations. Implements DISPLAY_DEVICE/DEVMODE structs, EnumDisplayDevicesA and ChangeDisplaySettingsExA P/Invoke calls, GetParsecDisplayNames and SetResolution helpers, and a short wait + resolution-assignment loop (cycles 1920x1080, 1280x720, 1600x900 @60Hz). Also log results of each change. Update CI workflow sleep from 5s to 10s to allow time for displays to be added, resolutions set, and registered by Windows.
@ReenigneArcher ReenigneArcher force-pushed the ci/replace-usbmmidd_v2 branch 2 times, most recently from 241c60f to 710ff55 Compare March 21, 2026 22:54
Replace the Parsec VDD setup with virtual-display-rs in the CI workflow: download and extract the virtual-display-rs release, install the MSI via msiexec, and invoke a new PowerShell helper. Remove the old scripts/parsec-vdd.ps1 helper and add scripts/virtual-display-rs.ps1 which configures distinct virtual monitor modes and sends a DriverNotify payload over the driver's named pipe (no keepalive required). Adjusted the CI PowerShell invocation and shortened the post-install wait time.
@ReenigneArcher ReenigneArcher force-pushed the ci/replace-usbmmidd_v2 branch from 710ff55 to 83dd56f Compare March 21, 2026 22:54
Replace MSI-based installation with the portable virtual-display-rs package in CI. The workflow now downloads the portable zip and nefconw.exe, extracts the driver, trusts its certificate, copies the VirtualDisplayDriver.dll into System32\drivers\UMDF, imports the provided registry entries, and creates the device node using nefconw. Removes the previous msiexec installation steps to support a portable CI-friendly installation method.
Switches JSON serialization to PowerShell's ConvertTo-Json for Windows PowerShell 5.1 compatibility and makes monitor objects ordered for consistent output. Normalizes the modes array to use an ordered hashtable for each mode. Replaces a single blocking pipe connect with a retry loop (30s deadline, 2s backoff, 2s per-attempt connect timeout), adds informative logging, and returns a non-zero exit on timeout.
CI: download both the portable and installer zips for virtual-display-rs, extract them to distinct paths, and install the driver via the installer package. The workflow now uses the installer DriverCertificate.cer (added to Root and TrustedPublisher) and pnputil to add/install the .inf instead of manually copying the DLL and importing registry entries. Also adjusted downloaded filenames and log messages for clarity.
@ReenigneArcher ReenigneArcher force-pushed the ci/replace-usbmmidd_v2 branch from 003cd8f to 2103d8f Compare March 21, 2026 23:37
Remove the Windows-specific "Prepare tests" step from the CI workflow and delete scripts/virtual-display-rs.ps1. This removes the logic that downloaded and installed the virtual-display-rs driver (portable and installer zips), trusted the driver certificate, installed the driver and device node, started the control app, and configured virtual displays via the PowerShell script. Simplifies CI by no longer setting up virtual displays on Windows runners.
@ReenigneArcher ReenigneArcher changed the title ci: replace usbmmidd_v2 ci: remove usbmmidd_v2 Mar 21, 2026
@sonarqubecloud
Copy link

@ReenigneArcher ReenigneArcher marked this pull request as ready for review March 21, 2026 23:49
@ReenigneArcher ReenigneArcher merged commit ff51f9f into master Mar 21, 2026
21 checks passed
@ReenigneArcher ReenigneArcher deleted the ci/replace-usbmmidd_v2 branch March 21, 2026 23:50
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant