AutomatedLab (AL) enables you to setup test and lab environments on Hyper-v or Azure with multiple products or just a single VM in a very short time. There are only two requirements you need to make sure: You need the DVD ISO images and a Hyper-V host or an Azure subscription.
Apart from the module itself your system needs to meet the following requirements:Windows Management Framework 5+ (Windows) .NET 4.7.1 (Windows PowerShell) or .NET Core 2.x (PowerShell 6+) Windows Server 2012 R2+/Windows 8.1+ (Hyper-V, Azure) or Linux (Azure) Recommended OS language is en-us Admin privileges are required ISO files for all operating systems and roles to be deployed Intel VT-x or AMD/V capable CPU A decent amount of RAM Low-Latency high-throughput storage (No spinning disks please, as there are issues related to them)
WindowsWindows Management Framework 5+ Windows Server 2012 R2+/Windows 8.1+ Recommended OS language is en-us Admin privileges are required
LinuxWSL supported, Azure Cloud Shell supported Tested on Fedora and Ubuntu, should run on any system capable of running PowerShell PowerShell 6+ gss-ntlmssp to enable remoting (mandatory - no remoting, no way for AutomatedLab to do its thing) ip and route commands available Azure subscription - At the moment, AutomatedLab only works using Azure. KVM is planned for a later date.
There are two options installing AutomatedLab:You can use the MSI installer published on GitHub. Or you install from the PowerShell Gallery using the cmdlet Install-Module. Please refer to the wiki for some details.
This solution supports setting up virtual machines with the following productsWindows 7, 2008 R2, 8 / 8.1 and 2012 / 2012 R2, 10 / 2016, 2019 SQL Server 2008, 2008R2, 2012, 2014, 2016, 2017, 2019 Visual Studio 2012, 2013, 2015 Team Foundation Services 2018, Azure DevOps Server Exchange 2013, 2016, 2019 System Center Orchestrator 2012 System Center Operations Manager 2019 System Center Service Manager 2019 Microsoft Endpoint Manager Configuration Manager 1902 (and newer) MDT ProGet (Private PowerShell Gallery) Office 2013, 2016, 2019 DSC Pull Server (with SQL Reporting)
Feature ListAutomatedLab (AL) makes the setup of labs extremely easy. Setting up a lab with just a single machine is only 3 lines. And even complex labs can be defined with about 100 lines (see sample scripts). Labs on Azure can be connected to each other or connected to a Hyper-V lab using a single command. AL can be used to setup scenarios to demo a PowerShell Gallery using Inedo ProGet, PowerShell DSC Pull Server scenarios, ADFS or a lab with 3 Active Directory forests trusting each other. Create, restore and remove snapshots of some or all lab machines with one cmdlet (Checkpoint-LabVM, Restore-LabVMSnapshot, Remove-LabVMSnapshot). Install Windows Features on one, some or all lab machines with one line of code (Install-LabWindowsFeature). Install software to a bunch of lab machines with just one cmdlet (Install-LabSoftwarePackages). You only need to know the argument to make the MSI or EXE go into silent installation mode. This can also work in parallel thanks to PowerShell workflows. Run any custom activity (Script or ScriptBlock) on a number of lab machines (Invoke-LabCommand). You do not have to care about credentials or double-hop authentication issues as CredSsp is always enabled and can be used with the UseCredSsp switch. Creating a virtual environment that is connected to the internet was never easier. The only requirements are defining an external facing virtual switch and a machine with two network cards that acts as the router. AL takes care about all the configuration details like setting the gateway on all machines and also the DNS settings (see introduction script 05 Single domain-joined server (internet facing).ps1). AL offers offline patching with a single command. As all machines a based on one disk per OS, it is much more efficient to patch the ISO files that are used to create the base images (Update-LabIsoImage). See script 11 ISO Offline Patching.ps1 for more details. If a lab is no longer required, one command is enough to remove everything to be ready to start from scratch (Remove-Lab)