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

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

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

revision 1285 by torben, Mon Apr 11 07:52:15 2011 UTC revision 1845 by torben, Fri Aug 31 06:33:37 2012 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                            double failure_percentage = ((double) acb.getTotalFailureCount()*100) / ((double) acb.getTotalCallCount() );
88                            StringBuilder sbf = new StringBuilder();
89                            Formatter formatter = new Formatter(sb);
90                            formatter.format("%.2f", failure_percentage);
91                            
92    
93                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");
94                          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");
95                          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");
96                          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");
97                          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");
98                          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");
99                            sb.append("<tr><td>Failure Percentage</td><td>").append( sbf.toString() ).append("%</td></tr>\n");
100                          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");
101                          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");
102                          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 109  public class ViewCircuitBreaker implemen
109                          LoggingCircuitBreaker lcb = (LoggingCircuitBreaker) breaker;                                              LoggingCircuitBreaker lcb = (LoggingCircuitBreaker) breaker;                    
110                                                    
111                          LinkedList<LoggingCircuitBreaker.LogEntry> list = lcb.getLog();                          LinkedList<LoggingCircuitBreaker.LogEntry> list = lcb.getLog();
112                            String headerLink = String.format("<a href=\"%s?command=log&breaker=%s\">Logging</a>", req.getRequestURI(), breaker.getName() );
113    
114                          sb.append("<tr><th colspan=\"2\">Logging</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">").append(headerLink).append("</th></tr>\n");
115                          for(LoggingCircuitBreaker.LogEntry entry : list) {                          
116                                  sb.append("<tr><td>");                          int max = list.size() > 10 ? 10 : list.size();                  
117                                  sb.append( formatDate(entry.time) ).append(" : ").append(entry.event);                                                    for (int i=0; i<max; i++) {
118                                    LoggingCircuitBreaker.LogEntry entry = list.get(i);
119                                    sb.append("<tr><td colspan=\"2\">");
120                                    sb.append( entry.toString() );                          
121                                  sb.append("</td></tr>");                                  sb.append("</td></tr>");
122                          }                          }
123                  }                  }
# Line 119  public class ViewCircuitBreaker implemen Line 132  public class ViewCircuitBreaker implemen
132                          if (breaker instanceof AccountingCircuitBreaker ) {                          if (breaker instanceof AccountingCircuitBreaker ) {
133                                  sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");                                      sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");    
134                          }                          }
135                            if (breaker instanceof LoggingCircuitBreaker ) {
136                                    sb.append( actionBuilder(uri, "clearLog", breaker.getName())).append("<br>\n");
137                            }
138                  } else {                  } else {
139                          sb.append("<i>the CircuitBreakers can only be viewed</i>");                          sb.append("<i>the CircuitBreakers can only be viewed</i>");
140                  }                  }

Legend:
Removed from v.1285  
changed lines
  Added in v.1845

  ViewVC Help
Powered by ViewVC 1.1.20