| <!DOCTYPE html> | |
| <!-- saved from url=(0039)http://wingsrom.ro/trxer/trxExample.htm --> | |
| <html xmlns:t="http://microsoft.com/schemas/VisualStudio/TeamTest/2010" xmlns:trxreport="urn:my-scripts"> | |
| <head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> | |
| <link href="bootstrap.min.css" rel="stylesheet"> | |
| <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js" type="application/javascript"></script> | |
| <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" type="application/javascript"></script> | |
| <style> | |
| .wrapOverall { | |
| width: auto; | |
| margin: -8px 0px 0px 0px; | |
| height: auto; | |
| margin-left: auto; | |
| margin-right: auto; | |
| } | |
| .hWhite { | |
| color: white; | |
| } | |
| .titleCenterd { | |
| position: relative; | |
| top: 12px; | |
| } | |
| .StatusesBorders { | |
| border-width: 0; | |
| border-right: 1px solid; | |
| border-left: 1px solid; | |
| width: 100px; | |
| } | |
| .PackageStatus { | |
| width: 100px; | |
| } | |
| .SummaryTable { | |
| width: auto; | |
| max-width: 407px; | |
| float: left; | |
| margin-right: 20px; | |
| } | |
| #divToRefresh > div > table.SummaryTable > tbody > tr > th { | |
| width: auto; | |
| } | |
| .DetailsTable { | |
| width: auto; | |
| max-width: 407px; | |
| float: left; | |
| margin-right: 20px; | |
| text-align: left; | |
| word-wrap: break-word; | |
| } | |
| .StatusesTable { | |
| width: auto; | |
| } | |
| #divToRefresh > div.SummaryDiv > table.DetailsTable > tbody > tr > td { | |
| text-align: left; | |
| word-wrap: break-word; | |
| } | |
| #divToRefresh > div.SummaryDiv > table.DetailsTable > tbody > tr > th { | |
| width: 30px; | |
| } | |
| #TotalTestsTable { | |
| min-width: 250px; | |
| width: auto; | |
| float: left; | |
| margin-right: 20px; | |
| } | |
| .SummaryDiv { | |
| width: 90%; | |
| border-top: 1px solid #e5eff8; | |
| border-right: 1px solid #e5eff8; | |
| margin: 1em auto 1em 195px; | |
| border-collapse: collapse; | |
| } | |
| .Summary { | |
| float: left; | |
| border-collapse: collapse; | |
| } | |
| .Atached { | |
| width: 30px; | |
| } | |
| .column1 { | |
| background: rgb(245, 244, 242); | |
| width: 170px; | |
| } | |
| .column1Failed { | |
| background: #d8534f; | |
| width: 30px; | |
| } | |
| #ReportsTable > tbody > tr > th { | |
| background: #E8E8E8; | |
| width: 170px; | |
| } | |
| #dataViewer { | |
| width: 240px; | |
| } | |
| .hiddenRow { | |
| display: none; | |
| visibility: hidden; | |
| } | |
| .visibleRow { | |
| visibility: visible; | |
| } | |
| .atachmentImage { | |
| float: right; | |
| cursor: pointer; | |
| width: 20px; | |
| height: 20px; | |
| background-size: 20px 20px; | |
| background-image: url(''); | |
| } | |
| </style> | |
| <style> | |
| tr.odd .column1 { | |
| background: rgb(245, 244, 242); | |
| } | |
| tr.odd.column1Failed { | |
| background: #a90000; | |
| width: 30px; | |
| } | |
| tr.odd.column1Warn { | |
| background: #efac4e; | |
| width: 30px; | |
| } | |
| tr.odd.column1Passed { | |
| background: #339833; | |
| width: 30px; | |
| } | |
| tr.odd td, tr.sep td { | |
| background: #FFFFFF; | |
| } | |
| tr.odd .ex, | |
| tr.sep .ex, | |
| td.ex { | |
| text-align: left; | |
| width: 100px; | |
| } | |
| th.statusCount, | |
| td.statusCount { | |
| width: auto; | |
| } | |
| td.slowest { | |
| width: auto; | |
| } | |
| td.Message { | |
| text-align: center; | |
| width: auto; | |
| word-wrap: break-word; | |
| } | |
| td.Messages { | |
| text-align: left; | |
| width: auto; | |
| word-wrap: break-word; | |
| max-width: 550px; | |
| } | |
| td.Function { | |
| text-align: left; | |
| } | |
| td.outcomeMessage { | |
| max-width: 240px; | |
| } | |
| tr.odd .failed, | |
| tr.sep.failed, | |
| td.failed, | |
| tr.odd .info, | |
| td.info, | |
| tr.sep .info, | |
| tr.odd .passed, | |
| tr.sep.passed, | |
| tr.odd .warn, | |
| tr.sep .warn, | |
| td.warn, | |
| td.passed { | |
| width: 90px; | |
| } | |
| thead th.TestsTable { | |
| font-size: 17px; | |
| font-weight: normal; | |
| } | |
| td.testOutputs { | |
| border-top: none; | |
| } | |
| td.testOutputsTitle { | |
| color: black; | |
| font-weight: bold; | |
| text-align: left; | |
| border: 1px solid rgb(221, 221, 221); | |
| } | |
| </style> | |
| <style>.stacktraceButton { | |
| float: right; | |
| width: 20px; | |
| height: 20px; | |
| cursor: pointer; | |
| background-size: 20px 20px; | |
| background-image: url(''); | |
| } | |
| .stdErrButton { | |
| float: right; | |
| width: 20px; | |
| height: 20px; | |
| cursor: pointer; | |
| background-size: 20px 20px; | |
| background-image: url(''); | |
| } | |
| .stdOutButton { | |
| float: right; | |
| width: 20px; | |
| height: 20px; | |
| cursor: pointer; | |
| background-size: 20px 20px; | |
| background-image: url(''); | |
| } | |
| .testBaseActionButton { | |
| float: right; | |
| width: 20px; | |
| height: 20px; | |
| cursor: pointer; | |
| background-size: 20px 20px; | |
| } | |
| .OpenMoreButton { | |
| height: auto; | |
| width: 200px; | |
| cursor: pointer; | |
| text-decoration: none; | |
| text-align: center; | |
| color: #1b99fb; | |
| background-color: white; | |
| border: 1px solid #7ac5ff; | |
| float: right; | |
| } | |
| .OpenStacktraceButton { | |
| height: auto; | |
| width: 200px; | |
| cursor: pointer; | |
| text-decoration: none; | |
| text-align: center; | |
| color: #1b99fb; | |
| background-color: white; | |
| border: 1px solid #7ac5ff; | |
| float: right; | |
| } | |
| .OpenMoreButton:hover { | |
| background-color: #bfe3ff; | |
| text-decoration: none; | |
| } | |
| #btn-download { | |
| font-size: 14px; | |
| } | |
| #MoreButtonText { | |
| color: #1b99fb; | |
| top: 0; | |
| left: 25px; | |
| font-weight: normal; | |
| text-align: center; | |
| font-size: 15px; | |
| font-family: "Trebuchet MS", Arial, Helvetica, sans-serif; | |
| } | |
| </style> | |
| <style>#floatingImageDock { | |
| background-color: #000000; | |
| height: 60px; | |
| width: 100%; | |
| top: 0px; | |
| position: absolute; | |
| } | |
| #floatingGrayBackground { | |
| background-color: #000000; | |
| opacity: 0.8; | |
| position: fixed; | |
| left: 0px; | |
| top: 0px; | |
| float: left; | |
| width: 100%; | |
| height: 100%; | |
| display: none; | |
| z-index: 1; | |
| } | |
| #leftButton { | |
| float: left; | |
| position: fixed; | |
| } | |
| #imageViewTable { | |
| border: none; | |
| } | |
| .arrowCell { | |
| width: 40px; | |
| } | |
| #rightBtton img { | |
| float: right; | |
| position: fixed; | |
| } | |
| img.displayed { | |
| display: block; | |
| margin-left: auto; | |
| margin-right: auto; | |
| } | |
| .floatingImageCloseButton { | |
| color: white; | |
| font-size: 30px; | |
| width: 40px; | |
| height: 40px; | |
| margin-top: -20px; | |
| text-align: center; | |
| cursor: pointer; | |
| float: right; | |
| background-repeat: no-repeat; | |
| } | |
| #floatingImageTitle { | |
| color: white; | |
| font-size: 20px; | |
| text-align: center; | |
| margin-top: 20px; | |
| float: inherit; | |
| margin-left: auto; | |
| margin-right: auto; | |
| top: 50%; | |
| left: 50%; | |
| } | |
| #floatingImageBackground { | |
| /* TODO set a width and height here */ | |
| visibility: hidden; | |
| } | |
| #wrapperView { | |
| position: absolute; | |
| left: 50%; | |
| top: 50%; /*move the object to the center of the parent object*/ | |
| -webkit-transform: translate(-50%, -50%); | |
| -moz-transform: translate(-50%, -50%); | |
| -ms-transform: translate(-50%, -50%); | |
| -o-transform: translate(-50%, -50%); | |
| transform: translate(-50%, -50%); | |
| /*these 5 settings change the base (or registration) point of the wrapper object to it's own center - so we align child center with parent center*/ | |
| } | |
| .closeImageViewButton { | |
| float: right; | |
| color: white; | |
| font-size: 20px; | |
| cursor: pointer; | |
| width: 90%; | |
| } | |
| #leftArrow { | |
| width: 41px; | |
| height: 74px; | |
| cursor: pointer; | |
| background-size: 41px 74px; | |
| background-image: url(''); | |
| } | |
| #rightArrow { | |
| width: 41px; | |
| height: 74px; | |
| cursor: pointer; | |
| background-size: 41px 74px; | |
| background-image: url(''); | |
| } | |
| div#navigation { | |
| position: fixed; | |
| width: 100%; | |
| z-index: 100; | |
| top: 50%; | |
| transform: translateY(-50%); | |
| } | |
| div#navigation table { | |
| width: auto; | |
| border: none; | |
| border-top: none; | |
| } | |
| div#navigation table td { | |
| border-top: none; | |
| } | |
| div#navigation table { | |
| margin-left: auto; | |
| margin-right: auto; | |
| } | |
| .overFlowImage { | |
| width: 100%; | |
| position: relative; | |
| display: inline-block; | |
| /* overflow: hidden; */ | |
| } | |
| .overFlowImage img { | |
| /* position: absolute; */ | |
| /* top: 50%; */ | |
| /* min-height: 100%; */ | |
| /* display: block; */ | |
| /* left: 50%; */ | |
| /* -webkit-transform: translate(-50%, -50%); */ | |
| /* min-width: 100%; */ | |
| width: 100%; | |
| height: 100%; | |
| max-width: 80%; | |
| } | |
| </style> | |
| <style> | |
| .alert-status-failed { | |
| background-color: #f2dede; | |
| color: #a94442; | |
| border: 1px solid rgb(221, 221, 221); | |
| border-top: none; | |
| text-align: left; | |
| max-width: 30px; | |
| } | |
| .alert-status-out { | |
| background-color: #d8f2ff; | |
| color: #4f8fae; | |
| border: 1px solid rgb(221, 221, 221); | |
| border-top: none; | |
| text-align: left; | |
| max-width: 30px; | |
| } | |
| .alert-status-err { | |
| background-color: #ffeea4; | |
| color: #efca28; | |
| border: 1px solid rgb(221, 221, 221); | |
| border-top: none; | |
| text-align: left; | |
| max-width: 30px; | |
| } | |
| .Tag { | |
| display: inline; | |
| padding-left: 3px; | |
| padding-right: 3px; | |
| margin-right: 4px; | |
| text-align: center; | |
| margin-bottom: 2px; | |
| line-height: 27px; | |
| height: auto; | |
| } | |
| .NumberTag { | |
| color: #678197; | |
| border: 1px solid #78bcff; | |
| border-radius: 8px; | |
| } | |
| .StatusTag { | |
| color: white; | |
| font-size: 80%; | |
| background-color: #ffffff; | |
| border-radius: .25em; | |
| } | |
| .NumberTagRed { | |
| background-color: #d8534f; | |
| } | |
| .NumberTagGreen { | |
| background-color: #5bab5b; | |
| } | |
| .NumberTagYellow { | |
| background-color: #efac4e; | |
| } | |
| .graphsDiv { | |
| text-align: center; | |
| margin-bottom: 2px; | |
| line-height: 27px; | |
| height: 10px; | |
| float: left; | |
| } | |
| .StatusBar { | |
| width: 100%; | |
| height: 60px; | |
| } | |
| .statusBarInner { | |
| position: relative; | |
| width: 100%; | |
| height: 70%; | |
| margin-left: auto; | |
| margin-right: auto; | |
| margin-top: auto; | |
| margin-bottom: auto; | |
| top: 15%; | |
| } | |
| .statusBarPassed, | |
| .statusBarCompleted { | |
| background-color: #5bab5b; | |
| } | |
| .statusBarFailed, | |
| .statusBarError { | |
| background-color: #b93333; | |
| } | |
| .statusBarFailedInner, | |
| .statusBarErrorInner { | |
| background-color: #a90000; | |
| } | |
| .statusBarPassedInner, | |
| .statusBarCompletedInner { | |
| background-color: #339833; | |
| } | |
| </style> | |
| <style>.tooltip { | |
| display: inline; | |
| position: relative; | |
| } | |
| .tooltip:hover:after { | |
| background: #333; | |
| background: rgba(0, 0, 0, .8); | |
| border-radius: 5px; | |
| bottom: 26px; | |
| color: #fff; | |
| content: attr(title); | |
| padding: 5px 15px; | |
| position: absolute; | |
| z-index: 98; | |
| max-width: 300px; | |
| width: auto; | |
| } | |
| </style> | |
| <style> | |
| html, | |
| body, | |
| form, | |
| fieldset, | |
| h2, | |
| h3, | |
| h4, | |
| h5, | |
| h6, | |
| p, | |
| pre, | |
| blockquote, | |
| ul, | |
| ol, | |
| dl, | |
| address { | |
| margin: 0; | |
| padding: 0; | |
| } | |
| h1 { | |
| font-size: 25px; | |
| } | |
| body { | |
| font: 16px/20px "Trebuchet MS", Verdana, Arial, Helvetica, sans-serif; | |
| margin-top: -10px; | |
| min-width: 890px; | |
| } | |
| p { | |
| text-align: center; | |
| } | |
| a:link { | |
| color: #d42945; | |
| text-decoration: none; | |
| border-bottom: 1px dotted #ffbac8; | |
| } | |
| a:visited { | |
| color: #d42945; | |
| border-bottom: none; | |
| text-decoration: none; | |
| } | |
| a:hover, | |
| a:focus { | |
| color: #f03b58; | |
| border-bottom: 1px solid #f03b58; | |
| text-decoration: none; | |
| } | |
| table a, | |
| table a:link, | |
| table a:visited { | |
| border: none; | |
| } | |
| img { | |
| border: 0; | |
| margin-top: .5em; | |
| } | |
| table { | |
| width: 90%; | |
| margin: 1em auto; | |
| border-collapse: collapse; | |
| border: 1px solid #a2caf2; | |
| } | |
| caption { | |
| color: #9ba9b4; | |
| font-size: 16px; | |
| letter-spacing: .2em; | |
| margin: 1em 0 0 0; | |
| padding: 0; | |
| caption-side: top; | |
| text-align: center; | |
| font-weight: normal; | |
| border-top: 1px solid #a2caf2; | |
| border-left: 1px solid #a2caf2; | |
| border-right: 1px solid #a2caf2; | |
| } | |
| td { | |
| color: #425b71; | |
| ; | |
| padding: .3em 1em; | |
| text-align: center; | |
| border-top: 1px solid #a2caf2; | |
| word-wrap: break-word; | |
| } | |
| th { | |
| font-weight: normal; | |
| color: #678197; | |
| text-align: left; | |
| border-top: 1px solid #a2caf2; | |
| padding: .3em 1em; | |
| } | |
| thead th { | |
| background: rgb(245, 244, 242); | |
| text-align: center; | |
| font: bold 1.2em/2em "Century Gothic", "Trebuchet MS", Arial, Helvetica, sans-serif; | |
| color: #66a3d3; | |
| }</style> | |
| <style>/* | |
| make each pie piece a rectangle twice as high as it is wide. | |
| move the transform origin to the middle of the left side. | |
| Also ensure that overflow is set to hidden. | |
| */ | |
| .pie { | |
| position: absolute; | |
| width: 100px; | |
| height: 200px; | |
| overflow: hidden; | |
| left: 150px; | |
| -moz-transform-origin: left center; | |
| -ms-transform-origin: left center; | |
| -o-transform-origin: left center; | |
| -webkit-transform-origin: left center; | |
| transform-origin: left center; | |
| } | |
| /* | |
| unless the piece represents more than 50% of the whole chart. | |
| then make it a square, and ensure the transform origin is | |
| back in the center. | |
| NOTE: since this is only ever a single piece, you could | |
| move this to a piece specific rule and remove the extra class | |
| */ | |
| .pie.big { | |
| width: 200px; | |
| height: 200px; | |
| left: 50px; | |
| -moz-transform-origin: center center; | |
| -ms-transform-origin: center center; | |
| -o-transform-origin: center center; | |
| -webkit-transform-origin: center center; | |
| transform-origin: center center; | |
| } | |
| /* | |
| this is the actual visible part of the pie. | |
| Give it the same dimensions as the regular piece. | |
| Use border radius make it a half circle. | |
| move transform origin to the middle of the right side. | |
| Push it out to the left of the containing box. | |
| */ | |
| .pie:BEFORE { | |
| content: ""; | |
| position: absolute; | |
| width: 100px; | |
| height: 200px; | |
| left: -100px; | |
| border-radius: 100px 0 0 100px; | |
| -moz-transform-origin: right center; | |
| -ms-transform-origin: right center; | |
| -o-transform-origin: right center; | |
| -webkit-transform-origin: right center; | |
| transform-origin: right center; | |
| } | |
| /* if it's part of a big piece, bring it back into the square */ | |
| .pie.big:BEFORE { | |
| left: 0px; | |
| } | |
| /* | |
| big pieces will also need a second semicircle, pointed in the | |
| opposite direction to hide the first part behind. | |
| */ | |
| .pie.big:AFTER { | |
| content: ""; | |
| position: absolute; | |
| width: 100px; | |
| height: 200px; | |
| left: 100px; | |
| border-radius: 0 100px 100px 0; | |
| } | |
| /* | |
| add colour to each piece. | |
| */ | |
| .pie:nth-of-type(1):BEFORE, | |
| .pie:nth-of-type(1):AFTER { | |
| background-color: #fad446; | |
| } | |
| .pie:nth-of-type(2):AFTER, | |
| .pie:nth-of-type(2):BEFORE { | |
| background-color: #5bab5b; | |
| } | |
| .pie:nth-of-type(3):AFTER, | |
| .pie:nth-of-type(3):BEFORE { | |
| background-color: #d8534f; | |
| } | |
| .pie:nth-of-type(4):AFTER, | |
| .pie:nth-of-type(4):BEFORE { | |
| background-color: orange; | |
| } | |
| /* | |
| now rotate each piece based on their cumulative starting | |
| position | |
| */ | |
| .pie[data-start="30"] { | |
| -moz-transform: rotate(30deg); /* Firefox */ | |
| -ms-transform: rotate(30deg); /* IE */ | |
| -webkit-transform: rotate(30deg); /* Safari and Chrome */ | |
| -o-transform: rotate(30deg); /* Opera */ | |
| transform: rotate(30deg); | |
| } | |
| .pie[data-start="60"] { | |
| -moz-transform: rotate(60deg); /* Firefox */ | |
| -ms-transform: rotate(60deg); /* IE */ | |
| -webkit-transform: rotate(60deg); /* Safari and Chrome */ | |
| -o-transform: rotate(60deg); /* Opera */ | |
| transform: rotate(60deg); | |
| } | |
| .pie[data-start="100"] { | |
| -moz-transform: rotate(100deg); /* Firefox */ | |
| -ms-transform: rotate(100deg); /* IE */ | |
| -webkit-transform: rotate(100deg); /* Safari and Chrome */ | |
| -o-transform: rotate(100deg); /* Opera */ | |
| transform: rotate(100deg); | |
| } | |
| /* | |
| and rotate the amount of the pie that's showing. | |
| NOTE: add an extra degree to all but the final piece, | |
| to fill in unsightly gaps. | |
| */ | |
| .pie[data-value="30"]:BEFORE { | |
| -moz-transform: rotate(31deg); /* Firefox */ | |
| -ms-transform: rotate(31deg); /* IE */ | |
| -webkit-transform: rotate(31deg); /* Safari and Chrome */ | |
| -o-transform: rotate(31deg); /* Opera */ | |
| transform: rotate(31deg); | |
| } | |
| .pie[data-value="40"]:BEFORE { | |
| -moz-transform: rotate(41deg); /* Firefox */ | |
| -ms-transform: rotate(41deg); /* IE */ | |
| -webkit-transform: rotate(41deg); /* Safari and Chrome */ | |
| -o-transform: rotate(41deg); /* Opera */ | |
| transform: rotate(41deg); | |
| } | |
| .pie[data-value="260"]:BEFORE { | |
| -moz-transform: rotate(260deg); /* Firefox */ | |
| -ms-transform: rotate(260deg); /* IE */ | |
| -webkit-transform: rotate(260deg); /* Safari and Chrome */ | |
| -o-transform: rotate(260deg); /* Opera */ | |
| transform: rotate(260deg); | |
| } | |
| /* | |
| NOTE: you could also apply custom classes (i.e. .s0 .v30) | |
| but if the CSS3 attr() function proposal ever gets implemented, | |
| then all the above custom piece rules could be replaced with | |
| the following: | |
| .pie[data-start] { | |
| transform:rotate(attr(data-start,deg,0); | |
| } | |
| .pie[data-value]:BEFORE { | |
| transform:rotate(attr(data-value,deg,0); | |
| } | |
| */</style><script language="javascript" type="text/javascript"> | |
| var myColor = ["#5bab5b", "#d8534f", "#fad446"]; //green,red,yellow | |
| function ShowHideWithChange(id1, id2, textOnHide, textOnShow) { | |
| if (document.getElementById(id1).className == 'visibleRow') { | |
| document.getElementById(id2).innerHTML = textOnHide; | |
| document.getElementById(id1).className = 'hiddenRow'; | |
| } else { | |
| document.getElementById(id2).innerHTML = textOnShow; | |
| document.getElementById(id1).className = 'visibleRow'; | |
| } | |
| } | |
| function ShowHide(id1) { | |
| if (document.getElementById(id1).className == 'visibleRow') { | |
| document.getElementById(id1).className = 'hiddenRow'; | |
| } else { | |
| document.getElementById(id1).className = 'visibleRow'; | |
| } | |
| } | |
| function AddEventListener() { | |
| var button = document.getElementById('btn-download'); | |
| button.addEventListener('click', function() { | |
| button.href = canvas.toDataURL('image/png'); | |
| }); | |
| } | |
| function show(id) { | |
| document.getElementById(id).style.visibility = "visible"; | |
| document.getElementById(id).style.display = "block"; | |
| } | |
| function hide(id) { | |
| document.getElementById(id).style.visibility = "hidden"; | |
| document.getElementById(id).style.display = "none"; | |
| } | |
| function updateFloatingImage(url) { | |
| document.getElementById('floatingImage').src = url; | |
| } | |
| /** | |
| * @return {number} | |
| */ | |
| function GetTotal() { | |
| var myTotal = 0; | |
| for (var j = 0; j < myData.length; j++) { | |
| myTotal += (typeof myData[j] == 'number') ? myData[j] : 0; | |
| } | |
| return myTotal; | |
| } | |
| function CreateHorizontalBars(id, totalPass, totalFailed, totalWarn) { | |
| if (isNaN(totalPass) || isNaN(totalFailed) || isNaN(totalWarn)) { | |
| drawLine(30, 4.5, 3, 30.5, id); | |
| } | |
| var canvas; | |
| var ctx; | |
| var myArray = new Array(3); | |
| myArray[0] = totalPass; | |
| myArray[1] = totalFailed; | |
| myArray[2] = totalWarn; | |
| canvas = document.getElementById(id); | |
| ctx = canvas.getContext("2d"); | |
| var cw = canvas.width; | |
| var ch = canvas.height; | |
| var width = 6; | |
| var currX = -12; | |
| ctx.translate(cw / 2, ch / 2); | |
| ctx.rotate(Math.PI / 2); | |
| ctx.restore(); | |
| for (var i = 0; i < myArray.length; i++) { | |
| ctx.moveTo(100, 0); | |
| ctx.fillStyle = myColor[i]; | |
| var h = myArray[i]; | |
| ctx.fillRect(currX, (canvas.height - h) + 25, width, h); | |
| currX += width + 1; | |
| } | |
| } | |
| function CreatePie() { | |
| var canvas; | |
| var ctx; | |
| var lastend = 0; | |
| var myTotal = GetTotal(); | |
| canvas = document.getElementById('canvas'); | |
| ctx = canvas.getContext('2d'); | |
| ctx.clearRect(0, 0, canvas.width, canvas.height); | |
| CreateText(); | |
| for (var i = 0; i < myData.length; i++) { | |
| ctx.fillStyle = myColor[i]; | |
| ctx.beginPath(); | |
| ctx.moveTo(160, 75); | |
| ctx.arc(160, 75, 75, lastend, lastend + | |
| (Math.PI * 2 * (myData[i] / myTotal)), false); | |
| ctx.lineTo(160, 75); | |
| ctx.fill(); | |
| lastend += Math.PI * 2 * (myData[i] / myTotal); | |
| ctx.arc(160, 75, 40, 0, Math.PI * 2); | |
| } | |
| // either change this to the background color,CalculateTestsStatuses or use the global composition | |
| ctx.globalCompositeOperation = "destination-out"; | |
| ctx.beginPath(); | |
| ctx.moveTo(160, 35); | |
| ctx.arc(160, 75, 40, 0, Math.PI * 2); | |
| ctx.fill(); | |
| ctx.closePath(); | |
| // if using the global composition method, make sure to change it back to default. | |
| ctx.globalCompositeOperation = "source-over"; | |
| } | |
| function drawLine(x1, y1, x2, y2, id) { | |
| var canvas = document.getElementById(id); | |
| var context = canvas.getContext("2d"); | |
| for (var i = 0; i < 8; i++) { | |
| context.fillStyle = '#000'; | |
| context.strokeStyle = '#B0B0B0'; | |
| context.beginPath(); | |
| context.moveTo(x1, y1); | |
| context.lineTo(x2, y2); | |
| context.lineWidth = 1; | |
| context.stroke(); | |
| context.closePath(); | |
| x1 += 10; | |
| y2 += 10; | |
| } | |
| } | |
| function CreateText() { | |
| var canvas; | |
| var ctx; | |
| var textPosY = 50; | |
| var textPosX = 0; | |
| canvas = document.getElementById("canvas"); | |
| ctx = canvas.getContext("2d"); | |
| ctx.clearRect(0, 0, canvas.width, canvas.height); | |
| for (var i = 0; i < myData.length; i++) { | |
| ctx.fillStyle = myColor[i]; | |
| ctx.font = "15px arial"; | |
| ctx.fillText(myParsedData[i], textPosX, textPosY); | |
| textPosY += 35; | |
| } | |
| } | |
| var allPassed = 0; | |
| var allFailed = 0; | |
| var allWarns = 0; | |
| var myData = []; | |
| var myParsedData = []; | |
| function CalculateTotalPrecents() { | |
| var totalTests = allPassed + allFailed + allWarns; | |
| var passedPrec = (allPassed / totalTests) * 100; | |
| var failedPrec = (allFailed / totalTests) * 100; | |
| var warnPrec = (allWarns / totalTests) * 100; | |
| myData.push(passedPrec); | |
| myData.push(failedPrec); | |
| myData.push(warnPrec); | |
| myParsedData.push(allPassed + " (" + Math.round(passedPrec).toFixed(2) + "%)"); | |
| myParsedData.push(allFailed + " (" + Math.round(failedPrec).toFixed(2) + "%)"); | |
| myParsedData.push(allWarns + " (" + Math.round(warnPrec).toFixed(2) + "%)"); | |
| document.getElementById('dataViewer').innerHTML = "<tr class='odd'><td><canvas id='canvas' width='240' height='150'>This text is displayed if your browser does not support HTML5 Canvas.</canvas></td></tr>"; | |
| CreatePie(); | |
| AddEventListener(); | |
| } | |
| function CalculateTestsStatuses(testContaineId, classId) { | |
| var totalPassed = 0; | |
| var totalFailed = 0; | |
| var totalInconclusive = 0; | |
| var e = document.getElementById(testContaineId); | |
| var tests = e.getElementsByClassName('Test'); | |
| for (var i = 0; i < tests.length; i++) { | |
| var test = tests[i]; | |
| if (test.getElementsByClassName('warn').length > 0) { | |
| totalInconclusive++; | |
| allWarns++; | |
| } else if (test.getElementsByClassName('failed').length > 0) { | |
| totalFailed++; | |
| allFailed++; | |
| } else if (test.getElementsByClassName('passed').length > 0) { | |
| totalPassed++; | |
| allPassed++; | |
| } | |
| } | |
| var totalTests = totalFailed + totalInconclusive + totalPassed; | |
| var passedPrec = (totalPassed / totalTests) * 100; | |
| var failedPrec = (totalFailed / totalTests) * 100; | |
| var warnPrec = (totalInconclusive / totalTests) * 100; | |
| passedPrec = passedPrec.toFixed(2).replace("/\.(\d\d)\d?$/", '.$1'); | |
| failedPrec = failedPrec.toFixed(2).replace("/\.(\d\d)\d?$/", '.$1'); | |
| warnPrec = warnPrec.toFixed(2).replace("/\.(\d\d)\d?$/", '.$1'); | |
| document.getElementById(classId + "Failed").style.width = failedPrec + "%"; | |
| document.getElementById(classId + "Passed").style.width = passedPrec + "%"; | |
| document.getElementById(classId + "Warn").style.width = warnPrec + "%"; | |
| document.getElementById(classId + "Failed").title = totalFailed + "(" + failedPrec + "%)"; | |
| document.getElementById(classId + "Passed").title = totalPassed + "(" + passedPrec + "%)"; | |
| document.getElementById(classId + "Warn").title = totalInconclusive + "(" + warnPrec + "%)"; | |
| } | |
| var img; | |
| function AddToArray(imagesString) { | |
| img = imagesString.split("|"); | |
| slideimagesRight(); | |
| } | |
| function slideimagesRight() { | |
| var lastPlace = img[img.length - 1]; //Save the last cell | |
| for (var i = 1; i < img.length; i++) { | |
| img[img.length - i] = img[img.length - 1 - i]; //Do the replacment,shift left | |
| } | |
| img[0] = lastPlace; //Replace first cell with the last cell we stored | |
| for (var i = 0; i < img.length; i++) { | |
| updateFloatingImage(img[i]); | |
| } | |
| } | |
| function slideimagesLeft() { | |
| var firstPlace = img[0]; | |
| for (var i = 0; i < img.length - 1; i++) { | |
| img[i] = img[i + 1]; | |
| } | |
| img[img.length - 1] = firstPlace; | |
| for (var i = 0; i < img.length; i++) { | |
| updateFloatingImage(img[i]); | |
| } | |
| } | |
| </script><title>NivNavick@NIVNAVICK-PC 2014-07-28 21:47:29</title> | |
| <script type="text/javascript" src="chrome-extension://aadgmnobpdmgmigaicncghmmoeflnamj/ng-inspector.js"></script></head> | |
| <body> | |
| <div id="divToRefresh" class="wrapOverall"> | |
| <div id="floatingGrayBackground" onclick=" hide('floatingGrayBackground');hide('floatingImageBackground'); "></div> | |
| <div id="floatingImageBackground"> | |
| <div id="navigation"> | |
| <table border="0" cellspacing="0" cellpadding="0"> | |
| <tbody><tr> | |
| <td class="arrowCell"> | |
| <div id="leftArrow" onclick=" slideimagesLeft(); "></div> | |
| </td> | |
| <td valign="top"> | |
| <div class="overFlowImage"><img src="http://wingsrom.ro/trxer/trxExample.htm" class="displayed" id="floatingImage"> | |
| </div> | |
| </td> | |
| <td class="arrowCell"> | |
| <div id="rightArrow" onclick=" slideimagesRight(); "></div> | |
| </td> | |
| </tr> | |
| <tr> | |
| <td></td> | |
| <td colspan="3" class="closeImageViewButton"><a href="javascript:hide('floatingImageBackground');hide('floatingGrayBackground')">✖Close</a></td> | |
| <td></td> | |
| </tr> | |
| </tbody></table> | |
| </div> | |
| </div><br> | |
| <div class="StatusBar statusBarFailed"> | |
| <div class="statusBarInner statusBarFailedInner"> | |
| <center> | |
| <h1 class="hWhite"> | |
| <div class="titleCenterd">EBS Test Report</div> | |
| </h1> | |
| </center> | |
| </div> | |
| </div> | |
| <div class="SummaryDiv"> | |
| <table id="TotalTestsTable"> | |
| <caption>Results Summary</caption> | |
| <thead> | |
| <tr class="odd"> | |
| <th scope="col" abbr="Status"> | |
| Pie View (TBD) | |
| </th> | |
| </tr> | |
| </thead> | |
| <tbody> | |
| <tr> | |
| <td> | |
| <div id="dataViewer"><canvas id="canvas" width="240" height="150">This text is displayed if your browser does not support HTML5 Canvas.</canvas> | |
| </div> | |
| </td> | |
| </tr> | |
| <tr id="DownloadSection"> | |
| <td><a href="http://wingsrom.ro/trxer/trxExample.htm#" class="button" id="btn-download" download="NivNavick@NIVNAVICK-PC 2014-07-28 21:47:29StatusesPie.png">Save graph</a></td> | |
| </tr> | |
| </tbody> | |
| </table> | |
| <table class="DetailsTable StatusesTable"> | |
| <caption>Tests Statuses</caption> | |
| <tbody> | |
| <tr class="odd"> | |
| <th class="column1 statusCount">Total</th> | |
| <td class="statusCount">4</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1 statusCount">Executed</th> | |
| <td class="statusCount">4</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1 statusCount">Passed</th> | |
| <td class="statusCount">4</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1 statusCount">Failed</th> | |
| <td class="statusCount">0</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1 statusCount">Inconclusive</th> | |
| <td class="statusCount">0</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1 statusCount">Error</th> | |
| <td class="statusCount">0</td> | |
| </tr> | |
| </tbody> | |
| </table> | |
| <table class="SummaryTable"> | |
| <caption>Summary</caption> | |
| <tbody> | |
| <tr class="odd"> | |
| <th class="column1">Start Time</th> | |
| <td>3:36 PM</td> | |
| </tr> | |
| <tr> | |
| <th class="column1">End Time</th> | |
| <td>3:36 PM</td> | |
| </tr> | |
| <tr> | |
| <th class="column1">Duration</th> | |
| <td>781 ms</td> | |
| </tr> | |
| <tr class="odd"> | |
| <th class="column1">User</th> | |
| <td>anair</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1">Machine</th> | |
| <td>10.2.147.254</td> | |
| </tr> | |
| <tr> | |
| <th scope="row" class="column1">Outcome</th> | |
| <td>TBD</td> | |
| </tr> | |
| </tbody> | |
| </table> | |
| </div> | |
| </div> | |
| <script> | |
| CalculateTotalPrecents(); | |
| </script> | |
| <div class="row"></div> | |
| <div class="card"> | |
| <div class="panel-group visibleRow" id="accordion"> | |
| <div class="panel panel-default"> | |
| <div class="panel-heading"> | |
| <h4 class="panel-title"> | |
| <a data-toggle="collapse" data-parent="#accordion" href="#collapse1"><strong>Feature</strong>: PlayerAuthenticationFeature: PlayerAuthenticationFeature</a> | |
| </h4> | |
| </div> | |
| <div id="collapse1" class="panel-collapse collapse in"> | |
| <div class="panel-body"> | |
| <div><b>Scenario: </b>PlayerAuthenticationFeature: ProjectReport.TestResultsFeatureScenarioName - Passed <span class="badge badge-success">Success</span></div> | |
| <div>GIVEN A Player Has Inserted A Card Into A Slot</div> | |
| <div>WHEN Player Is Validated</div> | |
| <div>THEN Should Create A New Session For The Player</div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="row"></div> | |
| <div class="card"> | |
| <div class="panel-group visibleRow" id="accordion"> | |
| <div class="panel panel-default"> | |
| <div class="panel-heading"> | |
| <h4 class="panel-title"> | |
| <a data-toggle="collapse" data-parent="#accordion" href="#collapse1"><strong>Feature</strong>: PowerWinnerPromotionIsCreatedForAllEligiblePlayers: PowerWinnerPromotionIsCreatedForAllEligiblePlayers</a> | |
| </h4> | |
| </div> | |
| <div id="collapse1" class="panel-collapse collapse in"> | |
| <div class="panel-body"> | |
| <div><b>Scenario: </b>PowerWinnerPromotionIsCreatedForAllEligiblePlayers: ProjectReport.TestResultsFeatureScenarioName - Passed <span class="badge badge-success">Success</span></div> | |
| <div>GIVEN A Player Has Inserted A Card Into A Slot</div> | |
| <div>WHEN A Session Is Created For Player</div> | |
| <div>THEN Should Return List Of Eligible Power Winner Promotions</div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="row"></div> | |
| <div class="card"> | |
| <div class="panel-group visibleRow" id="accordion"> | |
| <div class="panel panel-default"> | |
| <div class="panel-heading"> | |
| <h4 class="panel-title"> | |
| <a data-toggle="collapse" data-parent="#accordion" href="#collapse1"><strong>Feature</strong>: PowerWinnerRatingRequestWhenPromotionIsEligible: PowerWinnerRatingRequestWhenPromotionIsEligible</a> | |
| </h4> | |
| </div> | |
| <div id="collapse1" class="panel-collapse collapse in"> | |
| <div class="panel-body"> | |
| <div><b>Scenario: </b>PowerWinnerRatingRequestWhenPromotionIsEligible: ProjectReport.TestResultsFeatureScenarioName - Passed <span class="badge badge-success">Success</span></div> | |
| <div>GIVEN A Player Has Inserted A Card Into A Slot</div> | |
| <div>WHEN A Session Is Created For Player</div> | |
| <div>THEN Should Return List Of Eligible Power Winner Promotions</div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="row"></div> | |
| <div class="card"> | |
| <div class="panel-group visibleRow" id="accordion"> | |
| <div class="panel panel-default"> | |
| <div class="panel-heading"> | |
| <h4 class="panel-title"> | |
| <a data-toggle="collapse" data-parent="#accordion" href="#collapse1"><strong>Feature</strong>: PowerWinnerSessionStartForDifferentPromotionStatus: PowerWinnerSessionStartForDifferentPromotionStatus</a> | |
| </h4> | |
| </div> | |
| <div id="collapse1" class="panel-collapse collapse in"> | |
| <div class="panel-body"> | |
| <div><b>Scenario: </b>PowerWinnerSessionStartForDifferentPromotionStatus: ProjectReport.TestResultsFeatureScenarioName - Passed <span class="badge badge-success">Success</span></div> | |
| <div>GIVEN template method</div> | |
| <div>WHEN template method</div> | |
| <div>THEN THEN template method</div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </body> | |
| </html> | |
| Thank you, Arun |