Skip to content

Commit

Permalink
Update resource module to standard (#15)
Browse files Browse the repository at this point in the history
- Changes to xBitlocker
  - Added Codecov support.
  -  Updated appveyor.yml to use the one in template.
  - Added folders for future unit and integration tests.
  - Added Visual Studio Code formatting settings.
  - Added .gitignore file.
  - Added markdown lint rules.
  - Fixed encoding on README.md.
  - Added `PowerShellVersion = '4.0'`, and updated copyright information, in the
    module manifest.
  • Loading branch information
johlju authored May 28, 2018
1 parent f718d81 commit 9b00d76
Show file tree
Hide file tree
Showing 10 changed files with 380 additions and 113 deletions.
24 changes: 24 additions & 0 deletions .codecov.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
codecov:
notify:
require_ci_to_pass: no

comment:
layout: "reach, diff"
behavior: default

coverage:
range: 50..80
round: down
precision: 0

status:
project:
default:
# Set the overall project code coverage requirement to 70%
target: 70
patch:
default:
# Set the pull request requirement to not regress overall coverage by more than 5%
# and let codecov.io set the goal for the code changed in the patch.
target: auto
threshold: 5
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
DSCResource.Tests
.vs
.vscode
node_modules
10 changes: 10 additions & 0 deletions .markdownlint.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"default": true,
"MD029": {
"style": "one"
},
"MD013": true,
"MD024": false,
"MD034": false,
"no-hard-tabs": true
}
13 changes: 13 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
{
"powershell.codeFormatting.openBraceOnSameLine": false,
"powershell.codeFormatting.newLineAfterOpenBrace": false,
"powershell.codeFormatting.newLineAfterCloseBrace": true,
"powershell.codeFormatting.whitespaceBeforeOpenBrace": true,
"powershell.codeFormatting.whitespaceBeforeOpenParen": true,
"powershell.codeFormatting.whitespaceAroundOperator": true,
"powershell.codeFormatting.whitespaceAfterSeparator": true,
"powershell.codeFormatting.ignoreOneLineBlock": false,
"powershell.codeFormatting.preset": "Custom",
"files.trimTrailingWhitespace": true,
"files.insertFinalNewline": true
}
131 changes: 80 additions & 51 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,13 +1,32 @@
[![Build status](https://ci.appveyor.com/api/projects/status/wi5i60tojfd7056b/branch/master?svg=true)](https://ci.appveyor.com/project/PowerShell/xbitlocker/branch/master)

# xBitlocker

The **xBitlocker** module is a part of the Windows PowerShell Desired State Configuration (DSC) Resource Kit, which is a collection of DSC Resources produced by the PowerShell Team.
This module contains the **xBLAutoBitlocker, xBLBitlocker, xBLTpm** resources.
This DSC Module allows you to configure Bitlocker on a single disk, configure a TPM chip, or automatically enable Bitlocker on multiple disks.

This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [[email protected]](mailto:[email protected]) with any additional questions or comments.

## Branches

### master

[![Build status](https://ci.appveyor.com/api/projects/status/wi5i60tojfd7056b/branch/master?svg=true)](https://ci.appveyor.com/project/PowerShell/xBitlocker/branch/master)
[![codecov](https://codecov.io/gh/PowerShell/xBitlocker/branch/master/graph/badge.svg)](https://codecov.io/gh/PowerShell/xBitlocker/branch/master)

This is the branch containing the latest release -
no contributions should be made directly to this branch.

### dev

[![Build status](https://ci.appveyor.com/api/projects/status/wi5i60tojfd7056b/branch/dev?svg=true)](https://ci.appveyor.com/project/PowerShell/xBitlocker/branch/dev)
[![codecov](https://codecov.io/gh/PowerShell/xBitlocker/branch/dev/graph/badge.svg)](https://codecov.io/gh/PowerShell/xBitlocker/branch/dev)

This is the development branch
to which contributions should be proposed by contributors as pull requests.
This development branch will periodically be merged to the master branch,
and be released to [PowerShell Gallery](https://www.powershellgallery.com/).

## Contributing
Please check out common DSC Resources [contributing guidelines](https://github.com/PowerShell/DscResource.Kit/blob/master/CONTRIBUTING.md).

Expand All @@ -17,9 +36,9 @@ To install **xBitlocker** module

* Unzip the content under $env:ProgramFiles\WindowsPowerShell\Modules folder

To confirm installation:
To confirm installation:

* Run **Get-DSCResource** to see that **xBLAutoBitlocker, xBLBitlocker, xBLTpm** are among the DSC Resources listed
* Run **Get-DSCResource** to see that **xBLAutoBitlocker, xBLBitlocker, xBLTpm** are among the DSC Resources listed

## Requirements

Expand All @@ -40,68 +59,78 @@ It does not work on Operating System drives.
**xBLAutoBitlocker** has the following properties.
Where no description is listed, properties correspond directly to [Enable-Bitlocker](http://technet.microsoft.com/en-us/library/jj649837.aspx) parameters.

* *DriveType:The type of volume, as reported by Get-Volume, to auto apply Bitlocker to
* *DriveType:The type of volume, as reported by Get-Volume, to auto apply Bitlocker to
* *PrimaryProtector:The primary protector type to be used for AutoBitlocker.
Valid values are: "AdAccountOrGroupProtector", "PasswordProtector", "Pin", "RecoveryKeyProtector", "RecoveryPasswordProtector", "StartupKeyProtector", or "TpmProtector"
* MinDiskCapacityGB:If specified, only disks this size or greater will auto apply Bitlocker
* AutoUnlock:Whether volumes should be enabled for auto unlock using Enable-BitlockerAutoUnlock
* AdAccountOrGroup
* AdAccountOrGroupProtector
* EncryptionMethod
* HardwareEncryption
* Password
* PasswordProtector
* Pin
* RecoveryKeyPath
* RecoveryKeyProtector
* RecoveryPasswordProtector
* Service
* SkipHardwareTest
* StartupKeyPath
* StartupKeyProtector
* TpmProtector
* UsedSpaceOnly
Valid values are: "AdAccountOrGroupProtector", "PasswordProtector", "Pin", "RecoveryKeyProtector", "RecoveryPasswordProtector", "StartupKeyProtector", or "TpmProtector"
* MinDiskCapacityGB:If specified, only disks this size or greater will auto apply Bitlocker
* AutoUnlock:Whether volumes should be enabled for auto unlock using Enable-BitlockerAutoUnlock
* AdAccountOrGroup
* AdAccountOrGroupProtector
* EncryptionMethod
* HardwareEncryption
* Password
* PasswordProtector
* Pin
* RecoveryKeyPath
* RecoveryKeyProtector
* RecoveryPasswordProtector
* Service
* SkipHardwareTest
* StartupKeyPath
* StartupKeyProtector
* TpmProtector
* UsedSpaceOnly

**xBLBitlocker** has the following properties.
Where no description is listed, properties correspond directly to [Enable-Bitlocker](http://technet.microsoft.com/en-us/library/jj649837.aspx) parameters.

* *MountPoint:The MountPoint name as reported in Get-BitLockerVolume
* *MountPoint:The MountPoint name as reported in Get-BitLockerVolume
* *PrimaryProtector:The primary protector type to be used for AutoBitlocker.
Valid values are: "AdAccountOrGroupProtector", "PasswordProtector", "Pin", "RecoveryKeyProtector", "RecoveryPasswordProtector", "StartupKeyProtector", or "TpmProtector"
* AutoUnlock:Whether volumes should be enabled for auto unlock using Enable-BitlockerAutoUnlock
Valid values are: "AdAccountOrGroupProtector", "PasswordProtector", "Pin", "RecoveryKeyProtector", "RecoveryPasswordProtector", "StartupKeyProtector", or "TpmProtector"
* AutoUnlock:Whether volumes should be enabled for auto unlock using Enable-BitlockerAutoUnlock
* AllowImmediateReboot:Whether the computer can be immediately rebooted after enabling Bitlocker on an OS drive.
Defaults to false.

* AdAccountOrGroup
* AdAccountOrGroupProtector
* EncryptionMethod
* HardwareEncryption
* Password
* PasswordProtector
* Pin
* RecoveryKeyPath
* RecoveryKeyProtector
* RecoveryPasswordProtector
* Service
* SkipHardwareTest
* StartupKeyPath
* StartupKeyProtector
* TpmProtector
* UsedSpaceOnly
* AdAccountOrGroup
* AdAccountOrGroupProtector
* EncryptionMethod
* HardwareEncryption
* Password
* PasswordProtector
* Pin
* RecoveryKeyPath
* RecoveryKeyProtector
* RecoveryPasswordProtector
* Service
* SkipHardwareTest
* StartupKeyPath
* StartupKeyProtector
* TpmProtector
* UsedSpaceOnly

**xBLTpm** is used to initialize a TPM chip using [Initialize-TPM](http://technet.microsoft.com/en-us/library/jj603112.aspx).
**xBLTpm** has the following properties.

* *Identity:Not actually used, so could be anything
* AllowClear:Indicates that the provisioning process clears the TPM, if necessary, to move the TPM closer to complying with Windows Server® 2012 standards
* *Identity:Not actually used, so could be anything
* AllowClear:Indicates that the provisioning process clears the TPM, if necessary, to move the TPM closer to complying with Windows Server® 2012 standards
* AllowPhysicalPresence:Indicates that the provisioning process may send physical presence commands that require a user to be present in order to continue.

* AllowImmediateReboot:Whether the computer can rebooted immediately after initializing the TPM
* AllowImmediateReboot:Whether the computer can rebooted immediately after initializing the TPM

## Versions

### Unreleased

* Converted appveyor.yml to install Pester from PSGallery instead of from Chocolatey.
* Added Codecov support.
* Updated appveyor.yml to use the one in template.
* Added folders for future unit and integration tests.
* Added Visual Studio Code formatting settings.
* Added .gitignore file.
* Added markdown lint rules.
* Fixed encoding on README.md.
* Added `PowerShellVersion = '4.0'`, and updated copyright information, in the
module manifest.

### 1.1.0.0

Expand All @@ -116,10 +145,10 @@ Defaults to false.

### 1.0.0.0

* Initial release with the following resources
* xBLAutoBitlocker
* xBLBitlocker
* xBLTpm
* Initial release with the following resources
* xBLAutoBitlocker
* xBLBitlocker
* xBLTpm

## Examples

Expand All @@ -132,4 +161,4 @@ The example code for ConfigureBitlockerOnOSDrive is located in [`ConfigureBitloc

Enables Bitlocker on an Operating System drive, and automatically enables Bitlocker on all drives of type 'Fixed'.
The example code for ConfigureBitlockerAndAutoBitlocker is located in [`ConfigureBitlockerAndAutoBitlocker.ps1`](Examples/ConfigureBitlockerAndAutoBitlocker/ConfigureBitlockerAndAutoBitlocker.ps1).

26 changes: 26 additions & 0 deletions Tests/Integration/integration_template.config.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<#
.Synopsis
DSC Configuration Template for DSC Resource Integration tests.
.DESCRIPTION
To Use:
1. Copy to \Tests\Integration\ folder and rename <ResourceName>.config.ps1 (e.g. MSFT_Firewall.config.ps1)
2. Customize TODO sections.
.NOTES
#>

# Integration Test Config Template Version: 1.0.1

# TODO: Modify ResourceName (e.g. MSFT_Firewall_config)
configuration <ResourceName>_config {
# TODO: Modify ModuleName (e.g. NetworkingDsc)
Import-DscResource -ModuleName '<ModuleName>'
node localhost {
# TODO: Modify ResourceFriendlyName (e.g. Firewall_Integration_Test)
<ResourceFriendlyName> Integration_Test {
# TODO: Fill Configuration Code Here
}
}
}

# TODO: (Optional): Add More Configuration Templates
87 changes: 87 additions & 0 deletions Tests/Integration/integration_template.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
<#
.Synopsis
Template for creating DSC Resource Integration Tests
.DESCRIPTION
To Use:
1. Copy to \Tests\Integration\ folder and rename <ResourceName>.Integration.tests.ps1 (e.g. MSFT_Firewall.Integration.tests.ps1)
2. Customize TODO sections.
3. Create test DSC Configuration file <ResourceName>.config.ps1 (e.g. MSFT_Firewall.config.ps1) from integration_config_template.ps1 file.
.NOTES
Code in HEADER, FOOTER and DEFAULT TEST regions are standard and may be moved into
DSCResource.Tools in Future and therefore should not be altered if possible.
#>

# TODO: Customize these parameters...
$script:DSCModuleName = '<ModuleName>' # Example NetworkingDsc
$script:DSCResourceName = '<ResourceName>' # Example MSFT_Firewall

#region HEADER
# Integration Test Template Version: 1.2.1
[String] $script:moduleRoot = Split-Path -Parent (Split-Path -Parent $PSScriptRoot)
if ( (-not (Test-Path -Path (Join-Path -Path $script:moduleRoot -ChildPath 'DSCResource.Tests'))) -or `
(-not (Test-Path -Path (Join-Path -Path $script:moduleRoot -ChildPath 'DSCResource.Tests\TestHelper.psm1'))) )
{
& git @('clone', 'https://github.com/PowerShell/DscResource.Tests.git', (Join-Path -Path $script:moduleRoot -ChildPath 'DSCResource.Tests'))
}

Import-Module -Name (Join-Path -Path $script:moduleRoot -ChildPath (Join-Path -Path 'DSCResource.Tests' -ChildPath 'TestHelper.psm1')) -Force
$TestEnvironment = Initialize-TestEnvironment `
-DSCModuleName $script:DSCModuleName `
-DSCResourceName $script:DSCResourceName `
-TestType Integration

#endregion

# TODO: Other Init Code Goes Here...

# Using try/finally to always cleanup.
try
{
#region Integration Tests
$configFile = Join-Path -Path $PSScriptRoot -ChildPath "$($script:DSCResourceName).config.ps1"
. $configFile

Describe "$($script:DSCResourceName)_Integration" {
#region DEFAULT TESTS
It 'Should compile and apply the MOF without throwing' {
{
& "$($script:DSCResourceName)_Config" -OutputPath $TestDrive

$startDscConfigurationParameters = @{
Path = $TestDrive
ComputerName = 'localhost'
Wait = $true
Verbose = $true
Force = $true
ErrorAction = 'Stop'
}

Start-DscConfiguration @startDscConfigurationParameters
} | Should -Not -Throw
}

It 'Should be able to call Get-DscConfiguration without throwing' {
{
Get-DscConfiguration -Verbose -ErrorAction Stop
} | Should -Not -Throw
}
#endregion

It 'Should have set the resource and all the parameters should match' {
# TODO: Validate the Config was Set Correctly Here...
}
}
#endregion

}
finally
{
#region FOOTER

Restore-TestEnvironment -TestEnvironment $TestEnvironment

#endregion

# TODO: Other Optional Cleanup Code Goes Here...
}
Loading

0 comments on commit 9b00d76

Please sign in to comment.