Skip to content

Commit

Permalink
[regression-test](case) do statistics table compaction before quit re…
Browse files Browse the repository at this point in the history
…gression tests (#36611)

## Proposed changes
In regression, we will check whether there are pipeline tasks after all
test cases were finished.
But in regression-tests, creating and dropping tables are frequency
operations, which will cause multiple delete predicater in statistics
table rowsets, which will cause statistics operations running slowly.
This pr will try to do a full compaction in statitics in nonConccurent
mode, try to solve the problem.

Issue Number: close #xxx

<!--Describe your changes.-->
  • Loading branch information
shuke987 authored Jun 21, 2024
1 parent 28f7ed3 commit 909c554
Showing 1 changed file with 70 additions and 0 deletions.
70 changes: 70 additions & 0 deletions regression-test/suites/pipeline_p0/statitics_compaction.groovy
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
// 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.

suite("statistic_table_compaction", "nonConcurrent,p0") {
def backendId_to_backendIP = [:]
def backendId_to_backendHttpPort = [:]
getBackendIpHttpPort(backendId_to_backendIP, backendId_to_backendHttpPort);

def do_compaction = { String table ->
try {
def tablets = sql_return_maparray """show tablets from ${table}"""

// trigger compactions for all tablets in ${tableName}
for (def tablet in tablets) {
String tablet_id = tablet.TabletId
String backend_id = tablet.BackendId
def (code, out, err) = be_run_full_compaction(backendId_to_backendIP.get(backend_id), backendId_to_backendHttpPort.get(backend_id), tablet_id)
logger.info("Run compaction: code=" + code + ", out=" + out + ", err=" + err)
assertEquals(code, 0)
def compactJson = parseJson(out.trim())
assertEquals("success", compactJson.status.toLowerCase())
}

Integer counter = 600

// wait for all compactions done
for (def tablet in tablets) {
boolean running = true
do {
counter -= 1
Thread.sleep(1000)
String tablet_id = tablet.TabletId
String backend_id = tablet.BackendId
def (code, out, err) = be_get_compaction_status(backendId_to_backendIP.get(backend_id), backendId_to_backendHttpPort.get(backend_id), tablet_id)
logger.info("Get compaction status: code=" + code + ", out=" + out + ", err=" + err)
assertEquals(code, 0)
def compactionStatus = parseJson(out.trim())
assertEquals("success", compactionStatus.status.toLowerCase())
running = compactionStatus.run_status
} while (running && counter > 0)
}

assertTrue(counter >= 0)
} catch (Exception e) {
logger.info(e.getMessage())
if (e.getMessage().contains("Unknown table")) {
return
} else {
throw e
}
}
}

do_compaction("__internal_schema.column_statistics")
do_compaction("__internal_schema.histogram_statistics")
}

0 comments on commit 909c554

Please sign in to comment.