org.gradle.performance.results.PerformanceDatabase Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2014 the original author or authors.
*
* Licensed 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.
*/
package org.gradle.performance.results;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List;
public class PerformanceDatabase {
// This value specifies that a DB connection will stay at pool for at most 30 seconds
private static final int MAX_LIFETIME_MS = 30 * 1000;
private static final String PERFORMANCE_DB_URL_PROPERTY_NAME = "org.gradle.performance.db.url";
private final String databaseName;
private final List> databaseInitializers;
private HikariDataSource dataSource;
@SafeVarargs
public PerformanceDatabase(String databaseName, ConnectionAction... schemaInitializers) {
this.databaseName = databaseName;
this.databaseInitializers = Arrays.asList(schemaInitializers);
}
private Connection getConnection() throws SQLException {
if (dataSource == null) {
HikariConfig config = new HikariConfig();
config.setJdbcUrl(getUrl());
config.setUsername(getUserName());
config.setPassword(getPassword());
config.setMaximumPoolSize(1);
config.setMaxLifetime(MAX_LIFETIME_MS);
dataSource = new HikariDataSource(config);
executeInitializers(dataSource);
}
return dataSource.getConnection();
}
private void executeInitializers(DataSource dataSource) throws SQLException {
try (Connection connection = dataSource.getConnection()) {
for (ConnectionAction initializer : databaseInitializers) {
try {
initializer.execute(connection);
} catch (SQLException e) {
if (e.getErrorCode() == 90096) {
System.out.println("Not enough permissions to migrate the performance database. This is okay if you are only trying to read.");
} else {
throw e;
}
}
}
}
}
public static boolean isAvailable() {
return System.getProperty(PERFORMANCE_DB_URL_PROPERTY_NAME) != null;
}
public void close() {
if (dataSource != null) {
try {
dataSource.close();
} finally {
dataSource = null;
}
}
}
public T withConnection(ConnectionAction action) throws SQLException {
try (Connection connection = getConnection()) {
return action.execute(connection);
}
}
public T withConnection(String actionName, ConnectionAction action) {
try {
return withConnection(action);
} catch (SQLException e) {
throw new RuntimeException(String.format("Could not %s from datastore '%s'.", actionName, getUrl()), e);
}
}
public String getUrl() {
String baseUrl = System.getProperty(PERFORMANCE_DB_URL_PROPERTY_NAME);
if (baseUrl == null) {
throw new RuntimeException("You need to specify a URL for the performance database");
}
StringBuilder url = new StringBuilder(baseUrl);
if (!baseUrl.endsWith("/")) {
url.append('/');
}
url.append(databaseName);
return url.toString();
}
public String getUserName() {
return System.getProperty("org.gradle.performance.db.username", "sa");
}
public String getPassword() {
return System.getProperty("org.gradle.performance.db.password", "");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy