/* * Copyright (c) 2014 Paul Scherrer Institute. All rights reserved. */ import ch.psi.utils.swing.MonitoredPanel; import ch.psi.pshell.ui.Panel; import ch.psi.utils.swing.SwingUtils; import ch.psi.wsaf.Task; import java.awt.Desktop; 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.IOException; import java.io.InputStream; import java.util.Properties; import java.util.logging.FileHandler; import java.util.logging.SimpleFormatter; import javax.swing.JFileChooser; import org.apache.commons.io.FilenameUtils; public class TestingList extends Panel { NetbeansPluginPanel testingList; Task task = new Task() { @Override protected Object execute() throws Exception { return true; } }; @Override protected JPanel create() { try { testingList = new NetbeansPluginPanel(); } catch (IOException ex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); } return testingList; } //listen to script end of execution and get return value @Override protected void onExecutedFile(String fileName) { int iCurrentTestPos = 0; try { Object ret = eval("ret"); boolean success = (boolean) eval("success"); Object deviceName = eval("DEVICE"); String sSuccess = (success == true) ? "Success" : "Failed"; if (ret != null) { //SwingUtils.showMessage(getComponent(), "", ret.toString() + " - " + ret.getClass().getName()); iCurrentTestPos = testingList.showResult(deviceName.toString(), fileName, ret.toString(), sSuccess); //start next test if(iCurrentTestPos>0) { testingList.executeTest(iCurrentTestPos+1); } } } catch (Exception ex) { String ret = "Could not start test script"; String sSuccess = "Failed"; String[] deviceName = testingList.getTestInProgress(); SwingUtils.showException(getComponent(), ex ); SwingUtils.showMessage(getComponent(), "", ex.toString() + deviceName[0]); if(deviceName != null){ iCurrentTestPos = testingList.showResult(deviceName[0], fileName, ret, sSuccess); //start next test if(iCurrentTestPos>0) { testingList.executeTest(iCurrentTestPos+1); } } } } public class NetbeansPluginPanel extends MonitoredPanel { 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/production/"); 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"); //table1 columns indexes private final int COL_CHECK = 0; private final int COL_TIME = 1; private final int COL_DEVICENAME = 2; private final int COL_DEVICEDESCR = 3; private final int COL_TESTSUITE = 4; private final int COL_TESTNAME = 5; private final int COL_RESULT = 6; private final int COL_STATUS = 7; private final int COL_ICON = 8; private void initLogger() { try { FileHandler fh; // This block configure the logger with handler and formatter fh = new FileHandler(TESTS_LOG_DEFAULT_DIR); logger.addHandler(fh); SimpleFormatter formatter = new SimpleFormatter(); fh.setFormatter(formatter); logger.log(Level.INFO, "New Testing Session"); } catch (SecurityException e) { SwingUtils.showMessage(this, "", e.toString()); } catch (IOException e) { SwingUtils.showMessage(this, "", e.toString()); } } public NetbeansPluginPanel() throws IOException { initComponents(); initLogger(); buildTable(); loadTests(); } @SuppressWarnings("unchecked") // //GEN-BEGIN:initComponents private void initComponents() { jButtonRun = new javax.swing.JButton(); jScrollPane2 = new javax.swing.JScrollPane(); jTable1 = new javax.swing.JTable(); jCheckBox1 = new javax.swing.JCheckBox(); jScrollPane1 = new javax.swing.JScrollPane(); jTextField1 = new javax.swing.JTextArea(); jButtonOpenLog = new javax.swing.JButton(); setLayout(new java.awt.BorderLayout()); jButtonRun.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/button_play-64px.png"))); // NOI18N jButtonRun.setToolTipText("Run selected tests"); jButtonRun.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonRunActionPerformed(evt); } }); add(jButtonRun, java.awt.BorderLayout.CENTER); jTable1.setFont(new java.awt.Font("Tahoma", 0, 15)); // NOI18N jTable1.setModel(new javax.swing.table.DefaultTableModel( new Object [][] { }, new String [] { "Select", "Time", "Device Name", "Device Description", "Test Suite", "Test Name", "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, javax.swing.Icon.class }; boolean[] canEdit = new boolean [] { true, true, true, true, true, true, true, true, 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.addInputMethodListener(new java.awt.event.InputMethodListener() { public void caretPositionChanged(java.awt.event.InputMethodEvent evt) { jTable1CaretPositionChanged(evt); } public void inputMethodTextChanged(java.awt.event.InputMethodEvent evt) { jTable1InputMethodTextChanged(evt); } }); jTable1.addKeyListener(new java.awt.event.KeyAdapter() { public void keyTyped(java.awt.event.KeyEvent evt) { jTable1KeyTyped(evt); } }); jScrollPane2.setViewportView(jTable1); add(jScrollPane2, java.awt.BorderLayout.PAGE_END); jCheckBox1.setText("All"); jCheckBox1.setToolTipText("Select/Deselect All Tests"); jCheckBox1.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jCheckBox1ActionPerformed(evt); } }); add(jCheckBox1, java.awt.BorderLayout.LINE_START); jTextField1.setColumns(20); jTextField1.setRows(5); jTextField1.setMaximumSize(new java.awt.Dimension(2147483647, 100)); jTextField1.setPreferredSize(new java.awt.Dimension(204, 40)); jScrollPane1.setViewportView(jTextField1); add(jScrollPane1, java.awt.BorderLayout.PAGE_START); jButtonOpenLog.setIcon(new javax.swing.ImageIcon(getClass().getResource("/icons/log-icon-64px.png"))); // NOI18N jButtonOpenLog.setToolTipText("Open current sessions Log"); jButtonOpenLog.addActionListener(new java.awt.event.ActionListener() { public void actionPerformed(java.awt.event.ActionEvent evt) { jButtonOpenLogActionPerformed(evt); } }); add(jButtonOpenLog, java.awt.BorderLayout.LINE_END); }// //GEN-END:initComponents private void jButtonRunActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonRunActionPerformed this.executeTest(0); }//GEN-LAST:event_jButtonRunActionPerformed private void jCheckBox1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jCheckBox1ActionPerformed boolean bSelected = jCheckBox1.isSelected(); for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { jTable1.setValueAt(bSelected, row, 0); } updateStatus(); }//GEN-LAST:event_jCheckBox1ActionPerformed private void jTable1InputMethodTextChanged(java.awt.event.InputMethodEvent evt) {//GEN-FIRST:event_jTable1InputMethodTextChanged }//GEN-LAST:event_jTable1InputMethodTextChanged private void jTable1CaretPositionChanged(java.awt.event.InputMethodEvent evt) {//GEN-FIRST:event_jTable1CaretPositionChanged }//GEN-LAST:event_jTable1CaretPositionChanged private void jTable1MouseClicked(java.awt.event.MouseEvent evt) {//GEN-FIRST:event_jTable1MouseClicked updateStatus(); // TODO add your handling code here: }//GEN-LAST:event_jTable1MouseClicked private void jTable1KeyTyped(java.awt.event.KeyEvent evt) {//GEN-FIRST:event_jTable1KeyTyped updateStatus(); // TODO add your handling code here: }//GEN-LAST:event_jTable1KeyTyped private void jButtonOpenLogActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jButtonOpenLogActionPerformed // TODO add your handling code here: jTable1.setValueAt("Running",0,8); String[] deviceName = testingList.getTestInProgress(); SwingUtils.showMessage(this, "", deviceName[0]); /* if (System.getProperty("os.name").toLowerCase().contains("windows")) { String cmd; cmd = "notepad.exe " + TESTS_LOG_DEFAULT_DIR; try { Runtime.getRuntime().exec(cmd); } catch (IOException ex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); } } else { File log = new File(TESTS_LOG_DEFAULT_DIR); try { Desktop.getDesktop().edit(log); } catch (IOException ex) { Logger.getLogger(TestingList.class.getName()).log(Level.SEVERE, null, ex); } } */ }//GEN-LAST:event_jButtonOpenLogActionPerformed // Variables declaration - do not modify//GEN-BEGIN:variables private javax.swing.JButton jButtonOpenLog; private javax.swing.JButton jButtonRun; private javax.swing.JCheckBox jCheckBox1; private javax.swing.JScrollPane jScrollPane1; private javax.swing.JScrollPane jScrollPane2; private javax.swing.JTable jTable1; private javax.swing.JTextArea jTextField1; // End of variables declaration//GEN-END:variables //show test result in table public int showResult(String deviceName, String testName, String res, String status) { 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))) { rowD = row; break; } } if (rowD >= 0) { //search for test name in table if (testName.equals(jTable1.getValueAt(rowD, COL_TESTNAME))) { colT = COL_TESTNAME; } } String iconSource = "/icons/button_help-16px.png"; switch (status) { case "Success": iconSource = "/icons/button_ok-16px.png"; logger.log(Level.INFO, "Device: " + testName + "Test: " + testName + " Result: " + res + " (" + status + ")"); break; case "Failed": iconSource = "/icons/button_close-16px.png"; logger.log(Level.SEVERE, "Device: " + testName + "Test: " + testName + " Result: " + res + " (" + status + ")"); break; case "Running": iconSource = "/icons/button_play-16px.png"; logger.log(Level.INFO, "Running Test: " + testName + " ... "); break; } ImageIcon icon = new ImageIcon(getClass().getResource(iconSource)); jTable1.setValueAt(icon, rowD, COL_ICON); if (colT >= 0 && rowD >= 0) { jTable1.setValueAt(getNow(), rowD, COL_TIME); jTable1.setValueAt(res, rowD, COL_RESULT); jTable1.setValueAt(status, rowD, COL_STATUS); } return rowD; } //find the test currently in progress public String[] getTestInProgress() { String[] dsTestProperties = null; //search for device name in table for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { if (jTable1.getValueAt(row, COL_STATUS).toString().equals("Running")) { dsTestProperties[0] = jTable1.getValueAt(row, COL_DEVICENAME).toString(); dsTestProperties[1] = jTable1.getValueAt(row, COL_TESTNAME).toString(); break; } } return dsTestProperties; } //returns the status of the specified test name for specified device name public String getResult(String deviceName, String testName){ 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))) { rowD = row; break; } } if (rowD >= 0) { //search for test name in table if (testName.equals(jTable1.getValueAt(rowD, COL_TESTNAME))) { colT = COL_TESTNAME; } } if (colT >= 0 && rowD >= 0) { sStatus = jTable1.getValueAt(rowD, COL_STATUS).toString(); } return sStatus; } public void updateStatus() { String sStatus, iconSource; boolean bSelected; for (int row = 0; row <= jTable1.getRowCount() - 1; row++) { bSelected = (boolean) jTable1.getValueAt(row, COL_CHECK); if (bSelected) { sStatus = "Pending"; iconSource = "/icons/button_pause-16px.png"; } else { sStatus = "Disabled"; iconSource = "/icons/button_stop-16px.png"; } ImageIcon icon = new ImageIcon(getClass().getResource(iconSource)); jTable1.setValueAt(bSelected, row, COL_CHECK); jTable1.setValueAt(icon, row, COL_ICON); jTable1.setValueAt(sStatus, row, COL_STATUS); } } //execute the selected tests in the list, starting from the position public void executeTest(int position){ boolean bSelected = false; String sDeviceName; String sTestName; HashMap args = new HashMap(); //scan through the table starting from 'position' and execute the first selected test found int row = position; if (row <= jTable1.getRowCount() ) { for(row = position ; row <= jTable1.getRowCount() ; row++){ bSelected = (boolean) jTable1.getValueAt(row, COL_CHECK); if(bSelected) break; } if (bSelected) { sDeviceName = jTable1.getValueAt(row, COL_DEVICENAME).toString(); sTestName = jTable1.getValueAt(row, COL_TESTNAME).toString(); showResult(sDeviceName, sTestName, "Test running", "Running"); //launch the test try{ args.put("DEVICE", sDeviceName); run(sTestName, args); } catch (Exception ex) { SwingUtils.showMessage(this, "", ex.toString()); } } } } //table management public void buildTable() { String sDate = getNow(); ImageIcon icon = new ImageIcon(getClass().getResource("/icons/button_pause-16px.png")); DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); jTable1.setModel(model); jTable1.getColumnModel().getColumn(COL_ICON).setMaxWidth(27); jTable1.getColumnModel().getColumn(COL_CHECK).setMaxWidth(27); jTable1.getColumnModel().getColumn(COL_DEVICENAME).setPreferredWidth(30); jTable1.getColumnModel().getColumn(COL_STATUS).setPreferredWidth(30); updateStatus(); } //append test info to table public void addToTable(String deviceName, String deviceDescription, String testSuite, String testName) { String sDate = ""; if (testName.equals("") || deviceName.equals("")) { return; } ImageIcon icon = new ImageIcon(getClass().getResource("/icons/button_pause-16px.png")); DefaultTableModel model = (DefaultTableModel) jTable1.getModel(); model.addRow(new Object[]{false, sDate, deviceName, deviceDescription, testSuite, testName, "", "Pending", icon}); jTable1.setModel(model); updateStatus(); } //formatted time public String getNow() { DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); Date date = new Date(); return dateFormat.format(date); } //time without 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. public void loadTests() throws FileNotFoundException, IOException { Properties propDevice = new Properties(); Properties propTest = new Properties(); String fileName = TESTS_DEVICES_DEFAULT_DIR; this.jTextField1.setText(fileName + "\n"); File folder = new File(fileName); File testsFolder = null; String sTestName; int iCounter = 0; //search of devices and their tests //Scan the list of devices File[] listOfFiles = folder.listFiles(); for (File listOfFile : listOfFiles) { if (listOfFile.isFile()) { this.jTextField1.append("\nFile " + listOfFile.getName()); } else if (listOfFile.isDirectory()) { this.jTextField1.append("\nDirectory " + listOfFile.getName()); 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"); this.jTextField1.append("\nTest suite: " + sTestName); testsFolder = new File(sTestName); if (testsFolder.exists() && testsFolder.isDirectory()) { File[] listOfTests = testsFolder.listFiles(); for (File listOfTest : listOfTests) { if (listOfTest.isDirectory()) { this.jTextField1.append("\nTest: " + listOfTest.getPath()); 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")); this.jTextField1.append("\nProperties: "); this.jTextField1.append(propDevice.getProperty("name")); this.jTextField1.append(propDevice.getProperty("description")); this.jTextField1.append(propDevice.getProperty("tests")); this.jTextField1.append(propTest.getProperty("name")); iCounter++; } } } } } } } logger.log(Level.INFO, iCounter + " tests loaded."); } public void selectFile() { final JFileChooser fc = new JFileChooser(); int returnVal = fc.showOpenDialog(NetbeansPluginPanel.this); if (returnVal == JFileChooser.APPROVE_OPTION) { File file = fc.getSelectedFile(); //This is where a real application would open the file. System.out.println("Opening: " + file.getName() + "."); } else { System.out.println("Open command cancelled by user."); } } } }