- Windows PowerShell 4+ or PowerShell Core
- Git - for cloning and pushing changes
- Pester - PS module for running unit tests
- PSScriptAnalyzer - PS module to check code formatting
- PlatyPS - PS module to update documentation
- Psake - PS module for build automation
- Text editor or IDE that supports EditorConfig (e.g. Visual Studio Code)
- VirtualBox - Virtualisation platform used by Vagrant and Test Kitchen
- Vagrant - Used to automate the build of VMs used for integration testing
- Test Kitchen - Used to automate the integration testing process
- Fork it ( https://github.com/ahaydon/Qlik-Cli-Windows/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- docs - markdown documentation generated by PlatyPS
- functions - scripts containing internal functions
- resources - scripts containing exported commands
- tests - Pester test scripts
Before making a pull request you should check that your code changes will pass the automated checks, this will help to prevent you request being rejected.
- Run unit tests
Invoke-Pester
- Check your code conforms to best practices
Invoke-ScriptAnalyzer -Path . -Recurse -ReportSummary
- Check your code meets the code formatting standards of this repo
Invoke-ScriptAnalyzer -Path . -Recurse -ReportSummary -Settings CodeFormatting -ExcludeRule PSAlignAssignmentStatement
- Ensure documentation is up to date, if you have Psake installed you can run
Invoke-Psake UpdateDocs
, otherwise run the following:
Remove-Module Qlik-Cli; Import-Module ./Qlik-Cli.psd1 -Force
Update-MarkdownHelpModule -Path ./docs -RefreshModulePage -ModulePagePath ./docs/index.md -UpdateInputOutput -Force
- Update the markdown help files by adding descriptions and examples for any cmdlet that you have added or changed
A Vagrantfile is provided that will build a machine running Docker and CircleCI CLI, this machine can be used to test CI configs.
vagrant up
vagrant ssh
cd /vagrant
circleci local execute --job test-unit
circleci local execute --job quality-check
To override the box used for a platform add the following to a file called kitchen.local.yml and set the box you want to use.
platforms:
- name: windows-2019
driver:
box: my/windows-2019
To prevent the need to download Qlik Sense every time the instances are rebuilt you can mount the cache folder to the host machine.
Adding the following code to the Kitchen config ($HOME/.kitchen/config.yml
) will mount the cache directory on all instances.
driver:
name: vagrant
synced_folders:
- ["<%= ENV['HOME'] %>/.kitchen/cache", "C:\kitchen-cache"]
kitchen create
kitchen converge
kitchen verify
kitchen destroy