用于EagleEye3.0 规则集漏报和误报测试的示例项目,项目收集于github和gitee
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.7 KiB

5 months ago
// Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License, version 2.0,
// as published by the Free Software Foundation.
//
// This program is also distributed with certain software (including
// but not limited to OpenSSL) that is licensed under separate terms,
// as designated in a particular file or component or in included license
// documentation. The authors of MySQL hereby grant you an additional
// permission to link the program and your derivative works with the
// separately licensed software that they have included with MySQL.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License, version 2.0, for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#include "client/mysqltest/utils.h"
#include <cstring>
#include <iostream>
#include <stdexcept>
/// Run a query and return one field in the result set from the first
/// row and column.
///
/// @param mysql mysql handle
/// @param query Query string
/// @param column Column value
/// @param str String object to store the rvalue
///
/// @retval True if fails to get the value, true otherwise.
bool query_get_string(MYSQL *mysql, const char *query, int column,
std::string *str) {
MYSQL_RES *res = NULL;
MYSQL_ROW row;
if (mysql_query(mysql, query)) {
mysql_free_result(res);
return true;
}
if (((res = mysql_store_result(mysql)) == NULL) ||
((row = mysql_fetch_row(res)) == NULL)) {
mysql_free_result(res);
str = 0;
return true;
}
str->assign(row[column] ? row[column] : "NULL");
mysql_free_result(res);
return false;
}
/// Use stoi function to get the integer value from a string.
///
/// @param str String which may contain an integer or an alphanumeric
/// string.
///
/// @retval Integer value corresponding to the contents of the string,
/// if conversion is successful, or -1 if integer is out of
/// range, or if the conversion fails.
int get_int_val(const char *str) {
int value;
std::size_t size;
try {
value = std::stoi(str, &size, 10);
if (size != std::strlen(str)) value = -1;
} catch (const std::out_of_range &) {
std::fprintf(stderr, "Integer value '%s' is out of range. ", str);
value = -1;
} catch (const std::invalid_argument &) {
value = -1;
}
return value;
}