/**
* 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);