diff options
Diffstat (limited to 'qpid/cpp/src/tests/stop_broker.ps1')
-rw-r--r-- | qpid/cpp/src/tests/stop_broker.ps1 | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/qpid/cpp/src/tests/stop_broker.ps1 b/qpid/cpp/src/tests/stop_broker.ps1 new file mode 100644 index 0000000000..4fdeb26e2b --- /dev/null +++ b/qpid/cpp/src/tests/stop_broker.ps1 @@ -0,0 +1,56 @@ +# +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# + +# Stop the broker, check for errors. +Get-Content -path qpidd.port -totalCount 1 | Set-Variable -name qpid_port +Remove-Item qpidd.port + +# Test runs from the tests directory but the broker executable is one level +# up, and most likely in a subdirectory from there based on what build type. +# Look around for it before trying to start it. +$subs = "Debug","Release","MinSizeRel","RelWithDebInfo" +foreach ($sub in $subs) { + $prog = "..\$sub\qpidd.exe" + if (Test-Path $prog) { + break + } +} +if (!(Test-Path $prog)) { + "Cannot locate qpidd.exe" + exit 1 +} + +# Piping the output makes the script wait for qpidd to finish. +Invoke-Expression "$prog --quit --port $qpid_port" | Write-Output +$stopped = $? + +# Check qpidd.log. +filter bad_stuff { + $_ -match "( warning | error | critical )" +} + +$qpidd_errors = $false +Get-Content -path qpidd.log | where { bad_stuff } | Out-Default | Set-Variable -name qpidd_errors -value $true +if ($qpidd_errors -eq $true) { + "WARNING: Suspicious broker log entries in qpidd.log, above." +} +if ($stopped -eq $true) { + exit 0 +} +exit 1 |