From 0f694ba913171bbc50547e6771fd187e4f6a500b Mon Sep 17 00:00:00 2001 From: Andrew Jimenez Date: Mon, 22 Mar 2021 13:42:09 -0700 Subject: [PATCH 1/2] Improve Starting the VM - Attempt to Start the VM if it is not running - Reset the Count for waiting for the VM to start. Previously if you had 10 apps, and each of them triggered the count once, the script would close prematurely. --- Test Applications in HyperV.ps1 | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Test Applications in HyperV.ps1 b/Test Applications in HyperV.ps1 index 17b6a12..8784a8e 100644 --- a/Test Applications in HyperV.ps1 +++ b/Test Applications in HyperV.ps1 @@ -322,6 +322,7 @@ foreach ($instance in $Script:AppList) { $MakeCheckPoint = $false $CopyLogFiles = $false $StopLoop = $false + $Count = 0 Do { $Script:VMObject = Get-VM -Name $Script:strVMName If ($VMObject.State -eq "Running") { @@ -329,6 +330,7 @@ foreach ($instance in $Script:AppList) { $StopLoop = $true } else { + $VMObject | Start-VM Start-Sleep 10 $Count++ If ($Count -gt 10) { From e33b62ef680640e3119324c34f3c6a3cb80561bd Mon Sep 17 00:00:00 2001 From: Andrew Jimenez Date: Tue, 23 Mar 2021 13:42:00 -0700 Subject: [PATCH 2/2] Improvements - Format - Added a Counter to show progress - Save results to a csv file after completion --- Test Applications in HyperV.ps1 | 504 +++++++++++++++++++------------- 1 file changed, 306 insertions(+), 198 deletions(-) diff --git a/Test Applications in HyperV.ps1 b/Test Applications in HyperV.ps1 index 8784a8e..3b7c704 100644 --- a/Test Applications in HyperV.ps1 +++ b/Test Applications in HyperV.ps1 @@ -16,8 +16,9 @@ This needs to be run on the computer running Hyper-V! $ScriptName = $MyInvocation.MyCommand.path $Directory = Split-Path $ScriptName -$Popup = new-object -comobject wscript.shell +$Popup = New-Object -ComObject wscript.shell $Script:LogFile = "$Directory\ApplicationInstalls.log" +$Script:ResultsFile = "$Directory\ApplicationInstalls.csv" $Script:SaveCMMLogFiles = $false $Script:CreateCheckPointPerApp = $false $Script:AppList = @() @@ -29,46 +30,54 @@ $Script:SaveLogsError = $false $Script:SaveCheckPointSuccessful = $false $Script:SaveCheckPointError = $false -If(!([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltinRole]"Administrator")){ - Start-Process Powershell.exe -ArgumentList "-STA -noprofile -file `"$ScriptName`"" -Verb RunAs - Exit +If (!([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltinRole]"Administrator")) { + Start-Process Powershell.exe -ArgumentList "-STA -noprofile -file `"$ScriptName`"" -Verb RunAs + Exit } -Try { Import-Module Hyper-V } +Try { + Import-Module Hyper-V +} Catch { - $Popup.Popup("This must be run on the Hyper-V machine with the Hyper-V Cmdlets!",0,"Error",16) + $Popup.Popup("This must be run on the Hyper-V machine with the Hyper-V Cmdlets!", 0, "Error", 16) Exit } Function Log { Param ( - [Parameter(Mandatory=$false)] - $Message, + [Parameter(Mandatory = $false)] + $Message, - [Parameter(Mandatory=$false)] - $ErrorMessage, + [Parameter(Mandatory = $false)] + $ErrorMessage, - [Parameter(Mandatory=$false)] - $Component, + [Parameter(Mandatory = $false)] + $Component, - [Parameter(Mandatory=$false)] - [int]$Type, + [Parameter(Mandatory = $false)] + [int]$Type, - [Parameter(Mandatory=$true)] - $LogFile - ) -<# + [Parameter(Mandatory = $true)] + $LogFile + ) + <# Type: 1 = Normal, 2 = Warning (yellow), 3 = Error (red) #> - $Time = Get-Date -Format "HH:mm:ss.ffffff" - $Date = Get-Date -Format "MM-dd-yyyy" + $Time = Get-Date -Format "HH:mm:ss.ffffff" + $Date = Get-Date -Format "MM-dd-yyyy" - if ($ErrorMessage -ne $null) {$Type = 3} - if ($Component -eq $null) {$Component = " "} - if ($Type -eq $null) {$Type = 1} + if ($ErrorMessage -ne $null) { + $Type = 3 + } + if ($Component -eq $null) { + $Component = " " + } + if ($Type -eq $null) { + $Type = 1 + } - $LogMessage = "" - $LogMessage | Out-File -Append -Encoding UTF8 -FilePath $LogFile + $LogMessage = "" + $LogMessage | Out-File -Append -Encoding UTF8 -FilePath $LogFile $Message = "$Message - $ErrorMessage" Write-Host $Message } @@ -78,35 +87,93 @@ Function Translate-EvaluationState { $strEvaluationState = "" Switch ($EvaluationState) { - 0 { $strEvaluationState = "No state information is available." } - 1 { $strEvaluationState = "Application is enforced to desired/resolved state." } - 2 { $strEvaluationState = "Application is not required on the client." } - 3 { $strEvaluationState = "Application is available for enforcement (install or uninstall based on resolved state). Content may/may not have been downloaded." } - 4 { $strEvaluationState = "Application last failed to enforce (install/uninstall)." } - 5 { $strEvaluationState = "Application is currently waiting for content download to complete." } - 6 { $strEvaluationState = "Application is currently waiting for content download to complete." } - 7 { $strEvaluationState = "Application is currently waiting for its dependencies to download." } - 8 { $strEvaluationState = "Application is currently waiting for a service (maintenance) window." } - 9 { $strEvaluationState = "Application is currently waiting for a previously pending reboot." } - 10 { $strEvaluationState = "Application is currently waiting for serialized enforcement." } - 11 { $strEvaluationState = "Application is currently enforcing dependencies." } - 12 { $strEvaluationState = "Application is currently enforcing." } - 13 { $strEvaluationState = "Application install/uninstall enforced and soft reboot is pending." } - 14 { $strEvaluationState = "Application installed/uninstalled and hard reboot is pending." } - 15 { $strEvaluationState = "Update is available but pending installation." } - 16 { $strEvaluationState = "Application failed to evaluate." } - 17 { $strEvaluationState = "Application is currently waiting for an active user session to enforce." } - 18 { $strEvaluationState = "Application is currently waiting for all users to logoff." } - 19 { $strEvaluationState = "Application is currently waiting for a user logon." } - 20 { $strEvaluationState = "Application in progress, waiting for retry." } - 21 { $strEvaluationState = "Application is waiting for presentation mode to be switched off." } - 22 { $strEvaluationState = "Application is pre-downloading content (downloading outside of install job)." } - 23 { $strEvaluationState = "Application is pre-downloading dependent content (downloading outside of install job)." } - 24 { $strEvaluationState = "Application download failed (downloading during install job)." } - 25 { $strEvaluationState = "Application pre-downloading failed (downloading outside of install job)." } - 26 { $strEvaluationState = "Download success (downloading during install job)." } - 27 { $strEvaluationState = "Post-enforce evaluation." } - 28 { $strEvaluationState = "Waiting for network connectivity." } + 0 { + $strEvaluationState = "No state information is available." + } + 1 { + $strEvaluationState = "Application is enforced to desired/resolved state." + } + 2 { + $strEvaluationState = "Application is not required on the client." + } + 3 { + $strEvaluationState = "Application is available for enforcement (install or uninstall based on resolved state). Content may/may not have been downloaded." + } + 4 { + $strEvaluationState = "Application last failed to enforce (install/uninstall)." + } + 5 { + $strEvaluationState = "Application is currently waiting for content download to complete." + } + 6 { + $strEvaluationState = "Application is currently waiting for content download to complete." + } + 7 { + $strEvaluationState = "Application is currently waiting for its dependencies to download." + } + 8 { + $strEvaluationState = "Application is currently waiting for a service (maintenance) window." + } + 9 { + $strEvaluationState = "Application is currently waiting for a previously pending reboot." + } + 10 { + $strEvaluationState = "Application is currently waiting for serialized enforcement." + } + 11 { + $strEvaluationState = "Application is currently enforcing dependencies." + } + 12 { + $strEvaluationState = "Application is currently enforcing." + } + 13 { + $strEvaluationState = "Application install/uninstall enforced and soft reboot is pending." + } + 14 { + $strEvaluationState = "Application installed/uninstalled and hard reboot is pending." + } + 15 { + $strEvaluationState = "Update is available but pending installation." + } + 16 { + $strEvaluationState = "Application failed to evaluate." + } + 17 { + $strEvaluationState = "Application is currently waiting for an active user session to enforce." + } + 18 { + $strEvaluationState = "Application is currently waiting for all users to logoff." + } + 19 { + $strEvaluationState = "Application is currently waiting for a user logon." + } + 20 { + $strEvaluationState = "Application in progress, waiting for retry." + } + 21 { + $strEvaluationState = "Application is waiting for presentation mode to be switched off." + } + 22 { + $strEvaluationState = "Application is pre-downloading content (downloading outside of install job)." + } + 23 { + $strEvaluationState = "Application is pre-downloading dependent content (downloading outside of install job)." + } + 24 { + $strEvaluationState = "Application download failed (downloading during install job)." + } + 25 { + $strEvaluationState = "Application pre-downloading failed (downloading outside of install job)." + } + 26 { + $strEvaluationState = "Download success (downloading during install job)." + } + 27 { + $strEvaluationState = "Post-enforce evaluation." + } + 28 { + $strEvaluationState = "Waiting for network connectivity." + } } return $strEvaluationState } @@ -114,49 +181,57 @@ Function Translate-EvaluationState { Function LoadApplications { Param ($CompName) $ApplicationArray = New-Object System.Collections.ArrayList - Try { - Get-WmiObject -Query "select * from CCM_Application" -Namespace root\ccm\clientsdk -ComputerName $CompName | ForEach-Object { - $Results = Select-Object -InputObject "" Name, Installed, Required, LastEvaluated - $Results.Name = $_.Name - if ($Results.Name -ne $null) {$FoundApps = $true} - $Results.Installed = $_.InstallState - $ResolvedState = $_.ResolvedState - If ($ResolvedState -eq "Available") {$Results.Required = "False"} - else {$Results.Required = "True"} - $LastEvalTime = $_.LastEvalTime - if ($LastEvalTime -ne $null) { - $EvalTime = $_.ConvertToDateTime($_.LastEvalTime) - $Results.LastEvaluated = $EvalTime.ToShortDateString() + " " + $EvalTime.ToShortTimeString() - } - $ApplicationArray += $Results - } + Try { + Get-WmiObject -Query "select * from CCM_Application" -Namespace root\ccm\clientsdk -ComputerName $CompName | ForEach-Object { + $Results = Select-Object -InputObject "" Name, Installed, Required, LastEvaluated + $Results.Name = $_.Name + if ($Results.Name -ne $null) { + $FoundApps = $true + } + $Results.Installed = $_.InstallState + $ResolvedState = $_.ResolvedState + If ($ResolvedState -eq "Available") { + $Results.Required = "False" + } + else { + $Results.Required = "True" + } + $LastEvalTime = $_.LastEvalTime + if ($LastEvalTime -ne $null) { + $EvalTime = $_.ConvertToDateTime($_.LastEvalTime) + $Results.LastEvaluated = $EvalTime.ToShortDateString() + " " + $EvalTime.ToShortTimeString() + } + $ApplicationArray += $Results + } Log -Message "Finished loading application list!" -LogFile $LogFile - } - Catch {Log -Message "Error loading applications -" -ErrorMessage $_.Exception.Message -LogFile $LogFile} + } + Catch { + Log -Message "Error loading applications -" -ErrorMessage $_.Exception.Message -LogFile $LogFile + } return $ApplicationArray } Function LoadWPF { Param ($XAML) - Add-Type -AssemblyName PresentationFramework,PresentationCore,WindowsBase - $XMLReader = (New-Object System.Xml.XmlNodeReader $XAML) - $XAML = $XAML.OuterXML - $SplitXaml = $XAML.Split("`n") - $Script:Window = [Windows.Markup.XamlReader]::Load($XMLReader) + Add-Type -AssemblyName PresentationFramework, PresentationCore, WindowsBase + $XMLReader = (New-Object System.Xml.XmlNodeReader $XAML) + $XAML = $XAML.OuterXML + $SplitXaml = $XAML.Split("`n") + $Script:Window = [Windows.Markup.XamlReader]::Load($XMLReader) foreach ($Line in $SplitXaml) { if ($Line.ToLower().Contains("x:name")) { - $SplitLine = $Line.Split("`"") - $Count = 0 - foreach ($instance in $SplitLine) { - $Count++ - if ($instance.ToLower().Contains("x:name")) { - $ControlName = $SplitLine[$Count] + $SplitLine = $Line.Split("`"") + $Count = 0 + foreach ($instance in $SplitLine) { + $Count++ + if ($instance.ToLower().Contains("x:name")) { + $ControlName = $SplitLine[$Count] $strExpression = "`$Script:" + "$ControlName = `$Window.FindName(`"$ControlName`")" Invoke-Expression $strExpression - } - } - } + } + } + } } } @@ -222,92 +297,102 @@ Function LoadWPF { LoadWPF -XAML $XAML -$LoadApplications.Add_Click({ - $ApplicationGrid.ItemsSource = LoadApplications -CompName $ComputerName.Text -}) - -$RemoveFromList.Add_Click({ - $SelectedItems = $ApplicationList.SelectedItems - $tempAppArray = $ApplicationList.Items - $tempNewArray = @() - Foreach ($instance in $tempAppArray) { - $AddItem = $true - foreach ($item in $SelectedItems) { - if ($item -eq $instance) { $AddItem = $false } - } - if ($AddItem) { $tempNewArray += @($instance) } - } - $ApplicationList.ItemsSource = $tempNewArray -}) +$LoadApplications.Add_Click( { + $ApplicationGrid.ItemsSource = LoadApplications -CompName $ComputerName.Text + }) -$AddToList.Add_Click({ - $SelectedItems = $ApplicationGrid.SelectedItems - Foreach ($Item in $SelectedItems) { - $AddToArray = $true - Foreach ($instance in $ApplicationList.Items) { - If ($instance -eq $Item.Name) { $AddToArray = $false } +$RemoveFromList.Add_Click( { + $SelectedItems = $ApplicationList.SelectedItems + $tempAppArray = $ApplicationList.Items + $tempNewArray = @() + Foreach ($instance in $tempAppArray) { + $AddItem = $true + foreach ($item in $SelectedItems) { + if ($item -eq $instance) { + $AddItem = $false + } + } + if ($AddItem) { + $tempNewArray += @($instance) + } } - If ($AddToArray) { $ApplicationList.Items.Add($Item.Name) } - } -}) + $ApplicationList.ItemsSource = $tempNewArray + }) -$StartBtn.Add_Click({ - $Message = "Do you want to install these apps on the VM?`nNote, if you click yes the UI will go away and you can track progress in the log file and console window`n" - Foreach ($instance in $ApplicationList.Items) { - $Script:AppList += @($instance) - $Message = $Message + "`n" + $instance - } - $Answer = $Popup.Popup($Message,0,"Are you sure?",1) - if ($Answer -eq 1) { - $Script:strVMName = $VMName.Text - Switch ($ComboSaveLogs.SelectedIndex) { - 0 { - $Script:SaveLogsSuccessful = $false - $Script:SaveLogsError = $false - } - 1 { - $Script:SaveLogsSuccessful = $false - $Script:SaveLogsError = $true +$AddToList.Add_Click( { + $SelectedItems = $ApplicationGrid.SelectedItems + Foreach ($Item in $SelectedItems) { + $AddToArray = $true + Foreach ($instance in $ApplicationList.Items) { + If ($instance -eq $Item.Name) { + $AddToArray = $false + } } - 2 { - $Script:SaveLogsSuccessful = $true - $Script:SaveLogsError = $true + If ($AddToArray) { + $ApplicationList.Items.Add($Item.Name) } } - Switch ($ComboCheckPoint.SelectedIndex) { - 0 { - $Script:SaveCheckPointSuccessful = $false - $Script:SaveCheckPointError = $false + }) + +$StartBtn.Add_Click( { + $Message = "Do you want to install these apps on the VM?`nNote, if you click yes the UI will go away and you can track progress in the log file and console window`n" + Foreach ($instance in $ApplicationList.Items) { + $Script:AppList += @($instance) + $Message = $Message + "`n" + $instance + } + $Answer = $Popup.Popup($Message, 0, "Are you sure?", 1) + if ($Answer -eq 1) { + $Script:strVMName = $VMName.Text + Switch ($ComboSaveLogs.SelectedIndex) { + 0 { + $Script:SaveLogsSuccessful = $false + $Script:SaveLogsError = $false + } + 1 { + $Script:SaveLogsSuccessful = $false + $Script:SaveLogsError = $true + } + 2 { + $Script:SaveLogsSuccessful = $true + $Script:SaveLogsError = $true + } } - 1 { - $Script:SaveCheckPointSuccessful = $false - $Script:SaveCheckPointError = $true + Switch ($ComboCheckPoint.SelectedIndex) { + 0 { + $Script:SaveCheckPointSuccessful = $false + $Script:SaveCheckPointError = $false + } + 1 { + $Script:SaveCheckPointSuccessful = $false + $Script:SaveCheckPointError = $true + } + 2 { + $Script:SaveCheckPointSuccessful = $true + $Script:SaveCheckPointError = $true + } } - 2 { - $Script:SaveCheckPointSuccessful = $true - $Script:SaveCheckPointError = $true + $Script:strCompName = $ComputerName.Text + $ContinueScript = $true + try { + $Script:VMObject = Get-VM -Name $strVMName + if ($Script:VMObject -eq $null) { + $ContinueScript = $false + } } - } - $Script:strCompName = $ComputerName.Text - $ContinueScript = $true - try { - $Script:VMObject = Get-VM -Name $strVMName - if ($Script:VMObject -eq $null) { - $ContinueScript = $false + catch { + $Popup.Popup("Could not find $strVMName", 0, "Error!", 16) + } + If ($ContinueScript) { + $Window.Close() | Out-Null } } - catch { - $Popup.Popup("Could not find $strVMName",0,"Error!",16) - } - If ($ContinueScript) { - $Window.Close() | Out-Null - } - } -}) + }) $Window.ShowDialog() | Out-Null -Try { Checkpoint-VM -Name $Script:strVMName -SnapshotName "TestAppScript-Original" } +Try { + Checkpoint-VM -Name $Script:strVMName -SnapshotName "TestAppScript-Original" +} catch { Log -Message "Could not create VM checkpoint" -ErrorMessage $_.Exception.Message -LogFile $LogFile Exit @@ -315,9 +400,16 @@ catch { Log -Message "Successfully created checkpoint TestAppScript-Original" -LogFile $LogFile Log -Message "Starting install of applications" -LogFile $LogFile +$ResultsList = @() foreach ($instance in $Script:AppList) { - + $Results = [PSCustomObject]@{ + Name = $instance + Result = "" + Error = "" + } + + Log "Processing Application $($applist.indexof($instance) + 1) of $($Applist.count)" -LogFile $LogFile Log "Installing $instance" -LogFile $LogFile $MakeCheckPoint = $false $CopyLogFiles = $false @@ -340,46 +432,49 @@ foreach ($instance in $Script:AppList) { } } while ($StopLoop -ne $true) - $AppErrorCodes = 8,16,17,18,19,21,24,25, 4 - $AppInProgressCodes = 0,3,5,6,7,10,11,12,15,20,22,23,26,27,28 - $AppSuccessfulCodes = 1,2 - $AppRestartCodes = 13,14,9 + $AppErrorCodes = 8, 16, 17, 18, 19, 21, 24, 25, 4 + $AppInProgressCodes = 0, 3, 5, 6, 7, 10, 11, 12, 15, 20, 22, 23, 26, 27, 28 + $AppSuccessfulCodes = 1, 2 + $AppRestartCodes = 13, 14, 9 Try { - $WMIPath = "\\" + $Script:strCompName + "\root\ccm\clientsdk:CCM_Application" - $WMIClass = [WMIClass] $WMIPath + $WMIPath = "\\" + $Script:strCompName + "\root\ccm\clientsdk:CCM_Application" + $WMIClass = [WMIClass] $WMIPath $ApplicationID = "" $ApplicationRevision = "" $IsMachineTarget = "" - Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { - if ($_.Name -eq $instance) { - $ApplicationRevision = $_.Revision - $IsMachineTarget = $_.IsMachineTarget - $EnforcePreference = $_.EnforcePreference - $ApplicationID = $_.ID - } - } - $WMIClass.Install($ApplicationID, $ApplicationRevision, $IsMachineTarget, "", "1", $false) | Out-null + Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { + if ($_.Name -eq $instance) { + $ApplicationRevision = $_.Revision + $IsMachineTarget = $_.IsMachineTarget + $EnforcePreference = $_.EnforcePreference + $ApplicationID = $_.ID + } + } + $WMIClass.Install($ApplicationID, $ApplicationRevision, $IsMachineTarget, "", "1", $false) | Out-Null $EndLoop = $false do { $InstallState = "NotInstalled" - Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { - if ($_.Name -eq $instance) { - $InstallState = $_.InstallState + Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { + if ($_.Name -eq $instance) { + $InstallState = $_.InstallState $EvaluationState = $_.EvaluationState - } - } + } + } $TranslatedEvaluationState = Translate-EvaluationState -EvaluationState $EvaluationState If ($InstallState -eq "Installed") { $CopyLogFiles = $Script:SaveLogsSuccessful $MakeCheckPoint = $Script:SaveCheckPointSuccessful $EndLoop = $true + $Results.Result = "Success" Log "$instance - Successfully installed. Evaluation State: $TranslatedEvaluationState" -LogFile $LogFile } else { - + $Results.Result = "Failure" + If ($AppErrorCodes -contains $EvaluationState) { + $Results.Error = $TranslatedEvaluationState Log "$instance - Error installing application" -ErrorMessage $TranslatedEvaluationState -LogFile $LogFile $MakeCheckPoint = $Script:SaveCheckPointError $CopyLogFiles = $Script:SaveLogsError @@ -395,32 +490,37 @@ foreach ($instance in $Script:AppList) { shutdown /r /t 0 /m "\\$Script:strCompName" Start-Sleep 180 } - catch { Log "$instance - Error restarting computer!" -ErrorMessage $_.Exception.Message -LogFile $LogFile } + catch { + Log "$instance - Error restarting computer!" -ErrorMessage $_.Exception.Message -LogFile $LogFile + } try { Log "$instance - Starting CCMExec service so the Application install can restart" -LogFile $LogFile (Get-WmiObject -ComputerName $Script:strCompName -Query "Select * From Win32_Service where Name like 'ccmexec'").StartService() Start-Sleep 60 } - catch { Log "$instance - Error starting ccmexec on remote computer" -ErrorMessage $_.Exception.Message -LogFile $LogFile } + catch { + Log "$instance - Error starting ccmexec on remote computer" -ErrorMessage $_.Exception.Message -LogFile $LogFile + } try { Log "$instance - Triggering application install again to re-check detection method..." -LogFile $LogFile $WMIPath = "\\" + $Script:strCompName + "\root\ccm\clientsdk:CCM_Application" - $WMIClass = [WMIClass] $WMIPath + $WMIClass = [WMIClass] $WMIPath $ApplicationID = "" $ApplicationRevision = "" $IsMachineTarget = "" - Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { - if ($_.Name -eq $instance) { - $ApplicationRevision = $_.Revision - $IsMachineTarget = $_.IsMachineTarget - $EnforcePreference = $_.EnforcePreference - $ApplicationID = $_.ID - } - } - $WMIClass.Install($ApplicationID, $ApplicationRevision, $IsMachineTarget, "", "1", $false) | Out-null + Get-WmiObject -ComputerName $Script:strCompName -Query "select * from CCM_Application" -Namespace root\ccm\ClientSDK | ForEach-Object { + if ($_.Name -eq $instance) { + $ApplicationRevision = $_.Revision + $IsMachineTarget = $_.IsMachineTarget + $EnforcePreference = $_.EnforcePreference + $ApplicationID = $_.ID + } + } + $WMIClass.Install($ApplicationID, $ApplicationRevision, $IsMachineTarget, "", "1", $false) | Out-Null Start-Sleep 20 } - catch { + catch { + $Results.Error = $TranslatedEvaluationState Log "$instance - Error triggering application install" -ErrorMessage $_.Exception.Message -LogFile $LogFile $MakeCheckPoint = $Script:SaveCheckPointError $CopyLogFiles = $Script:SaveLogsError @@ -431,17 +531,20 @@ foreach ($instance in $Script:AppList) { $MakeCheckPoint = $Script:SaveCheckPointSuccessful $CopyLogFiles = $Script:SaveLogsSuccessful $EndLoop = $true + $Results.Result = "Success" + $Results.Error = "" Log "$instance - Successfully installed. Evaluation State: $TranslatedEvaluationState" -LogFile $LogFile } } } while ($EndLoop -ne $true) - } - Catch { + } + Catch { + $Results.Error = $TranslatedEvaluationState Log -Message "Error installing $AppName -" -ErrorMessage $_.Exception.Message -LogFile $LogFile $MakeCheckPoint = $Script:SaveCheckPointError $CopyLogFiles = $Script:SaveLogsError } - + $ResultsList += $Results If ($MakeCheckPoint) { Try { Log -Message "$instance - Creating checkpoint" -LogFile $LogFile @@ -449,7 +552,9 @@ foreach ($instance in $Script:AppList) { Checkpoint-VM -Name $Script:strVMName -SnapshotName $CheckpointName Log -Message "$instance - Created checkpoint!" -LogFile $LogFile } - catch { Log -Message "$instance - Error creating checkpoint" -ErrorMessage $_.Exception.Message -LogFile $LogFile } + catch { + Log -Message "$instance - Error creating checkpoint" -ErrorMessage $_.Exception.Message -LogFile $LogFile + } } if ($CopyLogFiles) { @@ -459,7 +564,9 @@ foreach ($instance in $Script:AppList) { $CopyPath = "\\" + $Script:strCompName + "\c$\windows\ccm\logs" Copy-Item $CopyPath $AppLogDirectory -Recurse -Force } - catch { Log -Message "$instance - Error copying log files!" -ErrorMessage $_.Exception.Message -LogFile $LogFile } + catch { + Log -Message "$instance - Error copying log files!" -ErrorMessage $_.Exception.Message -LogFile $LogFile + } } Try { @@ -473,6 +580,7 @@ foreach ($instance in $Script:AppList) { } } +$ResultsList | Export-Csv -Path $ResultsFile -NoTypeInformation Log -Message "Finished!" -Type 2 -LogFile $LogFile