From f2dfe7a4743d8a6624184564aa48f256b4581849 Mon Sep 17 00:00:00 2001 From: onyx-and-iris <75868496+onyx-and-iris@users.noreply.github.com> Date: Sat, 18 Jun 2022 14:00:34 +0100 Subject: [PATCH] pre-commit.ps1 for use with git-hook added --- tests/pre-commit.ps1 | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 tests/pre-commit.ps1 diff --git a/tests/pre-commit.ps1 b/tests/pre-commit.ps1 new file mode 100644 index 0000000..98394ff --- /dev/null +++ b/tests/pre-commit.ps1 @@ -0,0 +1,31 @@ +Function RunTests { + $coverage = "./tests/pytest_coverage.log" + $run_tests = "pytest -v --capture=tee-sys --junitxml=./tests/.coverage.xml" + $match_pattern = "^=|^\s*$|^Running|^Using|^plugins|^collecting|^tests" + + if ( Test-Path $coverage ) { Clear-Content $coverage } + + ForEach ($line in $(Invoke-Expression $run_tests)) { + If ( $line -Match $match_pattern ) { + if ( $line -Match "^Running tests for kind \[(\w+)\]" ) { $kind = $Matches[1] } + $line | Tee-Object -FilePath $coverage -Append + } + } + Write-Output "$(Get-TimeStamp)" | Out-file $coverage -Append + + Invoke-Expression "genbadge tests -t 90 -i ./tests/.coverage.xml -o ./tests/$kind.svg" +} + +Function Get-TimeStamp { + + return "[{0:MM/dd/yy} {0:HH:mm:ss}]" -f (Get-Date) + +} + +if ($MyInvocation.InvocationName -ne ".") { + Invoke-Expression ".\.venv\Scripts\Activate.ps1" + + RunTests + + Invoke-Expression "deactivate" +}