-
-
Notifications
You must be signed in to change notification settings - Fork 2.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Persist query performance stats (#8250)
Fixes #7694 This implementation has the following limitation: if user modifies pack_delimiter, then all pack-related data is reset. Specifically, the old data will still be in DB, and can be viewed with --database_dump, but osquery will now use the new pack_delimiter to save/retrieve the data. To fix this, a larger chunk of code needs to change to track the name of the query without the pack delimiter. I believe it is reasonable not to change pack_delimiter once set. Also, persistence will only apply to scheduled queries, and not distributed queries.
- Loading branch information
Showing
8 changed files
with
183 additions
and
27 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
/** | ||
* Copyright (c) 2014-present, The osquery authors | ||
* | ||
* This source code is licensed as defined by the LICENSE file found in the | ||
* root directory of this source tree. | ||
* | ||
* SPDX-License-Identifier: (Apache-2.0 OR GPL-2.0-only) | ||
*/ | ||
|
||
#include "osquery/core/sql/query_performance.h" | ||
#include <gtest/gtest.h> | ||
|
||
namespace osquery { | ||
|
||
class QueryPerformanceTests : public testing::Test {}; | ||
|
||
TEST_F(QueryPerformanceTests, test_query_performance) { | ||
// Default case | ||
QueryPerformance defaultStats; | ||
auto emptyStats = QueryPerformance(""); | ||
ASSERT_EQ(defaultStats, emptyStats); | ||
ASSERT_EQ("0,0,0,0,0,0,0,0,0,0,0,0", defaultStats.toCSV()); | ||
|
||
// Normal case | ||
{ | ||
QueryPerformance expected; | ||
expected.executions = 1; | ||
expected.last_executed = 2; | ||
expected.wall_time = 3; | ||
expected.wall_time_ms = 4; | ||
expected.last_wall_time_ms = 5; | ||
expected.user_time = 6; | ||
expected.last_user_time = 7; | ||
expected.system_time = 8; | ||
expected.last_system_time = 9; | ||
expected.average_memory = 10; | ||
expected.last_memory = 11; | ||
expected.output_size = 12; | ||
std::string csv = "1,2,3,4,5,6,7,8,9,10,11,12"; | ||
auto filledStats = QueryPerformance(csv); | ||
ASSERT_EQ(expected, filledStats); | ||
ASSERT_EQ(csv, expected.toCSV()); | ||
ASSERT_EQ(csv, filledStats.toCSV()); | ||
} | ||
|
||
// Invalid case | ||
{ | ||
std::string csv = "1,,bozo,4,5,6,7,8,9,10,11,12"; | ||
auto filledStats = QueryPerformance(csv); | ||
ASSERT_EQ(0, filledStats.last_executed); | ||
ASSERT_EQ(0, filledStats.wall_time); | ||
ASSERT_EQ("1,0,0,4,5,6,7,8,9,10,11,12", filledStats.toCSV()); | ||
} | ||
} | ||
|
||
} // namespace osquery |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters