This repository contains a PowerShell module with DSC resources that can be used to install and configure an Octopus Deploy Server and Tentacle agent.
Read about the cTentacleAgent or cOctopusServer resources.
Authentication can be configured to use:
- Active Directory Domain with cOctopusServerActiveDirectoryAuthentication
- Azure AD with cOctopusServerAzureADAuthentication
- GoogleApps with cOctopusServerGoogleAppsAuthentication
- Username/passwords stored in Octopus with cOctopusServerUsernamePasswordAuthentication
This project is setup to use Vagrant to provide a dev/test environment. Once you've installed Vagrant, you can use build-virtualbox.sh to spin up a local virtual machine using VirtualBox and run the test scenarios (NOTE: The first time you run vagrant up
it has to download the octopusdeploy/dsc-test-server
box and this can take some time depending on your Internet speed, so be patient and go grab a coffee while it downloads). On a build server, you most likely want to use build-aws.sh to spin up a virtual machine on AWS to run the tests.
Configuration is handled by environment variables. The shell scripts will show a message letting you know what variables need to be set.
As there are no windows specific build scripts at present, if you want to run the tests against AWS on windows:
- Install Vagrant from vagrantup.com
- Install VirtualBox from virtualbox.org
- If you are on a Mac or Linux you need to install PowerShell, see https://github.com/PowerShell/PowerShell/blob/master/docs/installation/linux.md.
- If you want to test locally using virtualbox
- Run
vagrant plugin install vagrant-dsc
- Run
vagrant plugin install vagrant-winrm
- Run
vagrant plugin install vagrant-winrm-syncedfolders
- Run
vagrant up -- provider virtualbox
. This will run all the scenarios under the Tests folder.
- Run
- If you want to test using AWS
- Run
vagrant plugin install vagrant-aws
- Run
vagrant plugin install vagrant-aws-winrm
- Set an environment variable
AWS_ACCESS_KEY_ID
to a valid value - Set an environment variable
AWS_SECRET_ACCESS_KEY
to a valid value - Set an environment variable
AWS_SUBNET_ID
to a valid subnet where you want the instance launched - Set an environment variable
AWS_SECURITY_GROUP_ID
to a valid security group you want to assign to the instance - Run
vagrant up --provider aws
. This will run all the scenarios under the Tests folder.
- Run
- Run
vagrant destroy -f
once you have finished to kill the virtual machine.
Tests are written in ServerSpec, which is an infrastructure oriented layer over RSpec.
When creating a PR, please ensure that all existing tests run succesfully against VirtualBox, and please include a new scenario where possible. Before you start, please raise an issue to discuss your plans so we can make sure it fits with the goals of the project.