The steps to create an image that has to be instantiated on a hypervisor before use:
- Validate that the image configuration is correct:
- compression_format needs to be supported
- Validate host requirements:
- DISM version
- Running as administrator
- Image exists in the WIM file
- Remove the image path or the VHD path
- Create VHD(X) and mount it
- Create the Unattend XML used for the first boot and move it to the mount point root
- Copy resources to the mounted point:
- VMware tools
- MAAS hooks
- UnattendResources folder from the repo
- Custom resources defined by the user
- Configuration file
- Windows wallpaper GPO
- zapfree
- cloudbase-init
- Expand the WIM file to the mount point
- Apply boot configuration according to the disk layout (BIOS or UEFI)
- Customization:
- Enable extra features or capabilites
- Add extra packages
- Apply VirtIO drivers from Fedora or other drivers
- Unmount VHD and convert it to the desired disk format
- Compress the image file
The steps to create a fully functional image:
- Validate that the image configuration is correct:
- If the desired image is a golden, the path should be a VHD(X)
- Validate host requirements:
- Running as administrator
- If sysprep is not run then force flag needs to set to true
- Checks if HyperV is installed
- An external switch exists and is external
- If there are enough CPUs
- Remove the image path or the VHD path
- Create a different config file from the initial one for running New-WindowsCloudImage:
- image_path is changed to the VHDx one
- zip_password is removed
- virtual_disk_format is set to VHDX
- Run New-WindowsCloudImage with the config file generated at the previous step
- Create a Windows HyperV virtual machine with the VHDx generated at the previous step
- Start the VM and wait for it to stop running and remove the VM
- Shrink the VHD to the minimum size
- Convert VHD to the desired format using qemu-img bundled in the repo
- Compress the image file