All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.quickperf.sql.connection.ConnectionProfiler Maven / Gradle / Ivy

/*
 * 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.
 *
 * Copyright 2019-2021 the original author or authors.
 */

package org.quickperf.sql.connection;

import org.quickperf.sql.connection.stack.StackTraceDisplayConfig;
import org.quickperf.sql.connection.stack.StackTracerPrinter;

import java.io.PrintWriter;
import java.sql.Connection;

public class ConnectionProfiler {

    private final StackTraceDisplayConfig stacktracedisplayConfig;

    private final PrintWriter printWriter;

    private final StackTracerPrinter stackTracerPrinter;

    private boolean enabled;

    ConnectionProfiler( StackTraceDisplayConfig stacktracedisplayConfig
                      , PrintWriter printWriter) {
        this.stacktracedisplayConfig = stacktracedisplayConfig;
        this.printWriter = printWriter;
        this.stackTracerPrinter =
                new StackTracerPrinter(printWriter);
    }

    void enables() {
        enabled = true;
    }

    void disables() {
        enabled = false;
    }

    void profile(Connection connection, String eventDescription) {
        if (enabled) {
            printConnectionEvent(connection, eventDescription);
            if(stacktracedisplayConfig.isStackTraceDisplayed()) {
                printStackTrace();
            }
        }
    }

    private void printConnectionEvent(Connection connection, String eventDescription) {
        String connectionDescription = buildConnectionDescription(connection);
        String eventText = connectionDescription + " - " + eventDescription;
        printWriter.println(eventText);
        printWriter.flush();
    }

    private void printStackTrace() {
        StackTraceElement[] currentStackTrace = findCurrentStackTrace();
        StackTraceElement[] stackTraceToDisplay
                = stacktracedisplayConfig.format(currentStackTrace);
        stackTracerPrinter.printStackTrace(stackTraceToDisplay);
    }

    private StackTraceElement[] findCurrentStackTrace() {
        Thread currentThead = Thread.currentThread();
        return currentThead.getStackTrace();
    }

    private String buildConnectionDescription(Connection connection) {
        return "connection " + computeIdentifier(connection);
    }

    private int computeIdentifier(Connection connection) {
        return connection.hashCode();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy