Merge pull request #824 from yuslepukhin/try_ci_tests_on_daily
Try running db_test during integration build
This commit is contained in:
commit
2391b459b8
@ -383,7 +383,7 @@ set(TESTS
|
|||||||
utilities/geodb/geodb_test.cc
|
utilities/geodb/geodb_test.cc
|
||||||
utilities/memory/memory_test.cc
|
utilities/memory/memory_test.cc
|
||||||
utilities/merge_operators/string_append/stringappend_test.cc
|
utilities/merge_operators/string_append/stringappend_test.cc
|
||||||
utilities/options_util_test.cc
|
utilities/options/options_util_test.cc
|
||||||
utilities/redis/redis_lists_test.cc
|
utilities/redis/redis_lists_test.cc
|
||||||
utilities/spatialdb/spatial_db_test.cc
|
utilities/spatialdb/spatial_db_test.cc
|
||||||
utilities/table_properties_collectors/compact_on_deletion_collector_test.cc
|
utilities/table_properties_collectors/compact_on_deletion_collector_test.cc
|
||||||
|
@ -2,10 +2,14 @@ version: 1.0.{build}
|
|||||||
before_build:
|
before_build:
|
||||||
- md %APPVEYOR_BUILD_FOLDER%\build
|
- md %APPVEYOR_BUILD_FOLDER%\build
|
||||||
- cd %APPVEYOR_BUILD_FOLDER%\build
|
- cd %APPVEYOR_BUILD_FOLDER%\build
|
||||||
- cmake -G "Visual Studio 12 Win64" ..
|
- cmake -G "Visual Studio 12 Win64" -DOPTDBG=1 ..
|
||||||
- cd ..
|
- cd ..
|
||||||
build:
|
build:
|
||||||
project: build\rocksdb.sln
|
project: build\rocksdb.sln
|
||||||
parallel: true
|
parallel: true
|
||||||
verbosity: minimal
|
verbosity: minimal
|
||||||
test: off
|
test:
|
||||||
|
test_script:
|
||||||
|
- ps: build_tools\run_ci_db_test.ps1 -EnableRerun -Run db_test -Exclude DBTest.Randomized -Concurrency 16
|
||||||
|
- ps: build_tools\run_ci_db_test.ps1 -Run env_test -Concurrency 1
|
||||||
|
|
||||||
|
@ -1,22 +0,0 @@
|
|||||||
version: 1.0.{build}
|
|
||||||
before_build:
|
|
||||||
- md %APPVEYOR_BUILD_FOLDER%\build
|
|
||||||
- cd %APPVEYOR_BUILD_FOLDER%\build
|
|
||||||
- cmake -G "Visual Studio 12 Win64" -DOPTDBG=1 ..
|
|
||||||
- cd ..
|
|
||||||
build:
|
|
||||||
project: build\rocksdb.sln
|
|
||||||
parallel: true
|
|
||||||
verbosity: minimal
|
|
||||||
test:
|
|
||||||
test_script:
|
|
||||||
- ps: build_tools\run_ci_db_test.ps1
|
|
||||||
notifications:
|
|
||||||
- provider: Email
|
|
||||||
to:
|
|
||||||
- svmtrocksdb@microsoft.com
|
|
||||||
subject: "Build {{status}}"
|
|
||||||
message: "{{message}}, {{commitId}}, ..."
|
|
||||||
on_build_success: false
|
|
||||||
on_build_failure: true
|
|
||||||
on_build_status_changed: true
|
|
@ -5,13 +5,15 @@
|
|||||||
# Run the script from the enlistment
|
# Run the script from the enlistment
|
||||||
Param(
|
Param(
|
||||||
[switch]$EnableJE = $false, # Use je executable
|
[switch]$EnableJE = $false, # Use je executable
|
||||||
|
[switch]$EnableRerun = $false, # Rerun failed tests sequentially at the end
|
||||||
[string]$WorkFolder = "", # Direct tests to use that folder
|
[string]$WorkFolder = "", # Direct tests to use that folder
|
||||||
[int]$Limit = -1, # -1 means run all otherwise limit for testing purposes
|
[int]$Limit = -1, # -1 means run all otherwise limit for testing purposes
|
||||||
[string]$Exclude = "", # Expect a comma separated list, no spaces
|
[string]$Exclude = "", # Expect a comma separated list, no spaces
|
||||||
[string]$Run = "db_test", # Run db_test|tests
|
[string]$Run = "db_test", # Run db_test|tests|testname1,testname2...
|
||||||
# Number of async tasks that would run concurrently. Recommend a number below 64.
|
# Number of async tasks that would run concurrently. Recommend a number below 64.
|
||||||
# However, CPU utlization really depends on the storage media. Recommend ram based disk.
|
# However, CPU utlization really depends on the storage media. Recommend ram based disk.
|
||||||
[int]$Concurrency = 62
|
# a value of 1 will run everything serially
|
||||||
|
[int]$Concurrency = 16
|
||||||
)
|
)
|
||||||
|
|
||||||
# Folders and commands must be fullpath to run assuming
|
# Folders and commands must be fullpath to run assuming
|
||||||
@ -52,7 +54,7 @@ if($EnableJE) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Write-Output "Root: $RootFolder, WorkFolder: $WorkFolder"
|
Write-Output "Root: $RootFolder, WorkFolder: $WorkFolder"
|
||||||
Write-Output "Binaries: $BinariesFolder exe: $db_test"
|
Write-Output "Binaries: $BinariesFolder db_test: $db_test"
|
||||||
|
|
||||||
#Exclusions that we do not want to run
|
#Exclusions that we do not want to run
|
||||||
$ExcludeTests = New-Object System.Collections.Generic.HashSet[string]
|
$ExcludeTests = New-Object System.Collections.Generic.HashSet[string]
|
||||||
@ -60,7 +62,7 @@ $ExcludeTests = New-Object System.Collections.Generic.HashSet[string]
|
|||||||
|
|
||||||
if($Exclude -ne "") {
|
if($Exclude -ne "") {
|
||||||
Write-Host "Exclude: $Exclude"
|
Write-Host "Exclude: $Exclude"
|
||||||
$l = $Exclude -split ','
|
$l = $Exclude -split ' '
|
||||||
ForEach($t in $l) { $ExcludeTests.Add($t) | Out-Null }
|
ForEach($t in $l) { $ExcludeTests.Add($t) | Out-Null }
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,41 +121,60 @@ function Normalize-DbTests($HashTable) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# The function removes trailing .exe siffix if any,
|
||||||
|
# creates a name for the log file
|
||||||
|
function MakeAndAdd([string]$token, $HashTable) {
|
||||||
|
$test_name = $token -replace '.exe$', ''
|
||||||
|
$log_name = -join ($test_name, ".log")
|
||||||
|
if(!$ExcludeTests.Contains($test)) {
|
||||||
|
$HashTable.Add($test_name, $log_name)
|
||||||
|
} else {
|
||||||
|
Write-Warning "Test $test_name is excluded"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# The function scans build\Debug folder to discover
|
# The function scans build\Debug folder to discover
|
||||||
# Test executables. It then populates a table with
|
# Test executables. It then populates a table with
|
||||||
# Test executable name -> Log file
|
# Test executable name -> Log file
|
||||||
function Discover-TestBinaries($HashTable) {
|
function Discover-TestBinaries([string]$Pattern, $HashTable) {
|
||||||
|
|
||||||
$Exclusions = @("db_test*", "db_sanity_test*")
|
$Exclusions = @("db_test*", "db_sanity_test*")
|
||||||
if($EnableJE) {
|
|
||||||
$p = -join ($BinariesFolder, "*_test_je.exe")
|
$p = -join ($BinariesFolder, $pattern)
|
||||||
} else {
|
|
||||||
$p = -join ($BinariesFolder, "*_test.exe")
|
Write-Host "Path: $p"
|
||||||
}
|
|
||||||
|
|
||||||
dir -Path $p -Exclude $Exclusions | ForEach-Object {
|
dir -Path $p -Exclude $Exclusions | ForEach-Object {
|
||||||
$t = ($_.Name) -replace '.exe$', ''
|
MakeAndAdd -token ($_.Name) -HashTable $HashTable
|
||||||
if($ExcludeTests.Contains($t)) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
$test_log = -join ($t, ".log")
|
|
||||||
$HashTable.Add($t, $test_log)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$TestToLog = [ordered]@{}
|
$TestsToRun = [ordered]@{}
|
||||||
|
|
||||||
if($Run -ceq "db_test") {
|
if($Run -ceq "db_test") {
|
||||||
Normalize-DbTests -HashTable $TestToLog
|
Normalize-DbTests -HashTable $TestsToRun
|
||||||
} elseif($Run -ceq "tests") {
|
} elseif($Run -ceq "tests") {
|
||||||
Discover-TestBinaries -HashTable $TestToLog
|
if($EnableJE) {
|
||||||
|
$pattern = "*_test_je.exe"
|
||||||
} else {
|
} else {
|
||||||
Write-Warning "Invalid -Run option value"
|
$pattern = "*_test.exe"
|
||||||
exit 2
|
}
|
||||||
|
Discover-TestBinaries -Pattern $pattern -HashTable $TestsToRun
|
||||||
|
} else {
|
||||||
|
|
||||||
|
$test_list = $Run -split ' '
|
||||||
|
|
||||||
|
ForEach($t in $test_list) {
|
||||||
|
MakeAndAdd -token $t -HashTable $TestsToRun
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$NumTestsToStart = $TestsToRun.Count
|
||||||
|
if($Limit -ge 0 -and $NumTestsToStart -gt $Limit) {
|
||||||
|
$NumTestsToStart = $Limit
|
||||||
|
}
|
||||||
|
|
||||||
Write-Host "Attempting to start: " ($TestToLog.Count) " tests"
|
Write-Host "Attempting to start: $NumTestsToStart tests"
|
||||||
|
|
||||||
# Invoke a test with a filter and redirect all output
|
# Invoke a test with a filter and redirect all output
|
||||||
$InvokeTestCase = {
|
$InvokeTestCase = {
|
||||||
@ -167,20 +188,28 @@ $InvokeTestAsync = {
|
|||||||
&$exe > $log 2>&1
|
&$exe > $log 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
$jobs = @()
|
# Hash that contains tests to rerun if any failed
|
||||||
$JobToLog = @{}
|
# Those tests will be rerun sequentially
|
||||||
|
$Rerun = [ordered]@{}
|
||||||
# Test limiting factor here
|
# Test limiting factor here
|
||||||
$count = 0
|
$count = 0
|
||||||
|
# Overall status
|
||||||
[bool]$success = $true;
|
[bool]$success = $true;
|
||||||
|
|
||||||
|
function RunJobs($TestToLog, [int]$ConcurrencyVal, [bool]$AddForRerun)
|
||||||
|
{
|
||||||
|
# Array to wait for any of the running jobs
|
||||||
|
$jobs = @()
|
||||||
|
# Hash JobToLog
|
||||||
|
$JobToLog = @{}
|
||||||
|
|
||||||
# Wait for all to finish and get the results
|
# Wait for all to finish and get the results
|
||||||
while(($JobToLog.Count -gt 0) -or
|
while(($JobToLog.Count -gt 0) -or
|
||||||
($TestToLog.Count -gt 0)) {
|
($TestToLog.Count -gt 0)) {
|
||||||
|
|
||||||
# Make sure we have maximum concurrent jobs running if anything
|
# Make sure we have maximum concurrent jobs running if anything
|
||||||
# and the $Limit either not set or allows to proceed
|
# and the $Limit either not set or allows to proceed
|
||||||
while(($JobToLog.Count -lt $Concurrency) -and
|
while(($JobToLog.Count -lt $ConcurrencyVal) -and
|
||||||
(($TestToLog.Count -gt 0) -and
|
(($TestToLog.Count -gt 0) -and
|
||||||
(($Limit -lt 0) -or ($count -lt $Limit)))) {
|
(($Limit -lt 0) -or ($count -lt $Limit)))) {
|
||||||
|
|
||||||
@ -240,7 +269,7 @@ while(($JobToLog.Count -gt 0) -or
|
|||||||
|
|
||||||
if(($l -match "^\[\s+PASSED") -or
|
if(($l -match "^\[\s+PASSED") -or
|
||||||
($l -match " : PASSED$") -or
|
($l -match " : PASSED$") -or
|
||||||
($l -match "^PASSED") -or
|
($l -match "^PASS$") -or # Special c_test case
|
||||||
($l -match "Passed all tests!") ) {
|
($l -match "Passed all tests!") ) {
|
||||||
$pass_found = $true
|
$pass_found = $true
|
||||||
}
|
}
|
||||||
@ -250,6 +279,9 @@ while(($JobToLog.Count -gt 0) -or
|
|||||||
$success = $false;
|
$success = $false;
|
||||||
Write-Warning $message
|
Write-Warning $message
|
||||||
$log_content | Write-Warning
|
$log_content | Write-Warning
|
||||||
|
if($AddForRerun) {
|
||||||
|
MakeAndAdd -token $completed.Name -HashTable $Rerun
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
Write-Host $message
|
Write-Host $message
|
||||||
}
|
}
|
||||||
@ -259,9 +291,20 @@ while(($JobToLog.Count -gt 0) -or
|
|||||||
# Should be no output
|
# Should be no output
|
||||||
Receive-Job -Job $completed | Out-Null
|
Receive-Job -Job $completed | Out-Null
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RunJobs -TestToLog $TestsToRun -ConcurrencyVal $Concurrency -AddForRerun $EnableRerun
|
||||||
|
|
||||||
|
if($Rerun.Count -gt 0) {
|
||||||
|
Write-Host "Rerunning " ($Rerun.Count) " tests sequentially"
|
||||||
|
$success = $true
|
||||||
|
$count = 0
|
||||||
|
RunJobs -TestToLog $Rerun -ConcurrencyVal $Concurrency -AddForRerun $false
|
||||||
|
}
|
||||||
|
|
||||||
Get-Date
|
Get-Date
|
||||||
|
|
||||||
|
|
||||||
if(!$success) {
|
if(!$success) {
|
||||||
# This does not succeed killing off jobs quick
|
# This does not succeed killing off jobs quick
|
||||||
# So we simply exit
|
# So we simply exit
|
||||||
|
Loading…
Reference in New Issue
Block a user