This folder contains everything you will need to build a Windows image, with the CircleCI dsc resources, on CircleCI. For more information on setting up VM service, which includes specifying your new Windows image for your users, see our VM Service guide.
The following steps will guide you through building a Windows AMI, which you can then specify in the VM Service settings for your installation of CircleCI Server, letting users of your installation run their builds in a Windows environment.
Please note Windows images are built on CircleCI, so we suggest you run through this process once your installation is up and running. Alternatively you can use any other CircleCI account – including on our managed Cloud service – to generate the image:
-
Create a new repository under your GitHub or GitHub Enterprise account.
-
Copy the contents of this repo into your new repo.
-
Open up your installation of CircleCI Server and connect your new repo by clicking Follow Project from the Add Projects page. Once you set up the project, the first build will get triggered automatically. It will fail because the AWS credentials are not configured yet — feel free to cancel the first build that gets created automatically.
-
Next, add your aws keys as env vars to the build in the CircleCI using:
- AWS_ACCESS_KEY_ID
- AWS_DEFAULT_REGION
- AWS_SECRET_ACCESS_KEY
-
Update the owner in
windows/visual-studio/packer.yaml
if you configured the keys under a different account to the once your Circleci Server installation is under. If you get any errors around not being able to find a default VPC, you will need to specify avpc_id
andsubnet_id
in this file. -
Click Rerun Workflow from the job details page to rerun the Windows image buider
-
Your will find your new Windows AMI ID at the end of the
summarize results
step in the job output
- Sets up winrm.
- Adds scripts for removing winrm when we are ready to clean up.
- Copies over ImageHelpers and CircleDSCResources to the powershell module path.
- Runs some configuration to get the machine ready to use DSC and clean up some defaults that are not helpful.
- Runs DSC and restarts the machine a few times to let it continue through the configuration process.
- Runs Pester tests to validate that the image is configured correctly. These tests are designed to ensure that all of the software is actually callable not just “installed”.
- Reenables Windows Defender and runs the virus scanner.
- Disables Windows Defender to improve performance.
- Copies: test results, the choco logs, and the software.md (a list of everything we install and test for the presence of) off of the host.
- Installs the SSH server and enables the cleanup script that runs on shutdown (check out the aws packer scripts for exactly how that works).
- Creates a Windows AMI.