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

kg.apc.jmeter.modifiers.CheckConsistencyAction Maven / Gradle / Ivy

package kg.apc.jmeter.modifiers;

import java.awt.Color;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import javax.swing.JTextArea;
import javax.swing.JTextField;
import kg.apc.jmeter.JMeterPluginsUtils;
import kg.apc.jmeter.RuntimeEOFException;
import org.apache.jorphan.logging.LoggingManager;
import org.apache.log.Logger;

public class CheckConsistencyAction implements ActionListener {
    private static final Logger log = LoggingManager.getLoggerForClass();
    private final JTextField filename;
    private final JTextArea infoArea;

    public CheckConsistencyAction(JTextField field, JTextArea checkInfo) {
        filename = field;
        infoArea = checkInfo;
    }

    public void actionPerformed(ActionEvent e) {
        infoArea.setText("");
        infoArea.setForeground(Color.black);
        final String fname = filename.getText();

        File f = new File(fname);
        if (!f.exists()) {
            reportError("File '" + fname + "' was not found");
            return;
        }

        int cnt = 0;
        try {
            RawRequestSourcePreProcessor preproc = new RawRequestSourcePreProcessor();
            preproc.testStarted();
            preproc.setFileName(fname);
            preproc.setVarName("test");
            preproc.setRewindOnEOF(false);
            while (true) {
                preproc.process();
                cnt++;
            }
        } catch (RuntimeEOFException ex) {
            reportOk("File seems to be OK.");
            infoArea.setForeground(Color.decode("0x00009900"));
        } catch (RuntimeException ex) {
            log.debug("Runtime Exception", ex);
            reportError(ex.toString()+" "+JMeterPluginsUtils.getStackTrace(ex));
        }
        reportOk("Parsed " + cnt + " requests in " + fname);
    }

    private void reportError(String msg) {
        infoArea.setText(infoArea.getText() + "File inconsistency: " + msg+"\n");
        infoArea.setForeground(Color.red);
    }

    private void reportOk(String string) {
        infoArea.setText(infoArea.getText() + string+ "\n" );
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy