2 <div class="wrapper wrapper-content animated fadeIn">
3 <div class="row" style="margin-bottom: 20px;">
5 <ol class="breadcrumb" style="padding-left: 20px; font-size: 17px;">
7 <router-link to="/" >root</router-link>
10 <router-link :to="{ path: '/testcase', query: { name: sname }}"><b>{{this.$route.query.name}}</b></router-link>
15 <div id="page-content" style="" class="row">
16 <div class="col-lg-8">
18 <div class="ibox-title">
19 <h5 style="font-size:26px;margin-top: -3px;">Test Case</h5>
20 <div class="ibox-tools">
21 <button class="btn btn-info btn-sm my-button-sm" type="button" v-on:click="runMultiTestcase()">Run</button>
22 <button class="btn btn-success btn-sm my-button-sm" type="button" v-on:click="create()">Create</button>
23 <button class="btn btn-danger btn-sm my-button-sm" v-on:click="deleteCases()" type="button">Delete</button>
24 <a class="collapse-link">
25 <i class="fa fa-chevron-up"></i>
27 <a class="fullscreen-link">
28 <i class="fa fa-expand"></i>
32 <div class="ibox-content" style="text-align:center;">
33 <table class="my-table table table-bordered" cellspacing="0" cellpadding="0" style="text-align: center;">
36 <td class="checkbox1" style="width:20px"><input type="checkbox" v-model="selectAll"> All</td>
37 <td class="smallbox" style="with:250px;">TestCase Name</td>
41 <tr v-for="testcase in testcases">
42 <td><input class="checkbox1" style="width:20px" type="checkbox" v-model="selected" :value="testcase.testcase"> </td>
43 <td class="smallbox" style="with:250px;"><router-link :to="{ path: '/content', query: { suiteName: sname, caseName: testcase.testcase } }">{{testcase.testcase}}</router-link></td>
46 <tfoot id="create-box" style="display: none">
48 <td class="checkbox1" style="width:20px"><input type="checkbox"> </td>
49 <td class="smallbox" style="with:250px;"><input type="text" v-model="newCase" @keydown.enter="additem" ></td>
59 <div class="col-lg-12">
61 <div class="ibox-title">
62 <h5 style="font-size:26px;margin-top: -3px;">Workflow</h5>
63 <div class="ibox-tools">
64 <a class="collapse-link">
65 <i class="fa fa-chevron-up"></i>
67 <a class="fullscreen-link">
68 <i class="fa fa-expand"></i>
72 <div class="ibox-content" style="padding-top: 30px;">
73 <div id="executing" class="row" style="padding: 0 30px 60px;">
74 <div class="col-md-offset-2 col-md-8">
75 <div class="table-responsive">
76 <table class="table text-center" style="margin-top: 30px;">
79 <th class="text-center">#</th>
80 <th class="text-center">testcase</th>
81 <th class="text-center">status</th>
82 <th class="text-center">operation</th>
86 <tr v-for="testcase in runTestcases">
87 <td>{{ testcase.id }}</td>
88 <td>{{ testcase.testcase }}</td>
89 <td><span class="badge" v-bind:class="'badge-' + statusClass(testcase.status)">{{ testcase.status }}</span></td>
91 <div style="display: inline-block;min-width: 130px;">
92 <button class="btn btn-primary btn-outline btn-xs fadeIn" v-on:click="runTestcase()" v-show="testcase.status == 'failed'">rerun</button>
93 <button class="btn btn-primary btn-outline btn-xs fadeIn" v-on:click="runNextCase($event.target)" v-show="testcase.status == 'failed'">run next one</button>
102 <hr class="hr-line-solid">
103 <div class="row" style="margin-top: 60px;">
104 <wfresult v-bind:workflowId="workflowId" v-bind:wfloading='wfloading' v-bind:wfJson='wfJson' v-on:wfComplete="wfComplete = $event"></wfresult>
113 import wfresult from './workflow_graph/wfresult.vue'
114 import showMessage from './message/showMessage.js'
120 sname: this.$route.query.name,
132 created: function() {
134 var msgTitle = "GET -- TESTCASES";
135 var errorInfo = "Failed to get testcase list.";
137 url: this.global.SERVER_ADDR + "testsuite/content",
140 suiteName: this.$route.query.name
142 success:function (data) {
143 if(data['code'] == 200) {
144 self.testcases = data['result'];
146 showMessage(data['code'], msgTitle, errorInfo, data['error']);
149 error: function(obj, status, msg) {
150 showMessage(status, msgTitle, errorInfo, msg);
157 return this.testcases ? this.selected.length == this.testcases.length : false;
159 set: function (value) {
162 this.testcases.forEach(function (testcase) {
163 selected.push(testcase.testcase);
166 this.selected = selected;
171 create: function () {
172 var cbox = document.getElementById("create-box");
173 cbox.style.display = "table-footer-group";
175 additem: function () {
177 var msgTitle = "CREATE -- TESTCASE";
178 const caseName = self.newCase.trim();
182 url: this.global.SERVER_ADDR + "testcase/new",
185 suiteName: self.sname,
188 success:function (data) {
189 if(data['code'] == 200){
190 self.testcases.push({
191 id: self.testcases.length + 1 ,
194 showMessage(data['code'], msgTitle, "Create <strong>" + caseName + "</strong> succesfully!");
196 showMessage(data['code'], msgTitle, "Failed to create <strong>" + caseName + "</strong>!", data['error']);
199 error: function(obj, status, msg) {
200 showMessage(status, msgTitle, "Failed to create <strong>" + caseName + "</strong>!", msg);
204 var cbox = document.getElementById("create-box");
205 cbox.style.display = "none";
208 deleteCases:function () {
210 var msgTitle = "DELETE -- TESTCASE";
211 var deleteArr = self.selected.slice(0);
212 self.testcases = self.testcases.filter(item => {
213 for(var i in deleteArr) {
214 if(item.testcase == deleteArr[i]) {
221 for(var i in deleteArr)
224 url: this.global.SERVER_ADDR + "testcase/delete",
227 suiteName: self.sname,
228 caseName: deleteArr[i]
230 success: function(data) {
231 if(data['code'] == 200){
232 showMessage(data['code'], msgTitle, "Delete <strong>" + deleteArr[i] + "</strong> succesfully!");
234 showMessage(data['code'], msgTitle, "Failed to delete <strong>" + deleteArr[i] + "</strong>!", data['error']);
237 error: function(obj, status, msg) {
238 showMessage(status, msgTitle, "Failed to delete <strong>" + deleteArr[i] + "</strong>!", msg);
243 runMultiTestcase: function() {
245 var msgTitle = "RUN -- TESTCASES";
246 self.runTestcases = [];
247 if(self.selected.length == 0) {
248 showMessage("warning", msgTitle, "please select one!");
251 for(var i=0; i < self.selected.length; i++) {
252 var testcaseItem = {'id': i, 'testcase': '', 'status': "waiting"};
253 testcaseItem['testcase'] = self.selected[i];
254 self.runTestcases.push(testcaseItem);
256 self.curRunningId = 0;
257 showMessage("info", msgTitle, "start to run <strong>testcases</strong>");
258 self.runOneTestcase();
260 runOneTestcase: function() {
262 var msgTitle = "RUN -- TESTCASE";
263 if (self.curRunningId == self.runTestcases.length) {
264 self.curRunningId = 0;
267 self.wfComplete = false;
268 var i = self.curRunningId;
269 self.runTestcases[i]['status'] = "running";
271 url: self.global.SERVER_ADDR + "execute/testcase",
274 "suiteName": self.sname,
275 "caseName": self.runTestcases[self.curRunningId]['testcase']
277 beforeSend: function(XHR) {
278 self.wfloading = true;
280 success: function(data) {
281 if(data['code'] == 200) {
282 self.workflowId = data['result']['workflowId'];
284 url: self.global.SERVER_ADDR + "story-content",
287 "service": self.sname,
288 "story": self.runTestcases[self.curRunningId]['testcase']
290 success: function(data) {
291 if(data['code'] == 200) {
292 self.wfJson = data['result']['content'];
294 showMessage(data['code'], msgTitle, "workflow.json get failed!");
297 error: function(obj, status, msg) {
298 showMessage(status, msgTitle, msg);
302 var i = self.curRunningId;
303 self.runTestcases[i]['status'] = "failed";
304 self.wfloading = false;
305 showMessage(data['code'], msgTitle, "Failed to run <strong>" + self.runTestcases[i]['testcase'] + "</strong>", data['error']);
308 error: function(obj, status, msg) {
309 var i = self.curRunningId;
310 self.runTestcases[i]['status'] = "failed";
311 self.wfloading = false;
312 showMessage(status, msgTitle, "Failed to run <strong>" + self.runTestcases[i]['testcase'] + "</strong>", msg);
316 statusClass: function(status) {
317 if(status == "waiting") {
320 if(status == "running") {
323 if(status == "pass") {
326 if(status == "failed") {
330 runNextCase: function(obj) {
331 $(obj).parent().css({"display": "none"});
332 var i = this.curRunningId++;
333 this.runOneTestcase();
337 wfComplete: function(val) {
338 if(val == false) return;
339 this.wfloading = false;
340 var i = this.curRunningId++;
341 this.runTestcases[i]['status'] = "pass";
342 this.runOneTestcase();