Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: port certificate-generation condition script to Rust #259

Open
wants to merge 7 commits into
base: main
Choose a base branch
from

Conversation

leon-xd
Copy link

@leon-xd leon-xd commented Jan 9, 2025

Ported last Duckscript condition script to Rust

closes #93

@wmmc88 wmmc88 self-assigned this Jan 10, 2025
@wmmc88 wmmc88 requested review from Copilot and wmmc88 and removed request for Copilot January 10, 2025 23:57
Copy link

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

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

Copilot reviewed 2 out of 2 changed files in this pull request and generated 1 comment.

Comments suppressed due to low confidence (2)

crates/wdk-build/src/cargo_make.rs:1041

  • The error message 'WDRLocalTestCert already in WDRTestCertStore. Skipping certificate generation.' could be more informative. Consider including more context about why the certificate generation is being skipped.
anyhow::anyhow!("WDRLocalTestCert already in WDRTestCertStore. Skipping certificate generation.")

crates/wdk-build/src/cargo_make.rs:1024

  • Ensure that the new behavior introduced in the generate_certificate_condition_script function is covered by tests.
pub fn generate_certificate_condition_script() -> anyhow::Result<()> {

])
.arg(get_wdk_build_output_directory().join("WDRLocalTestCert.cer"))
.output()
.expect("Failed to run certmgr.exe.");
Copy link
Preview

Copilot AI Jan 10, 2025

Choose a reason for hiding this comment

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

The error message 'Failed to run certmgr.exe.' could be more descriptive. Consider providing more context about what went wrong.

Suggested change
.expect("Failed to run certmgr.exe.");
.expect("Failed to run certmgr.exe with the provided arguments.");

Copilot is powered by AI, so mistakes are possible. Review output carefully before use.

Positive Feedback
Negative Feedback

Provide additional feedback

Please help us improve GitHub Copilot by sharing more details about this comment.

Please select one or more of the options
Copy link
Collaborator

Choose a reason for hiding this comment

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

@leon-xd I think the expect prints the Err variant contents, but doesn't print anything to do with the Command. It probably makes sense to print all the args here to make it more clear what command failed, since it will fail and then continue to try to run the task. Maybe do smth like:

let cert_save_location = get_wdk_build_output_directory().join("WDRLocalTestCert.cer");
let args = [
                "-put",
                "-s",
                "WDRTestCertStore",
                "-c",
                "-n",
                "WdrLocalTestCert",
                cert_save_location.as_str()
            ];
let output = Command::new("certmgr")
            .args(&args)
            .output()
            .unwrap_or_else(|| panic!("Failed to run 'certmgr.exe {}'", &args.join(" ")));

Copy link
Author

@leon-xd leon-xd Jan 15, 2025

Choose a reason for hiding this comment

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

@wmmc88 I ended up doing it slightly differently. cert_save_location is a PathBuf which is impossible to reduce to a &str without either an unwrap after a conversion or a lossy str conversion. Given that it's possible for path strings to be non-UTF8 I figured keeping the lossy conversion until the unwrap was more complete, in case a developer's build path contains a non-UTF8 string.

Copy link
Collaborator

Choose a reason for hiding this comment

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

I think its useful to look at why it was working before: https://doc.rust-lang.org/std/process/struct.Command.html#method.arg takes in a AsRef<OsStr>. Since slices need to have all members be of the same type, what you could do is actually just call as_os_str on the PathBuf, and then have all the other str in the slice be OsStr via AsRef<OsStr> for str

Example: https://play.rust-lang.org/?version=nightly&mode=release&edition=2024&gist=c8c49b3308e432a31ed278c2d89467c3

Copy link
Collaborator

@wmmc88 wmmc88 left a comment

Choose a reason for hiding this comment

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

some minor comments, but good to merge after

crates/wdk-build/src/cargo_make.rs Outdated Show resolved Hide resolved
crates/wdk-build/src/cargo_make.rs Outdated Show resolved Hide resolved
])
.arg(get_wdk_build_output_directory().join("WDRLocalTestCert.cer"))
.output()
.expect("Failed to run certmgr.exe.");
Copy link
Collaborator

Choose a reason for hiding this comment

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

@leon-xd I think the expect prints the Err variant contents, but doesn't print anything to do with the Command. It probably makes sense to print all the args here to make it more clear what command failed, since it will fail and then continue to try to run the task. Maybe do smth like:

let cert_save_location = get_wdk_build_output_directory().join("WDRLocalTestCert.cer");
let args = [
                "-put",
                "-s",
                "WDRTestCertStore",
                "-c",
                "-n",
                "WdrLocalTestCert",
                cert_save_location.as_str()
            ];
let output = Command::new("certmgr")
            .args(&args)
            .output()
            .unwrap_or_else(|| panic!("Failed to run 'certmgr.exe {}'", &args.join(" ")));

crates/wdk-build/src/cargo_make.rs Outdated Show resolved Hide resolved
crates/wdk-build/src/cargo_make.rs Outdated Show resolved Hide resolved
crates/wdk-build/src/cargo_make.rs Outdated Show resolved Hide resolved
@leon-xd leon-xd requested a review from wmmc88 January 15, 2025 19:41
)),
Some(1) => {
println!(
"WDRLocalTestCert not found in WDRTestCertStore. Generating new certificate."
Copy link
Collaborator

Choose a reason for hiding this comment

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

Does this print show up properly? I think I used eprintln for all the other prints for some reason to do with how cargo-make normally outputs things

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.

Port duckscript condition_script blocks to Rust
2 participants