/** * Copyright (c) 2017 Google Inc. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); you * may not use this file except in compliance with the License. You may * obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or * implied. See the License for the specific language governing * permissions and limitations under the License. */ (function ($, moment) { /** * Display test plan metadata in a vertical popout. * @param container The jquery object in which to insert the plan metadata. * @param metadataList The list of metadata objects to render on the display. */ function renderCard(container, entry) { var card = $('<a class="col s12 m6 l4"></a>'); var link = ( '/show_plan_run?plan=' + entry.testPlanRun.testPlanName + '&time=' + entry.testPlanRun.startTimestamp); card.attr('href', link); card.appendTo(container); var div = $('<div class="hoverable card release-entry"></div>'); var startTime = entry.testPlanRun.startTimestamp; var endTime = entry.testPlanRun.endTimestamp; div.appendTo(card); var span = $('<span></span>'); span.addClass('plan-run-metadata'); span.appendTo(div); $('<b></b>').text(entry.deviceInfo).appendTo(span); span.append('<br>'); $('<b></b>').text('VTS Build: ').appendTo(span); span.append(entry.testPlanRun.testBuildId).append('<br>'); var timeString = ( moment().renderTime(startTime, false) + ' - ' + moment().renderTime(endTime, true) + ' (' + moment().renderDuration(endTime - startTime) + ')'); span.append(timeString); var counter = $('<span></span>'); var color = entry.testPlanRun.failCount > 0 ? 'red' : 'green'; counter.addClass('counter center ' + color); counter.append( entry.testPlanRun.passCount + '/' + (entry.testPlanRun.passCount + entry.testPlanRun.failCount)); counter.appendTo(div); } $.fn.showPlanRuns = function(data) { var self = $(this); data.forEach(function (entry) { renderCard(self, entry); }) } })(jQuery, moment);