-
Notifications
You must be signed in to change notification settings - Fork 292
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
[REVIEW please] CreateGroups additions #530
base: main
Are you sure you want to change the base?
Conversation
871c524
to
06e7fa6
Compare
15346cb
to
fc0bf93
Compare
fc0bf93
to
8dad7d5
Compare
@barnson Are there any additional integration tests that you think would be good to have beyond what I've already got in this?
I know there's a heap of code in this PR, however there's not really many easily separable portions that would be meaningful on their own. However, let me know if there's any way you can see that I could split it into more easily reviewable/pull-able portions. |
I'm not a domain expert but the tests look reasonable to me. |
53691b4
to
f507768
Compare
f507768
to
d20becc
Compare
One new test failed:
This is the test: // Verify that a group cannot be created on a domain on which you don't have create user permission.
[RuntimeFact]
public void FailsIfRestrictedDomain()
{
var productRestrictedDomain = this.CreatePackageInstaller("ProductRestrictedDomain");
string logFile = productRestrictedDomain.InstallProduct(MSIExec.MSIExecReturnCode.ERROR_INSTALL_FAILURE, "TESTDOMAIN=DOESNOTEXIST");
// Verify expected error message in the log file
Assert.True(LogVerifier.MessageInLogFile(logFile, "CreateGroup: Error 0x8007054b: failed to find Domain DOESNOTEXIST."));
} |
Thanks, it looks like it's the log error message that couldn't be found. Any chance there's a way to retrieve the log file from the Github Action? |
Not today. E2E Burn logs are captured, but MSI E2E logs are not. 😢 |
No worries. And in your recent PR to update the runner actions it looked like the master repo was exempted from exporting those artefacts to prevent secret leakage also. I just wanted to avoid a ‘works for me..’ situation. |
The |
Drats. This looks like an issue with the revised Domain->Server method. I think this GetDomainFromServerName doesn't make sense as-is... since we are explicitely given the domain. It's the domain server that we need to identify (i.e. DC01.DOMAIN / PDC.DOMAIN etc). Unsure how I skipped this test on re-basing after that PR landed though... |
Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
Local group membership Add/Remove working, however with BUILTIN local system groups .NET doesn't appear to locate them as either groups nor basic security Principals. Still needs work to fix the test for nested groups. Ideally with some way to test for domain groups. Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
Fixups to a few test cases. Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
Since there's no reason to not have them identical where practical. Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
Signed-off-by: Bevan Weiss <bevan.weiss@gmail.com>
d20becc
to
1c29f42
Compare
Fixed. I went back to the earlier GetDomainServerName() method, since this provides a usable HRESULT if the domain doesn't actually exist. |
Just a placeholder for the current state of development on the ability to add Groups. wixtoolset/issues#8577
Not sure if it works yet, splitting out the tables cost me a little more time than I anticipated, and I'm unsure that the decompile is right.
I'll build out a few more of the build test cases, to validate the expected preconditions etc (i.e. marking CreateGroup when it's not under a component, and similar).
Please raise any style / formatting issues, that way I've got the most time to address them :)
I've just noticed I've missed a couple of Wix4-.Wix6 references (around CustomAction names). I'll tidy these up tomorrow.
Closes wixtoolset/issues#8577