Remove missing dependencies from solution XML with PowerShell
The import of the solution XYZ failed. The following components are missing in your system and are not included in the solution. Import the managed solutions that contain these components (Active) and then try importing this solution again. If you ever run into this exception and there are all the components already present in the environment you just need to get rid of few lines in a solution definition in the ZIP file you are trying to import. Do this only if you are absolutely sure that you know what you are doing. This is caused by this section of solution.xml file which is inside your solution’s ZIP file. The import wizard does not perform any check whether the component is actually present in the environment. There may be a situation when you have all the components in place and solution import should proceed without issues but the wizard throws this error. In this case you can delete dependencies from the definition. If you do it quite often or you need to make it part of your automated deployment, here is a PowerShell script just for that:
param (
[string]$zipfileName
)
$fileToEdit = "solution.xml"
$zipfileName = Resolve-Path $zipfileName
# Open zip and find the solution.xml file
Add-Type -assembly System.IO.Compression.FileSystem
$zip = [System.IO.Compression.ZipFile]::Open($zipfileName,"Update")
$solutionFile = $zip.Entries.Where({$_.name -eq $fileToEdit})
# Read the XML
$streamReader = [System.IO.StreamReader]($solutionFile).Open()
$XmlDocument = [xml]$streamReader.ReadToEnd()
$XmlDocument.PreserveWhiteSpace = $true
$streamReader.Close()
# Remove MissingDependency nodes
if ($XmlDocument.ImportExportXml.SolutionManifest.MissingDependencies -is [Xml.XmlElement]) {
$XmlDocument.ImportExportXml.SolutionManifest.MissingDependencies.MissingDependency | %{ $_.ParentNode.RemoveChild($_) | Out-Null }
}
# Overwrite the file
$streamWriter = [System.IO.StreamWriter]($solutionFile).Open()
$streamWriter.BaseStream.SetLength(0)
$streamWriter.Write($XmlDocument.OuterXml)
$streamWriter.Flush()
$streamWriter.Close()
# Close the zip file
$zip.Dispose()
You can use it like this:
- Save the script in a new file. Call it RemoveMissingDependencies.ps1 and place it to the same folder where you’re downloading your solutions.
- Open PowerShell in the folder where you downloaded your solution’s ZIP file and where you placed your script.
- Invoke this: .\RemoveMissingDependencies.ps1 YourSolution_1_0_0_0_managed.zip
- Now you can import the modified file.
UPDATE 7/6/2018: The function is included in Dynamics 365 Release Automation Tools
Comments
Missing Dependencies - managed vs unmanaged PART 2 (Microsoft Power Platform and CDS) - NETWORG | Blog
[…] we have an article here in this blog, which provides you with tooling to automatically remove missing dependencies, in case that you […]
Leo
Hello. I stumbled upon this article recently when trying to figure out why Missing Dependency lines were getting added to the Solution.xml file referencing components that were in the solution. As an example, there is an new entity that I added to the solution along with a relationship. Despite being in the solution, both components are getting listed as Missing Dependencies. I was able to unpack the solution and remove the lines from the solution.xml file, but I was wondering if you had any insight into why they were getting added in the first place. Thank you.
Sebastian
Really a super awesome tool. No more extracting, no more scrolling foretc.
To submit comments, go to GitHub Discussions.