/[projects]/miscJava/CircuitBreaker/src/main/java/dk/thoerup/circuitbreaker/web/ViewCircuitBreaker.java
ViewVC logotype

Diff of /miscJava/CircuitBreaker/src/main/java/dk/thoerup/circuitbreaker/web/ViewCircuitBreaker.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1287 by torben, Mon Apr 11 07:58:57 2011 UTC revision 2075 by torben, Sat Nov 23 10:25:05 2013 UTC
# Line 1  Line 1 
1  package dk.thoerup.circuitbreaker.web;  package dk.thoerup.circuitbreaker.web;
2    
3  import java.util.Date;  import java.util.Date;
4    import java.util.Formatter;
5  import java.util.LinkedList;  import java.util.LinkedList;
6    
7  import javax.servlet.http.HttpServletRequest;  import javax.servlet.http.HttpServletRequest;
# Line 47  public class ViewCircuitBreaker implemen Line 48  public class ViewCircuitBreaker implemen
48                  return sb.toString();                  return sb.toString();
49          }          }
50                    
51          public String formatDate(long date) {          public static String formatDate(long date) {
52                  if (date == 0L) {                  if (date == 0L) {
53                          return "-";                          return "-";
54                  } else {                  } else {
# Line 82  public class ViewCircuitBreaker implemen Line 83  public class ViewCircuitBreaker implemen
83                                    
84                  if (breaker instanceof AccountingCircuitBreaker) {                  if (breaker instanceof AccountingCircuitBreaker) {
85                          AccountingCircuitBreaker acb = (AccountingCircuitBreaker) breaker;                          AccountingCircuitBreaker acb = (AccountingCircuitBreaker) breaker;
86            
87                            StringBuilder sbf = new StringBuilder();
88                            if (acb.getTotalCallCount() > 0) {
89                                    double failure_percentage = ((double) acb.getTotalFailureCount()*100) / ((double) acb.getTotalCallCount() );
90                                    Formatter formatter = new Formatter(sbf);
91                                    formatter.format("%.2f", failure_percentage);
92                                    formatter.close();
93                            } else {
94                                    sbf.append("0.0");
95                            }
96                            
97    
98                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");
99                          sb.append("<tr><td>Trip count</td><td>").append( acb.getTripCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Trip count</td><td>").append( acb.getTripCount() ).append("</td></tr>\n");
100                          sb.append("<tr><td>Re-trip count</td><td>").append( acb.getRetripCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Re-trip count</td><td>").append( acb.getRetripCount() ).append("</td></tr>\n");
101                          sb.append("<tr><td>Block count</td><td>").append( acb.getBlockCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Block count</td><td>").append( acb.getBlockCount() ).append("</td></tr>\n");
102                          sb.append("<tr><td>Total failure count</td><td>").append( acb.getTotalFailureCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Total failure count</td><td>").append( acb.getTotalFailureCount() ).append("</td></tr>\n");
103                          sb.append("<tr><td>Total Call count</td><td>").append( acb.getTotalCallCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Total Call count</td><td>").append( acb.getTotalCallCount() ).append("</td></tr>\n");
104                            sb.append("<tr><td>Failure Percentage</td><td>").append( sbf.toString() ).append("%</td></tr>\n");
105                          sb.append("<tr><td>Last failure</td><td>").append( formatDate(acb.getLastFailure()) ).append("</td></tr>\n");                          sb.append("<tr><td>Last failure</td><td>").append( formatDate(acb.getLastFailure()) ).append("</td></tr>\n");
106                          sb.append("<tr><td>Last trip</td><td>").append( formatDate(acb.getLastTrip()) ).append("</td></tr>\n");                          sb.append("<tr><td>Last trip</td><td>").append( formatDate(acb.getLastTrip()) ).append("</td></tr>\n");
107                          sb.append("<tr><td>Last re-trip</td><td>").append( formatDate(acb.getLastRetrip()) ).append("</td></tr>\n");                          sb.append("<tr><td>Last re-trip</td><td>").append( formatDate(acb.getLastRetrip()) ).append("</td></tr>\n");
# Line 100  public class ViewCircuitBreaker implemen Line 114  public class ViewCircuitBreaker implemen
114                          LoggingCircuitBreaker lcb = (LoggingCircuitBreaker) breaker;                                              LoggingCircuitBreaker lcb = (LoggingCircuitBreaker) breaker;                    
115                                                    
116                          LinkedList<LoggingCircuitBreaker.LogEntry> list = lcb.getLog();                          LinkedList<LoggingCircuitBreaker.LogEntry> list = lcb.getLog();
117                            String headerLink = String.format("<a href=\"%s?command=log&breaker=%s\">Logging</a>", req.getRequestURI(), breaker.getName() );
118    
119                          sb.append("<tr><th colspan=\"2\">Logging</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">").append(headerLink).append("</th></tr>\n");
120                          for(LoggingCircuitBreaker.LogEntry entry : list) {                          
121                            int max = list.size() > 10 ? 10 : list.size();                  
122                            for (int i=0; i<max; i++) {
123                                    LoggingCircuitBreaker.LogEntry entry = list.get(i);
124                                  sb.append("<tr><td colspan=\"2\">");                                  sb.append("<tr><td colspan=\"2\">");
125                                  sb.append( formatDate(entry.time) ).append(" : ").append(entry.event);                                                            sb.append( entry.toString() );                          
126                                  sb.append("</td></tr>");                                  sb.append("</td></tr>");
127                          }                          }
128                  }                  }
# Line 119  public class ViewCircuitBreaker implemen Line 137  public class ViewCircuitBreaker implemen
137                          if (breaker instanceof AccountingCircuitBreaker ) {                          if (breaker instanceof AccountingCircuitBreaker ) {
138                                  sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");                                      sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");    
139                          }                          }
140                            if (breaker instanceof LoggingCircuitBreaker ) {
141                                    sb.append( actionBuilder(uri, "clearLog", breaker.getName())).append("<br>\n");
142                            }
143                  } else {                  } else {
144                          sb.append("<i>the CircuitBreakers can only be viewed</i>");                          sb.append("<i>the CircuitBreakers can only be viewed</i>");
145                  }                  }

Legend:
Removed from v.1287  
changed lines
  Added in v.2075

  ViewVC Help
Powered by ViewVC 1.1.20