/* * Copyright (c) 2015 Paul Scherrer Institute. All rights reserved. */ // import ch.psi.pshell.ui.Panel; import ch.psi.pshell.ui.Plugin; import ch.psi.utils.swing.SwingUtils; import ch.psi.wsaf.Task; import java.io.File; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.logging.Level; import java.util.logging.Logger; import javax.swing.ImageIcon; import javax.swing.JPanel; import javax.swing.table.DefaultTableModel; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.nio.file.Path; import java.nio.file.Paths; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Properties; import java.util.Vector; import java.util.logging.FileHandler; import java.util.logging.SimpleFormatter; import javax.swing.DefaultCellEditor; import javax.swing.JComboBox; import javax.swing.JDialog; import javax.swing.JFileChooser; import javax.swing.table.DefaultTableCellRenderer; import org.apache.commons.io.FilenameUtils; import org.python.core.PyList; import static org.python.bouncycastle.util.Arrays.append; // /** * * @author boccioli_m */ public class TestingList extends Panel { Task task = new Task() { @Override protected Object execute() throws Exception { return true; } }; public TestingList() throws Exception{ initComponents(); initLogger(); buildTable(); try{ loadTests(); } catch (Exception ex){ getLogger().severe(ex.getMessage()); } } //delete this @Override public void onExecutedFile(String fileName, Object result) { int iCurrentTestPos = 0; try { Object ret = eval("ret"); boolean status = (boolean) eval("status"); Object deviceName = eval("DEVICE"); String sStatus = (status == true) ? TestStatus.SUCCESS.toString() : TestStatus.FAILURE.toString(); System.out.println("onExecutedFile: received end of test for test " + fileName); // if (ret != "") { //start next test if (isTestRunAllowed() && runningTestsCount() == 0) { // executeTests(iCurrentTestPos); } /* } else { // ret empty means that either the test script does not have variable ret, or that the script could not be started at all ret = "Could not start test script or script doea not contain default variables"; sStatus = TestStatus.FAILURE.toString(); String[] dsDeviceName = getTestInProgress(); //SwingUtils.showException(this, ex ); if (dsDeviceName[0] != "") { iCurrentTestPos = showResult(dsDeviceName[0], fileName, ret.toString(), sStatus); //start next test if (isTestRunAllowed() && runningTestsCount()==0) { executeTest(iCurrentTestPos); } } } */ } catch (Exception ex) { String ret = "Could not start test script"; String sStatus = TestStatus.FAILURE.toString(); String[] dsDeviceName = getTestInProgress(); //SwingUtils.showException(this, ex ); SwingUtils.showMessage(this, "onExecutedFile()", ex.toString() + " " + dsDeviceName[0]); if (dsDeviceName[0] != "") { iCurrentTestPos = showResult(dsDeviceName[0], fileName, ret, sStatus); //start next test if (isTestRunAllowed()) { // executeTests(iCurrentTestPos + 1); } } } } /** * enumeration of table column indexes */ public enum COL { CHECK(0), STARTSEQUENCE(1), TIME(2), DEVICENAME(3), DEVICEDESCR(4), TESTSUITE(5), TESTNAME(6), TESTPATH(7), TESTPARAMS(8), TESTDESCR(9), TESTHELP(10), RESULT(11), STATUS(12), ICON(13); private int value; private COL(int value) { this.value = value; } /** * * @return int index of the corresponding column */ public int index() { return (int) value; } }; /** * enumeration of possible test statuses: text and related icon */ public enum TestStatus { SUCCESS, FAILURE, PENDING, DISABLED, RUNNING; /** * * @return */ public String IconFilename() { String iconFileName = ""; switch (this) { case SUCCESS: iconFileName = "/icons/button_ok-16px.png"; break; case FAILURE: iconFileName = "/icons/button_close-16px.png"; break; case PENDING: iconFileName = "/icons/button_stop-16px.png"; break; case DISABLED: iconFileName = ""; break; case RUNNING: iconFileName = "/icons/button_play-16px.png"; break; } return iconFileName; } @Override public final String toString() { String status = ""; switch (this) { case SUCCESS: status = "Success"; break; case FAILURE: status = "Failure"; break; case PENDING: status = "Pending"; break; case DISABLED: status = "Disabled"; break; case RUNNING: status = "Running"; break; } return status; } /** * * @return ImageIcon corresponding to the selected testStatus */ public ImageIcon Icon() { String iconFileName = this.IconFilename(); ImageIcon icon = null; if (iconFileName != "") { icon = new ImageIcon(getClass().getResource(this.IconFilename())); } return icon; } }; /** * Sequence options: AFTER: the test starts after the test above has * finished TOGETHER: the test starts at the same time as the test above */ public enum StartSequence { AFTER, TOGETHER; @Override public final String toString() { String status = ""; switch (this) { case AFTER: status = "After previous"; break; case TOGETHER: status = "With previous"; break; } return status; } }; /** * List of Keys defining the arguments to be passed to a test script */ public enum testArgNames { PARAMETERS, TEST, DEVICE, TEST_PATH, STATUS; @Override public final String toString() { String status = ""; switch (this) { case PARAMETERS: status = "parameters"; break; case TEST: status = "test"; break; case DEVICE: status = "device"; break; case TEST_PATH: status = "testPath"; break; case STATUS: status = "status"; break; } return status; } }; Logger logger = Logger.getLogger("TestsLog"); //these paths are converted to unix or win path according to host OS // private final String TESTS_DEVICES_DEFAULT_DIR = new java.io.File(".").getCanonicalPath() // + FilenameUtils.separatorsToSystem("/home/script/tests/devices/"); // private final String TESTS_TESTS_DEFAULT_DIR = new java.io.File(".").getCanonicalPath() // + FilenameUtils.separatorsToSystem("/home/script/tests/tests/"); // private final String TESTS_LOG_DEFAULT_DIR = new java.io.File(".").getCanonicalPath() // + FilenameUtils.separatorsToSystem("/home/script/tests/log/TestsLog" + getnow() + ".txt"); private final Path TESTS_DEVICES_DEFAULT_DIR = Paths.get(".","home", "script", "tests", "devices"); private final Path TESTS_TESTS_DEFAULT_DIR = Paths.get(".","home", "script", "tests", "tests"); private final Path TESTS_LOG_DEFAULT_DIR = Paths.get(".","home", "script", "tests", "log", "TestsLog"+ getnow() + ".txt"); private void log(Object text){ try { getController().getDataManager().appendLog(String.valueOf(text)); } catch (IOException ex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); } } private void initLogger() { try { FileHandler fh; // This block configure the logger with handler and formatter fh = new FileHandler(TESTS_LOG_DEFAULT_DIR.toString()); logger.addHandler(fh); SimpleFormatter formatter = new SimpleFormatter(); fh.setFormatter(formatter); log("INFO - " + "New testing session"); } catch (SecurityException e) { SwingUtils.showMessage(this, "initLogger()", e.toString()); } catch (IOException e) { SwingUtils.showMessage(this, "initLogger()", e.toString()); } } /** * * @throws IOException */ @SuppressWarnings("unchecked") // //GEN-BEGIN:initComponents private void initComponents() { jScrollPane2 = new javax.swing.JScrollPane(); jTable1 = new javax.swing.JTable(); jPanel1 = new javax.swing.JPanel(); jButtonRun = new javax.swing.JButton(); jPanel3 = new javax.swing.JPanel(); jButtonOpenLog = new javax.swing.JButton(); jButtonOpen = new javax.swing.JButton(); jButtonSave = new javax.swing.JButton(); jPanel2 = new javax.swing.JPanel(); jCheckBox1 = new javax.swing.JCheckBox(); jButtonMoveDown = new javax.swing.JButton(); jButtonMoveUp = new javax.swing.JButton(); setLayout(new java.awt.BorderLayout()); jTable1.setFont(new java.awt.Font("Tahoma", 0, 15)); // NOI18N jTable1.setModel(new javax.swing.table.DefaultTableModel( new Object [][] { }, new String [] { "Select", "Start", "Time", "Device Name", "Device Description", "Test Suite", "Test Name", "Test Peth", "Test Parameters", "Test Description", "Test Help", "Last Test Result", "Status", "" } ) { Class[] types = new Class [] { java.lang.Boolean.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, java.lang.Object.class, javax.swing.Icon.class }; boolean[] canEdit = new boolean [] { true, true, false, false, false, false, false, false, false, false, false, false, false, false }; public Class getColumnClass(int columnIndex) { return types [columnIndex]; } public boolean isCellEditable(int rowIndex, int columnIndex) { return canEdit [columnIndex]; } }); jTable1.getTableHeader().setReorderingAllowed(false); jTable1.setDragEnabled(true); jTable1.setDropMode(javax.swing.DropMode.INSERT); jTable1.setRowHeight(22); jTable1.addMouseListener(new java.awt.event.MouseAdapter() { public void mouseClicked(java.awt.event.MouseEvent evt) { jTable1MouseClicked(evt); } }); jTable1.addKeyListener(new java.awt.event.KeyAdapter() { public void keyReleased(java.awt.event.KeyEvent evt) { jTable1KeyReleased(evt); } }); jScrollPane2.setViewportView(jTable1); add(jScrollPane2, java.awt.BorderLayout.CENTER); jPanel1.setMinimumSize(new java.awt.Dimension(100, 100)); jPanel1.setPreferredSize(new java.awt.Dimension(110, 110)); jPanel1.setLayout(new java.awt.BorderLayout()); jButtonRun.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/play-circled-64-000000.png"))); // NOI18N jButtonRun.setToolTipText("Run selected tests"); jButtonRun.setMaximumSize(new java.awt.Dimension(33, 39)); jButtonRun.setMinimumSize(new java.awt.Dimension(90, 90)); jButtonRun.setPreferredSize(new java.awt.Dimension(33, 39)); jButtonRun.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonRunActionPerformed(evt); } }); jPanel1.add(jButtonRun, java.awt.BorderLayout.CENTER); jPanel3.setLayout(new java.awt.BorderLayout()); jButtonOpenLog.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/logbook-64px.png"))); // NOI18N jButtonOpenLog.setToolTipText("Open current sessions Log"); jButtonOpenLog.setMaximumSize(new java.awt.Dimension(80, 39)); jButtonOpenLog.setMinimumSize(new java.awt.Dimension(90, 90)); jButtonOpenLog.setPreferredSize(new java.awt.Dimension(90, 70)); jButtonOpenLog.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonOpenLogActionPerformed(evt); } }); jPanel3.add(jButtonOpenLog, java.awt.BorderLayout.SOUTH); jButtonOpen.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/folder-open-24-000000.png"))); // NOI18N jButtonOpen.setToolTipText("Open configuration"); jButtonOpen.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonOpenActionPerformed(evt); } }); jPanel3.add(jButtonOpen, java.awt.BorderLayout.CENTER); jButtonSave.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/android-save-24-000000.png"))); // NOI18N jButtonSave.setToolTipText("Save current configuration"); jButtonSave.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonSaveActionPerformed(evt); } }); jPanel3.add(jButtonSave, java.awt.BorderLayout.LINE_END); jPanel1.add(jPanel3, java.awt.BorderLayout.EAST); jPanel2.setLayout(new java.awt.BorderLayout()); jCheckBox1.setToolTipText("Select/Deselec thet highlighted tests"); jCheckBox1.setHorizontalAlignment(javax.swing.SwingConstants.CENTER); jCheckBox1.setHorizontalTextPosition(javax.swing.SwingConstants.CENTER); jCheckBox1.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jCheckBox1ActionPerformed(evt); } }); jPanel2.add(jCheckBox1, java.awt.BorderLayout.WEST); jButtonMoveDown.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/chevron-down-16-000000.png"))); // NOI18N jButtonMoveDown.setToolTipText("Move the highlighted tests down"); jButtonMoveDown.setMaximumSize(new java.awt.Dimension(25, 25)); jButtonMoveDown.setMinimumSize(new java.awt.Dimension(25, 25)); jButtonMoveDown.setPreferredSize(new java.awt.Dimension(25, 25)); jButtonMoveDown.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonMoveDownActionPerformed(evt); } }); jPanel2.add(jButtonMoveDown, java.awt.BorderLayout.SOUTH); jButtonMoveUp.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/chevron-up-16-000000.png"))); // NOI18N jButtonMoveUp.setToolTipText("Move the highlighted tests up"); jButtonMoveUp.setMaximumSize(new java.awt.Dimension(25, 25)); jButtonMoveUp.setMinimumSize(new java.awt.Dimension(25, 25)); jButtonMoveUp.setPreferredSize(new java.awt.Dimension(25, 25)); jButtonMoveUp.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonMoveUpActionPerformed(evt); } }); jPanel2.add(jButtonMoveUp, java.awt.BorderLayout.PAGE_START); jPanel1.add(jPanel2, java.awt.BorderLayout.LINE_START); add(jPanel1, java.awt.BorderLayout.NORTH); }// //GEN-END:initComponents private void jButtonRunActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonRunActionPerformed if (this.jButtonRun.getToolTipText().equals("Run selected tests")) { setButtonToStart(); updateStatus(); executeTests(); } else { setToStopped(); } }//GEN-LAST:event_jButtonRunActionPerformed private void setButtonToStop() { abort(); this.jButtonRun.setToolTipText("Run selected tests"); jButtonRun.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/play-circled-64-000000.png"))); this.jTable1.setEnabled(true); } private void setButtonToStart() { this.jButtonRun.setToolTipText("Stop tests"); jButtonRun.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/stop-circled-64-000000.png"))); this.jTable1.clearSelection(); this.jTable1.setEnabled(false); } private void jCheckBox1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jCheckBox1ActionPerformed boolean bSelected = jCheckBox1.isSelected(); int iSelRows = jTable1.getSelectedRowCount(); if (iSelRows > 0) {// if some rows are selected, check/uncheck selected rows for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { for (int selRow = 0; selRow <= jTable1.getSelectedRowCount() - 1; selRow++) { if (row == jTable1.getSelectedRows()[selRow]) { jTable1.setValueAt(bSelected, row, 0); } } } } else {//if none of the rows are selected, check/uncheck all for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { jTable1.setValueAt(bSelected, row, 0); } } updateStatus(); }//GEN-LAST:event_jCheckBox1ActionPerformed private void jTable1MouseClicked(java.awt.event.MouseEvent evt) {//GEN-FIRST:event_jTable1MouseClicked if (this.jTable1.isEnabled()) { try { switch (evt.getClickCount()) { case 1: break; case 2: openDetails(); break; } updateStatus(); } catch (Exception ex) { SwingUtils.showException(this, ex); } } }//GEN-LAST:event_jTable1MouseClicked //oopen the log file using one of th default OS text reades private void jButtonOpenLogActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonOpenLogActionPerformed String cmd; if (System.getProperty("os.name").toLowerCase().contains("windows")) { cmd = "notepad.exe " + TESTS_LOG_DEFAULT_DIR; } else { cmd = "nedit " + TESTS_LOG_DEFAULT_DIR; } try { Runtime.getRuntime().exec(cmd); } catch (IOException ex) { SwingUtils.showMessage(this, "jButtonOpenLogActionPerformed()", "jButtonOpenLogActionPerformed() " + ex.toString() + " \nPlease open the file manually. \nFile dir: " + TESTS_LOG_DEFAULT_DIR); Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); } }//GEN-LAST:event_jButtonOpenLogActionPerformed private void jTable1KeyReleased(java.awt.event.KeyEvent evt) {//GEN-FIRST:event_jTable1KeyReleased updateStatus(); }//GEN-LAST:event_jTable1KeyReleased private void jButtonMoveDownActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonMoveDownActionPerformed moveDown(); }//GEN-LAST:event_jButtonMoveDownActionPerformed private void jButtonMoveUpActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonMoveUpActionPerformed moveUp(); }//GEN-LAST:event_jButtonMoveUpActionPerformed private void jButtonOpenActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonOpenActionPerformed this.loadSettings(); new Thread(() -> { try { //Object ret = eval("parallelize((run,('testLocalVar1',globals(),{'a':'21', 'b':34})), (run,('testLocalVar2',globals(),{'a':231, 'b':234})))"); Object ret; ret = eval("parallelize((run,('dummy',)))"); ret = eval("parallelize((run,('testLocalVar1', None,{'a':21, 'b':34})), (run,('testLocalVar2', None, {'a':231, 'b':234})))"); Object ret1 = ((ArrayList) ret).get(0); Object ret2 = ((ArrayList) ret).get(1); System.out.println(String.valueOf(ret1)); System.out.println(String.valueOf(ret2)); } catch (Exception ex) { SwingUtils.showException(this, ex); } }).start(); }//GEN-LAST:event_jButtonOpenActionPerformed private void jButtonSaveActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonSaveActionPerformed saveSettings(); }//GEN-LAST:event_jButtonSaveActionPerformed // // Variables declaration - do not modify//GEN-BEGIN:variables private javax.swing.JButton jButtonMoveDown; private javax.swing.JButton jButtonMoveUp; private javax.swing.JButton jButtonOpen; private javax.swing.JButton jButtonOpenLog; private javax.swing.JButton jButtonRun; private javax.swing.JButton jButtonSave; private javax.swing.JCheckBox jCheckBox1; private javax.swing.JPanel jPanel1; private javax.swing.JPanel jPanel2; private javax.swing.JPanel jPanel3; private javax.swing.JScrollPane jScrollPane2; private javax.swing.JTable jTable1; // End of variables declaration//GEN-END:variables // /** * returns whether or not the tests can run (Run launched by the user) * * @return status of run button. True = tests launching sequence is running */ public boolean isTestRunAllowed() { return (this.jButtonRun.getToolTipText().equals("Stop tests") && pendingTestsCount() > 0); } /** * move selected rows up in table */ private void moveUp() { DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); int[] rows = jTable1.getSelectedRows(); if (rows[0] - 1 >= 0) { jTable1.setAutoCreateRowSorter(false); model.moveRow(rows[0], rows[rows.length - 1], rows[0] - 1); jTable1.setAutoCreateRowSorter(true); jTable1.setRowSelectionInterval(rows[0] - 1, rows[rows.length - 1] - 1); } } /** * move selected rows down in table */ private void moveDown() { DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); int[] rows = jTable1.getSelectedRows(); if (rows[rows.length - 1] < jTable1.getRowCount()) { jTable1.setAutoCreateRowSorter(false); model.moveRow(rows[0], rows[rows.length - 1], rows[0] + 1); jTable1.setAutoCreateRowSorter(true); jTable1.setRowSelectionInterval(rows[0] + 1, rows[rows.length - 1] + 1); } } /** * open details of the selected row in a new panel * * @throws exception */ private void openDetails() throws Exception { //pick details from the clicked row int row = jTable1.getSelectedRow(); String sDeviceName = jTable1.getValueAt(row, COL.DEVICENAME.ordinal()).toString(); String sTestName = jTable1.getValueAt(row, COL.TESTNAME.ordinal()).toString(); String sTestPath = String.valueOf(jTable1.getValueAt(row, COL.TESTPATH.ordinal())); String sTestCaseName = jTable1.getValueAt(row, COL.TESTSUITE.ordinal()).toString(); String sTestDescription = jTable1.getValueAt(row, COL.TESTDESCR.ordinal()).toString(); String sDeviceDescription = jTable1.getValueAt(row, COL.DEVICEDESCR.ordinal()).toString(); String sLastResult = jTable1.getValueAt(row, COL.RESULT.ordinal()).toString(); String sResultTime = jTable1.getValueAt(row, COL.TIME.ordinal()).toString(); String sTestHelp = String.valueOf(jTable1.getValueAt(row, COL.TESTHELP.ordinal())); HashMap mParameters = buildParametersMap(String.valueOf(jTable1.getValueAt(row, COL.TESTPARAMS.ordinal()))); //create map for passing details to Details Panel HashMap details = new HashMap(); details.put("deviceName", sDeviceName); details.put("deviceDescription", sDeviceDescription); details.put("testDescription", sTestDescription); details.put("testSuite", sTestCaseName); details.put("testName", sTestName); details.put("testResult", sLastResult); details.put("time", sResultTime); details.put("parameters", mParameters); details.put("testHelp", sTestHelp); details.put("testPath", sTestPath); //open details panel JDialog dlg = new JDialog(getView(), "Test Details - " + sTestName, true); //create a class to visualise the details panel Class testingListDetailsClass = getController().getClassByName("TestingListDetails"); JPanel detailsPanel = (JPanel) testingListDetailsClass.getConstructor(new Class[]{HashMap.class}).newInstance(new Object[]{details}); dlg.getContentPane().add(detailsPanel); //dlg.add(new TestingListDetails()); dlg.pack(); dlg.setVisible(true); } /** * put the test result in table * * @param deviceName name of the device to search in table * @param testPath path of the test to search in table * @param res String result returned by the test * @param status String status returned by the test * @return int index of the row of the device in table */ public int showResult(String deviceName, String testPath, String res, String status) { int rowD = -1; String sTestName = testPath; //getController().getDataManager().appendLog(str(log)); getLogger().log(Level.FINE, "Looking for: deviceName: " + deviceName + "; testPath: " + testPath + " in table."); String sStatus; if (status == "true") { sStatus = TestStatus.SUCCESS.toString(); } else if (status == "false") { sStatus = TestStatus.FAILURE.toString(); } else { sStatus = status; } //search for device name in table for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { if (deviceName.equals(jTable1.getValueAt(row, COL.DEVICENAME.ordinal())) && testPath.equals(jTable1.getValueAt(row, COL.TESTPATH.ordinal()))) { rowD = row; sTestName = jTable1.getValueAt(rowD, COL.TESTNAME.ordinal()).toString(); break; } } ImageIcon icon = new ImageIcon(); switch (sStatus) { case "Success": icon = TestStatus.SUCCESS.Icon(); logger.log(Level.INFO, sStatus + " - Device: " + deviceName + "; Test: " + sTestName + "; Result: " + res); log("INFO - " + sStatus + " - Device: " + deviceName + "; Test: " + sTestName + "; Result: " + res); break; case "Failure": icon = TestStatus.FAILURE.Icon(); logger.log(Level.SEVERE, sStatus + " - Device: " + deviceName + "; Test: " + sTestName + "; Result: " + res); break; case "Running": icon = TestStatus.RUNNING.Icon(); //logger.log(Level.INFO, "Running Test: " + sTestName + "."); break; } if (rowD >= 0) { jTable1.setValueAt(icon, rowD, COL.ICON.ordinal()); jTable1.setValueAt(getNow(), rowD, COL.TIME.ordinal()); jTable1.setValueAt(res, rowD, COL.RESULT.ordinal()); jTable1.setValueAt(sStatus, rowD, COL.STATUS.ordinal()); } else { logger.log(Level.SEVERE, "Cant find Test: " + testPath + " in table."); } //check if there are still pending tests. If not, set the status of the tool to Stopped. if (pendingTestsCount() == 0 && runningTestsCount() == 0) { setToStopped(); } return rowD; } /** * returns the amount of tests currently in Pending state * * @return int counter of pending tests */ public int pendingTestsCount() { return testsStatusCount(TestStatus.PENDING); } /** * returns the amount of tests currently in Running state * * @return int counter of running tests */ public int runningTestsCount() { return testsStatusCount(TestStatus.RUNNING); } /** * returns the amount of tests currently in Pending state * * @return int counter of successful tests */ public int successTestsCount() { return testsStatusCount(TestStatus.SUCCESS); } /** * returns the amount of tests currently in "status" state * * @param status type of status to count * @return int counter with occurrences of the status */ private int testsStatusCount(TestStatus status) { String sStatus; boolean bSelected; int iPendingTestsCount = 0; for (int row = 0; row < jTable1.getRowCount(); row++) { bSelected = (boolean) jTable1.getValueAt(row, COL.CHECK.ordinal()); sStatus = jTable1.getValueAt(row, COL.STATUS.ordinal()).toString(); if (bSelected && sStatus == status.toString()) { iPendingTestsCount++; } } return iPendingTestsCount; } /** * set the tests to stopped */ private void setToStopped() { //No more tests to play. Stop setButtonToStop(); logger.log(Level.INFO, "End of tests."); } /** * get the first test currently in progress * * @return properties of the test in progress */ public String[] getTestInProgress() { String[] dsTestProperties = {"", ""}; //search for device name in table try { for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { if (jTable1.getValueAt(row, COL.STATUS.ordinal()).toString().equals(TestStatus.RUNNING.toString())) { dsTestProperties[0] = jTable1.getValueAt(row, COL.DEVICENAME.ordinal()).toString(); dsTestProperties[1] = jTable1.getValueAt(row, COL.TESTPATH.ordinal()).toString(); break; } } } catch (Exception ex) { this.setToStopped(); SwingUtils.showMessage(this, "getTestInProgress()", ex.toString()); } finally { return dsTestProperties; } } /** * returns the status of the specified test name for specified device name * * @param deviceName name of the device * @param testPath path of the test file * @return String containing the result returned by the test */ public String getResult(String deviceName, String testPath) { String sStatus = ""; int rowD = -1, colT = -1; //search for device name in table for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { if (deviceName.equals(jTable1.getValueAt(row, COL.DEVICENAME.ordinal()))) { rowD = row; break; } } if (rowD >= 0) { //search for test in table if (testPath.equals(jTable1.getValueAt(rowD, COL.TESTPATH.ordinal()))) { colT = COL.TESTNAME.ordinal(); } } //get the test result if (colT >= 0 && rowD >= 0) { sStatus = jTable1.getValueAt(rowD, COL.STATUS.ordinal()).toString(); } return sStatus; } /** * visualise test status (columns status and icon) */ public void updateStatus() { String sStatus; boolean bSelected; ImageIcon icon = null; String sStart; for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { bSelected = (boolean) jTable1.getValueAt(row, COL.CHECK.ordinal()); sStart = String.valueOf(jTable1.getValueAt(row, COL.STARTSEQUENCE.ordinal())); if (bSelected) { sStatus = TestStatus.PENDING.toString(); icon = TestStatus.PENDING.Icon(); if (sStart == "") { sStart = StartSequence.AFTER.toString(); } } else { sStatus = TestStatus.DISABLED.toString(); icon = TestStatus.DISABLED.Icon(); sStart = ""; } jTable1.setValueAt(bSelected, row, COL.CHECK.ordinal()); jTable1.setValueAt(icon, row, COL.ICON.ordinal()); jTable1.setValueAt(sStatus, row, COL.STATUS.ordinal()); jTable1.setValueAt(sStart, row, COL.STARTSEQUENCE.ordinal()); } } /** * launch the execution of the tests */ public void executeTests() { RunTest runTest = new RunTest(); Thread t = new Thread(runTest); t.start(); } /** * */ public class RunTest implements Runnable { private HashMap mParameters; //private HashMap args; private HashMap hTests; /** * */ public RunTest() { //System.out.println("A0"); } public void run() { // code in the other thread, can reference "var" variable executeTest(0); } /** * execute the selected tests in the list, starting from the position * * @param position row number from which to start executing tests */ private void executeTest(int position) { boolean bSelected = false; String sStartSequence, sStatus; int[] selectedTestsRows = {}; //scan through the table starting from 'position' and execute the first selected test found int row = 0;// position; if (row >= 0 && row < jTable1.getRowCount()) { for (row = position; row < jTable1.getRowCount(); row++) { bSelected = (boolean) jTable1.getValueAt(row, COL.CHECK.ordinal()); sStartSequence = jTable1.getValueAt(row, COL.STARTSEQUENCE.ordinal()).toString(); sStatus = jTable1.getValueAt(row, COL.STATUS.ordinal()).toString(); //collect tests to be launched in parallel //the test must be: selected, set as start with previous, pending. //alternatively, the test must be: selected, first of the list. //System.out.println(String.valueOf(row) + "\t" + String.valueOf(bSelected) + "\t" + String.valueOf(selectedTestsRows.length) + "\t" + sStartSequence + "\t" + sStatus); if (bSelected && sStatus.equals(TestStatus.PENDING.toString()) && (selectedTestsRows.length == 0 || //the test must be: selected, pending, first of the list. sStartSequence.equals(StartSequence.TOGETHER.toString()))) { //or the test must be: selected, pending, set as start with previous selectedTestsRows = append(selectedTestsRows, row); } else if (bSelected && sStatus.equals(TestStatus.PENDING.toString()) &&//if this test must be executed... selectedTestsRows.length > 0 && //but there are already tests to be executed in parallel.... (sStartSequence.equals(StartSequence.AFTER.toString()))) { //...and this test must be executed in series, then stop searching break; } } if (selectedTestsRows.length > 0) { //at least one test is selected: launch it (or them) System.out.println("\n===================================================\n"); executeParallelTestsGroup(selectedTestsRows); //last execution did not find a test file. Continue with next execution executeTest(position + 1); } else {//no tests were selected. end. setToStopped(); } } } private HashMap buildMapFromTableRow(int row) { String sDeviceName = jTable1.getValueAt(row, COL.DEVICENAME.ordinal()).toString(); String sTestName = jTable1.getValueAt(row, COL.TESTNAME.ordinal()).toString(); String sTestCaseName = jTable1.getValueAt(row, COL.TESTSUITE.ordinal()).toString(); String sTestPath = jTable1.getValueAt(row, COL.TESTPATH.ordinal()).toString(); HashMap mParameters = buildParametersMap(String.valueOf(jTable1.getValueAt(row, COL.TESTPARAMS.ordinal()))); HashMap testArgs = new HashMap(); //args.put("ret", ""); testArgs.put(testArgNames.PARAMETERS.toString(), mParameters); testArgs.put(testArgNames.TEST.toString(), sTestName); testArgs.put(testArgNames.DEVICE.toString(), sDeviceName); testArgs.put(testArgNames.TEST_PATH.toString(), sTestPath); testArgs.put(testArgNames.STATUS.toString(), false); return testArgs; } /** * convert HashMap string separators to python dictionary string sepatators * * @param sParameters string coming from HashMap conaining the list of parameters to be passed to the test script. * Example: * {repeatTimes={description=Repeat N times, value=1}, midPoint={description=Middle point A, value=41.0}, spanFromMidPoint={description=B steps around middle point A, value=2.0}} * @return string of dictionary in python syntax. This can be passed to the python test script. * Example of output: * {'repeatTimes':{'description':'Repeat N times','value':'1'},'midPoint':{'description':'Middle point A','value':'41.0'},'spanFromMidPoint':{'description':'B steps around middle point A','value':'2.0'} */ private String convertParametersMapToPythonMap(String sParameters){ String sPythonParams = sParameters; sPythonParams = sPythonParams.replace(", " , ","); sPythonParams = sPythonParams.replace(" ," , ","); sPythonParams = sPythonParams.replace("{{" , "#@"); sPythonParams = sPythonParams.replace("}}" , "@#"); sPythonParams = sPythonParams.replace("}," , "@%#"); sPythonParams = sPythonParams.replace(",{" , "#%@"); sPythonParams = sPythonParams.replace("={" , "^%&"); sPythonParams = sPythonParams.replace("=}" , "&%^"); sPythonParams = sPythonParams.replace("," , "','"); sPythonParams = sPythonParams.replace("{" , "{'"); sPythonParams = sPythonParams.replace("}" , "'}"); sPythonParams = sPythonParams.replace("=" , "':'"); sPythonParams = sPythonParams.replace("^%&", "':{'"); sPythonParams = sPythonParams.replace("&%^", "'}:'"); sPythonParams = sPythonParams.replace("#@" , "{{'"); sPythonParams = sPythonParams.replace("@#" , "'}}"); sPythonParams = sPythonParams.replace("@%#", "'},'"); sPythonParams = sPythonParams.replace("#%@", "',{'"); return sPythonParams; } /** start all the tests in the array rowsToExecute. * all tests in the listed row indexes will be started at the same time. * * @param rowsToExecute array of indexes relative to the test rows in the table. * The indexes in the array will execute the test in corresponding row * @return return value: 0 means ok, <0 means problem */ private int executeParallelTestsGroup(int[] rowsToExecute) { int iRet = -1; HashMap args2 = new HashMap(); //this is the global map that will contain one map per test. HashMap testArgs; //this is the map for a test. RunTest runTest; String sTestName = "", sDeviceName = "", sTestPath = ""; for (int row : rowsToExecute) { //System.out.println(String.valueOf(row) + "\t" + sDeviceName + "\t" + sTestName + "\t" + sTestCaseName + "\t" + String.valueOf(rowsToExecute.length)); try { testArgs = buildMapFromTableRow(row); sTestName = (String) testArgs.get(testArgNames.TEST.toString()); sTestPath = (String) testArgs.get(testArgNames.TEST_PATH.toString()); sDeviceName = (String) testArgs.get(testArgNames.DEVICE.toString()); mParameters = (HashMap) testArgs.get(testArgNames.PARAMETERS.toString()); File f = new File(sTestPath); if (!f.exists() || f.isDirectory()) { logger.log(Level.SEVERE, "Cannot find test script: " + sTestPath); showResult(sDeviceName, sTestPath, "Cannot find test script: " + sTestPath, TestStatus.FAILURE.toString()); continue; } showResult(sDeviceName, sTestPath, "Test running", TestStatus.RUNNING.toString()); //launch the test if (!mParameters.isEmpty()) { logger.log(Level.INFO, "Running test '" + sTestName + "' with the following parameters: " + mParameters.toString()); System.out.println("Running test '" + sTestName + "' with the following parameters: " + mParameters.toString()); } else { logger.log(Level.INFO, "Running Test '" + sTestName + "'. No parameters found."); System.out.println("Running test '" + sTestName + "'. No parameters found."); } args2.put(sTestPath, testArgs); hTests = args2; iRet = 0; } catch (Exception ex) { SwingUtils.showMessage(TestingList.this, "executeTest()", ex.toString()); logger.log(Level.SEVERE, ex.toString()); showResult(sDeviceName, sTestPath, ex.toString(), TestStatus.FAILURE.toString()); setToStopped(); } } try { int iLastExecutedTestIndex = -1; final String sParallelizeBegin = "(run,(str('"; final String sParallelizeEnd = "'),))"; String sParallelizeArguments; try { //System.out.println("A0.1"); String sParallelizeCommand = "parallelize("; int i = 0; int iTotalEntries = hTests.entrySet().size(); HashMap args = new HashMap(); for (Map.Entry hTest : hTests.entrySet()) { //REMOVE this when local parameters will work /* args.put("parameters", hTest.getValue().get("parameters")); args.put("device", hTest.getValue().get(testArgNames.DEVICE.toString())); args.put("test", hTest.getValue().get(testArgNames.TEST.toString())); args.put("ret", ""); args.put("status", hTest.getValue().get(testArgNames.STATUS.toString())); setGlobalsVars(hTest.getValue()); //set global variables that can be read by all test scripts setGlobalsVars(args); //set global variables that can be read by all test scripts //end REMOVE */ sTestPath = hTest.getKey().toString(); sTestPath = sTestPath.replace("\\", "\\\\"); //System.out.println(hTest.getValue().get("test")); sParallelizeCommand = sParallelizeCommand + "(run,(str('" + sTestPath; //System.out.println("A"+i); sParallelizeArguments = "None, {'parameters':" + convertParametersMapToPythonMap(hTest.getValue().get("parameters").toString()) + ",'test':'" + hTest.getValue().get(testArgNames.TEST.toString()) + "','device':'" + hTest.getValue().get(testArgNames.DEVICE.toString()) + "','status':'" + hTest.getValue().get(testArgNames.STATUS.toString()) + "'}"; //without parameters: /* sParallelizeArguments = "None" + ",{'test':'" + hTest.getValue().get(testArgNames.TEST.toString()) + "','device':'" + hTest.getValue().get(testArgNames.DEVICE.toString()) + "','status':'" + hTest.getValue().get(testArgNames.STATUS.toString()) + "'}"; */ //this to remove arguments. COMMENT OUT when arguments work well //sParallelizeArguments = ""; sParallelizeCommand = sParallelizeCommand + "')," + sParallelizeArguments; i++; if (i < iTotalEntries) { sParallelizeCommand = sParallelizeCommand + ")),"; //between each "run" command } else { sParallelizeCommand = sParallelizeCommand + ")))"; //very last part of command "parallelize" } } System.out.println(sParallelizeCommand); Object ret; //ret = eval("str(locals())"); //ret = eval("str(globals())"); //ret = eval("run('dummy.py')"); ret = eval(sParallelizeCommand); System.out.println("c"); // Object ret = eval("parallelize((run,(str('"+sTestPath+"'),)), (run,('Motor Test 3 200ms',)))"); //System.out.println("Ret = " + String.valueOf(ret)); String sTestResult, sTestStatus; //read the return mapping and put the result in the right table row //System.out.println("ret type "+ret.getClass().toString() ); //scan through all return mappings of all run tests for (Object oTestRet : (ArrayList) ret) { //check if the mapping of the selected test has all expected return values if (((List) oTestRet).size() >= 4) { //extract return data of the current test sTestPath = String.valueOf(((List) oTestRet).get(0)); sDeviceName = String.valueOf(((List) oTestRet).get(1)); sTestResult = String.valueOf(((List) oTestRet).get(2)); sTestStatus = String.valueOf(((List) oTestRet).get(3)); //from the map of executed tests, get the test name (key is test path) HashMap hTest = hTests.get(sTestPath); sTestName = String.valueOf(hTest.get(testArgNames.TEST.toString())); } else { //problem, the test script does not return all the expected return values String sErrorText = "Test " + sTestPath + " did not return all required return values"; Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, sErrorText); SwingUtils.showMessage(TestingList.this, "executeParallelTestsGroup()", sErrorText); System.out.println(String.valueOf(sErrorText)); //try to fetch at least first element of returned map. If fails, it will go to catch sTestPath = String.valueOf(((List) oTestRet).get(0)); sTestStatus = sErrorText; sTestResult = "false"; HashMap hTest = hTests.get(sTestPath); sDeviceName = String.valueOf(hTest.get(testArgNames.DEVICE.toString())); sTestName = String.valueOf(hTest.get(testArgNames.TEST.toString())); } System.out.println("Result: " + sDeviceName + "|" + sTestPath + "|" + sTestResult + "|" + sTestStatus); iLastExecutedTestIndex = showResult(sDeviceName, sTestPath, sTestResult, sTestStatus); } } catch (ClassCastException ccex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ccex); SwingUtils.showMessage(TestingList.this, "executeParallelTestsGroup()", ccex.toString()); //System.out.println(String.valueOf(ccex)); if (!sDeviceName.isEmpty()) { showResult(sDeviceName, sTestPath, ccex.toString(), TestStatus.FAILURE.toString()); } } catch (Exception ex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); SwingUtils.showMessage(TestingList.this, "executeParallelTestsGroup()", ex.toString()); System.out.println(String.valueOf(ex)); showResult(sDeviceName, sTestPath, ex.toString(), TestStatus.FAILURE.toString()); } } catch (Exception ex) { SwingUtils.showMessage(TestingList.this, "executeParallelTestsGroup(), run thread", ex.toString()); logger.log(Level.SEVERE, ex.toString()); setToStopped(); } return iRet; } } /** * table management */ private void buildTable() { String sDate = getNow(); DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); jTable1.setModel(model); //Set up the combo box editor for the Start Sequence cells. JComboBox comboBox = new JComboBox(); comboBox.addItem(StartSequence.AFTER.toString()); comboBox.addItem(StartSequence.TOGETHER.toString()); jTable1.getColumnModel().getColumn(COL.STARTSEQUENCE.ordinal()).setCellEditor(new DefaultCellEditor(comboBox)); //Set up tool tips for the sequence cells. DefaultTableCellRenderer renderer = new DefaultTableCellRenderer(); renderer.setToolTipText("Click for options"); jTable1.getColumnModel().getColumn(COL.STARTSEQUENCE.ordinal()).setCellRenderer(renderer); jTable1.getColumnModel().getColumn(COL.STARTSEQUENCE.ordinal()).setPreferredWidth(30); jTable1.getColumnModel().getColumn(COL.ICON.ordinal()).setMaxWidth(27); jTable1.getColumnModel().getColumn(COL.CHECK.ordinal()).setMaxWidth(27); jTable1.getColumnModel().getColumn(COL.DEVICENAME.ordinal()).setPreferredWidth(30); jTable1.getColumnModel().getColumn(COL.STATUS.ordinal()).setPreferredWidth(20); hideColumn(COL.DEVICEDESCR); hideColumn(COL.TESTPATH); hideColumn(COL.TESTDESCR); hideColumn(COL.TESTPARAMS); hideColumn(COL.TESTHELP); jTable1.setAutoCreateRowSorter(true); updateStatus(); } private void hideColumn(COL column) { jTable1.getColumnModel().getColumn(column.ordinal()).setMinWidth(0); jTable1.getColumnModel().getColumn(column.ordinal()).setMaxWidth(0); } //append test info to table private void addToTable(String deviceName, String deviceDescription, String testSuite, String testName, String testParams, String testDescription, String testHelp) { String sDate = ""; if (testName.equals("") || deviceName.equals("")) { return; } ImageIcon icon = null;// new ImageIcon(getClass().getResource("/icons/button_pause-16px.png")); DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); //String testPath = FilenameUtils.separatorsToSystem(TESTS_TESTS_DEFAULT_DIR + testSuite + "/" + testName + "/" + testName + ".py"); String testPath = Paths.get(TESTS_TESTS_DEFAULT_DIR.toString(), testSuite, testName, testName + ".py").toString(); model.addRow(new Object[]{false, "", sDate, deviceName, deviceDescription, testSuite, testName, testPath, testParams, testDescription, testHelp, "", "Pending", icon}); jTable1.setModel(model); updateStatus(); } /** * get the current time in format like 2015/07/02 15:59:43 * * @return formatted time */ public String getNow() { DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); Date date = new Date(); return dateFormat.format(date); } /** * get the current time in format like 20150702155943 * * @return time with sortable format */ public String getnow() { DateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmmss"); Date date = new Date(); return dateFormat.format(date); } /** * scan tests directory, scan devices directory, search for their test cases * and scan for tests. * * @throws FileNotFoundException * @throws IOException */ public void loadTests() throws FileNotFoundException, IOException { Properties propDevice = new Properties(); Properties propTest = new Properties(); //String fileName = TESTS_DEVICES_DEFAULT_DIR; //File folder = new File(fileName); File testsFolder = null; String sTestName; int iCounter = 0; //search devices and their tests //Scan the list of devices File[] listOfFiles = TESTS_DEVICES_DEFAULT_DIR.toFile().listFiles(); for (File listOfFile : listOfFiles) { propDevice.clear(); if (listOfFile.isFile()) { } else if (listOfFile.isDirectory()) { File configFile = new File(listOfFile.getPath() + FilenameUtils.separatorsToSystem("/.config")); if (configFile.exists() && !configFile.isDirectory()) { InputStream is = new FileInputStream(configFile); propDevice.load(is); //config of device was loaded. now load the config of each test belonging to the device //sTestName = TESTS_TESTS_DEFAULT_DIR + propDevice.getProperty("tests"); //testsFolder = new File(sTestName); testsFolder = Paths.get(TESTS_TESTS_DEFAULT_DIR.toString(), propDevice.getProperty("tests")).toFile(); if (testsFolder.exists() && testsFolder.isDirectory()) { File[] listOfTests = testsFolder.listFiles(); for (File listOfTest : listOfTests) { propTest.clear(); if (listOfTest.isDirectory()) { configFile = new File(listOfTest.getPath() + FilenameUtils.separatorsToSystem("/.config")); if (configFile.exists() && !configFile.isDirectory()) { InputStream ist = new FileInputStream(configFile); propTest.load(ist); addToTable(propDevice.getProperty("name"), propDevice.getProperty("description"), propDevice.getProperty("tests"), propTest.getProperty("name"), propTest.getProperty("parameters"), propTest.getProperty("description"), propTest.getProperty("help")); iCounter++; } } } } } } } logger.log(Level.INFO, iCounter + " tests loaded."); } /** * Build a map with optional parameters to be passed to the testing script. * The map is like this: parameters \_ name | \_ value | \_ description \_ * name | \_ value | \_ description ... the name 'name' is the mapping key. * 'value' and 'description' are constant mapping keys of a nested map. * * @param parametersString string containing the parameters. Syntax: * name:value:description[;name:value:description;...] */ private HashMap buildParametersMap(String parametersString) { HashMap mParameters = new HashMap(); // contains name and attributes HashMap mParameterAttributes = new HashMap(); //contians value and description String[] dsParameterAttributes = null; String[] dsParameters = parametersString.split(";"); for (String sParameter : dsParameters) { dsParameterAttributes = sParameter.split(":"); if (dsParameterAttributes.length > 2) { mParameterAttributes = new HashMap(); mParameterAttributes.put("value", (Object) dsParameterAttributes[1]); mParameterAttributes.put("description", dsParameterAttributes[2]); //add parameter name and attributes (value + description) mParameters.put(dsParameterAttributes[0], mParameterAttributes); } } return mParameters; } /** * Save current setup in a file. The current position of table rows is also * saved. */ public void saveSettings() { final JFileChooser fc = new JFileChooser(); int returnVal = fc.showSaveDialog(this); if (returnVal == JFileChooser.APPROVE_OPTION) { File file = fc.getSelectedFile(); saveSettings(file); } } /** * Save current setup in a file. The current position of table rows is also * saved. * * @param file file containing the settings */ private void saveSettings(File file) { DefaultTableModel tableModel = (DefaultTableModel) jTable1.getModel(); try { ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream(file)); out.writeObject(tableModel.getDataVector()); out.close(); } catch (Exception ex) { ex.printStackTrace(); } } /** * Save current setup in a file. The current position of table rows is also * saved. */ public void loadSettings() { final JFileChooser fc = new JFileChooser(); int returnVal = fc.showOpenDialog(this); if (returnVal == JFileChooser.APPROVE_OPTION) { File file = fc.getSelectedFile(); loadSettings(file); } } /** * Save current setup in a file. The current position of table rows is also * saved. * * @param file file containing the settings */ private void loadSettings(File file) { DefaultTableModel tableModel = (DefaultTableModel) jTable1.getModel(); try { ObjectInputStream in = new ObjectInputStream(new FileInputStream(file)); Vector rowData = (Vector) in.readObject(); Iterator itr = rowData.iterator(); //clear table tableModel.getDataVector().removeAllElements(); tableModel.fireTableDataChanged(); //rewrite table while (itr.hasNext()) { tableModel.addRow((Vector) itr.next()); } in.close(); } catch (Exception ex) { ex.printStackTrace(); SwingUtils.showMessage(this, "loadSettings()", ex.toString()); } } //end of class }