success to filter behavior
This commit is contained in:
parent
4e01cf19db
commit
8b0e7a1985
|
@ -4,6 +4,7 @@ import java.lang.reflect.Field;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -166,8 +167,7 @@ public class TestPlanFactory {
|
||||||
private Script createAScriptWithFilter(
|
private Script createAScriptWithFilter(
|
||||||
ScriptFilterOptionsModel scriptFilterOptionsModel, Script script) {
|
ScriptFilterOptionsModel scriptFilterOptionsModel, Script script) {
|
||||||
RunScenarioModel runScenarioModel = (RunScenarioModel) MarshalHelper
|
RunScenarioModel runScenarioModel = (RunScenarioModel) MarshalHelper
|
||||||
.tryUnmarshal(RunScenarioModel.class,
|
.tryUnmarshal(RunScenarioModel.class, script.getScriptContent());
|
||||||
script.getFilteredScriptCnt());
|
|
||||||
List<String> filterPluginId = new ArrayList<String>();
|
List<String> filterPluginId = new ArrayList<String>();
|
||||||
if (scriptFilterOptionsModel.isFilterTimer()) {
|
if (scriptFilterOptionsModel.isFilterTimer()) {
|
||||||
for (UsePluginModel pluginModel : runScenarioModel.getUsePlugins()) {
|
for (UsePluginModel pluginModel : runScenarioModel.getUsePlugins()) {
|
||||||
|
@ -180,20 +180,23 @@ public class TestPlanFactory {
|
||||||
&& !scriptFilterOptionsModel.getFilterTypeMatches().equals("")) {
|
&& !scriptFilterOptionsModel.getFilterTypeMatches().equals("")) {
|
||||||
for (PageModel pageModel : runScenarioModel.getPages()) {
|
for (PageModel pageModel : runScenarioModel.getPages()) {
|
||||||
for (BatchModel batchModel : pageModel.getBatches()) {
|
for (BatchModel batchModel : pageModel.getBatches()) {
|
||||||
for (BehaviorModel behaviorModel : batchModel
|
Iterator<BehaviorModel> behaviIterator = batchModel
|
||||||
.getBehaviors()) {
|
.getBehaviors().iterator();
|
||||||
|
while (behaviIterator.hasNext()) {
|
||||||
|
BehaviorModel behaviorModel = behaviIterator.next();
|
||||||
if (filterPluginId.contains(behaviorModel.getUse())
|
if (filterPluginId.contains(behaviorModel.getUse())
|
||||||
|| isFilterType(
|
|| isFilterType(
|
||||||
scriptFilterOptionsModel
|
scriptFilterOptionsModel
|
||||||
.getFilterTypeMatches(),
|
.getFilterTypeMatches(),
|
||||||
behaviorModel)) {
|
behaviorModel)) {
|
||||||
batchModel.getBehaviors().remove(behaviorModel);
|
behaviIterator.remove();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String contentString = MarshalHelper.tryMarshal(runScenarioModel);
|
String contentString = MarshalHelper.tryMarshal(runScenarioModel);
|
||||||
|
System.out.println(contentString);
|
||||||
script.setFilteredScriptCnt(contentString);
|
script.setFilteredScriptCnt(contentString);
|
||||||
return script;
|
return script;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
filter.type.list=text/css,text/html,text/plain,image/*,*javascript,application/json,application/xml,think-time
|
filter.type.list=text/css,text/html,text/plain,image/.*,.*javascript,application/json,application/xml,think-time
|
|
@ -233,6 +233,7 @@ public class TestPlanMessager extends MasterMessager {
|
||||||
handleInvalidatedResponse(url);
|
handleInvalidatedResponse(url);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
System.out.println("getLatestScriptBriefResult:\r\n"+httpResponse.getContent());
|
||||||
return (ScriptBriefResultModel) MarshalHelper.tryUnmarshal(
|
return (ScriptBriefResultModel) MarshalHelper.tryUnmarshal(
|
||||||
ScriptBriefResultModel.class, httpResponse.getContent());
|
ScriptBriefResultModel.class, httpResponse.getContent());
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
}
|
}
|
||||||
.title-frame{
|
.title-frame{
|
||||||
margin-top:30px;
|
margin-top:30px;
|
||||||
|
cursor:pointer;
|
||||||
}
|
}
|
||||||
i{
|
i{
|
||||||
float:left;
|
float:left;
|
||||||
|
|
|
@ -36,4 +36,144 @@ function getScriptFilterOptions(){
|
||||||
}
|
}
|
||||||
return scriptFilterOptions;
|
return scriptFilterOptions;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function checkTotalAllocation() {
|
||||||
|
if (document.getElementById("totalNumber").childNodes[0].nodeValue == "100%") {
|
||||||
|
$("#totalNumber").attr("class","total-right");
|
||||||
|
$("#alertMessage").attr("class", "hide");
|
||||||
|
} else {
|
||||||
|
$("#totalNumber").attr("class","total-false");
|
||||||
|
$("#alertMessage").attr("class", "show");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkRequireLoad() {
|
||||||
|
if (parseInt($("#RequireLoad").val()) <= 0
|
||||||
|
|| $("#RequireLoad").val() == "")
|
||||||
|
$("#RequireLoad").attr("class",
|
||||||
|
"load-config-input-alert");
|
||||||
|
else
|
||||||
|
$("#RequireLoad").attr("class",
|
||||||
|
"load-config-input");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkWarmUp() {
|
||||||
|
if (parseInt($("#WarmUp").val()) <= 0
|
||||||
|
|| $("#WarmUp").val() == "")
|
||||||
|
$("#WarmUp").attr("class",
|
||||||
|
"load-config-input-alert");
|
||||||
|
else
|
||||||
|
$("#WarmUp").attr("class",
|
||||||
|
"load-config-input");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkCoolDown() {
|
||||||
|
if (parseInt($("#CoolDown").val()) <= 0
|
||||||
|
|| $("#CoolDown").val() == "")
|
||||||
|
$("#CoolDown").attr("class",
|
||||||
|
"load-config-input-alert");
|
||||||
|
else
|
||||||
|
$("#CoolDown").attr("class",
|
||||||
|
"load-config-input");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkExecuteRange() {
|
||||||
|
if (parseInt($("#ExecuteRange").val()) <= 0
|
||||||
|
|| $("#ExecuteRange").val() == "")
|
||||||
|
$("#ExecuteRange").attr("class",
|
||||||
|
"load-config-input-alert");
|
||||||
|
else
|
||||||
|
$("#ExecuteRange").attr("class",
|
||||||
|
"load-config-input");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkLoadConfig() {
|
||||||
|
checkExecuteRange();
|
||||||
|
checkCoolDown();
|
||||||
|
checkRequireLoad();
|
||||||
|
checkWarmUp();
|
||||||
|
if ($("#ExecuteRange").attr("class") == "load-config-input"
|
||||||
|
&& $("#CoolDown").attr("class") == "load-config-input"
|
||||||
|
&& $("#WarmUp").attr("class") == "load-config-input"
|
||||||
|
&& $("#RequireLoad").attr("class") == "load-config-input")
|
||||||
|
$("#loadConfigMessage").attr("class",
|
||||||
|
"hide");
|
||||||
|
else
|
||||||
|
$("#loadConfigMessage").attr("class",
|
||||||
|
"show");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkUserScenarios() {
|
||||||
|
var input= $("#userScenarios").find("input");
|
||||||
|
var boolean = 0;
|
||||||
|
var number = 0;
|
||||||
|
for ( var i = 0; i < input.length; i++) {
|
||||||
|
if (input[i].value == "" || parseInt(input[i].value) <= 0) {
|
||||||
|
// input[i].setAttribute("class", "allocation-input-alert");
|
||||||
|
boolean = 1;
|
||||||
|
}
|
||||||
|
// else
|
||||||
|
// input[i].setAttribute("class", "allocation-input");
|
||||||
|
}
|
||||||
|
for ( var k = 0; k < input.length; k++) {
|
||||||
|
if ($(input[k]).attr("class") == "allocation-input")
|
||||||
|
number++;
|
||||||
|
}
|
||||||
|
if (number == input.length)
|
||||||
|
boolean = 0;
|
||||||
|
if (boolean == 1)
|
||||||
|
$("#userConfigMessage").attr("class",
|
||||||
|
"show");
|
||||||
|
else
|
||||||
|
$("#userConfigMessage").attr("class",
|
||||||
|
"hide");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkIP() {
|
||||||
|
|
||||||
|
var input = $("#ipConfig").find("input");
|
||||||
|
var patrn = /^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$/;
|
||||||
|
var boolean = 0;
|
||||||
|
var number = 0;
|
||||||
|
for ( var i = 0; i < input.length; i++) {
|
||||||
|
if (input[i].value == "" || patrn.exec(input[i].value) == null) {
|
||||||
|
input[i].setAttribute("class", "ip-input-alert");
|
||||||
|
boolean = 1;
|
||||||
|
} else
|
||||||
|
input[i].setAttribute("class", "ip-input");
|
||||||
|
}
|
||||||
|
for ( var k = 0; k < input.length; k++) {
|
||||||
|
if (input[k].getAttribute("class") == "ip-input")
|
||||||
|
number++;
|
||||||
|
}
|
||||||
|
if (number == input.length)
|
||||||
|
boolean = 0;
|
||||||
|
if (boolean == 1)
|
||||||
|
$("#ipConfigMessage")
|
||||||
|
.attr("class", "show");
|
||||||
|
else
|
||||||
|
$("#ipConfigMessage")
|
||||||
|
.attr("class", "hide");
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkName() {
|
||||||
|
if ($("#testConfigurationName").val() == "") {
|
||||||
|
$("#testConfigurationName").attr("class",
|
||||||
|
"name-input-alert");
|
||||||
|
$("#nameMessage").attr("class", "show");
|
||||||
|
} else {
|
||||||
|
$("#testConfigurationName").attr("class",
|
||||||
|
"name-input");
|
||||||
|
$("#nameMessage").attr("class", "hide");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkAllInpute() {
|
||||||
|
checkLoadConfig();
|
||||||
|
checkUserScenarios();
|
||||||
|
checkIP();
|
||||||
|
checkName();
|
||||||
}
|
}
|
|
@ -85,14 +85,29 @@ function start() {
|
||||||
for ( var j = 0; j < input.length; j++)
|
for ( var j = 0; j < input.length; j++)
|
||||||
loadList.push(parseInt(requireLoad * allocationList[j] / 100));
|
loadList.push(parseInt(requireLoad * allocationList[j] / 100));
|
||||||
scriptIdList = getScriptIdList();
|
scriptIdList = getScriptIdList();
|
||||||
// var scriptFilterOptions=getScriptFilterOptions();
|
|
||||||
|
var isFilterTimer = false;
|
||||||
|
var filterTypeMatches = "";
|
||||||
|
var filterSelected = $("#filterList").find("input[name='filterList']:checked");
|
||||||
|
|
||||||
|
for(var i=0;i<filterSelected.length;i++)
|
||||||
|
{
|
||||||
|
var id = filterSelected[i].id;
|
||||||
|
if(id == "think-time"){
|
||||||
|
isFilterTimer = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
filterTypeMatches += id+"|";
|
||||||
|
}
|
||||||
|
//delete last |
|
||||||
|
if(filterTypeMatches != "")
|
||||||
|
filterTypeMatches = filterTypeMatches.substring(0,filterTypeMatches.length-1);
|
||||||
|
|
||||||
for ( var k = 0; k < input.length; k++){
|
for ( var k = 0; k < input.length; k++){
|
||||||
scriptList.push(new ScriptModel(scriptIdList[k], loadList[k], warmUp,
|
scriptList.push(new ScriptModel(scriptIdList[k], loadList[k], warmUp,
|
||||||
coolDown, executeRange));
|
coolDown, executeRange,isFilterTimer,filterTypeMatches));
|
||||||
}
|
}
|
||||||
var filterSelected = $("#filterList div input[name='filterList']:checked");
|
|
||||||
for(var i=0;i<filterSelected.length;i++)
|
|
||||||
filterArray.push(filterSelected[i].id);
|
|
||||||
|
|
||||||
var name = $("#testConfigurationName").val();
|
var name = $("#testConfigurationName").val();
|
||||||
var testPlan = new TestPlanRequestModel(scriptList, ipList, name);
|
var testPlan = new TestPlanRequestModel(scriptList, ipList, name);
|
||||||
|
@ -110,4 +125,18 @@ function start() {
|
||||||
error : function(request, status, error) {
|
error : function(request, status, error) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function createNewScript(){
|
||||||
|
window.open("script.jsp");
|
||||||
|
}
|
||||||
|
function viewScript(node) {
|
||||||
|
var scriptId;
|
||||||
|
var scriptName;
|
||||||
|
var selectNodes = document.getElementsByName("select");
|
||||||
|
var index = node.parentNode.parentNode.rowIndex - 1;
|
||||||
|
scriptName = selectNodes[index].options[selectNodes[index].selectedIndex].value;
|
||||||
|
scriptId = getScriptId(scriptName);
|
||||||
|
window.open("editScript.jsp?name=" + scriptName + "&scriptId=" + scriptId);
|
||||||
|
}
|
||||||
|
|
|
@ -1,17 +1,104 @@
|
||||||
function createCheckbox(id,text){
|
function createCheckbox(id,text){
|
||||||
var line = $("<td style=\"cursor:pointer;\"></td>");
|
var line = $("<td style=\"cursor:pointer;\"></td>");
|
||||||
line.click(function(){
|
line.click(function(){checkBoxClick(id)});
|
||||||
if(document.getElementById(id).checked){
|
|
||||||
document.getElementById(id).checked = false;
|
|
||||||
}else{
|
|
||||||
document.getElementById(id).checked = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
})
|
|
||||||
var input = $("<input type='checkbox' name='filterList' id="+id+">");
|
var input = $("<input type='checkbox' name='filterList' id="+id+">");
|
||||||
input.attr("text",text);
|
input.attr("text",text);
|
||||||
|
input.click(function(){checkBoxClick(id)});
|
||||||
line.append(input);
|
line.append(input);
|
||||||
line.append(document.createTextNode(text));
|
line.append(document.createTextNode(text));
|
||||||
line.addClass("line");
|
line.addClass("line");
|
||||||
return line;
|
return line;
|
||||||
|
}
|
||||||
|
function checkBoxClick(id){
|
||||||
|
if(document.getElementById(id).checked){
|
||||||
|
document.getElementById(id).checked = false;
|
||||||
|
}else{
|
||||||
|
document.getElementById(id).checked = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function loadSchedulePlot() {
|
||||||
|
var options = {
|
||||||
|
chart : {
|
||||||
|
renderTo : 'highchartsPlot',
|
||||||
|
defaultSeriesType : 'line',
|
||||||
|
type : 'area',
|
||||||
|
height : 300,
|
||||||
|
|
||||||
|
},
|
||||||
|
plotOptions : {
|
||||||
|
series : {
|
||||||
|
fillOpacity : 0.5,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
credits : {
|
||||||
|
enabled : false
|
||||||
|
},
|
||||||
|
legend : {
|
||||||
|
enabled : false
|
||||||
|
},
|
||||||
|
title : {
|
||||||
|
text : $.i18n.prop('test-loadSchedule') ,
|
||||||
|
x : -50
|
||||||
|
},
|
||||||
|
xAxis : {
|
||||||
|
categories : [ 0 ],
|
||||||
|
min : 0,
|
||||||
|
},
|
||||||
|
yAxis : {
|
||||||
|
plotLines : [ {
|
||||||
|
value : 0,
|
||||||
|
width : 1,
|
||||||
|
color : '#808080'
|
||||||
|
} ],
|
||||||
|
min : 0
|
||||||
|
},
|
||||||
|
tooltip : {
|
||||||
|
formatter : function() {
|
||||||
|
var formatStr = '<b>'+this.y+ ' users after ' + this.x + ' seconds</b>';
|
||||||
|
return formatStr;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
series : [ {
|
||||||
|
data : [ 0 ]
|
||||||
|
} ]
|
||||||
|
};
|
||||||
|
var RequireLoad = parseInt($("#RequireLoad").val());
|
||||||
|
var WarmUp = parseInt($("#WarmUp").val());
|
||||||
|
var CoolDown = parseInt($("#CoolDown").val());
|
||||||
|
var ExecuteRange = parseInt($("#ExecuteRange").val());
|
||||||
|
options.xAxis.categories.push(WarmUp);
|
||||||
|
options.xAxis.categories.push(WarmUp + ExecuteRange);
|
||||||
|
options.xAxis.categories.push(WarmUp + ExecuteRange + CoolDown);
|
||||||
|
options.series[0].data.push(RequireLoad);
|
||||||
|
options.series[0].data.push(RequireLoad);
|
||||||
|
options.series[0].data.push(0);
|
||||||
|
var chart = new Highcharts.Chart(options);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function toggleTestExecutionPlan() {
|
||||||
|
$("#loadTestExecutionPlan").slideToggle();
|
||||||
|
$('#loadConfigMessage').attr("class", "hide");
|
||||||
|
if ($("#icon-load").attr("class") == "icon-plus")
|
||||||
|
$("#icon-load").attr("class", "icon-minus");
|
||||||
|
else
|
||||||
|
$("#icon-load").attr("class", "icon-plus");
|
||||||
|
}
|
||||||
|
function toggleUserScenarios() {
|
||||||
|
$("#userScenarios").slideToggle();
|
||||||
|
$('#alertMessage').attr("class", "hide");
|
||||||
|
$('#userConfigMessage').attr("class", "hide");
|
||||||
|
if ($("#icon-user").attr("class") == "icon-plus")
|
||||||
|
$("#icon-user").attr("class", "icon-minus");
|
||||||
|
else
|
||||||
|
$("#icon-user").attr("class", "icon-plus");
|
||||||
|
}
|
||||||
|
function toggleIpConfig() {
|
||||||
|
$("#ipConfig").slideToggle();
|
||||||
|
$('#ipConfigMessage').attr("class", "hide");
|
||||||
|
if ($("#icon-ip").attr("class").indexOf("icon-plus") >= 0)
|
||||||
|
$("#icon-ip").attr("class", "icon-minus");
|
||||||
|
else
|
||||||
|
$("#icon-ip").attr("class", "icon-plus");
|
||||||
}
|
}
|
|
@ -3,104 +3,72 @@ $(document).ready(function() {
|
||||||
loadSchedulePlot();
|
loadSchedulePlot();
|
||||||
loadFilterTypeList();
|
loadFilterTypeList();
|
||||||
});
|
});
|
||||||
|
|
||||||
$("#selectFilter #ok").click(function() {
|
$("#selectFilter #ok").click(function() {
|
||||||
$("#selectFilter").hide();
|
$("#selectFilter").hide();
|
||||||
// $("#selectFilter #ok").addClass("clicked");
|
|
||||||
// filter=[];
|
|
||||||
});
|
});
|
||||||
$("#createFilter").click(function(){
|
$("#createFilter").click(function() {
|
||||||
$("#selectFilter").show();
|
$("#selectFilter").show();
|
||||||
})
|
})
|
||||||
function toggleTestExecutionPlan() {
|
|
||||||
$("#loadTestExecutionPlan").slideToggle();
|
|
||||||
$('#loadConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-load").attr("class") == "icon-plus")
|
|
||||||
$("#icon-load").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-load").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
function toggleUserScenarios() {
|
|
||||||
$("#userScenarios").slideToggle();
|
|
||||||
$('#alertMessage').attr("class", "hide");
|
|
||||||
$('#userConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-user").attr("class") == "icon-plus")
|
|
||||||
$("#icon-user").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-user").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
function toggleIpConfig() {
|
|
||||||
$("#ipConfig").slideToggle();
|
|
||||||
$('#ipConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-ip").attr("class").indexOf("icon-plus") >= 0)
|
|
||||||
$("#icon-ip").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-ip").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
|
|
||||||
var scenarioConfigContent;
|
var scenarioConfigContent;
|
||||||
function addScenario() {
|
function addScenario() {
|
||||||
|
//create delete button
|
||||||
var newTdNode = document.createElement("td");
|
var newTdNode = document.createElement("td");
|
||||||
var newINode = document.createElement("i");
|
var newINode = document.createElement("i");
|
||||||
newINode.setAttribute("class", "icon-trash");
|
newINode.setAttribute("class", "icon-trash");
|
||||||
|
|
||||||
newINode.setAttribute("style", "cursor:pointer");
|
newINode.setAttribute("style", "cursor:pointer");
|
||||||
|
|
||||||
newINode.setAttribute("onClick", "deleteScenarios(this)");
|
newINode.setAttribute("onClick", "deleteScenarios(this)");
|
||||||
newTdNode.appendChild(newINode);
|
newTdNode.appendChild(newINode);
|
||||||
var lastInputNodeValue;
|
//end
|
||||||
var lengthBeforAddAction = $("#userConfig").find("input").length;
|
var lastScaleValue;
|
||||||
lastInputNodeValue = document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction - 1].value;
|
var scaleObject = $("#userConfig").find("input");
|
||||||
if (document.getElementById("userConfig").childNodes.length == 2) {
|
var numOfScript = scaleObject.length;
|
||||||
scenarioConfigContent = $("#userConfig").html();
|
lastScaleValue = scaleObject[numOfScript - 1].value;
|
||||||
document.getElementById("userConfig").innerHTML = $("#userConfig").html()+ scenarioConfigContent;
|
//create new tr
|
||||||
var length = $("#userConfig").find("tr").length;
|
if (numOfScript == 1) {
|
||||||
document.getElementById("userConfig").getElementsByTagName("tr")[length - 1].appendChild(newTdNode);
|
$("#userConfig")[0].children[1].children[0].appendChild(newTdNode);
|
||||||
|
scenarioConfigContent = $("#userConfig")[0].children[1].innerHTML;
|
||||||
|
$("#userConfig")[0].children[1].innerHTML += scenarioConfigContent;
|
||||||
} else {
|
} else {
|
||||||
document.getElementById("userConfig").innerHTML =$("#userConfig").html()+ scenarioConfigContent;
|
$("#userConfig")[0].children[1].innerHTML += scenarioConfigContent;
|
||||||
var length = $("#userConfig").find("tr").length;
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("tr")[length - 1].appendChild(newTdNode);
|
|
||||||
}
|
}
|
||||||
if (lengthBeforAddAction <= 2) {
|
scaleObject = $("#userConfig").find("input");
|
||||||
var allocationLess = parseInt(100 / (lengthBeforAddAction + 1));
|
if (numOfScript == 1) {
|
||||||
var allocationMore = 100 - parseInt(100 / (lengthBeforAddAction + 1))
|
var allocationLess = parseInt(100 / (numOfScript + 1));
|
||||||
* lengthBeforAddAction;
|
var allocationMore = 100 - parseInt(100 / (numOfScript + 1))
|
||||||
for ( var i = 0; i < lengthBeforAddAction; i++) {
|
* numOfScript;
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[i]
|
for (var i = 0; i < numOfScript; i++) {
|
||||||
.setAttribute("value", allocationLess);
|
scaleObject[i].setAttribute("value", allocationLess);
|
||||||
}
|
}
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction]
|
scaleObject[numOfScript].setAttribute("value", allocationMore);
|
||||||
.setAttribute("value", allocationMore);
|
|
||||||
} else {
|
} else {
|
||||||
var allocationLess = parseInt(lastInputNodeValue / 2);
|
var allocationLess = parseInt(lastScaleValue / 2);
|
||||||
var allocationMore = lastInputNodeValue - allocationLess;
|
var allocationMore = lastScaleValue - allocationLess;
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction - 1]
|
scaleObject[numOfScript - 1].setAttribute("value", allocationLess);
|
||||||
.setAttribute("value", allocationLess);
|
scaleObject[numOfScript].setAttribute("value", allocationMore);
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction]
|
|
||||||
.setAttribute("value", allocationMore);
|
|
||||||
}
|
}
|
||||||
if ($("#userConfig").find("input").length == 10) {
|
if ($("#userConfig").find("input").length == 10) {
|
||||||
$("#userScenariosButton").attr("class",
|
$("#userScenariosButton").attr("class", "btn disabled");
|
||||||
"btn disabled");
|
$("#userScenariosButton").attr("onClick", "");
|
||||||
$("#userScenariosButton").attr("onClick",
|
|
||||||
"");
|
|
||||||
}
|
}
|
||||||
changeTotal();
|
changeTotal();
|
||||||
checkUserScenarios();
|
checkUserScenarios();
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteScenarios(selectedNode) {
|
function deleteScenarios(selectedNode) {
|
||||||
var deleteNode = selectedNode.parentNode.parentNode.parentNode;
|
var deleteNode = selectedNode.parentNode.parentNode;//tr
|
||||||
var Node = deleteNode.parentNode;
|
var Node = deleteNode.parentNode;//tbody
|
||||||
var previousSiblingNode = deleteNode.previousSibling;
|
|
||||||
Node.removeChild(deleteNode);
|
Node.removeChild(deleteNode);
|
||||||
Node.removeChild(previousSiblingNode);
|
var scaleObject = $("#userConfig").find("input");
|
||||||
if ($("#userConfig").find("input").length < 10) {
|
var numOfScript = scaleObject.length;
|
||||||
$("#userScenariosButton").attr("class",
|
if (numOfScript < 10) {
|
||||||
"btn btn-primary");
|
$("#userScenariosButton").attr("class", "btn btn-primary");
|
||||||
$("#userScenariosButton").attr("onClick",
|
$("#userScenariosButton").attr("onClick", "addScenario()");
|
||||||
"addScenario()");
|
if(numOfScript == 1){
|
||||||
|
//remove delete button
|
||||||
|
var onlyOneTrNode = scaleObject[0].parentNode.parentNode;
|
||||||
|
var deleteNode = onlyOneTrNode.children[3];
|
||||||
|
onlyOneTrNode.removeChild(deleteNode);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
changeTotal();
|
changeTotal();
|
||||||
checkUserScenarios();
|
checkUserScenarios();
|
||||||
|
@ -113,9 +81,9 @@ function addIP() {
|
||||||
var textNode = document.createTextNode("IP:");
|
var textNode = document.createTextNode("IP:");
|
||||||
var inputNode = document.createElement("input");
|
var inputNode = document.createElement("input");
|
||||||
var tr = document.createElement("tr");
|
var tr = document.createElement("tr");
|
||||||
|
|
||||||
// inputNode.attr({type:"text",class:"ip-input",onblur:"checkIP()"});
|
// inputNode.attr({type:"text",class:"ip-input",onblur:"checkIP()"});
|
||||||
|
|
||||||
inputNode.setAttribute("type", "text");
|
inputNode.setAttribute("type", "text");
|
||||||
inputNode.setAttribute("class", "ip-input");
|
inputNode.setAttribute("class", "ip-input");
|
||||||
inputNode.setAttribute("onblur", "checkIP()");
|
inputNode.setAttribute("onblur", "checkIP()");
|
||||||
|
@ -144,235 +112,19 @@ function changeTotal() {
|
||||||
var inputNode = $("#userConfig").find(".allocation-input");
|
var inputNode = $("#userConfig").find(".allocation-input");
|
||||||
var total = 0;
|
var total = 0;
|
||||||
var length = inputNode.length;
|
var length = inputNode.length;
|
||||||
for ( var i = 0; i < length; i++) {
|
for (var i = 0; i < length; i++) {
|
||||||
total = parseInt(total) + parseInt(inputNode[i].value);
|
total = parseInt(total) + parseInt(inputNode[i].value);
|
||||||
}
|
}
|
||||||
document.getElementById("totalNumber").innerHTML = total + "%";
|
document.getElementById("totalNumber").innerHTML = total + "%";
|
||||||
checkTotalAllocation();
|
checkTotalAllocation();
|
||||||
}
|
}
|
||||||
|
|
||||||
function viewScript(node) {
|
|
||||||
var scriptId;
|
|
||||||
var scriptName;
|
|
||||||
var selectNodes = document.getElementsByName("select");
|
|
||||||
var index = node.parentNode.parentNode.rowIndex - 1;
|
|
||||||
scriptName = selectNodes[index].options[selectNodes[index].selectedIndex].value;
|
|
||||||
scriptId = getScriptId(scriptName);
|
|
||||||
window.open("editScript.jsp?name=" + scriptName + "&scriptId=" + scriptId);
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkTotalAllocation() {
|
|
||||||
if (document.getElementById("totalNumber").childNodes[0].nodeValue == "100%") {
|
|
||||||
$("#totalNumber").attr("class","total-right");
|
|
||||||
$("#alertMessage").attr("class", "hide");
|
|
||||||
} else {
|
|
||||||
$("#totalNumber").attr("class","total-false");
|
|
||||||
$("#alertMessage").attr("class", "show");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkRequireLoad() {
|
|
||||||
if (parseInt($("#RequireLoad").val()) <= 0
|
|
||||||
|| $("#RequireLoad").val() == "")
|
|
||||||
$("#RequireLoad").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#RequireLoad").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkWarmUp() {
|
|
||||||
if (parseInt($("#WarmUp").val()) <= 0
|
|
||||||
|| $("#WarmUp").val() == "")
|
|
||||||
$("#WarmUp").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#WarmUp").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkCoolDown() {
|
|
||||||
if (parseInt($("#CoolDown").val()) <= 0
|
|
||||||
|| $("#CoolDown").val() == "")
|
|
||||||
$("#CoolDown").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#CoolDown").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkExecuteRange() {
|
|
||||||
if (parseInt($("#ExecuteRange").val()) <= 0
|
|
||||||
|| $("#ExecuteRange").val() == "")
|
|
||||||
$("#ExecuteRange").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#ExecuteRange").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkLoadConfig() {
|
|
||||||
checkExecuteRange();
|
|
||||||
checkCoolDown();
|
|
||||||
checkRequireLoad();
|
|
||||||
checkWarmUp();
|
|
||||||
if ($("#ExecuteRange").attr("class") == "load-config-input"
|
|
||||||
&& $("#CoolDown").attr("class") == "load-config-input"
|
|
||||||
&& $("#WarmUp").attr("class") == "load-config-input"
|
|
||||||
&& $("#RequireLoad").attr("class") == "load-config-input")
|
|
||||||
$("#loadConfigMessage").attr("class",
|
|
||||||
"hide");
|
|
||||||
else
|
|
||||||
$("#loadConfigMessage").attr("class",
|
|
||||||
"show");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkUserScenarios() {
|
|
||||||
var input= $("#userScenarios").find("input");
|
|
||||||
var boolean = 0;
|
|
||||||
var number = 0;
|
|
||||||
for ( var i = 0; i < input.length; i++) {
|
|
||||||
if (input[i].value == "" || parseInt(input[i].value) <= 0) {
|
|
||||||
// input[i].setAttribute("class", "allocation-input-alert");
|
|
||||||
boolean = 1;
|
|
||||||
}
|
|
||||||
// else
|
|
||||||
// input[i].setAttribute("class", "allocation-input");
|
|
||||||
}
|
|
||||||
for ( var k = 0; k < input.length; k++) {
|
|
||||||
if ($(input[k]).attr("class") == "allocation-input")
|
|
||||||
number++;
|
|
||||||
}
|
|
||||||
if (number == input.length)
|
|
||||||
boolean = 0;
|
|
||||||
if (boolean == 1)
|
|
||||||
$("#userConfigMessage").attr("class",
|
|
||||||
"show");
|
|
||||||
else
|
|
||||||
$("#userConfigMessage").attr("class",
|
|
||||||
"hide");
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkIP() {
|
|
||||||
|
|
||||||
var input = $("#ipConfig").find("input");
|
|
||||||
var patrn = /^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$/;
|
|
||||||
var boolean = 0;
|
|
||||||
var number = 0;
|
|
||||||
for ( var i = 0; i < input.length; i++) {
|
|
||||||
if (input[i].value == "" || patrn.exec(input[i].value) == null) {
|
|
||||||
input[i].setAttribute("class", "ip-input-alert");
|
|
||||||
boolean = 1;
|
|
||||||
} else
|
|
||||||
input[i].setAttribute("class", "ip-input");
|
|
||||||
}
|
|
||||||
for ( var k = 0; k < input.length; k++) {
|
|
||||||
if (input[k].getAttribute("class") == "ip-input")
|
|
||||||
number++;
|
|
||||||
}
|
|
||||||
if (number == input.length)
|
|
||||||
boolean = 0;
|
|
||||||
if (boolean == 1)
|
|
||||||
$("#ipConfigMessage")
|
|
||||||
.attr("class", "show");
|
|
||||||
else
|
|
||||||
$("#ipConfigMessage")
|
|
||||||
.attr("class", "hide");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkName() {
|
|
||||||
if ($("#testConfigurationName").val() == "") {
|
|
||||||
$("#testConfigurationName").attr("class",
|
|
||||||
"name-input-alert");
|
|
||||||
$("#nameMessage").attr("class", "show");
|
|
||||||
} else {
|
|
||||||
$("#testConfigurationName").attr("class",
|
|
||||||
"name-input");
|
|
||||||
$("#nameMessage").attr("class", "hide");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkAllInpute() {
|
|
||||||
checkLoadConfig();
|
|
||||||
checkUserScenarios();
|
|
||||||
checkIP();
|
|
||||||
checkName();
|
|
||||||
}
|
|
||||||
|
|
||||||
function loadSchedulePlot() {
|
|
||||||
var options = {
|
|
||||||
chart : {
|
|
||||||
renderTo : 'highchartsPlot',
|
|
||||||
defaultSeriesType : 'line',
|
|
||||||
type : 'area',
|
|
||||||
height : 300,
|
|
||||||
|
|
||||||
},
|
|
||||||
plotOptions : {
|
|
||||||
series : {
|
|
||||||
fillOpacity : 0.5,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
credits : {
|
|
||||||
enabled : false
|
|
||||||
},
|
|
||||||
legend : {
|
|
||||||
enabled : false
|
|
||||||
},
|
|
||||||
title : {
|
|
||||||
text : $.i18n.prop('test-loadSchedule') ,
|
|
||||||
x : -50
|
|
||||||
},
|
|
||||||
xAxis : {
|
|
||||||
categories : [ 0 ],
|
|
||||||
min : 0,
|
|
||||||
},
|
|
||||||
yAxis : {
|
|
||||||
plotLines : [ {
|
|
||||||
value : 0,
|
|
||||||
width : 1,
|
|
||||||
color : '#808080'
|
|
||||||
} ],
|
|
||||||
min : 0
|
|
||||||
},
|
|
||||||
tooltip : {
|
|
||||||
formatter : function() {
|
|
||||||
return '<b>' + + '</b><br/>' + this.y
|
|
||||||
+ 'users after' + this.x + 'seconds';
|
|
||||||
}
|
|
||||||
},
|
|
||||||
series : [ {
|
|
||||||
data : [ 0 ]
|
|
||||||
} ]
|
|
||||||
};
|
|
||||||
var RequireLoad = parseInt($("#RequireLoad").val());
|
|
||||||
var WarmUp = parseInt($("#WarmUp").val());
|
|
||||||
var CoolDown = parseInt($("#CoolDown").val());
|
|
||||||
var ExecuteRange = parseInt($("#ExecuteRange").val());
|
|
||||||
options.xAxis.categories.push(WarmUp);
|
|
||||||
options.xAxis.categories.push(WarmUp + ExecuteRange);
|
|
||||||
options.xAxis.categories.push(WarmUp + ExecuteRange + CoolDown);
|
|
||||||
options.series[0].data.push(RequireLoad);
|
|
||||||
options.series[0].data.push(RequireLoad);
|
|
||||||
options.series[0].data.push(0);
|
|
||||||
var chart = new Highcharts.Chart(options);
|
|
||||||
}
|
|
||||||
|
|
||||||
function startTest() {
|
function startTest() {
|
||||||
checkAllInpute();
|
checkAllInpute();
|
||||||
if ($("#nameMessage").attr("class") == "hide"
|
if ($("#nameMessage").attr("class") == "hide"
|
||||||
&& $("#loadConfigMessage").attr(
|
&& $("#loadConfigMessage").attr("class") == "hide"
|
||||||
"class") == "hide"
|
|
||||||
&& $("#alertMessage").attr("class") == "hide"
|
&& $("#alertMessage").attr("class") == "hide"
|
||||||
&& $("#userConfigMessage").attr(
|
&& $("#userConfigMessage").attr("class") == "hide"
|
||||||
"class") == "hide"
|
|
||||||
&& $("#ipConfigMessage").attr("class") == "hide")
|
&& $("#ipConfigMessage").attr("class") == "hide")
|
||||||
start();
|
start();
|
||||||
}
|
}
|
||||||
|
|
||||||
function createNewScript(){
|
|
||||||
window.open("script.jsp");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,376 +0,0 @@
|
||||||
$(document).ready(function() {
|
|
||||||
loadScripts();
|
|
||||||
loadSchedulePlot();
|
|
||||||
loadFilterTypeList();
|
|
||||||
});
|
|
||||||
|
|
||||||
$("#selectFilter #ok").click(function() {
|
|
||||||
$("#selectFilter").hide();
|
|
||||||
// $("#selectFilter #ok").addClass("clicked");
|
|
||||||
// filter=[];
|
|
||||||
});
|
|
||||||
|
|
||||||
function toggleTestExecutionPlan() {
|
|
||||||
$("#loadTestExecutionPlan").slideToggle();
|
|
||||||
$('#loadConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-load").attr("class") == "icon-plus")
|
|
||||||
$("#icon-load").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-load").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
function toggleUserScenarios() {
|
|
||||||
$("#userScenarios").slideToggle();
|
|
||||||
$('#alertMessage').attr("class", "hide");
|
|
||||||
$('#userConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-user").attr("class") == "icon-plus")
|
|
||||||
$("#icon-user").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-user").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
function toggleIpConfig() {
|
|
||||||
$("#ipConfig").slideToggle();
|
|
||||||
$('#ipConfigMessage').attr("class", "hide");
|
|
||||||
if ($("#icon-ip").attr("class").indexOf("icon-plus") >= 0)
|
|
||||||
$("#icon-ip").attr("class", "icon-minus");
|
|
||||||
else
|
|
||||||
$("#icon-ip").attr("class", "icon-plus");
|
|
||||||
}
|
|
||||||
|
|
||||||
var scenarioConfigContent;
|
|
||||||
function addScenario() {
|
|
||||||
|
|
||||||
var newTdNode = document.createElement("td");
|
|
||||||
var newINode = document.createElement("i");
|
|
||||||
newINode.setAttribute("class", "icon-trash");
|
|
||||||
|
|
||||||
newINode.setAttribute("style", "cursor:pointer");
|
|
||||||
|
|
||||||
newINode.setAttribute("onClick", "deleteScenarios(this)");
|
|
||||||
newTdNode.appendChild(newINode);
|
|
||||||
var lastInputNodeValue;
|
|
||||||
var lengthBeforAddAction = $("#userConfig").find("input").length;
|
|
||||||
lastInputNodeValue = document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction - 1].value;
|
|
||||||
if (document.getElementById("userConfig").childNodes.length == 2) {
|
|
||||||
scenarioConfigContent = $("#userConfig").html();
|
|
||||||
document.getElementById("userConfig").innerHTML = $("#userConfig").html()+ scenarioConfigContent;
|
|
||||||
var length = $("#userConfig").find("tr").length;
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("tr")[length - 1].appendChild(newTdNode);
|
|
||||||
} else {
|
|
||||||
document.getElementById("userConfig").innerHTML =$("#userConfig").html()+ scenarioConfigContent;
|
|
||||||
var length = $("#userConfig").find("tr").length;
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("tr")[length - 1].appendChild(newTdNode);
|
|
||||||
}
|
|
||||||
if (lengthBeforAddAction <= 2) {
|
|
||||||
var allocationLess = parseInt(100 / (lengthBeforAddAction + 1));
|
|
||||||
var allocationMore = 100 - parseInt(100 / (lengthBeforAddAction + 1))
|
|
||||||
* lengthBeforAddAction;
|
|
||||||
for ( var i = 0; i < lengthBeforAddAction; i++) {
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[i]
|
|
||||||
.setAttribute("value", allocationLess);
|
|
||||||
}
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction]
|
|
||||||
.setAttribute("value", allocationMore);
|
|
||||||
} else {
|
|
||||||
var allocationLess = parseInt(lastInputNodeValue / 2);
|
|
||||||
var allocationMore = lastInputNodeValue - allocationLess;
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction - 1]
|
|
||||||
.setAttribute("value", allocationLess);
|
|
||||||
document.getElementById("userConfig").getElementsByTagName("input")[lengthBeforAddAction]
|
|
||||||
.setAttribute("value", allocationMore);
|
|
||||||
}
|
|
||||||
if ($("#userConfig").find("input").length == 10) {
|
|
||||||
$("#userScenariosButton").attr("class",
|
|
||||||
"btn disabled");
|
|
||||||
$("#userScenariosButton").attr("onClick",
|
|
||||||
"");
|
|
||||||
}
|
|
||||||
changeTotal();
|
|
||||||
checkUserScenarios();
|
|
||||||
}
|
|
||||||
|
|
||||||
function deleteScenarios(selectedNode) {
|
|
||||||
var deleteNode = selectedNode.parentNode.parentNode.parentNode;
|
|
||||||
var Node = deleteNode.parentNode;
|
|
||||||
var previousSiblingNode = deleteNode.previousSibling;
|
|
||||||
Node.removeChild(deleteNode);
|
|
||||||
Node.removeChild(previousSiblingNode);
|
|
||||||
if ($("#userConfig").find("input").length < 10) {
|
|
||||||
$("#userScenariosButton").attr("class",
|
|
||||||
"btn btn-primary");
|
|
||||||
$("#userScenariosButton").attr("onClick",
|
|
||||||
"addScenario()");
|
|
||||||
}
|
|
||||||
changeTotal();
|
|
||||||
checkUserScenarios();
|
|
||||||
}
|
|
||||||
|
|
||||||
function addIP() {
|
|
||||||
var th1 = document.createElement("th");
|
|
||||||
var th2 = document.createElement("th");
|
|
||||||
var th3 = document.createElement("th");
|
|
||||||
var textNode = document.createTextNode("IP:");
|
|
||||||
var inputNode = document.createElement("input");
|
|
||||||
var tr = document.createElement("tr");
|
|
||||||
|
|
||||||
// inputNode.attr({type:"text",class:"ip-input",onblur:"checkIP()"});
|
|
||||||
|
|
||||||
inputNode.setAttribute("type", "text");
|
|
||||||
inputNode.setAttribute("class", "ip-input");
|
|
||||||
inputNode.setAttribute("onblur", "checkIP()");
|
|
||||||
var i = document.createElement("i");
|
|
||||||
i.setAttribute("class", "icon-trash");
|
|
||||||
i.setAttribute("style", "cursor:pointer");
|
|
||||||
i.setAttribute("onClick", "deleteIP(this)");
|
|
||||||
th1.appendChild(textNode);
|
|
||||||
th2.appendChild(inputNode);
|
|
||||||
th3.appendChild(i);
|
|
||||||
tr.appendChild(th1);
|
|
||||||
tr.appendChild(th2);
|
|
||||||
tr.appendChild(th3);
|
|
||||||
document.getElementById("ipConfigTable").appendChild(tr);
|
|
||||||
checkIP();
|
|
||||||
}
|
|
||||||
|
|
||||||
function deleteIP(selectedNode) {
|
|
||||||
var deletedNode = selectedNode.parentNode.parentNode;
|
|
||||||
var parentNode = deletedNode.parentNode;
|
|
||||||
parentNode.removeChild(deletedNode);
|
|
||||||
checkIP();
|
|
||||||
}
|
|
||||||
|
|
||||||
function changeTotal() {
|
|
||||||
var inputNode = $("#userConfig").find(".allocation-input");
|
|
||||||
var total = 0;
|
|
||||||
var length = inputNode.length;
|
|
||||||
for ( var i = 0; i < length; i++) {
|
|
||||||
total = parseInt(total) + parseInt(inputNode[i].value);
|
|
||||||
}
|
|
||||||
document.getElementById("totalNumber").innerHTML = total + "%";
|
|
||||||
checkTotalAllocation();
|
|
||||||
}
|
|
||||||
|
|
||||||
function viewScript(node) {
|
|
||||||
var scriptId;
|
|
||||||
var scriptName;
|
|
||||||
var selectNodes = document.getElementsByName("select");
|
|
||||||
var index = node.parentNode.parentNode.rowIndex - 1;
|
|
||||||
scriptName = selectNodes[index].options[selectNodes[index].selectedIndex].value;
|
|
||||||
scriptId = getScriptId(scriptName);
|
|
||||||
window.open("editScript.jsp?name=" + scriptName + "&scriptId=" + scriptId);
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkTotalAllocation() {
|
|
||||||
if (document.getElementById("totalNumber").childNodes[0].nodeValue == "100%") {
|
|
||||||
$("#totalNumber").attr("class","total-right");
|
|
||||||
$("#alertMessage").attr("class", "hide");
|
|
||||||
} else {
|
|
||||||
$("#totalNumber").attr("class","total-false");
|
|
||||||
$("#alertMessage").attr("class", "show");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkRequireLoad() {
|
|
||||||
if (parseInt($("#RequireLoad").val()) <= 0
|
|
||||||
|| $("#RequireLoad").val() == "")
|
|
||||||
$("#RequireLoad").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#RequireLoad").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkWarmUp() {
|
|
||||||
if (parseInt($("#WarmUp").val()) <= 0
|
|
||||||
|| $("#WarmUp").val() == "")
|
|
||||||
$("#WarmUp").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#WarmUp").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkCoolDown() {
|
|
||||||
if (parseInt($("#CoolDown").val()) <= 0
|
|
||||||
|| $("#CoolDown").val() == "")
|
|
||||||
$("#CoolDown").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#CoolDown").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkExecuteRange() {
|
|
||||||
if (parseInt($("#ExecuteRange").val()) <= 0
|
|
||||||
|| $("#ExecuteRange").val() == "")
|
|
||||||
$("#ExecuteRange").attr("class",
|
|
||||||
"load-config-input-alert");
|
|
||||||
else
|
|
||||||
$("#ExecuteRange").attr("class",
|
|
||||||
"load-config-input");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkLoadConfig() {
|
|
||||||
checkExecuteRange();
|
|
||||||
checkCoolDown();
|
|
||||||
checkRequireLoad();
|
|
||||||
checkWarmUp();
|
|
||||||
if ($("#ExecuteRange").attr("class") == "load-config-input"
|
|
||||||
&& $("#CoolDown").attr("class") == "load-config-input"
|
|
||||||
&& $("#WarmUp").attr("class") == "load-config-input"
|
|
||||||
&& $("#RequireLoad").attr("class") == "load-config-input")
|
|
||||||
$("#loadConfigMessage").attr("class",
|
|
||||||
"hide");
|
|
||||||
else
|
|
||||||
$("#loadConfigMessage").attr("class",
|
|
||||||
"show");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkUserScenarios() {
|
|
||||||
var input= $("#userScenarios").find("input");
|
|
||||||
var boolean = 0;
|
|
||||||
var number = 0;
|
|
||||||
for ( var i = 0; i < input.length; i++) {
|
|
||||||
if (input[i].value == "" || parseInt(input[i].value) <= 0) {
|
|
||||||
// input[i].setAttribute("class", "allocation-input-alert");
|
|
||||||
boolean = 1;
|
|
||||||
}
|
|
||||||
// else
|
|
||||||
// input[i].setAttribute("class", "allocation-input");
|
|
||||||
}
|
|
||||||
for ( var k = 0; k < input.length; k++) {
|
|
||||||
if ($(input[k]).attr("class") == "allocation-input")
|
|
||||||
number++;
|
|
||||||
}
|
|
||||||
if (number == input.length)
|
|
||||||
boolean = 0;
|
|
||||||
if (boolean == 1)
|
|
||||||
$("#userConfigMessage").attr("class",
|
|
||||||
"show");
|
|
||||||
else
|
|
||||||
$("#userConfigMessage").attr("class",
|
|
||||||
"hide");
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkIP() {
|
|
||||||
|
|
||||||
var input = $("#ipConfig").find("input");
|
|
||||||
var patrn = /^(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])$/;
|
|
||||||
var boolean = 0;
|
|
||||||
var number = 0;
|
|
||||||
for ( var i = 0; i < input.length; i++) {
|
|
||||||
if (input[i].value == "" || patrn.exec(input[i].value) == null) {
|
|
||||||
input[i].setAttribute("class", "ip-input-alert");
|
|
||||||
boolean = 1;
|
|
||||||
} else
|
|
||||||
input[i].setAttribute("class", "ip-input");
|
|
||||||
}
|
|
||||||
for ( var k = 0; k < input.length; k++) {
|
|
||||||
if (input[k].getAttribute("class") == "ip-input")
|
|
||||||
number++;
|
|
||||||
}
|
|
||||||
if (number == input.length)
|
|
||||||
boolean = 0;
|
|
||||||
if (boolean == 1)
|
|
||||||
$("#ipConfigMessage")
|
|
||||||
.attr("class", "show");
|
|
||||||
else
|
|
||||||
$("#ipConfigMessage")
|
|
||||||
.attr("class", "hide");
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkName() {
|
|
||||||
if ($("#testConfigurationName").val() == "") {
|
|
||||||
$("#testConfigurationName").attr("class",
|
|
||||||
"name-input-alert");
|
|
||||||
$("#nameMessage").attr("class", "show");
|
|
||||||
} else {
|
|
||||||
$("#testConfigurationName").attr("class",
|
|
||||||
"name-input");
|
|
||||||
$("#nameMessage").attr("class", "hide");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkAllInpute() {
|
|
||||||
checkLoadConfig();
|
|
||||||
checkUserScenarios();
|
|
||||||
checkIP();
|
|
||||||
checkName();
|
|
||||||
}
|
|
||||||
|
|
||||||
function loadSchedulePlot() {
|
|
||||||
var options = {
|
|
||||||
chart : {
|
|
||||||
renderTo : 'highchartsPlot',
|
|
||||||
defaultSeriesType : 'line',
|
|
||||||
type : 'area',
|
|
||||||
height : 300,
|
|
||||||
|
|
||||||
},
|
|
||||||
plotOptions : {
|
|
||||||
series : {
|
|
||||||
fillOpacity : 0.5,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
credits : {
|
|
||||||
enabled : false
|
|
||||||
},
|
|
||||||
legend : {
|
|
||||||
enabled : false
|
|
||||||
},
|
|
||||||
title : {
|
|
||||||
text : $.i18n.prop('test-loadSchedule') ,
|
|
||||||
x : -50
|
|
||||||
},
|
|
||||||
xAxis : {
|
|
||||||
categories : [ 0 ],
|
|
||||||
min : 0,
|
|
||||||
},
|
|
||||||
yAxis : {
|
|
||||||
plotLines : [ {
|
|
||||||
value : 0,
|
|
||||||
width : 1,
|
|
||||||
color : '#808080'
|
|
||||||
} ],
|
|
||||||
min : 0
|
|
||||||
},
|
|
||||||
tooltip : {
|
|
||||||
formatter : function() {
|
|
||||||
return '<b>' + + '</b><br/>' + this.y
|
|
||||||
+ 'users after' + this.x + 'seconds';
|
|
||||||
}
|
|
||||||
},
|
|
||||||
series : [ {
|
|
||||||
data : [ 0 ]
|
|
||||||
} ]
|
|
||||||
};
|
|
||||||
var RequireLoad = parseInt($("#RequireLoad").val());
|
|
||||||
var WarmUp = parseInt($("#WarmUp").val());
|
|
||||||
var CoolDown = parseInt($("#CoolDown").val());
|
|
||||||
var ExecuteRange = parseInt($("#ExecuteRange").val());
|
|
||||||
options.xAxis.categories.push(WarmUp);
|
|
||||||
options.xAxis.categories.push(WarmUp + ExecuteRange);
|
|
||||||
options.xAxis.categories.push(WarmUp + ExecuteRange + CoolDown);
|
|
||||||
options.series[0].data.push(RequireLoad);
|
|
||||||
options.series[0].data.push(RequireLoad);
|
|
||||||
options.series[0].data.push(0);
|
|
||||||
var chart = new Highcharts.Chart(options);
|
|
||||||
}
|
|
||||||
|
|
||||||
function startTest() {
|
|
||||||
checkAllInpute();
|
|
||||||
if ($("#nameMessage").attr("class") == "hide"
|
|
||||||
&& $("#loadConfigMessage").attr(
|
|
||||||
"class") == "hide"
|
|
||||||
&& $("#alertMessage").attr("class") == "hide"
|
|
||||||
&& $("#userConfigMessage").attr(
|
|
||||||
"class") == "hide"
|
|
||||||
&& $("#ipConfigMessage").attr("class") == "hide")
|
|
||||||
start();
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNewScript(){
|
|
||||||
window.open("script.jsp");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -25,10 +25,10 @@ body {
|
||||||
padding: 9px 0;
|
padding: 9px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.modal{
|
.modal {
|
||||||
position:absolute;
|
position: absolute;
|
||||||
left:617px;
|
left: 617px;
|
||||||
top:850px
|
top: 850px
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<link href="lib/chrisma/css/charisma-app.css" rel="stylesheet">
|
<link href="lib/chrisma/css/charisma-app.css" rel="stylesheet">
|
||||||
|
@ -74,9 +74,8 @@ body {
|
||||||
</div>
|
</div>
|
||||||
<!--box content-->
|
<!--box content-->
|
||||||
|
|
||||||
<div class="title-frame">
|
<div class="title-frame" onClick="toggleTestExecutionPlan()">
|
||||||
<a href="#"><i class="icon-minus" id="icon-load"
|
<i class="icon-minus" id="icon-load"></i>
|
||||||
onClick="toggleTestExecutionPlan()"></i></a>
|
|
||||||
<p class="title">
|
<p class="title">
|
||||||
<fmt:message key="testPlanConfig" />
|
<fmt:message key="testPlanConfig" />
|
||||||
</p>
|
</p>
|
||||||
|
@ -127,9 +126,8 @@ body {
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="title-frame">
|
<div class="title-frame" onClick="toggleUserScenarios()">
|
||||||
<a href="#"><i class="icon-minus" id="icon-user"
|
<i class="icon-minus" id="icon-user"></i>
|
||||||
onClick="toggleUserScenarios()"></i></a>
|
|
||||||
<p class="title">
|
<p class="title">
|
||||||
<fmt:message key="script" />
|
<fmt:message key="script" />
|
||||||
</p>
|
</p>
|
||||||
|
@ -163,54 +161,53 @@ body {
|
||||||
</table>
|
</table>
|
||||||
<div id="alertMessage" class="hide">The total allocation
|
<div id="alertMessage" class="hide">The total allocation
|
||||||
needs to be 100%</div>
|
needs to be 100%</div>
|
||||||
<button type="submit" class="btn btn-primary"
|
<button type="submit" class="btn btn-primary"
|
||||||
id="userScenariosButton"
|
id="userScenariosButton"
|
||||||
onClick="addScenario();checkUserScenarios()">
|
onClick="addScenario();checkUserScenarios()">
|
||||||
<fmt:message key="addScript" />
|
<fmt:message key="addScript" />
|
||||||
</button>
|
</button>
|
||||||
<button type="submit" class="btn btn-primary" id="createNewScript"
|
<button type="submit" class="btn btn-primary" id="createNewScript"
|
||||||
onClick="createNewScript()">
|
onClick="createNewScript()">
|
||||||
<fmt:message key="test_jsp_makeNewScript" />
|
<fmt:message key="test_jsp_makeNewScript" />
|
||||||
</button>
|
</button>
|
||||||
<button type="submit" class="btn btn-primary" id="createFilter">
|
<button type="submit" class="btn btn-primary" id="createFilter">
|
||||||
<fmt:message key="plugin_jsp_filter" />
|
<fmt:message key="plugin_jsp_filter" />
|
||||||
</button>
|
</button>
|
||||||
<div class="modal hide" id="selectFilter">
|
<div class="modal hide" id="selectFilter">
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<div class="inset scroll" id="filterList"></div>
|
<div class="inset scroll" id="filterList"></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
<button type="button" class="btn btn-primary btn-width" id="ok">
|
<button type="button" class="btn btn-primary btn-width" id="ok">
|
||||||
<fmt:message key="plugin_jsp_finish" />
|
<fmt:message key="plugin_jsp_finish" />
|
||||||
</button>
|
</button>
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div id="userConfigMessage" class="hide">all input can not
|
|
||||||
be empty and must be greater than zero!</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
<div id="userConfigMessage" class="hide">all input can not
|
||||||
|
be empty and must be greater than zero!</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="title-frame">
|
<div class="title-frame" onClick="toggleIpConfig()">
|
||||||
<a href="#"><i class="icon-plus float-left" id="icon-ip"
|
<i class="icon-plus float-left" id="icon-ip"></i>
|
||||||
onClick="toggleIpConfig()"></i></a>
|
<p class="title">
|
||||||
<p class="title">
|
<fmt:message key="sutIp" />
|
||||||
<fmt:message key="sutIp" />
|
</p>
|
||||||
</p>
|
</div>
|
||||||
</div>
|
<div id="ipConfig" class="content-frame hide">
|
||||||
<div id="ipConfig" class="content-frame hide">
|
<table id="ipConfigTable" class="table-margin-top"></table>
|
||||||
<table id="ipConfigTable" class="table-margin-top"></table>
|
<button type="submit" class="btn btn-primary add-button"
|
||||||
<button type="submit" class="btn btn-primary add-button"
|
onClick="addIP();checkIP()">
|
||||||
onClick="addIP();checkIP()">
|
<fmt:message key="addIp" />
|
||||||
<fmt:message key="addIp" />
|
</button>
|
||||||
</button>
|
<div id="ipConfigMessage" class="hide">
|
||||||
<div id="ipConfigMessage" class="hide">
|
<fmt:message key="test-iptip" />
|
||||||
<fmt:message key="test-iptip" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="span12 center">
|
|
||||||
<button class="btn btn-large btn-primary" onClick="startTest()">
|
|
||||||
<fmt:message key="startTest" />
|
|
||||||
</button>
|
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="span12 center">
|
||||||
|
<button class="btn btn-large btn-primary" onClick="startTest()">
|
||||||
|
<fmt:message key="startTest" />
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr>
|
<hr>
|
||||||
|
|
Loading…
Reference in New Issue